{"remainingRequest":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\dataShare-fvue\\src\\views\\dataResource\\dataServices\\dataServiceAPI\\AddDialog.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\src\\views\\dataResource\\dataServices\\dataServiceAPI\\AddDialog.vue","mtime":1749063336055},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\@vue\\cli-plugin-babel\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\@vue\\cli-plugin-babel\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\@vue\\cli-plugin-babel\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\dataShare-fvue\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import API from '@/api/business/dataServiceAPI'
import dialogMixin from '@/mixins/dialog.js'
import codeEditor from '@/components/codeEditor/index.vue'

export default {
  name: 'DetailDialog',
  components: {codeEditor},
  mixins: [dialogMixin],
  props: {
    addId: {
      type: String,
      default: ''
    }

  },
  data() {
    return {
      isSubmitting: false, // 标记是否正在提交中（用于防抖和按钮禁用）
      addJsonMultipleRequestParams: [],
      addJsonMultipleRequestHeader: [],
      addJsonMultipleResponseParams: [],
      addJsonMultipleResponseStatus: [],
      tabItemId: 1, // 表格数据的 id
      labelPosition: 'left',
      timeValue: '',
      qurey: '',
      mode: '',
      sqloptions: [],
      options: [
        {label: '分页', value: '1'},
        {label: '不分页', value: '0'}
      ],
      form: {
        sourceType: '1',
        sql: '',
        apiQureyType: '',
        // 请求参数说明
        requestParams: [
          {
            param: '',
            comment: '',
            type: 'String',
            required: false
          }
        ],
        // 请求头说明
        requestHeader: [
          {
            param: '',
            comment: '',
            type: 'String',
            required: false
          }
        ],
        // 返回参数说明
        responseParams: [
          {
            param: '',
            comment: '',
            type: 'String'
          }
        ],
        // 响应状态码信息
        responseStatus: [
          {
            param: '',
            comment: ''
          }
        ]
      },
      typeoptions: [
        {value: 'String', label: '字符串'},
        {value: 'Integer', label: '数字型'},
        {value: 'Date', label: '日期'}
        // { value: '4', label: '时间' },
      ],
      tableNameList: ['GET', 'POST'],
      rules: {
        apiName: [{required: true, message: '接口名称不能为空', trigger: 'blur'}],
        apiUrl: [{required: true, message: '接口地址不能为空', trigger: 'blur'}],
        apiQureyType: [{required: true, message: '接口查询方式不能为空', trigger: 'change'}],
        apiMode: [{required: true, message: '请求方式不能为空', trigger: 'change'}],
        apiSql: [{required: true, message: 'SQL查询语句不能为空', trigger: 'blur'}],
        dbAlias: [{required: true, message: '请选择数据源', trigger: 'change'}]
      },
      loading: false
    }
  },
  created() {
    this.onConfirm()
  },

  methods: {
    /**
     * @description: dialog每次显示时触发的init方法
     * @param {*} data 传入data
     * @return {*}
     */
    initData(data) {
      const orgForm = this.$options.data().form
      this.form = {...orgForm, ...data}
      console.log('scacac', this.catalogId)
      this.$nextTick(() => {
        this.$refs.form.clearValidate()
      })
      this.selectSql()
    },
    // 数据源接口调用
    selectSql() {
      return API.addSourceData()
        .then((res) => {
          console.log('cacacacs', res) // 数据库
          this.sqloptions = res.data.map((data) => {
            const form = {
              label: data.name,
              value: data.alias
            }
            return form
          })
          // console.log(res.rows);
          console.log('数据源', this.sqloptions)
        })
        .catch((error) => {
          console.error('获取数据源失败', error)
        })
    },
    RndNum(n) {
      // 生成随机数
      let rdmNum = ''
      for (let i = 0; i < n; i++) {
        rdmNum += Math.floor(Math.random() * 10) // [0,10)的整数
      }
      return rdmNum
    },
    // 请求参数说明-------------------------------
    addJsonRequestParams(val) {
      this.addJsonMultipleRequestParams = val
    },
    // 添加
    addTableRequestParams() {
      this.tabItemId = `T${this.RndNum(6)}` // 生成以T开头的七位随机数
      this.form.requestParams.push({
        name: '',
        value: '',
        tabItemId: this.tabItemId
      })
    },
    // 删除
    delTableRequestParams() {
      // 确认删除
      if (this.addJsonMultipleRequestParams.length > 0) {
        const arrs = []
        const ids = this.addJsonMultipleRequestParams.map((val) => val.tabItemId) // 拿到选中的数据id,
        this.form.requestParams.forEach((item) => {
          if (!ids.includes(item.tabItemId)) {
            // 当id在params中，表示数据被选中，该将其删除，即将不被选中的保留
            arrs.push(item)
          }
        })
        this.form.requestParams = arrs
      } else {
        this.$message.warning('请选择要删除的数据')
      }
    },
    // 请求头说明---------------------
    addJsonRequestHeader(val) {
      this.addJsonMultipleRequestHeader = val
    },
    // 添加
    addTableRequestHeader() {
      this.tabItemId = `T${this.RndNum(6)}` // 生成以T开头的七位随机数
      this.form.requestHeader.push({
        name: '',
        value: '',
        tabItemId: this.tabItemId
      })
    },
    // 删除
    delTableRequestHeader() {
      // 确认删除
      if (this.addJsonMultipleRequestHeader.length > 0) {
        const arrs = []
        const ids = this.addJsonMultipleRequestHeader.map((val) => val.tabItemId) // 拿到选中的数据id,
        this.form.requestHeader.forEach((item) => {
          if (!ids.includes(item.tabItemId)) {
            // 当id在params中，表示数据被选中，该将其删除，即将不被选中的保留
            arrs.push(item)
          }
        })
        this.form.requestHeader = arrs
      } else {
        this.$message.warning('请选择要删除的数据')
      }
    },
    // 返回参数说明-------------------------------
    addJsonResponseStatus(val) {
      this.addJsonMultipleResponseParams = val
    },
    // 添加
    addTableResponseParams() {
      this.tabItemId = `T${this.RndNum(6)}` // 生成以T开头的七位随机数
      this.form.responseParams.push({
        name: '',
        value: '',
        tabItemId: this.tabItemId
      })
    },
    // 删除
    delTableResponseParams() {
      // 确认删除
      if (this.addJsonMultipleResponseParams.length > 0) {
        const arrs = []
        const ids = this.addJsonMultipleResponseParams.map((val) => val.tabItemId) // 拿到选中的数据id,
        this.form.responseParams.forEach((item) => {
          if (!ids.includes(item.tabItemId)) {
            // 当id在params中，表示数据被选中，该将其删除，即将不被选中的保留
            arrs.push(item)
          }
        })
        this.form.responseParams = arrs
      } else {
        this.$message.warning('请选择要删除的数据')
      }
    },
    // 响应状态码信息---------------------------
    addJsonResponseParams(val) {
      this.addJsonMultipleResponseStatus = val
    },
    // 添加
    addTableResponseStatus() {
      this.tabItemId = `T${this.RndNum(6)}` // 生成以T开头的七位随机数
      this.form.responseStatus.push({
        name: '',
        value: '',
        tabItemId: this.tabItemId
      })
    },
    // 删除
    delTableResponseStatus() {
      // 确认删除
      if (this.addJsonMultipleResponseStatus.length > 0) {
        const arrs = []
        const ids = this.addJsonMultipleResponseStatus.map((val) => val.tabItemId) // 拿到选中的数据id,
        this.form.responseStatus.forEach((item) => {
          if (!ids.includes(item.tabItemId)) {
            // 当id在params中，表示数据被选中，该将其删除，即将不被选中的保留
            arrs.push(item)
          }
        })
        this.form.responseStatus = arrs
      } else {
        this.$message.warning('请选择要删除的数据')
      }
    },
    // 取消按钮
    onCancel() {
      this.visible = false
      this.form = this.$options.data().form
    },
    // 确定按钮-新增后接口调用，展示在列表
    onConfirm() {
      // this.$refs.form.validate(async (valid) => {
      //   if (valid) {
      //     this.form.catalogId = this.addId
      //     this.form.requestParams = JSON.stringify(this.form.requestParams) // 请求参数说明
      //     this.form.requestHeader = JSON.stringify(this.form.requestHeader) // 请求头说明
      //     this.form.responseParams = JSON.stringify(this.form.responseParams) // 返回参数说明
      //     this.form.responseStatus = JSON.stringify(this.form.responseStatus) // 响应状态码信息
      //     API.addAction(this.form, false)
      //       .then((res) => {
      //         console.log('adddatasss', res)
      //         this.$message.success('接口新增成功！')
      //         // 新增成功后，通过 $emit 触发自定义事件，传递新增成功的信号以及可能相关的数据（父组件可以监听这个事件来做出相应的处理）
      //         this.$emit('confirm')
      //       })
      //       .catch((error) => {
      //         console.error('获取数据失败', error)
      //       })
      //     this.loading = false
      //     // }
      //   } else {
      //     console.log('表单验证失败，请检查所有必填项')
      //     return false
      //   }
      // })
      // this.loading = false
      // this.visible = false
      // 防抖：如果正在提交中，直接返回
      if (this.isSubmitting) return

      this.$refs.form.validate(async (valid) => {
        if (!valid) {
          console.log('表单验证失败，请检查所有必填项')
          return false // 校验失败时阻止关闭弹层
        }

        // 开始提交，禁用按钮
        this.isSubmitting = true
        this.loading = true

        try {
          // 格式化数据
          // this.form.catalogId = this.addId
          // this.form.requestParams = JSON.stringify(this.form.requestParams)
          // this.form.requestHeader = JSON.stringify(this.form.requestHeader)
          // this.form.responseParams = JSON.stringify(this.form.responseParams)
          // this.form.responseStatus = JSON.stringify(this.form.responseStatus)
          // 格式化数据前处理空参数
          const formData = {...this.form}
          formData.catalogId = this.addId

          // 处理请求参数说明 - 保留结构但清空空参数的默认值
          formData.requestParams = this.form.requestParams.map(item => {
            if (item.param.trim() === '') {
              // 参数名为空时，清空所有字段值
              return {
                param: '',
                comment: '',
                type: '', // 清空默认类型
                required: ''
              }
            }
            return {
              param: item.param,
              comment: item.comment,
              type: item.type,
              required: item.required
            }
          })

          // 同样处理其他参数说明
          formData.requestHeader = this.form.requestHeader.map(item => {
            if (item.param.trim() === '') {
              return {
                param: '',
                comment: '',
                type: '',
                required: ''
              }
            }
            return {
              param: item.param,
              comment: item.comment,
              type: item.type,
              required: item.required
            }
          })

          formData.responseParams = this.form.responseParams.map(item => {
            if (item.param.trim() === '') {
              return {
                param: '',
                comment: '',
                type: ''
              }
            }
            return {
              param: item.param,
              comment: item.comment,
              type: item.type
            }
          })

          formData.responseStatus = this.form.responseStatus.map(item => {
            if (item.param.trim() === '') {
              return {
                param: '',
                comment: ''
              }
            }
            return {
              param: item.param,
              comment: item.comment
            }
          })

          // 转换为JSON字符串
          const requestData = {
            ...formData,
            requestParams: JSON.stringify(formData.requestParams),
            requestHeader: JSON.stringify(formData.requestHeader),
            responseParams: JSON.stringify(formData.responseParams),
            responseStatus: JSON.stringify(formData.responseStatus)
          }
          // 调用接口
          await API.addAction(requestData, false)
          this.$message.success('接口新增成功！')
          this.$emit('confirm')

          // 成功后关闭弹层
          this.visible = false
        } catch (error) {
          console.error('提交失败:', error)
          this.$message.error('接口新增失败，请重试')
        } finally {
          // 无论成功失败，恢复按钮状态
          this.isSubmitting = false
          this.loading = false
        }
      })
    }
  }
}
"},null]}