From 19f2e3bdbe04e7ea79c6a0bdc8c7318d4837b189 Mon Sep 17 00:00:00 2001
From: gongchunyi <deslre0381@gmail.com>
Date: 星期四, 28 五月 2026 17:36:45 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev_NEW_pro' into dev_pro_山西_晋和园

---
 src/views/productionPlan/productionPlan/index.vue |   51 +++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 41 insertions(+), 10 deletions(-)

diff --git a/src/views/productionPlan/productionPlan/index.vue b/src/views/productionPlan/productionPlan/index.vue
index 4251daa..e5bc1f8 100644
--- a/src/views/productionPlan/productionPlan/index.vue
+++ b/src/views/productionPlan/productionPlan/index.vue
@@ -56,7 +56,7 @@
                     style="width: 160px;"
                     @keyup.enter="handleQuery" />
         </el-form-item>
-        <el-form-item label="浜у搧瑙勬牸:"
+        <el-form-item label="瑙勬牸鍨嬪彿:"
                       prop="model">
           <el-input v-model="searchForm.model"
                     placeholder="璇疯緭鍏�"
@@ -121,7 +121,7 @@
         </el-row>
         <el-row :gutter="20">
           <el-col>
-            <el-form-item label="浜у搧瑙勬牸">
+            <el-form-item label="瑙勬牸鍨嬪彿">
               <div class="info-display">{{ mergeForm.model || '-' }}</div>
             </el-form-item>
           </el-col>
@@ -138,6 +138,12 @@
                            :max="sumAssignedQuantity"
                            @change="onBlur"
                            style="width: 100%" />
+        </el-form-item>
+        <el-form-item label="鍒涘缓鏃堕棿">
+          <el-date-picker v-model="mergeCreateTimeDate"
+                          type="date"
+                          value-format="YYYY-MM-DD"
+                          style="width: 100%" />
         </el-form-item>
       </el-form>
       <template #footer>
@@ -173,7 +179,7 @@
                       prop="mpsNo">
           <el-input v-model="form.mpsNo"
                     disabled
-                    placeholder="鏂板鍚庤嚜鍔ㄧ敓鎴�" />
+                    placeholder="淇濆瓨鍚庤嚜鍔ㄧ敓鎴�" />
         </el-form-item>
         <el-form-item label="浜у搧鍚嶇О"
                       prop="productId">
@@ -186,7 +192,7 @@
                           @change="handleProductChange"
                           style="width: 100%" />
         </el-form-item>
-        <el-form-item label="浜у搧瑙勬牸"
+        <el-form-item label="瑙勬牸鍨嬪彿"
                       prop="productModelId">
           <el-select v-model="form.productModelId"
                      @change="handleChangeSpecification"
@@ -226,6 +232,14 @@
                           value-format="YYYY-MM-DD"
                           style="width: 100%"
                           placeholder="璇烽�夋嫨鎵胯鏃ユ湡" />
+        </el-form-item>
+        <el-form-item label="鍒涘缓鏃堕棿"
+                      prop="createTime">
+          <el-date-picker v-model="formCreateTimeDate"
+                          type="date"
+                          value-format="YYYY-MM-DD"
+                          style="width: 100%"
+                          placeholder="璇烽�夋嫨鍒涘缓鏃堕棿" />
         </el-form-item>
         <el-form-item label="澶囨敞"
                       prop="remark">
@@ -321,7 +335,7 @@
       },
     },
     {
-      label: "浜у搧瑙勬牸",
+      label: "瑙勬牸鍨嬪彿",
       prop: "model",
       width: "150px",
       className: "spec-cell",
@@ -430,6 +444,7 @@
               Number(row.qtyRequired || 0) - Number(row.quantityIssued || 0);
             mergeForm.planCompleteTime = row.requiredDate || "";
             mergeForm.productId = row.productId || "";
+            mergeForm.createTime = dayjs().format("YYYY-MM-DD HH:mm:ss");
             mergeForm.ids = [row.id];
             sumAssignedQuantity.value =
               Number(row.qtyRequired || 0) - Number(row.quantityIssued || 0);
@@ -473,6 +488,13 @@
     totalAssignedQuantity: 0,
     planCompleteTime: "",
     productId: "",
+    createTime: "",
+  });
+  const mergeCreateTimeDate = computed({
+    get: () => (mergeForm.createTime ? String(mergeForm.createTime).split(" ")[0] : ""),
+    set: (value) => {
+      mergeForm.createTime = value ? `${value} ${dayjs().format("HH:mm:ss")}` : "";
+    },
   });
 
   // 瀵煎叆鐩稿叧
@@ -503,11 +525,18 @@
     requiredDate: "",
     promisedDeliveryDate: "",
     remark: "",
+    createTime: "",
+  });
+  const formCreateTimeDate = computed({
+    get: () => (form.createTime ? String(form.createTime).split(" ")[0] : ""),
+    set: (value) => {
+      form.createTime = value ? `${value} ${dayjs().format("HH:mm:ss")}` : "";
+    },
   });
   const rules = reactive({
     productId: [{ required: true, message: "璇烽�夋嫨浜у搧", trigger: "change" }],
     productModelId: [
-      { required: true, message: "璇烽�夋嫨浜у搧瑙勬牸", trigger: "change" },
+      { required: true, message: "璇烽�夋嫨瑙勬牸鍨嬪彿", trigger: "change" },
     ],
     qtyRequired: [{ required: true, message: "璇疯緭鍏ユ暟閲�", trigger: "blur" }],
     requiredDate: [
@@ -686,17 +715,17 @@
       });
   };
 
-  // 閫変腑鐨勪骇鍝佽鏍糏D
+  // 閫変腑鐨勮鏍煎瀷鍙稩D
   const selectedProductModelId = ref("");
 
   // 琛ㄦ牸閫夋嫨鏁版嵁
   const handleSelectionChange = selection => {
     selectedRows.value = selection;
-    // 濡傛灉鏈夐�変腑鐨勮锛岃褰曠涓�涓�変腑琛岀殑浜у搧瑙勬牸ID
+    // 濡傛灉鏈夐�変腑鐨勮锛岃褰曠涓�涓�変腑琛岀殑瑙勬牸鍨嬪彿ID
     if (selection.length > 0) {
       selectedProductModelId.value = selection[0].productModelId;
     } else {
-      // 濡傛灉娌℃湁閫変腑鐨勮锛屾竻绌轰骇鍝佽鏍糏D
+      // 濡傛灉娌℃湁閫変腑鐨勮锛屾竻绌鸿鏍煎瀷鍙稩D
       selectedProductModelId.value = "";
     }
   };
@@ -717,7 +746,7 @@
     if (!selectedProductModelId.value) {
       return true;
     }
-    // 濡傛灉鏈夐�変腑鐨勮锛屽彧鏈変骇鍝佽鏍糏D鐩稿悓鐨勮鎵嶅彲閫夋嫨
+    // 濡傛灉鏈夐�変腑鐨勮锛屽彧鏈夎鏍煎瀷鍙稩D鐩稿悓鐨勮鎵嶅彲閫夋嫨
     return row.productModelId === selectedProductModelId.value;
   };
   // 鎷夊彇鏁版嵁鎸夐挳鎿嶄綔
@@ -889,6 +918,7 @@
       requiredDate: "",
       promisedDeliveryDate: "",
       remark: "",
+      createTime: dayjs().format("YYYY-MM-DD HH:mm:ss"),
     });
     dialogVisible.value = true;
     fetchProductOptions();
@@ -909,6 +939,7 @@
       requiredDate: row.requiredDate || "",
       promisedDeliveryDate: row.promisedDeliveryDate || "",
       remark: row.remark || "",
+      createTime: row.createTime || "",
     });
     dialogVisible.value = true;
     fetchProductOptions();

--
Gitblit v1.9.3