From 1866b69e8f67e382a0a75268d63e6418c8ae02e7 Mon Sep 17 00:00:00 2001
From: heshaofeng <heshaofeng@hnkhzn.com>
Date: 星期二, 13 一月 2026 09:55:01 +0800
Subject: [PATCH] 1

---
 项目代码/WIDESEA_WMSClient/src/extension/inbound/extend/OrderStockTake.vue |  135 ++++++++++++++++++++++++++++++++++----------
 1 files changed, 104 insertions(+), 31 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEA_WMSClient/src/extension/inbound/extend/OrderStockTake.vue" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEA_WMSClient/src/extension/inbound/extend/OrderStockTake.vue"
index 5f1f0be..92a0bb3 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEA_WMSClient/src/extension/inbound/extend/OrderStockTake.vue"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEA_WMSClient/src/extension/inbound/extend/OrderStockTake.vue"
@@ -61,6 +61,35 @@
             </el-input>
           </el-form-item>
 
+          <!-- 鏂板锛氱珯鍙伴�夋嫨涓嬫媺妗� -->
+          <el-form-item
+            label="鍥炲簱绔欏彴锛�"
+            name="station"
+            :rules="[
+              {
+                required: true,
+                message: '璇烽�夋嫨鍥炲簱绔欏彴',
+                trigger: 'blur',
+              },
+            ]"
+            class="form-item"
+          >
+            <el-select
+              v-model="selectedStation"
+              placeholder="璇烽�夋嫨鍥炲簱绔欏彴"
+              :disabled="!formData.boxNo.trim() || loading"
+              class="custom-input"
+              :class="{ 'has-value': selectedStation }"
+            >
+              <el-option
+                v-for="item in stations"
+                :key="item.key || item.value"
+                :label="item.label"
+                :value="item.value"
+              ></el-option>
+            </el-select>
+          </el-form-item>
+
           <!-- 鏉$爜杈撳叆妗� -->
           <el-form-item
             label="鐩樼偣鏉$爜锛�"
@@ -130,13 +159,13 @@
           >
             <el-input
               v-model.number="formData.actualQuantity"
-              placeholder="璇疯緭鍏ュ疄闄呯洏鐐规暟閲忥紙澶т簬0锛�"
+              placeholder="璇疯緭鍏ュ疄闄呯洏鐐规暟閲�"
               type="number"
               clearable
               @keydown.enter="handleStockTakeComplete"
               :disabled="!formData.stockQuantity || loading"
               class="custom-input"
-              :class="{ 'has-value': formData.actualQuantity }"
+              :class="{ 'has-value': formData.actualQuantity !== '' }"
             ></el-input>
           </el-form-item>
         </el-form>
@@ -147,7 +176,7 @@
             type="info"
             size="small"
             @click="handleBoxReturn"
-            :disabled="!formData.boxNo.trim() || loading"
+            :disabled="!formData.boxNo.trim() || !selectedStation || loading"
             class="return-btn"
           >
             <Return /> 鏂欑鍥炲簱
@@ -156,13 +185,7 @@
             type="primary"
             size="small"
             @click="handleStockTakeComplete"
-            :disabled="
-              loading ||
-              !formData.boxNo.trim() ||
-              !formData.barcode.trim() ||
-              !formData.stockQuantity ||
-              !formData.actualQuantity
-            "
+            :disabled="isFormCompleteDisabled"
             class="complete-btn"
           >
             <Check /> 鐩樼偣瀹屾垚
@@ -185,10 +208,11 @@
 <script setup>
 import { ref, reactive, onMounted, nextTick, watch, defineEmits, computed } from "vue";
 import { ElMessage, ElTag, ElMessageBox } from "element-plus";
-import { Search, Check, Return } from "@element-plus/icons-vue";
 
 import VolBox from "@/components/basic/VolBox.vue";
 import http from "@/api/http";
+// 鏂板锛氬紩鍏ョ珯鍙扮鐞嗗伐鍏凤紙鍜岀ず渚嬩唬鐮佷繚鎸佷竴鑷达級
+import { stationManager, STATION_STORAGE_KEY } from "@/../src/uitils/stationManager";
 
 // 鍝嶅簲寮忓彉閲� - 鍗曟嵁鍙�
 const orderNo = ref("");
@@ -207,6 +231,13 @@
 const loading = ref(false);
 const formRef = ref(null);
 
+// 鏂板锛氱珯鍙扮浉鍏冲搷搴斿紡鏁版嵁锛堜豢鐓хず渚嬩唬鐮侊級
+const stations = ref([
+  { label: "绔欏彴2", value: "2-1" },
+  { label: "绔欏彴3", value: "3-1" },
+]);
+const selectedStation = ref(stationManager.getStation() || ""); // 榛樿閫変腑缂撳瓨鐨勭珯鍙�
+
 // 妯℃澘寮曠敤
 const boxNoInputRef = ref(null);
 const barcodeInputRef = ref(null);
@@ -214,6 +245,20 @@
 // 妫�娴嬫槸鍚︿负绉诲姩绔�
 const isMobile = computed(() => {
   return window.innerWidth < 768;
+});
+
+// 璁$畻灞炴�э細鐩樼偣瀹屾垚鎸夐挳鏄惁绂佺敤
+const isFormCompleteDisabled = computed(() => {
+  return (
+    loading.value ||
+    !formData.boxNo.trim() ||
+    !formData.barcode.trim() ||
+    !formData.stockQuantity ||
+    formData.actualQuantity === "" ||
+    formData.actualQuantity === null ||
+    formData.actualQuantity === undefined ||
+    Number(formData.actualQuantity) < 0 // 灏忎簬0鏃剁鐢紝0鏄厑璁哥殑
+  );
 });
 
 // 缁勪欢鎸傝浇鏃惰仛鐒﹀埌鏂欑鍙疯緭鍏ユ
@@ -233,6 +278,8 @@
       formData.barcode = "";
       formData.stockQuantity = "";
       formData.actualQuantity = "";
+      // 鏂板锛氭枡绠卞彿娓呯┖鏃讹紝閲嶇疆绔欏彴閫夋嫨
+      selectedStation.value = stationManager.getStation() || "";
     }
   },
   { immediate: true }
@@ -258,6 +305,8 @@
   formData.barcode = "";
   formData.stockQuantity = "";
   formData.actualQuantity = "";
+  // 鏂板锛氭墦寮�寮圭獥鏃堕噸缃珯鍙伴�夋嫨锛堥粯璁ゅ彇缂撳瓨鐨勭珯鍙帮級
+  selectedStation.value = stationManager.getStation() || "";
   nextTick(() => {
     boxNoInputRef.value?.focus();
   });
@@ -293,15 +342,18 @@
   }
 };
 
-// 瀹為檯鐩樼偣鏁伴噺楠岃瘉锛堜紭鍖栵細鏈夊�兼椂楠岃瘉鍚堟硶鎬э級
+// 瀹為檯鐩樼偣鏁伴噺楠岃瘉锛氬厑璁�0锛屼絾涓嶅厑璁稿皬浜�0
 const validateActualQuantity = (rule, value, callback) => {
-  if (value === null || value === undefined) {
-    callback(new Error("璇疯緭鍏ュ疄闄呯洏鐐规暟閲�"));
-  } else if (value <= 0) {
-    callback(new Error("瀹為檯鐩樼偣鏁伴噺蹇呴』澶т簬0"));
-  } else if (!Number.isInteger(value)) {
-    callback(new Error("瀹為檯鐩樼偣鏁伴噺蹇呴』鏄暣鏁�"));
-  } else {
+  // 绌哄�肩敱required瑙勫垯澶勭悊锛岃繖閲屽彧楠岃瘉鏁板�煎悎娉曟��
+  if (value === null || value === undefined || value === "") {
+    callback(); // 绌哄�间笉鍦ㄨ繖閲屾彁绀猴紝浜ょ粰required瑙勫垯
+  } 
+  // 楠岃瘉鏁板�兼槸鍚﹀皬浜�0
+  else if (value < 0) {
+    callback(new Error("瀹為檯鐩樼偣鏁伴噺涓嶈兘灏忎簬0"));
+  } 
+  // 楠岃瘉閫氳繃锛堝厑璁�0锛�
+  else {
     callback();
   }
 };
@@ -430,6 +482,12 @@
   const valid = await formRef.value.validate();
   if (!valid) return;
 
+  // 棰濆妫�鏌ュ疄闄呯洏鐐规暟閲忔槸鍚﹀皬浜�0
+  if (formData.actualQuantity < 0) {
+    ElMessage.error("瀹為檯鐩樼偣鏁伴噺涓嶈兘灏忎簬0");
+    return;
+  }
+
   const { boxNo, barcode, actualQuantity, stockQuantity } = formData;
   const receiptNo = orderNo.value;
 
@@ -469,16 +527,21 @@
   }
 };
 
-// 鏂欑鍥炲簱鍔熻兘
+// 鏂欑鍥炲簱鍔熻兘锛堟牳蹇冧慨鏀癸細澧炲姞绔欏彴楠岃瘉 + 浼犲叆sourceAddress鍙傛暟锛�
 const handleBoxReturn = async () => {
   const boxNo = formData.boxNo.trim();
+  // 鏂板锛氶獙璇佺珯鍙版槸鍚﹂�夋嫨
   if (!boxNo) {
     ElMessage.warning("璇峰厛杈撳叆鎴栨壂鎻忔枡绠卞彿");
     return;
   }
+  if (!selectedStation.value) {
+    ElMessage.warning("璇烽�夋嫨鍥炲簱绔欏彴");
+    return;
+  }
 
   try {
-    await ElMessageBox.confirm(`纭畾灏嗘枡绠便��${boxNo}銆戝洖搴撳悧锛焋, "鍥炲簱纭", {
+    await ElMessageBox.confirm(`纭畾灏嗘枡绠便��${boxNo}銆戝洖搴撹嚦銆�${selectedStation.value}銆戠珯鍙板悧锛焋, "鍥炲簱纭", {
       confirmButtonText: "纭畾",
       cancelButtonText: "鍙栨秷",
       type: "info",
@@ -489,19 +552,21 @@
 
     loading.value = true;
 
+    // 鏂板锛氭嫾鎺ourceAddress鍙傛暟锛堢珯鍙版暟鎹級鍒版帴鍙h姹備腑
     const res = await http.post(
       `/api/TakeStockOrder/ReturnBox?boxNo=${encodeURIComponent(boxNo)}&orderNo=${encodeURIComponent(
         orderNo.value
-      )}`,
+      )}&sourceAddress=${encodeURIComponent(selectedStation.value)}`, // 鏂板sourceAddress鍙傛暟
       "鏂欑鍥炲簱涓�..."
     );
 
     if (res.status) {
-      ElMessage.success(`鏂欑銆�${boxNo}銆戝洖搴撴垚鍔燂紒`);
+      ElMessage.success(`鏂欑銆�${boxNo}銆戝洖搴撹嚦銆�${selectedStation.value}銆戠珯鍙版垚鍔燂紒`);
       formData.boxNo = "";
       formData.barcode = "";
       formData.stockQuantity = "";
       formData.actualQuantity = "";
+      selectedStation.value = stationManager.getStation() || ""; // 閲嶇疆绔欏彴閫夋嫨
       nextTick(() => {
         boxNoInputRef.value?.focus();
       });
@@ -589,13 +654,15 @@
 }
 
 /* 鏈夊�兼椂闅愯棌鍗犱綅绗� + 浼樺寲杈规 */
-.custom-input.has-value :deep(.el-input__inner) {
+.custom-input.has-value :deep(.el-input__inner),
+.custom-input.has-value :deep(.el-select__wrapper) {
   --el-input-placeholder-color: transparent; /* 闅愯棌鍗犱綅绗� */
   border-color: #8cc5ff; /* 娴呰摑杈规锛屽尯鍒嗘棤鍊肩姸鎬� */
   background-color: #ffffff;
 }
 
-.custom-input :deep(.el-input__inner) {
+.custom-input :deep(.el-input__inner),
+.custom-input :deep(.el-select__wrapper) {
   border-radius: 8px;
   border-color: #e5f0fa;
   transition: all 0.2s ease;
@@ -607,7 +674,8 @@
 }
 
 /* 鑱氱劍鏍峰紡浼樺寲 */
-.custom-input :deep(.el-input__inner:focus) {
+.custom-input :deep(.el-input__inner:focus),
+.custom-input :deep(.el-select__wrapper:focus) {
   border-color: #409eff;
   box-shadow: 0 0 0 3px rgba(64, 158, 255, 0.1);
   background-color: #ffffff;
@@ -667,7 +735,8 @@
 }
 
 /* 鏈夊�兼椂鍗充娇楠岃瘉澶辫触锛屼篃涓嶆樉绀洪敊璇竟妗� */
-.custom-input.has-value :deep(.el-input__inner.el-input__inner--error) {
+.custom-input.has-value :deep(.el-input__inner.el-input__inner--error),
+.custom-input.has-value :deep(.el-select__wrapper.el-select__wrapper--error) {
   border-color: #8cc5ff;
   box-shadow: none;
 }
@@ -808,22 +877,26 @@
 }
 
 /* 鍗犱綅绗︽牱寮� - 缁熶竴棰滆壊 */
-.el-input__inner::-webkit-input-placeholder {
+.el-input__inner::-webkit-input-placeholder,
+.el-select__placeholder {
   color: #b3d8ff;
   font-size: 13px;
 }
 
-.el-input__inner::-moz-placeholder {
+.el-input__inner::-moz-placeholder,
+.el-select__placeholder {
   color: #b3d8ff;
   font-size: 13px;
 }
 
-.el-input__inner:-ms-input-placeholder {
+.el-input__inner:-ms-input-placeholder,
+.el-select__placeholder {
   color: #b3d8ff;
   font-size: 13px;
 }
 
-.el-input__inner::placeholder {
+.el-input__inner::placeholder,
+.el-select__placeholder {
   color: #b3d8ff;
   font-size: 13px;
 }

--
Gitblit v1.9.3