Jay
2024-10-14 fb7d4604d3b0c86f21deba3dfcdd247174e46227
src/views/model/mpk/file/MpkRun.vue
@@ -116,6 +116,7 @@
  const dialogTitle = ref('模型运行') // 弹窗的标题
  const formData = reactive({
    pyName: '',
    className: '',
    methodName: '',
    datas: [],
@@ -131,6 +132,7 @@
  const open = async (row) => {
    dialogVisible.value = true
    formData.className = row.pkgName + '.impl.' + row.pyName + 'Impl';
    formData.pyName = row.pyName;
    const mpk = await MpkApi.getMpk(row.id)
    methodList.value = mpk.modelMethods
    formData.methodName = mpk.modelMethods[0].methodName
@@ -139,6 +141,16 @@
     formData.datas[i] = '[[]]'
    }
    hasModel.value = mpk.modelMethods[0].model === 1
    // 回显参数
    if (mpk.modelMethods[0].methodSettings && mpk.modelMethods[0].methodSettings.length > 0) {
      formData.modelSettings = mpk.modelMethods[0].methodSettings.map(e => {
        return {
          settingKey: e.settingKey,
          settingValue: e.value
        }
      })
    }
  }
  defineExpose({ open }) // 提供 open 方法,用于打开弹窗
@@ -162,10 +174,22 @@
  }
  const methodChange = function (value) {
    formData.datas = []
    for (let i = 0 ; i < methodList.value.find(e => e.methodName === value)?.dataLength ; i++) {
    var method = methodList.value.find(e => e.methodName === value);
    for (let i = 0 ; i < method?.dataLength ; i++) {
      formData.datas[i] = '[[]]'
    }
    hasModel.value = methodList.value.find(e => e.methodName === value)?.model === 1
    hasModel.value = method?.model === 1
    // 回显参数
    if (method.methodSettings && method.methodSettings.length > 0) {
      formData.modelSettings = method.methodSettings.map(e => {
        return {
          settingKey: e.settingKey,
          settingValue: e.value
        }
      })
    }else {
      formData.modelSettings = []
    }
  }
  const fileList = ref([]) // 文件列表