| 1 |
- {"remainingRequest":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\babel-loader\\lib\\index.js!C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\src\\pages\\system\\backendRouting\\debugging.vue?vue&type=script&lang=js","dependencies":[{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\src\\pages\\system\\backendRouting\\debugging.vue","mtime":1761185180204},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\babel.config.js","mtime":1761185179818},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\.babelrc","mtime":1761185179813},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _objectSpread from "C:/Users/Administrator/Desktop/crmeb5.0/template/admin/node_modules/@babel/runtime/helpers/esm/objectSpread2.js";
import _regenerator from "C:/Users/Administrator/Desktop/crmeb5.0/template/admin/node_modules/@babel/runtime/helpers/esm/regenerator.js";
import _asyncToGenerator from "C:/Users/Administrator/Desktop/crmeb5.0/template/admin/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js";
import "core-js/modules/es.array.map.js";
import "core-js/modules/es.iterator.constructor.js";
import "core-js/modules/es.iterator.for-each.js";
import "core-js/modules/es.iterator.map.js";
import "core-js/modules/es.json.stringify.js";
import "core-js/modules/es.object.keys.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/web.dom-collections.for-each.js";
import request from './request';
import MonacoEditor from './components/MonacoEditor.vue';
import vuedraggable from 'vuedraggable';
import { getCookies } from '@/libs/util';
function requestMethod(url, method, params, data, headerItem) {
  return request({
    url: url,
    method: method,
    params: params,
    data: data,
    headerItem: headerItem
  });
}
export default {
  components: {
    MonacoEditor: MonacoEditor
  },
  props: {
    formValidate: {
      type: Object,
      default: function _default() {
        return {};
      }
    },
    requestTypeList: {
      type: Array,
      default: function _default() {
        return [];
      }
    },
    typeList: {
      type: Array,
      default: function _default() {
        return [];
      }
    },
    apiType: {
      type: String,
      default: 'adminapi'
    }
  },
  data: function data() {
    return {
      bodyType: 'form-data',
      interfaceData: undefined,
      paramsType: 'Params',
      editor: '',
      //当前编辑器对象
      codes: '',
      jsonBody: ''
    };
  },
  created: function created() {
    this.interfaceData = this.formValidate;
    this.interfaceData.request_body = JSON.parse(JSON.stringify(this.interfaceData.request));
  },
  mounted: function mounted() {
    var _this = this;
    if (!this.$refs.zTable.getTableData().tableData.length && this.apiType == 'adminapi') {
      this.insertEvent('zTable', {
        attribute: 'Authori-Zation',
        value: 'Bearer ' + getCookies('token')
      });
      // this.insertEvent('zaTable');
    } else {
      if (this.interfaceData.header) {
        this.interfaceData.header.forEach(function (item, index) {
          _this.insertEvent('zTable', {
            attribute: item.attribute || '',
            value: item.value || ''
          });
        });
      }
    }
  },
  methods: {
    handleChange: function handleChange(e, row, type) {
      var _this2 = this;
      return _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() {
        var arr, id, $table, i;
        return _regenerator().w(function (_context) {
          while (1) switch (_context.n) {
            case 0:
              if (!(e.value !== 'array' && e.value !== 'object')) {
                _context.n = 3;
                break;
              }
              if (!row.children.length) {
                _context.n = 3;
                break;
              }
              arr = _this2.$refs[type].getTableData().tableData;
              id = row.children[0].parentId;
              $table = _this2.$refs[type];
              i = 0;
            case 1:
              if (!(i < arr.length)) {
                _context.n = 3;
                break;
              }
              if (!(arr[i].parentId == id)) {
                _context.n = 2;
                break;
              }
              _context.n = 2;
              return $table.remove(arr[i]);
            case 2:
              i++;
              _context.n = 1;
              break;
            case 3:
              return _context.a(2);
          }
        }, _callee);
      }))();
    },
    insertCopy: function insertCopy() {
      var _this3 = this;
      this.$copyText(this.codes).then(function (message) {
        _this3.$message.success('复制成功');
      }).catch(function (err) {
        _this3.$message.error('复制失败');
      });
    },
    requestData: function requestData() {
      var _this4 = this;
      return _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2() {
        var url, method, params, body, headers, h, _t, _t2, _t3, _t4, _t5, _t6, _t7;
        return _regenerator().w(function (_context2) {
          while (1) switch (_context2.n) {
            case 0:
              url = _this4.apiType + '/' + _this4.interfaceData.path;
              method = _this4.interfaceData.method;
              _t = _this4;
              _context2.n = 1;
              return _this4.$refs.xTable.getTableData().tableData;
            case 1:
              _t2 = _context2.v;
              if (_t2) {
                _context2.n = 2;
                break;
              }
              _t2 = [];
            case 2:
              params = _t.filtersData.call(_t, _t2);
              if (!(_this4.bodyType === 'json')) {
                _context2.n = 3;
                break;
              }
              _t3 = _this4.jsonBody;
              _context2.n = 6;
              break;
            case 3:
              _t4 = _this4;
              _context2.n = 4;
              return _this4.$refs.yTable.getTableData().tableData;
            case 4:
              _t5 = _context2.v;
              if (_t5) {
                _context2.n = 5;
                break;
              }
              _t5 = [];
            case 5:
              _t3 = _t4.filtersData.call(_t4, _t5);
            case 6:
              body = _t3;
              _t6 = _this4;
              _context2.n = 7;
              return _this4.$refs.zTable.getTableData().tableData;
            case 7:
              _t7 = _context2.v;
              if (_t7) {
                _context2.n = 8;
                break;
              }
              _t7 = [];
            case 8:
              h = _t6.filtersData.call(_t6, _t7);
              headers = h;
              _this4.codes = '';
              requestMethod(url, method, params, body, headers).then(function (res) {
                if (!res) return _this4.$message.error('接口异常');
                _this4.codes = JSON.stringify(res);
              }).catch(function (err) {
                if (!err) return _this4.$message.error('接口异常');
                _this4.codes = JSON.stringify(err);
              });
            case 9:
              return _context2.a(2);
          }
        }, _callee2);
      }))();
    },
    filtersData: function filtersData(arr) {
      var _this5 = this;
      try {
        var x = {};
        arr.map(function (e) {
          if (!e.parentId) {
            var _loop = function _loop() {
              if (i == 'attribute') {
                if (e.type === 'object') {
                  var obj = {};
                  e.children.map(function (item, index) {
                    obj = _this5.filtersObj(item, 1);
                  });
                  x[e[i]] = obj;
                } else if (e.type !== 'array') {
                  x[e[i]] = e.value || '';
                } else {
                  var _arr = [];
                  e.children.map(function (item, index) {
                    _arr[index] = _this5.filtersObj(item);
                  });
                  x[e[i]] = _arr;
                }
              }
            };
            for (var i in e) {
              _loop();
            }
          }
        });
        return x;
      } catch (error) {
        console.log(error);
      }
    },
    // type 1 为obj属性
    filtersObj: function filtersObj(obj, type) {
      var _this6 = this;
      var x = {};
      var _loop2 = function _loop2() {
        if (i == 'attribute') {
          if (obj.type === 'object') {
            var oj = {};
            obj.children.map(function (item, index) {
              oj[obj.attribute] = _this6.filtersObj(item);
            });
            x = oj;
          } else if (obj.type !== 'array') {
            if (type) {
              x[obj.attribute] = obj.value || '';
            } else {
              x[obj[i]] = obj.value || '';
            }
          } else {
            var arr = [];
            obj.children.map(function (item, index) {
              arr[index] = _this6.filtersObj(item);
            });
            x[obj[i]] = arr;
          }
        }
      };
      for (var i in obj) {
        _loop2();
      }
      return x;
    },
    changeTab: function changeTab(name) {
      // if (name === 'Header') {
      //   if (!this.$refs.zTable.getTableData().tableData.length) {
      //     this.insertEvent('zTable', {
      //       attribute: 'Authori-Zation',
      //       value: 'Bearer ' + getCookies('token'),
      //     });
      //     this.insertEvent('zaTable');
      //   }
      // }
    },
    insertEvent: function insertEvent(type, d) {
      var _this7 = this;
      return _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee3() {
        var $table, newRow, _yield$$table$insertA, data;
        return _regenerator().w(function (_context3) {
          while (1) switch (_context3.n) {
            case 0:
              $table = _this7.$refs[type];
              if (type == 'xTable') {
                newRow = {
                  attribute: '',
                  type: 'string',
                  must: 0,
                  value: '',
                  trip: ''
                };
              } else if (type == 'yTable') {
                newRow = {
                  attribute: '',
                  type: 'string',
                  value: '',
                  must: 0,
                  trip: ''
                };
              } else if (type == 'zTable') {
                newRow = {
                  attribute: '',
                  type: '',
                  value: '',
                  trip: ''
                };
                newRow = _objectSpread(_objectSpread({}, newRow), d);
              } else if (type == 'zaTable') {
                newRow = {
                  attribute: 'token',
                  type: 'string',
                  value: '',
                  must: 0,
                  trip: ''
                };
              } else {
                newRow = {
                  code: '',
                  value: '',
                  solution: ''
                };
              }
              _context3.n = 1;
              return $table.insertAt(newRow, -1);
            case 1:
              _yield$$table$insertA = _context3.v;
              data = _yield$$table$insertA.row;
              _context3.n = 2;
              return $table.setActiveCell(data, 'name');
            case 2:
              return _context3.a(2);
          }
        }, _callee3);
      }))();
    },
    insertRow: function insertRow(currRow, type) {
      var _this8 = this;
      return _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee4() {
        var $table, record, _yield$$table$insertA2, newRow;
        return _regenerator().w(function (_context4) {
          while (1) switch (_context4.n) {
            case 0:
              $table = _this8.$refs[type]; // 如果 null 则插入到目标节点顶部
              // 如果 -1 则插入到目标节点底部
              // 如果 row 则有插入到效的目标节点该行的位置
              if (type == 'xTable') {
                record = {
                  attribute: '',
                  type: 'string',
                  must: 0,
                  value: '',
                  trip: '',
                  id: Date.now(),
                  parentId: currRow.id // 需要指定父节点，自动插入该节点中
                };
              } else {
                record = {
                  code: '',
                  value: '',
                  solution: '',
                  id: Date.now(),
                  parentId: currRow.id // 需要指定父节点，自动插入该节点中
                };
              }
              _context4.n = 1;
              return $table.insertAt(record, -1);
            case 1:
              _yield$$table$insertA2 = _context4.v;
              newRow = _yield$$table$insertA2.row;
              _context4.n = 2;
              return $table.setTreeExpand(currRow, true);
            case 2:
              _context4.n = 3;
              return $table.setActiveRow(newRow);
            case 3:
              return _context4.a(2);
          }
        }, _callee4);
      }))();
    },
    removeRow: function removeRow(row, type) {
      var _this9 = this;
      return _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee5() {
        var $table;
        return _regenerator().w(function (_context5) {
          while (1) switch (_context5.n) {
            case 0:
              $table = _this9.$refs[type];
              _context5.n = 1;
              return $table.remove(row);
            case 1:
              return _context5.a(2);
          }
        }, _callee5);
      }))();
    }
  }
};"},{"version":3,"names":["request","MonacoEditor","vuedraggable","getCookies","requestMethod","url","method","params","data","headerItem","components","props","formValidate","type","Object","default","requestTypeList","Array","typeList","apiType","String","bodyType","interfaceData","undefined","paramsType","editor","codes","jsonBody","created","request_body","JSON","parse","stringify","mounted","_this","$refs","zTable","getTableData","tableData","length","insertEvent","attribute","value","header","forEach","item","index","methods","handleChange","e","row","_this2","_asyncToGenerator","_regenerator","m","_callee","arr","id","$table","i","w","_context","n","children","parentId","remove","a","insertCopy","_this3","$copyText","then","message","$message","success","catch","err","error","requestData","_this4","_callee2","body","headers","h","_t","_t2","_t3","_t4","_t5","_t6","_t7","_context2","path","xTable","v","filtersData","call","yTable","res","_this5","x","map","_loop","obj","filtersObj","console","log","_this6","_loop2","oj","changeTab","name","d","_this7","_callee3","newRow","_yield$$table$insertA","_context3","must","trip","_objectSpread","code","solution","insertAt","setActiveCell","insertRow","currRow","_this8","_callee4","record","_yield$$table$insertA2","_context4","Date","now","setTreeExpand","setActiveRow","removeRow","_this9","_callee5","_context5"],"sources":["src/pages/system/backendRouting/debugging.vue"],"sourcesContent":["<template>\r\n <div class=\"content\" v-if=\"interfaceData\">\r\n <div class=\"head\">\r\n <el-input v-model=\"interfaceData.path\">\r\n <template #prepend>\r\n <el-select v-model=\"interfaceData.method\" style=\"width: 120px\">\r\n <el-option\r\n v-for=\"(item, index) in requestTypeList\"\r\n :key=\"index\"\r\n :value=\"item.value\"\r\n :label=\"item.label\"\r\n ></el-option>\r\n </el-select>\r\n </template>\r\n </el-input>\r\n <el-button class=\"ml20\" type=\"primary\" v-db-click @click=\"requestData\">请求</el-button>\r\n <el-button v-if=\"codes\" class=\"ml10 copy-btn\" type=\"success\" v-db-click @click=\"insertCopy()\">复制结果</el-button>\r\n </div>\r\n <div class=\"params\">\r\n <el-tabs class=\"mt10\" v-model=\"paramsType\" @tab-click=\"changeTab\">\r\n <el-tab-pane label=\"Params\" name=\"Params\"> </el-tab-pane>\r\n <el-tab-pane label=\"Body\" name=\"Body\"> </el-tab-pane>\r\n <el-tab-pane label=\"Header\" name=\"Header\"> </el-tab-pane>\r\n </el-tabs>\r\n <div v-show=\"paramsType === 'Params'\">\r\n <vxe-table\r\n class=\"mt10\"\r\n resizable\r\n show-overflow\r\n keep-source\r\n ref=\"xTable\"\r\n row-id=\"id\"\r\n :print-config=\"{}\"\r\n :export-config=\"{}\"\r\n :tree-config=\"{ transform: true, rowField: 'id', parentField: 'parentId' }\"\r\n :data=\"interfaceData.query\"\r\n >\r\n <vxe-column field=\"attribute\" width=\"150\" title=\"属性\" tree-node :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.attribute\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"value\" title=\"参数值\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.value\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"type\" title=\"类型\" width=\"120\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-select\r\n v-model=\"row.type\"\r\n transfer\r\n @change=\"\r\n (val) => {\r\n handleChange(val, row, 'xTable');\r\n }\r\n \"\r\n >\r\n <vxe-option\r\n v-for=\"item in typeList\"\r\n :key=\"item.value\"\r\n :value=\"item.value\"\r\n :label=\"item.label\"\r\n ></vxe-option>\r\n </vxe-select>\r\n </template>\r\n </vxe-column>\r\n <!-- <vxe-column field=\"must\" title=\"必填\" width=\"50\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <span>{{ row.must == '1' ? '是' : '否' }}</span>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"trip\" width=\"150\" title=\"说明\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.trip\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column> -->\r\n <vxe-column title=\"操作\" width=\"120\">\r\n <template #default=\"{ row }\">\r\n <vxe-button\r\n type=\"text\"\r\n v-if=\"['array', 'object'].includes(row.type)\"\r\n status=\"primary\"\r\n v-db-click\r\n @click=\"insertRow(row, 'xTable')\"\r\n >插入</vxe-button\r\n >\r\n <vxe-button type=\"text\" status=\"primary\" v-db-click @click=\"removeRow(row, 'xTable')\">删除</vxe-button>\r\n </template>\r\n </vxe-column>\r\n </vxe-table>\r\n <el-button class=\"mt10\" type=\"primary\" v-db-click @click=\"insertEvent('xTable')\">添加参数</el-button>\r\n </div>\r\n <div v-show=\"paramsType === 'Body'\">\r\n <el-radio-group v-model=\"bodyType\" class=\"mt10\">\r\n <el-radio label=\"form-data\"></el-radio>\r\n <el-radio label=\"json\"></el-radio>\r\n </el-radio-group>\r\n <vxe-table\r\n v-if=\"bodyType == 'form-data'\"\r\n class=\"mt10\"\r\n resizable\r\n show-overflow\r\n keep-source\r\n ref=\"yTable\"\r\n row-id=\"id\"\r\n :print-config=\"{}\"\r\n :export-config=\"{}\"\r\n :tree-config=\"{ transform: true, rowField: 'id', parentField: 'parentId' }\"\r\n :data=\"interfaceData.request_body\"\r\n >\r\n <vxe-column field=\"attribute\" width=\"150\" title=\"属性\" tree-node :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.attribute\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"value\" title=\"参数值\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.value\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"type\" title=\"类型\" width=\"120\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-select\r\n v-model=\"row.type\"\r\n transfer\r\n @change=\"\r\n (val) => {\r\n handleChange(val, row, 'yTable');\r\n }\r\n \"\r\n >\r\n <vxe-option\r\n v-for=\"item in typeList\"\r\n :key=\"item.value\"\r\n :value=\"item.value\"\r\n :label=\"item.label\"\r\n ></vxe-option>\r\n </vxe-select>\r\n </template>\r\n </vxe-column>\r\n <!-- <vxe-column field=\"must\" title=\"必填\" width=\"50\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <span>{{ row.must == '1' ? '是' : '否' }}</span>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"trip\" title=\"说明\" width=\"150\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.trip\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column> -->\r\n <vxe-column title=\"操作\" width=\"120\">\r\n <template #default=\"{ row }\">\r\n <vxe-button\r\n type=\"text\"\r\n v-if=\"['array', 'object'].includes(row.type)\"\r\n status=\"primary\"\r\n v-db-click\r\n @click=\"insertRow(row, 'yTable')\"\r\n >插入</vxe-button\r\n >\r\n <vxe-button type=\"text\" status=\"primary\" v-db-click @click=\"removeRow(row, 'yTable')\">删除</vxe-button>\r\n </template>\r\n </vxe-column>\r\n </vxe-table>\r\n <div v-else>\r\n <el-input v-model=\"jsonBody\" type=\"textarea\" :rows=\"8\" placeholder=\"请求数据\" />\r\n </div>\r\n <el-button v-if=\"bodyType == 'form-data'\" class=\"mt10\" type=\"primary\" v-db-click @click=\"insertEvent('yTable')\"\r\n >添加参数</el-button\r\n >\r\n </div>\r\n\r\n <div v-show=\"paramsType === 'Header'\">\r\n <vxe-table\r\n class=\"mt10\"\r\n resizable\r\n show-overflow\r\n keep-source\r\n ref=\"zTable\"\r\n row-id=\"id\"\r\n :print-config=\"{}\"\r\n :export-config=\"{}\"\r\n :tree-config=\"{ transform: true, rowField: 'id', parentField: 'parentId' }\"\r\n :data=\"interfaceData.headerData\"\r\n >\r\n <vxe-column field=\"attribute\" width=\"300\" title=\"属性\" tree-node :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.attribute\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column>\r\n <vxe-column field=\"value\" title=\"参数值\" :edit-render=\"{}\">\r\n <template #default=\"{ row }\">\r\n <vxe-input v-model=\"row.value\" type=\"text\"></vxe-input>\r\n </template>\r\n </vxe-column>\r\n <vxe-column title=\"操作\" width=\"100\">\r\n <template #default=\"{ row }\">\r\n <vxe-button\r\n type=\"text\"\r\n v-if=\"['array', 'object'].includes(row.type)\"\r\n status=\"primary\"\r\n v-db-click\r\n @click=\"insertRow(row, 'zTable')\"\r\n >插入</vxe-button\r\n >\r\n <vxe-button type=\"text\" status=\"primary\" v-db-click @click=\"removeRow(row, 'zTable')\">删除</vxe-button>\r\n </template>\r\n </vxe-column>\r\n </vxe-table>\r\n <el-button class=\"mt10\" type=\"primary\" v-db-click @click=\"insertEvent('zTable')\">添加参数</el-button>\r\n </div>\r\n </div>\r\n <div class=\"res mt10 mb10\" v-if=\"codes\">\r\n <MonacoEditor :codes=\"codes\" :readOnly=\"true\" />\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport request from './request';\r\nimport MonacoEditor from './components/MonacoEditor.vue';\r\nimport vuedraggable from 'vuedraggable';\r\nimport { getCookies } from '@/libs/util';\r\n\r\nfunction requestMethod(url, method, params, data, headerItem) {\r\n return request({\r\n url,\r\n method,\r\n params,\r\n data,\r\n headerItem,\r\n });\r\n}\r\nexport default {\r\n components: { MonacoEditor },\r\n props: {\r\n formValidate: {\r\n type: Object,\r\n default: () => {\r\n return {};\r\n },\r\n },\r\n requestTypeList: {\r\n type: Array,\r\n default: () => {\r\n return [];\r\n },\r\n },\r\n typeList: {\r\n type: Array,\r\n default: () => {\r\n return [];\r\n },\r\n },\r\n apiType: {\r\n type: String,\r\n default: 'adminapi',\r\n },\r\n },\r\n data() {\r\n return {\r\n bodyType: 'form-data',\r\n interfaceData: undefined,\r\n paramsType: 'Params',\r\n editor: '', //当前编辑器对象\r\n codes: '',\r\n jsonBody: '',\r\n };\r\n },\r\n created() {\r\n this.interfaceData = this.formValidate;\r\n this.interfaceData.request_body = JSON.parse(JSON.stringify(this.interfaceData.request));\r\n },\r\n mounted() {\r\n if (!this.$refs.zTable.getTableData().tableData.length && this.apiType == 'adminapi') {\r\n this.insertEvent('zTable', {\r\n attribute: 'Authori-Zation',\r\n value: 'Bearer ' + getCookies('token'),\r\n });\r\n // this.insertEvent('zaTable');\r\n } else {\r\n if (this.interfaceData.header) {\r\n this.interfaceData.header.forEach((item, index) => {\r\n this.insertEvent('zTable', {\r\n attribute: item.attribute || '',\r\n value: item.value || '',\r\n });\r\n });\r\n }\r\n }\r\n },\r\n methods: {\r\n async handleChange(e, row, type) {\r\n if (e.value !== 'array' && e.value !== 'object') {\r\n if (row.children.length) {\r\n let arr = this.$refs[type].getTableData().tableData;\r\n let id = row.children[0].parentId;\r\n const $table = this.$refs[type];\r\n for (let i = 0; i < arr.length; i++) {\r\n if (arr[i].parentId == id) {\r\n await $table.remove(arr[i]);\r\n }\r\n }\r\n }\r\n }\r\n },\r\n insertCopy() {\r\n this.$copyText(this.codes)\r\n .then((message) => {\r\n this.$message.success('复制成功');\r\n })\r\n .catch((err) => {\r\n this.$message.error('复制失败');\r\n });\r\n },\r\n async requestData() {\r\n let url, method, params, body, headers;\r\n url = this.apiType + '/' + this.interfaceData.path;\r\n method = this.interfaceData.method;\r\n params = this.filtersData((await this.$refs.xTable.getTableData().tableData) || []);\r\n body =\r\n this.bodyType === 'json'\r\n ? this.jsonBody\r\n : this.filtersData((await this.$refs.yTable.getTableData().tableData) || []);\r\n let h = this.filtersData((await this.$refs.zTable.getTableData().tableData) || []);\r\n headers = h;\r\n this.codes = '';\r\n requestMethod(url, method, params, body, headers)\r\n .then((res) => {\r\n if (!res) return this.$message.error('接口异常');\r\n this.codes = JSON.stringify(res);\r\n })\r\n .catch((err) => {\r\n if (!err) return this.$message.error('接口异常');\r\n this.codes = JSON.stringify(err);\r\n });\r\n },\r\n filtersData(arr) {\r\n try {\r\n let x = {};\r\n arr.map((e) => {\r\n if (!e.parentId) {\r\n for (let i in e) {\r\n if (i == 'attribute') {\r\n if (e.type === 'object') {\r\n let obj = {};\r\n\r\n e.children.map((item, index) => {\r\n obj = this.filtersObj(item, 1);\r\n });\r\n x[e[i]] = obj;\r\n } else if (e.type !== 'array') {\r\n x[e[i]] = e.value || '';\r\n } else {\r\n let arr = [];\r\n e.children.map((item, index) => {\r\n arr[index] = this.filtersObj(item);\r\n });\r\n x[e[i]] = arr;\r\n }\r\n }\r\n }\r\n }\r\n });\r\n return x;\r\n } catch (error) {\r\n console.log(error);\r\n }\r\n },\r\n // type 1 为obj属性\r\n filtersObj(obj, type) {\r\n let x = {};\r\n for (let i in obj) {\r\n if (i == 'attribute') {\r\n if (obj.type === 'object') {\r\n let oj = {};\r\n obj.children.map((item, index) => {\r\n oj[obj.attribute] = this.filtersObj(item);\r\n });\r\n x = oj;\r\n } else if (obj.type !== 'array') {\r\n if (type) {\r\n x[obj.attribute] = obj.value || '';\r\n } else {\r\n x[obj[i]] = obj.value || '';\r\n }\r\n } else {\r\n let arr = [];\r\n obj.children.map((item, index) => {\r\n arr[index] = this.filtersObj(item);\r\n });\r\n x[obj[i]] = arr;\r\n }\r\n }\r\n }\r\n return x;\r\n },\r\n changeTab(name) {\r\n // if (name === 'Header') {\r\n // if (!this.$refs.zTable.getTableData().tableData.length) {\r\n // this.insertEvent('zTable', {\r\n // attribute: 'Authori-Zation',\r\n // value: 'Bearer ' + getCookies('token'),\r\n // });\r\n // this.insertEvent('zaTable');\r\n // }\r\n // }\r\n },\r\n async insertEvent(type, d) {\r\n const $table = this.$refs[type];\r\n let newRow;\r\n if (type == 'xTable') {\r\n newRow = {\r\n attribute: '',\r\n type: 'string',\r\n must: 0,\r\n value: '',\r\n trip: '',\r\n };\r\n } else if (type == 'yTable') {\r\n newRow = {\r\n attribute: '',\r\n type: 'string',\r\n value: '',\r\n must: 0,\r\n trip: '',\r\n };\r\n } else if (type == 'zTable') {\r\n newRow = {\r\n attribute: '',\r\n type: '',\r\n value: '',\r\n trip: '',\r\n };\r\n newRow = { ...newRow, ...d };\r\n } else if (type == 'zaTable') {\r\n newRow = {\r\n attribute: 'token',\r\n type: 'string',\r\n value: '',\r\n must: 0,\r\n trip: '',\r\n };\r\n } else {\r\n newRow = {\r\n code: '',\r\n value: '',\r\n solution: '',\r\n };\r\n }\r\n const { row: data } = await $table.insertAt(newRow, -1);\r\n await $table.setActiveCell(data, 'name');\r\n },\r\n async insertRow(currRow, type) {\r\n const $table = this.$refs[type];\r\n // 如果 null 则插入到目标节点顶部\r\n // 如果 -1 则插入到目标节点底部\r\n // 如果 row 则有插入到效的目标节点该行的位置\r\n let record;\r\n if (type == 'xTable') {\r\n record = {\r\n attribute: '',\r\n type: 'string',\r\n must: 0,\r\n value: '',\r\n trip: '',\r\n id: Date.now(),\r\n parentId: currRow.id, // 需要指定父节点,自动插入该节点中\r\n };\r\n } else {\r\n record = {\r\n code: '',\r\n value: '',\r\n solution: '',\r\n id: Date.now(),\r\n parentId: currRow.id, // 需要指定父节点,自动插入该节点中\r\n };\r\n }\r\n const { row: newRow } = await $table.insertAt(record, -1);\r\n await $table.setTreeExpand(currRow, true); // 将父节点展开\r\n await $table.setActiveRow(newRow); // 插入子节点\r\n },\r\n async removeRow(row, type) {\r\n const $table = this.$refs[type];\r\n await $table.remove(row);\r\n },\r\n },\r\n};\r\n</script>\r\n<style>\r\n.vxe-select--panel.is--transfer {\r\n z-index: 99999 !important;\r\n}\r\n</style>\r\n<style lang=\"scss\" scoped>\r\n.content {\r\n padding: 12px;\r\n .head {\r\n display: flex;\r\n align-items: center;\r\n .item {\r\n display: flex;\r\n align-items: center;\r\n margin-bottom: 12px;\r\n font-size: 14px;\r\n .title {\r\n margin-right: 14px;\r\n }\r\n }\r\n }\r\n}\r\n.copy-btn {\r\n display: flex;\r\n justify-content: right;\r\n}\r\n::v-deep .monaco-editor {\r\n min-height: 700px;\r\n}\r\n</style>\r\n"],"mappings":"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","ignoreList":[]}]}
|