From 97081b89ee45da49b8dbb4173ab45df031fe3c0d Mon Sep 17 00:00:00 2001
From: yyb <995253665@qq.com>
Date: 星期三, 20 五月 2026 16:58:40 +0800
Subject: [PATCH] 删除冗余和无效代码

---
 src/views/officeProcessAutomation/ApproveManage/approve-list/index.vue |  150 +++++++++++++++++++++++++++----------------------
 1 files changed, 82 insertions(+), 68 deletions(-)

diff --git a/src/views/officeProcessAutomation/ApproveManage/approve-list/index.vue b/src/views/officeProcessAutomation/ApproveManage/approve-list/index.vue
index cdae763..eba9586 100644
--- a/src/views/officeProcessAutomation/ApproveManage/approve-list/index.vue
+++ b/src/views/officeProcessAutomation/ApproveManage/approve-list/index.vue
@@ -3,30 +3,35 @@
   <div class="app-container">
     <div class="search_form mb20">
       <div class="search_fields">
-        <span class="search_title">瀹℃壒绫诲瀷锛�</span>
+        <span class="search_title">妯℃澘绫诲瀷锛�</span>
         <el-select
-          v-model="searchForm.approvalType"
-          placeholder="璇烽�夋嫨瀹℃壒绫诲瀷"
+          v-model="searchForm.businessType"
+          placeholder="璇烽�夋嫨妯℃澘绫诲瀷"
           clearable
           filterable
           style="width: 200px"
         >
           <el-option
-            v-for="opt in APPROVAL_TYPE_OPTIONS"
+            v-for="opt in searchBusinessTypeOptions"
+            :key="`search-biz-type-${opt.value}`"
+            :label="opt.label"
+            :value="opt.value"
+          />
+        </el-select>
+        <span class="search_title" style="margin-left: 12px">瀹℃壒鐘舵�侊細</span>
+        <el-select
+          v-model="searchForm.status"
+          placeholder="璇烽�夋嫨瀹℃壒鐘舵��"
+          clearable
+          style="width: 140px"
+        >
+          <el-option
+            v-for="opt in APPROVAL_STATUS_SEARCH_OPTIONS"
             :key="opt.value"
             :label="opt.label"
             :value="opt.value"
           />
         </el-select>
-        <span class="search_title" style="margin-left: 12px">鐢宠浜哄悕绉帮細</span>
-        <el-input
-          v-model="searchForm.applicantKeyword"
-          style="width: 200px"
-          placeholder="璇疯緭鍏ョ敵璇蜂汉鍚嶇О"
-          clearable
-          :prefix-icon="Search"
-          @keyup.enter="handleQuery"
-        />
         <span class="search_title" style="margin-left: 12px">鍒涘缓鏃堕棿锛�</span>
         <el-date-picker
           v-model="searchForm.createTimeRange"
@@ -77,67 +82,79 @@
       @closed="resetSubmitDialogState"
     >
       <template v-if="submitDialog.step === 1 && !isSubmitEdit">
-        <p class="template-hint">璇烽�夋嫨宸插惎鐢ㄧ殑瀹℃壒妯℃澘锛岀郴缁熷皢鎸夋ā鏉块厤缃紩瀵煎~鎶ャ��</p>
+        <p class="template-hint">璇峰厛閫夋嫨妯℃澘绫诲瀷锛屽啀閫夋嫨璇ョ被鍨嬩笅宸插惎鐢ㄧ殑瀹℃壒妯℃澘銆�</p>
         <div v-loading="submitTemplatesLoading" class="template-grid">
           <div
-            v-for="card in submitTemplateCards"
-            :key="card.key"
+            v-for="opt in submitBusinessTypeOptions"
+            :key="`biz-type-${opt.value}`"
             class="template-card"
-            @click="onTemplatePick(card)"
+            :class="{ 'is-disabled': !countTemplatesByBusinessType(opt.value) }"
+            @click="onBusinessTypePick(opt.value)"
           >
-            <span class="template-card-type" :style="approvalTypeStyle(card.approvalType)">
-              {{ card.label }}
+            <span class="template-card-type">{{ opt.label }}</span>
+            <span class="template-card-desc">
+              {{ countTemplatesByBusinessType(opt.value) }} 涓彲鐢ㄦā鏉�
             </span>
-            <span class="template-card-desc">{{ card.summaryPlaceholder }}</span>
           </div>
           <el-empty
-            v-if="!submitTemplatesLoading && !submitTemplateCards.length"
-            description="鏆傛棤鍙敤瀹℃壒妯℃澘"
+            v-if="!submitTemplatesLoading && !submitBusinessTypeOptions.length"
+            description="鏆傛棤妯℃澘绫诲瀷"
             :image-size="80"
             class="template-empty"
           />
         </div>
       </template>
 
+      <template v-else-if="submitDialog.step === 2 && !isSubmitEdit">
+        <p class="template-hint">
+          褰撳墠绫诲瀷锛歿{ selectedBusinessTypeLabel || "鈥�" }}锛岃閫夋嫨鍏蜂綋瀹℃壒妯℃澘銆�
+          <el-button type="primary" link class="ml8" @click="backToBusinessTypePick">鏇存崲绫诲瀷</el-button>
+        </p>
+        <ApprovalTemplatePicker
+          :cards="submitTemplateCards"
+          :loading="submitTemplatesLoading"
+          @pick="onTemplatePick"
+        />
+      </template>
+
       <template v-else>
         <div v-loading="submitTemplatesLoading && !isSubmitEdit">
         <el-form ref="submitFormRef" :model="submitForm" :rules="submitFormRules" label-width="120px">
-          <el-form-item label="瀹℃壒绫诲瀷">
+          <el-form-item v-if="isSubmitEdit" label="瀹℃壒绫诲瀷">
             <span class="approve-type-cell" :style="approvalTypeStyle(activeTemplate.approvalType)">
               {{ activeTemplate.label }}
             </span>
-            <el-button
-              v-if="!isSubmitEdit"
-              type="primary"
-              link
-              class="ml12"
-              @click="backToTemplatePick"
-            >
-              鏇存崲妯℃澘
-            </el-button>
           </el-form-item>
-          <FormPayloadFields
+          <ApprovalTemplateFormSection
+            :active-template="activeTemplate"
             :fields="submitFormFields"
             :form-payload="submitForm.formPayload"
+            v-model:flow-nodes="submitForm.flowNodes"
+            v-model:attachments="submitForm.storageBlobDTOs"
+            :template-attachments="submitForm.templateAttachments"
+            :user-options="flowUserOptions"
+            :show-template-name="!isSubmitEdit"
+            :allow-change-template="!isSubmitEdit"
+            @change-template="backToTemplatePick"
           />
-          <el-form-item label="瀹℃壒娴佺▼" required>
-            <TemplateFlowEditor v-model="submitForm.flowNodes" :user-options="flowUserOptions" />
-            <p class="flow-tip">
-              鎸夐『搴忔祦杞細鍙负姣忎釜鑺傜偣娣诲姞澶氬悕瀹℃壒浜猴紱浼氱闇�鍏ㄩ儴閫氳繃锛屾垨绛句换涓�浜洪�氳繃鍗冲彲杩涘叆涓嬩竴鑺傜偣銆�
-            </p>
-          </el-form-item>
         </el-form>
         </div>
       </template>
 
       <template #footer>
         <el-button
-          v-if="submitDialog.step === 2 || isSubmitEdit"
+          v-if="submitDialog.step === 3 || isSubmitEdit"
           type="primary"
           :loading="submitSaving"
           @click="onSubmitInstance"
         >
           {{ isSubmitEdit ? "淇� 瀛�" : "鎻� 浜�" }}
+        </el-button>
+        <el-button
+          v-if="submitDialog.step === 2 && !isSubmitEdit"
+          @click="backToBusinessTypePick"
+        >
+          涓婁竴姝�
         </el-button>
         <el-button @click="submitDialog.visible = false">
           {{ submitDialog.step === 1 && !isSubmitEdit ? "鍙� 娑�" : "鍏� 闂�" }}
@@ -261,9 +278,9 @@
 import { Plus, RefreshRight } from "@element-plus/icons-vue";
 import { ElMessage } from "element-plus";
 import { onMounted, ref } from "vue";
-import { userListNoPageByTenantId } from "@/api/system/user.js";
-import TemplateFlowEditor from "../approve-template/components/TemplateFlowEditor.vue";
-import FormPayloadFields from "./components/FormPayloadFields.vue";
+import ApprovalTemplateFormSection from "../approve-shared/components/ApprovalTemplateFormSection.vue";
+import ApprovalTemplatePicker from "../approve-shared/components/ApprovalTemplatePicker.vue";
+import { useFlowUserOptions } from "../approve-shared/useFlowUserOptions.js";
 import { formatDisplayTime } from "../approve-template/approveTemplateConstants.js";
 import { approvalTypeStyle } from "./approveListConstants.js";
 import ApproveDetailPanel from "./components/ApproveDetailPanel.vue";
@@ -273,9 +290,16 @@
 const al = useApproveList();
 const {
   Search,
-  APPROVAL_TYPE_OPTIONS,
+  APPROVAL_STATUS_SEARCH_OPTIONS,
+  searchBusinessTypeOptions,
+  loadSearchBusinessTypeOptions,
+  submitBusinessTypeOptions,
   submitTemplateCards,
+  selectedBusinessTypeLabel,
+  countTemplatesByBusinessType,
   submitTemplatesLoading,
+  onBusinessTypePick,
+  backToBusinessTypePick,
   approvalTypeLabel,
   approvalActionLabel,
   searchForm,
@@ -311,29 +335,7 @@
   openApprove,
 } = al;
 
-const flowUserOptions = ref([]);
-
-function unwrapArray(payload) {
-  if (Array.isArray(payload)) return payload;
-  if (payload?.data && Array.isArray(payload.data)) return payload.data;
-  if (payload?.rows && Array.isArray(payload.rows)) return payload.rows;
-  return [];
-}
-
-function isActiveUser(u) {
-  if (u.delFlag === "2" || u.delFlag === 2) return false;
-  if (u.status == null) return true;
-  return String(u.status) === "0";
-}
-
-async function loadUsers() {
-  try {
-    const res = await userListNoPageByTenantId();
-    flowUserOptions.value = unwrapArray(res).filter(isActiveUser);
-  } catch {
-    flowUserOptions.value = [];
-  }
-}
+const { flowUserOptions, loadFlowUsers } = useFlowUserOptions();
 
 async function onSubmitInstance() {
   const ok = await submitInstanceForm();
@@ -368,7 +370,8 @@
 }
 
 onMounted(() => {
-  loadUsers();
+  loadFlowUsers();
+  loadSearchBusinessTypeOptions();
   handleQuery();
 });
 </script>
@@ -434,6 +437,17 @@
   border-color: var(--el-color-primary);
   box-shadow: var(--shadow-sm, 0 2px 8px rgba(0, 0, 0, 0.06));
 }
+.template-card.is-disabled {
+  opacity: 0.5;
+  cursor: not-allowed;
+}
+.template-card.is-disabled:hover {
+  border-color: var(--el-border-color-lighter);
+  box-shadow: none;
+}
+.ml8 {
+  margin-left: 8px;
+}
 .template-card-type {
   display: inline-block;
   padding: 2px 8px;

--
Gitblit v1.9.3