Просмотр исходного кода

Use the new separated codegen for code generation

Andrew Bastin 4 лет назад
Родитель
Сommit
ee066d7859
1 измененных файлов с 19 добавлено и 100 удалено
  1. 19 100
      pages/index.vue

+ 19 - 100
pages/index.vue

@@ -1044,9 +1044,9 @@
               <label for="requestType">{{ $t("request_type") }}</label>
               <label for="requestType">{{ $t("request_type") }}</label>
               <span class="select-wrapper">
               <span class="select-wrapper">
                 <select id="requestType" v-model="requestType">
                 <select id="requestType" v-model="requestType">
-                  <option>JavaScript XHR</option>
-                  <option>Fetch</option>
-                  <option>cURL</option>
+                  <option v-for="gen in codegens" :key="gen.id" :value="gen.id">
+                    {{ gen.name }}
+                  </option>
                 </select>
                 </select>
               </span>
               </span>
             </li>
             </li>
@@ -1262,6 +1262,7 @@ import { httpValid } from "~/helpers/utils/valid"
 import { knownContentTypes, isJSONContentType } from "~/helpers/utils/contenttypes"
 import { knownContentTypes, isJSONContentType } from "~/helpers/utils/contenttypes"
 import closeIcon from "~/static/icons/close-24px.svg?inline"
 import closeIcon from "~/static/icons/close-24px.svg?inline"
 import deleteIcon from "~/static/icons/delete-24px.svg?inline"
 import deleteIcon from "~/static/icons/delete-24px.svg?inline"
+import { codegens, generateCodeWithGenerator } from "~/helpers/codegen/codegen"
 
 
 const statusCategories = [
 const statusCategories = [
   {
   {
@@ -1344,6 +1345,7 @@ export default {
             : true,
             : true,
       },
       },
       currentMethodIndex: 0,
       currentMethodIndex: 0,
+      codegens: codegens,
       methodMenuItems: [
       methodMenuItems: [
         "GET",
         "GET",
         "HEAD",
         "HEAD",
@@ -1788,103 +1790,20 @@ export default {
       return (this.response.headers["content-type"] || "").split(";")[0].toLowerCase()
       return (this.response.headers["content-type"] || "").split(";")[0].toLowerCase()
     },
     },
     requestCode() {
     requestCode() {
-      if (this.requestType === "JavaScript XHR") {
-        const requestString = []
-        requestString.push("const xhr = new XMLHttpRequest()")
-        const user = this.auth === "Basic Auth" ? `'${this.httpUser}'` : null
-        const password = this.auth === "Basic Auth" ? `'${this.httpPassword}'` : null
-        requestString.push(
-          `xhr.open('${this.method}', '${this.url}${this.pathName}${this.queryString}', true, ${user}, ${password})`
-        )
-        if (this.auth === "Bearer Token" || this.auth === "OAuth 2.0") {
-          requestString.push(`xhr.setRequestHeader('Authorization', 'Bearer ${this.bearerToken}')`)
-        }
-        if (this.headers) {
-          this.headers.forEach(({ key, value }) => {
-            if (key) requestString.push(`xhr.setRequestHeader('${key}', '${value}')`)
-          })
-        }
-        if (["POST", "PUT", "PATCH", "DELETE"].includes(this.method)) {
-          let requestBody = this.rawInput ? this.rawParams : this.rawRequestBody
-          if (isJSONContentType(this.contentType)) {
-            requestBody = `JSON.stringify(${requestBody})`
-          } else if (this.contentType.includes("x-www-form-urlencoded")) {
-            requestBody = `"${requestBody}"`
-          }
-          requestString.push(
-            `xhr.setRequestHeader('Content-Type', '${this.contentType}; charset=utf-8')`
-          )
-          requestString.push(`xhr.send(${requestBody})`)
-        } else {
-          requestString.push("xhr.send()")
-        }
-        return requestString.join("\n")
-      } else if (this.requestType === "Fetch") {
-        const requestString = []
-        let headers = []
-        requestString.push(`fetch("${this.url}${this.pathName}${this.queryString}", {\n`)
-        requestString.push(`  method: "${this.method}",\n`)
-        if (this.auth === "Basic Auth") {
-          const basic = `${this.httpUser}:${this.httpPassword}`
-          headers.push(
-            `    "Authorization": "Basic ${window.btoa(unescape(encodeURIComponent(basic)))}",\n`
-          )
-        } else if (this.auth === "Bearer Token" || this.auth === "OAuth 2.0") {
-          headers.push(`    "Authorization": "Bearer ${this.bearerToken}",\n`)
-        }
-        if (["POST", "PUT", "PATCH", "DELETE"].includes(this.method)) {
-          let requestBody = this.rawInput ? this.rawParams : this.rawRequestBody
-          if (isJSONContentType(this.contentType)) {
-            requestBody = `JSON.stringify(${requestBody})`
-          } else if (this.contentType.includes("x-www-form-urlencoded")) {
-            requestBody = `"${requestBody}"`
-          }
-
-          requestString.push(`  body: ${requestBody},\n`)
-          headers.push(`    "Content-Type": "${this.contentType}; charset=utf-8",\n`)
-        }
-        if (this.headers) {
-          this.headers.forEach(({ key, value }) => {
-            if (key) headers.push(`    "${key}": "${value}",\n`)
-          })
-        }
-        headers = headers.join("").slice(0, -2)
-        requestString.push(`  headers: {\n${headers}\n  },\n`)
-        requestString.push('  credentials: "same-origin"\n')
-        requestString.push("}).then(function(response) {\n")
-        requestString.push("  response.status\n")
-        requestString.push("  response.statusText\n")
-        requestString.push("  response.headers\n")
-        requestString.push("  response.url\n\n")
-        requestString.push("  return response.text()\n")
-        requestString.push("}).catch(function(error) {\n")
-        requestString.push("  error.message\n")
-        requestString.push("})")
-        return requestString.join("")
-      } else if (this.requestType === "cURL") {
-        const requestString = []
-        requestString.push(`curl -X ${this.method}`)
-        requestString.push(`  '${this.url}${this.pathName}${this.queryString}'`)
-        if (this.auth === "Basic Auth") {
-          const basic = `${this.httpUser}:${this.httpPassword}`
-          requestString.push(
-            `  -H 'Authorization: Basic ${window.btoa(unescape(encodeURIComponent(basic)))}'`
-          )
-        } else if (this.auth === "Bearer Token" || this.auth === "OAuth 2.0") {
-          requestString.push(`  -H 'Authorization: Bearer ${this.bearerToken}'`)
-        }
-        if (this.headers) {
-          this.headers.forEach(({ key, value }) => {
-            if (key) requestString.push(`  -H '${key}: ${value}'`)
-          })
-        }
-        if (["POST", "PUT", "PATCH", "DELETE"].includes(this.method)) {
-          const requestBody = this.rawInput ? this.rawParams : this.rawRequestBody
-          requestString.push(`  -H 'Content-Type: ${this.contentType}; charset=utf-8'`)
-          requestString.push(`  -d '${requestBody}'`)
-        }
-        return requestString.join(" \\\n")
-      }
+      return generateCodeWithGenerator(this.requestType, {
+        method: this.method,
+        url: this.url,
+        pathName: this.pathName,
+        queryString: this.queryString,
+        httpUser: this.httpUser,
+        httpPassword: this.httpPassword,
+        bearerToken: this.bearerToken,
+        headers: this.headers,
+        rawInputs: this.rawInputs,
+        rawParams: this.rawParams,
+        rawRequestBody: this.rawRequestBody,
+        contentType: this.contentType,
+      })
     },
     },
     tokenReqDetails() {
     tokenReqDetails() {
       const details = {
       const details = {