From 5eadfbb64d2f288b92ec1f22cfef6f096b4b9a9e Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期五, 06 二月 2026 14:24:11 +0800
Subject: [PATCH] Merge branch 'dev_new' of http://114.132.189.42:9002/r/product-inventory-APP-before into dev_new

---
 src/pages/procurementManagement/procurementLedger/detail.vue |   70 +++++++++++++++++++++++++++--------
 1 files changed, 54 insertions(+), 16 deletions(-)

diff --git a/src/pages/procurementManagement/procurementLedger/detail.vue b/src/pages/procurementManagement/procurementLedger/detail.vue
index 41df1af..d7693cc 100644
--- a/src/pages/procurementManagement/procurementLedger/detail.vue
+++ b/src/pages/procurementManagement/procurementLedger/detail.vue
@@ -17,27 +17,30 @@
       </up-form-item>
       <up-form-item label="閿�鍞悎鍚屽彿"
                     prop="salesContractNo"
-                    required
-                    @click="showPicker = true">
+                    required>
         <up-input v-model="form.salesContractNo"
-                  readonly=""
-                  @click="showPicker = true"
+                  readonly
+                  :disabled="isReadOnly"
+                  @click="!isReadOnly && (showPicker = true)"
                   placeholder="鐐瑰嚮閫夋嫨閿�鍞悎鍚屽彿" />
         <template #right>
           <up-icon name="arrow-right"
+                   v-if="!isReadOnly"
                    @click="showPicker = true"></up-icon>
         </template>
       </up-form-item>
       <up-form-item label="渚涘簲鍟嗗悕绉�"
                     prop="supplierName"
                     required
-                    @click="showCustomerPicker = true">
+                    >
         <up-input v-model="form.supplierName"
-                  readonly=""
-                  @click="showCustomerPicker = true"
+                  readonly
+                  :disabled="isReadOnly"
+                  @click="!isReadOnly && (showCustomerPicker = true)"
                   placeholder="鐐瑰嚮閫夋嫨渚涘簲鍟�" />
         <template #right>
           <up-icon name="arrow-right"
+                   v-if="!isReadOnly"
                    @click="showCustomerPicker = true"></up-icon>
         </template>
       </up-form-item>
@@ -45,11 +48,13 @@
                     prop="projectName"
                     required>
         <up-input v-model="form.projectName"
+                  :disabled="isReadOnly"
                   placeholder="璇疯緭鍏ラ」鐩悕绉�" />
       </up-form-item>
       <up-form-item label="浠樻鏂瑰紡"
                     prop="paymentMethod">
         <up-input v-model="form.paymentMethod"
+                  :disabled="isReadOnly"
                   placeholder="璇疯緭鍏ヤ粯娆炬柟寮�" />
       </up-form-item>
       <up-form-item label="绛捐鏃ユ湡"
@@ -57,9 +62,11 @@
                     prop="executionDate">
         <up-input v-model="form.executionDate"
                   placeholder="璇烽�夋嫨"
-                  readonly="" />
+                  readonly
+                  :disabled="isReadOnly" />
         <template #right>
           <up-icon name="arrow-right"
+                   v-if="!isReadOnly"
                    @click="showTimePicker = true"></up-icon>
         </template>
       </up-form-item>
@@ -99,9 +106,10 @@
                   <text class="approver-name">{{ step.nickName }}</text>
                 </view>
                 <view class="delete-approver-btn"
+                      v-if="!isReadOnly"
                       @click="removeApprover(stepIndex)">脳</view>
               </view>
-              <view v-else
+              <view v-else-if="!isReadOnly"
                     class="add-approver-btn"
                     @click="addApprover(stepIndex)">
                 <view class="add-circle">+</view>
@@ -111,11 +119,11 @@
             <view class="step-line"
                   v-if="stepIndex < approverNodes.length - 1"></view>
             <view class="delete-step-btn"
-                  v-if="approverNodes.length > 1"
+                  v-if="approverNodes.length > 1 && !isReadOnly"
                   @click="removeApprovalStep(stepIndex)">鍒犻櫎鑺傜偣</view>
           </view>
         </view>
-        <view class="add-step-btn">
+        <view class="add-step-btn" v-if="!isReadOnly">
           <u-button icon="plus"
                     plain
                     type="primary"
@@ -400,7 +408,7 @@
   const operationType = ref("");
   const editData = ref(null);
   const formRef = ref(null);
-  // 瀹℃壒閫氳繃锛坅pprovalStatus === 3锛夊悗锛岀姝㈢紪杈�/鍒犻櫎浜у搧
+  // 瀹℃壒閫氳繃锛坅pprovalStatus === 3锛夊悗锛屾暣鍗曠姝㈢紪杈戯紙鍚骇鍝併�佸熀鏈俊鎭�佸鎵规祦绋嬶級
   const isApprovalPassed = computed(() => {
     const status = editData.value?.approvalStatus ?? form.value?.approvalStatus;
     return Number(status) === 3;
@@ -408,11 +416,17 @@
   const canEditProducts = computed(() => {
     return operationType.value !== "view" && !isApprovalPassed.value;
   });
+  // 鏄惁鏁翠綋鍙锛氭煡鐪嬫ā寮� 鎴� 宸插鎵归�氳繃
+  const isReadOnly = computed(() => {
+    return operationType.value === "view" || isApprovalPassed.value;
+  });
 
   const userStore = useUserStore();
   const form = ref({
     id: "",
     salesContractNo: "",
+    // 鍏宠仈閿�鍞彴璐D锛堢紪杈戝洖鏄炬椂鍙兘缂哄け锛岄渶瑕佷粠鍚堝悓鍙峰弽鏌ヨˉ榻愶級
+    salesLedgerId: "",
     purchaseContractNumber: "",
     supplierId: "",
     supplierName: "",
@@ -587,6 +601,18 @@
       form.value.salesLedgerId = selectedItem.value;
     }
     showPicker.value = false;
+  };
+
+  // 缂栬緫鍥炴樉鍦烘櫙锛氬彧鏈� salesContractNo锛屾病鏈� salesLedgerId 鏃讹紝灏濊瘯浠庡垪琛ㄥ弽鏌ヨˉ榻�
+  const syncSalesLedgerIdFromContractNo = () => {
+    if (form.value.salesLedgerId) return;
+    if (!form.value.salesContractNo) return;
+    const selectedItem = salesContractList.value.find(
+      contract => contract.text === form.value.salesContractNo
+    );
+    if (selectedItem) {
+      form.value.salesLedgerId = selectedItem.value;
+    }
   };
 
   // 渚涘簲鍟嗛�夋嫨浜嬩欢
@@ -891,6 +917,14 @@
   };
 
   const onSubmit = () => {
+    // 瀹℃壒閫氳繃鐨勫彴璐︾姝㈠啀娆′慨鏀�
+    if (isApprovalPassed.value) {
+      uni.showToast({
+        title: "宸插鎵归�氳繃鐨勫彴璐︿笉鍏佽淇敼",
+        icon: "none",
+      });
+      return;
+    }
     const hasEmptyApprover = approverNodes.value.some(node => !node.userId);
     if (hasEmptyApprover) {
       uni.showToast({
@@ -910,10 +944,8 @@
       });
       return;
     }
-    // 濡傛灉salesLedgerId涓虹┖锛屽垯涓嶄紶閫抯alesContractNo
-    if (!form.value.salesLedgerId) {
-      form.value.salesContractNo = "";
-    }
+    // 缂栬緫鍥炴樉鏃跺彲鑳藉彧鏈夊悎鍚屽彿锛屾彁浜ゅ墠灏濊瘯琛ラ綈 salesLedgerId
+    syncSalesLedgerIdFromContractNo();
     if (operationType.value == "add") {
       delete form.value.id;
     }
@@ -995,6 +1027,8 @@
         text: user.salesContractNo,
         value: user.id,
       }));
+      // 鍒楄〃鍥炴潵鍚庯紝琛ラ綈缂栬緫鍥炴樉鐨� salesLedgerId
+      syncSalesLedgerIdFromContractNo();
     });
   };
 
@@ -1096,6 +1130,7 @@
   };
 
   const addApprover = stepIndex => {
+    if (isReadOnly.value) return;
     // 璺宠浆鍒拌仈绯讳汉閫夋嫨椤甸潰
     uni.setStorageSync("stepIndex", stepIndex);
     uni.navigateTo({
@@ -1104,18 +1139,21 @@
   };
 
   const addApprovalStep = () => {
+    if (isReadOnly.value) return;
     // 娣诲姞鏂扮殑瀹℃壒姝ラ
     approverNodes.value.push({ userId: null, nickName: null });
     console.log(approverNodes.value, "approverNodes.value");
   };
 
   const removeApprover = stepIndex => {
+    if (isReadOnly.value) return;
     // 绉婚櫎瀹℃壒浜�
     approverNodes.value[stepIndex].userId = null;
     approverNodes.value[stepIndex].nickName = null;
   };
 
   const removeApprovalStep = stepIndex => {
+    if (isReadOnly.value) return;
     // 纭繚鑷冲皯淇濈暀涓�涓鎵规楠�
     if (approverNodes.value.length > 1) {
       approverNodes.value.splice(stepIndex, 1);

--
Gitblit v1.9.3