From d5207d8eaff6188ae0d79c07de17d0b8dbaed65a Mon Sep 17 00:00:00 2001
From: houzhongjian <houzhongyi@126.com>
Date: 星期一, 06 一月 2025 11:45:14 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/views/model/sche/scheme/ScheduleSchemeForm.vue |  265 +++++++++++++++++++++++++++++------------------------
 1 files changed, 145 insertions(+), 120 deletions(-)

diff --git a/src/views/model/sche/scheme/ScheduleSchemeForm.vue b/src/views/model/sche/scheme/ScheduleSchemeForm.vue
index f7c0b44..9ee1e84 100644
--- a/src/views/model/sche/scheme/ScheduleSchemeForm.vue
+++ b/src/views/model/sche/scheme/ScheduleSchemeForm.vue
@@ -10,12 +10,12 @@
       <el-row>
         <el-col :span="12">
           <el-form-item label="方案编号" prop="code">
-            <el-input v-model="formData.code" placeholder="请输入方案编号" />
+            <el-input v-model="formData.code" placeholder="请输入方案编号"/>
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="方案名称" prop="name">
-            <el-input v-model="formData.name" placeholder="请输入方案名称" />
+            <el-input v-model="formData.name" placeholder="请输入方案名称"/>
           </el-form-item>
         </el-col>
       </el-row>
@@ -24,7 +24,7 @@
           <el-form-item label="触发方式" prop="triggerMethod">
             <el-select v-model="formData.triggerMethod" placeholder="请选择">
               <el-option
-                v-for="dict in getIntDictOptions(DICT_TYPE.SCHE_TRIGGER_METHOD)"
+                v-for="dict in getDictOptions(DICT_TYPE.SCHE_TRIGGER_METHOD)"
                 :key="dict.value"
                 :label="dict.label"
                 :value="dict.value"
@@ -34,26 +34,26 @@
         </el-col>
         <el-col :span="12">
           <el-form-item label="触发条件" prop="triggerCondition">
-            <el-input v-model="formData.triggerCondition" placeholder="请输入触发条件" />
+            <el-input v-model="formData.triggerCondition" placeholder="请输入触发条件"/>
           </el-form-item>
         </el-col>
       </el-row>
       <el-row>
         <el-col :span="12">
           <el-form-item label="调整对象" prop="scheduleObj">
-            <el-input v-model="formData.scheduleObj" placeholder="请输入调整对象" />
+            <el-input v-model="formData.scheduleObj" placeholder="请输入调整对象"/>
           </el-form-item>
         </el-col>
         <el-col :span="12">
           <el-form-item label="调整类型" prop="scheduleType">
-            <el-input v-model="formData.scheduleType" placeholder="请输入调整类型" />
+            <el-input v-model="formData.scheduleType" placeholder="请输入调整类型"/>
           </el-form-item>
         </el-col>
       </el-row>
       <el-row>
         <el-col :span="12">
           <el-form-item label="调整策略" prop="scheduleStrategy">
-            <el-input v-model="formData.scheduleStrategy" placeholder="请输入调整策略 " />
+            <el-input v-model="formData.scheduleStrategy" placeholder="请输入调整策略 "/>
           </el-form-item>
         </el-col>
         <el-col :span="12">
@@ -71,9 +71,23 @@
         </el-col>
       </el-row>
       <el-row>
+        <el-col :span="12">
+          <el-form-item label="关联项目" prop="mpkprojectid">
+            <el-select v-model="formData.mpkprojectid" placeholder="请选择">
+              <el-option
+                v-for="item in mpkProjectList"
+                :key="item.id"
+                :label="item.projectName"
+                :value="item.id"/>
+            </el-select>
+          </el-form-item>
+        </el-col>
+      </el-row>
+      <el-row>
         <el-col :span="24">
           <el-form-item label="备注" prop="remark">
-            <el-input v-model="formData.remark" placeholder="请输入备注"  type="textarea" maxlength="100"
+            <el-input v-model="formData.remark" placeholder="请输入备注" type="textarea"
+                      maxlength="100"
                       show-word-limit/>
           </el-form-item>
         </el-col>
@@ -86,20 +100,127 @@
   </Dialog>
 </template>
 <script lang="ts" setup>
-  import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
-  import * as ScheduleSchemeApi from '@/api/model/sche/scheme'
-  import { CommonStatusEnum } from '@/utils/constants'
-  import * as ScheduleModelApi from "@/api/model/sche/model";
+import {DICT_TYPE, getDictOptions} from '@/utils/dict'
+import * as ScheduleSchemeApi from '@/api/model/sche/scheme'
+import {CommonStatusEnum} from '@/utils/constants'
+import * as ScheduleModelApi from "@/api/model/sche/model";
+import * as ProjectApi from '@/api/model/mpk/project'
 
-  defineOptions({ name: 'ScheduleSchemeForm' })
+defineOptions({name: 'ScheduleSchemeForm'})
 
-  const { t } = useI18n() // 国际化
-  const message = useMessage() // 消息弹窗
-  const dialogVisible = ref(false) // 弹窗的是否展示
-  const dialogTitle = ref('') // 弹窗的标题
-  const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
-  const formType = ref('') // 表单的类型:create - 新增;update - 修改
-  const formData = ref({
+const {t} = useI18n() // 国际化
+const message = useMessage() // 消息弹窗
+const dialogVisible = ref(false) // 弹窗的是否展示
+const dialogTitle = ref('') // 弹窗的标题
+const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
+const formType = ref('') // 表单的类型:create - 新增;update - 修改
+const formData = ref({
+  id: undefined,
+  code: undefined,
+  name: undefined,
+  triggerMethod: undefined,
+  triggerCondition: undefined,
+  scheduleObj: undefined,
+  scheduleType: undefined,
+  scheduleStrategy: undefined,
+  modelId: undefined,
+  scheduleTime: undefined,
+  remark: undefined,
+  status: 0,
+  mpkprojectid: undefined,
+})
+const formRules = reactive({
+  code: [{required: true, message: '编号不能为空', trigger: 'blur'}],
+  name: [{required: true, message: '名称不能为空', trigger: 'blur'}],
+  triggerMethod: [{required: true, message: '触发方式不能为空', trigger: 'blur'}],
+  triggerCondition: [{required: true, message: '触发条件不能为空', trigger: 'blur'}],
+  modelId: [{required: true, message: '调度模型不能为空', trigger: 'blur'}],
+  triggerCondition: [{required: true, message: '触发条件不能为空', trigger: 'blur'}],
+  mpkprojectid: [{required: true, message: '关联项目不能为空', trigger: 'blur'}],
+})
+const formRef = ref() // 表单 Ref
+const scheduleModelList = ref([] as ScheduleModelApi.ScheduleModelVO[])
+const mpkProjectList = ref([])
+const addRow = function (index, rows) {
+  let row = JSON.parse(JSON.stringify(rows[index]))
+  rows.splice(index, 0, row)
+  this.orderRow(rows)
+}
+
+const deleteRow = function (index, rows) {
+  if (!rows || rows.length === 1) {
+    message.error('不能全部删除!')
+    return
+  }
+  rows.splice(index, 1)
+  this.orderRow(rows)
+}
+
+const orderRow = function (rows) {
+  let modelparamorder = 0
+  let modelparamportorder = 0
+  rows.forEach(function (value) {
+    if (value.modelparamportorder !== modelparamportorder) {
+      modelparamportorder = value.modelparamportorder
+      modelparamorder = 1
+    }
+    value.modelparamorder = modelparamorder
+    modelparamorder++
+  })
+}
+
+/** 打开弹窗 */
+const open = async (type: string, id?: number) => {
+  dialogVisible.value = true
+  dialogTitle.value = t('action.' + type)
+  formType.value = type
+  resetForm()
+  // 修改时,设置数据
+  if (id) {
+    formLoading.value = true
+    try {
+      formData.value = await ScheduleSchemeApi.getScheduleScheme(id)
+    } finally {
+      formLoading.value = false
+    }
+  }
+  // 加载调度模型列表
+  scheduleModelList.value = await ScheduleModelApi.getScheduleModelList()
+
+  // 获取mpk项目列表
+  mpkProjectList.value = await ProjectApi.list()
+}
+defineExpose({open}) // 提供 open 方法,用于打开弹窗
+
+/** 提交表单 */
+const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调
+const submitForm = async () => {
+  // 校验表单
+  if (!formRef) return
+  const valid = await formRef.value.validate()
+  if (!valid) return
+  // 提交请求
+  formLoading.value = true
+  try {
+    const data = formData.value as unknown as ScheduleSchemeApi.ScheduleSchemeVO
+    if (formType.value === 'create') {
+      await ScheduleSchemeApi.createScheduleScheme(data)
+      message.success(t('common.createSuccess'))
+    } else {
+      await ScheduleSchemeApi.updateScheduleScheme(data)
+      message.success(t('common.updateSuccess'))
+    }
+    dialogVisible.value = false
+    // 发送操作成功的事件
+    emit('success')
+  } finally {
+    formLoading.value = false
+  }
+}
+
+/** 重置表单 */
+const resetForm = () => {
+  formData.value = {
     id: undefined,
     code: undefined,
     name: undefined,
@@ -111,105 +232,9 @@
     modelId: undefined,
     scheduleTime: undefined,
     remark: undefined,
-    status: 0
-  })
-  const formRules = reactive({
-    code: [{ required: true, message: '编号不能为空', trigger: 'blur' }],
-    name: [{ required: true, message: '名称不能为空', trigger: 'blur' }]
-  })
-  const formRef = ref() // 表单 Ref
-  const scheduleModelList = ref([] as ScheduleModelApi.ScheduleModelVO[])
-
-  const addRow = function (index, rows) {
-    let row = JSON.parse(JSON.stringify(rows[index]))
-    rows.splice(index, 0, row)
-    this.orderRow(rows)
+    status: CommonStatusEnum.ENABLE,
+    mpkprojectid: undefined
   }
-
-  const deleteRow = function (index, rows) {
-    if (!rows || rows.length === 1) {
-      message.error('不能全部删除!')
-      return
-    }
-    rows.splice(index, 1)
-    this.orderRow(rows)
-  }
-
-  const orderRow = function (rows) {
-    let modelparamorder = 0
-    let modelparamportorder = 0
-    rows.forEach(function (value) {
-      if (value.modelparamportorder !== modelparamportorder) {
-        modelparamportorder = value.modelparamportorder
-        modelparamorder = 1
-      }
-      value.modelparamorder = modelparamorder
-      modelparamorder++
-    })
-  }
-
-  /** 打开弹窗 */
-  const open = async (type: string, id?: number) => {
-    dialogVisible.value = true
-    dialogTitle.value = t('action.' + type)
-    formType.value = type
-    resetForm()
-    // 修改时,设置数据
-    if (id) {
-      formLoading.value = true
-      try {
-        formData.value = await ScheduleSchemeApi.getScheduleScheme(id)
-      } finally {
-        formLoading.value = false
-      }
-    }
-    // 加载调度模型列表
-    scheduleModelList.value = await ScheduleModelApi.getScheduleModelList()
-  }
-  defineExpose({ open }) // 提供 open 方法,用于打开弹窗
-
-  /** 提交表单 */
-  const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调
-  const submitForm = async () => {
-    // 校验表单
-    if (!formRef) return
-    const valid = await formRef.value.validate()
-    if (!valid) return
-    // 提交请求
-    formLoading.value = true
-    try {
-      const data = formData.value as unknown as ScheduleSchemeApi.ScheduleSchemeVO
-      if (formType.value === 'create') {
-        await ScheduleSchemeApi.createScheduleScheme(data)
-        message.success(t('common.createSuccess'))
-      } else {
-        await ScheduleSchemeApi.updateScheduleScheme(data)
-        message.success(t('common.updateSuccess'))
-      }
-      dialogVisible.value = false
-      // 发送操作成功的事件
-      emit('success')
-    } finally {
-      formLoading.value = false
-    }
-  }
-
-  /** 重置表单 */
-  const resetForm = () => {
-    formData.value = {
-      id: undefined,
-      code: undefined,
-      name: undefined,
-      triggerMethod: undefined,
-      triggerCondition: undefined,
-      scheduleObj: undefined,
-      scheduleType: undefined,
-      scheduleStrategy: undefined,
-      modelId: undefined,
-      scheduleTime: undefined,
-      remark: undefined,
-      status: CommonStatusEnum.ENABLE
-    }
-    formRef.value?.resetFields()
-  }
+  formRef.value?.resetFields()
+}
 </script>

--
Gitblit v1.9.3