From 5b248a9716688d8132cfb02b4ba0abecd4060b06 Mon Sep 17 00:00:00 2001
From: yyb <995253665@qq.com>
Date: 星期三, 20 五月 2026 11:49:08 +0800
Subject: [PATCH] 审批模板流程化

---
 src/views/officeProcessAutomation/ApproveManage/approve-list/components/FormPayloadFields.vue |   44 ++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 40 insertions(+), 4 deletions(-)

diff --git a/src/views/officeProcessAutomation/ApproveManage/approve-list/components/FormPayloadFields.vue b/src/views/officeProcessAutomation/ApproveManage/approve-list/components/FormPayloadFields.vue
index 6cdc627..7933db5 100644
--- a/src/views/officeProcessAutomation/ApproveManage/approve-list/components/FormPayloadFields.vue
+++ b/src/views/officeProcessAutomation/ApproveManage/approve-list/components/FormPayloadFields.vue
@@ -17,12 +17,17 @@
       </el-descriptions-item>
     </el-descriptions>
 
-    <el-form v-else label-width="120px" class="form-payload-edit">
+    <div
+      v-else
+      class="form-payload-edit"
+      v-loading="optionSourceLoading"
+    >
       <el-form-item
         v-for="field in fields"
         :key="field.key"
         :label="field.label"
         :prop="`formPayload.${field.key}`"
+        :required="Boolean(field.required)"
       >
         <el-input
           v-if="field.type === 'text'"
@@ -73,17 +78,25 @@
           :placeholder="`璇烽�夋嫨${field.label}`"
           style="width: 100%"
           clearable
+          filterable
         >
-          <el-option v-for="o in field.options" :key="o.value" :label="o.label" :value="o.value" />
+          <el-option
+            v-for="o in getOptions(field)"
+            :key="String(o.value)"
+            :label="o.label"
+            :value="o.value"
+          />
         </el-select>
         <span v-else class="field-value">{{ displayValue(field) }}</span>
       </el-form-item>
-    </el-form>
+    </div>
   </template>
   <el-empty v-else description="鏆傛棤濉姤椤�" :image-size="48" />
 </template>
 
 <script setup>
+import { onMounted, watch } from "vue";
+import { useSelectOptionSources } from "../../approve-template/useSelectOptionSources.js";
 import { formatFieldDisplayValue } from "../approveListConstants.js";
 
 const props = defineProps({
@@ -92,8 +105,31 @@
   readonly: { type: Boolean, default: false },
 });
 
+const { loading: optionSourceLoading, ensureForFields, getOptions, getDisplayLabel } =
+  useSelectOptionSources();
+
+async function loadOptionCaches() {
+  await ensureForFields(props.fields);
+}
+
+onMounted(() => {
+  loadOptionCaches();
+});
+
+watch(
+  () => props.fields,
+  () => {
+    loadOptionCaches();
+  },
+  { deep: true }
+);
+
 function displayValue(field) {
-  return formatFieldDisplayValue(field, props.formPayload?.[field.key]);
+  const val = props.formPayload?.[field.key];
+  if (field.type === "select" && field.optionSource && field.optionSource !== "static") {
+    return getDisplayLabel(field, val);
+  }
+  return formatFieldDisplayValue(field, val);
 }
 </script>
 

--
Gitblit v1.9.3