From dacc95761cf7090c628fc37a5d4f8bb825ccbbb0 Mon Sep 17 00:00:00 2001
From: yyb <995253665@qq.com>
Date: 星期六, 16 五月 2026 15:41:45 +0800
Subject: [PATCH] 企业新闻和通知公告

---
 src/views/salesManagement/salesLedger/index.vue |  992 +++++++++++++++++++++++++++++++++++----------------------
 1 files changed, 603 insertions(+), 389 deletions(-)

diff --git a/src/views/salesManagement/salesLedger/index.vue b/src/views/salesManagement/salesLedger/index.vue
index 1185ca9..4e2d84e 100644
--- a/src/views/salesManagement/salesLedger/index.vue
+++ b/src/views/salesManagement/salesLedger/index.vue
@@ -35,7 +35,8 @@
         </el-form-item>
         <el-form-item>
           <el-button type="primary"
-                     @click="handleQuery"> 鎼滅储 </el-button>
+                     @click="handleQuery"> 鎼滅储
+          </el-button>
         </el-form-item>
       </el-form>
     </div>
@@ -49,14 +50,17 @@
           </el-button>
           <el-button type="primary"
                      plain
-                     @click="handleImport">瀵煎叆</el-button>
+                     @click="handleImport">瀵煎叆
+          </el-button>
           <el-button @click="handleOut">瀵煎嚭</el-button>
           <el-button type="danger"
                      plain
-                     @click="handleDelete">鍒犻櫎</el-button>
+                     @click="handleDelete">鍒犻櫎
+          </el-button>
           <el-button type="primary"
                      plain
-                     @click="handlePrint">鎵撳嵃</el-button>
+                     @click="handlePrint">鎵撳嵃
+          </el-button>
         </div>
       </div>
       <el-table :data="tableData"
@@ -96,12 +100,15 @@
                                width="100px"
                                align="center">
                 <template #default="scope">
-                  <el-tag v-if="scope.row.approveStatus === 1 && (!scope.row.shippingDate || !scope.row.shippingCarNumber)"
-                          type="success">鍏呰冻</el-tag>
-                  <el-tag v-else-if="scope.row.approveStatus === 0 && (scope.row.shippingDate || scope.row.shippingCarNumber)"
-                          type="success">宸插嚭搴�</el-tag>
+                  <el-tag v-if="scope.row.approveStatus === 1 "
+                          type="success">鍏呰冻
+                  </el-tag>
+                  <el-tag v-else-if="scope.row.approveStatus === 0 && scope.row.noQuantity === 0"
+                          type="success">宸插嚭搴�
+                  </el-tag>
                   <el-tag v-else
-                          type="danger">涓嶈冻</el-tag>
+                          type="danger">涓嶈冻
+                  </el-tag>
                 </template>
               </el-table-column>
               <el-table-column label="鍙戣揣鐘舵��"
@@ -126,9 +133,11 @@
                 <template #default="scope">
                   <div>
                     <el-tag type="success"
-                            v-if="scope.row.shippingCarNumber">{{ scope.row.shippingCarNumber }}</el-tag>
+                            v-if="scope.row.shippingCarNumber">{{ scope.row.shippingCarNumber }}
+                    </el-tag>
                     <el-tag v-else
-                            type="info">-</el-tag>
+                            type="info">-
+                    </el-tag>
                   </div>
                 </template>
               </el-table-column>
@@ -139,12 +148,15 @@
                   <div>
                     <div v-if="scope.row.shippingDate">{{ scope.row.shippingDate }}</div>
                     <el-tag v-else
-                            type="info">-</el-tag>
+                            type="info">-
+                    </el-tag>
                   </div>
                 </template>
               </el-table-column>
               <el-table-column label="鏁伴噺"
                                prop="quantity" />
+              <el-table-column label="寰呭彂璐ф暟閲�"
+                               prop="noQuantity" />
               <el-table-column label="绋庣巼(%)"
                                prop="taxRate" />
               <el-table-column label="鍚◣鍗曚环(鍏�)"
@@ -228,10 +240,12 @@
             <el-button link
                        type="primary"
                        @click="openForm('edit', scope.row)"
-                       :disabled="!scope.row.isEdit || scope.row.hasProductionRecord || !canEditLedger(scope.row)">缂栬緫</el-button>
+                       :disabled="!scope.row.isEdit || scope.row.hasProductionRecord || !canEditLedger(scope.row)">缂栬緫
+            </el-button>
             <el-button link
                        type="primary"
-                       @click="downLoadFile(scope.row)">闄勪欢</el-button>
+                       @click="openFileDialog(scope.row)">闄勪欢
+            </el-button>
           </template>
         </el-table-column>
       </el-table>
@@ -395,11 +409,13 @@
                         prop="entryDate">
             <el-button v-if="operationType !== 'view'"
                        type="primary"
-                       @click="openProductForm('add')">娣诲姞</el-button>
+                       @click="openProductForm('add')">娣诲姞
+            </el-button>
             <el-button v-if="operationType !== 'view'"
                        plain
                        type="danger"
-                       @click="deleteProduct">鍒犻櫎</el-button>
+                       @click="deleteProduct">鍒犻櫎
+            </el-button>
           </el-form-item>
         </el-row>
         <el-table :data="productData"
@@ -454,7 +470,8 @@
                          type="primary"
                          size="small"
                          :disabled="isProductShipped(scope.row)"
-                         @click="openProductForm('edit', scope.row,scope.$index)">缂栬緫</el-button>
+                         @click="openProductForm('edit', scope.row,scope.$index)">缂栬緫
+              </el-button>
             </template>
           </el-table-column>
         </el-table>
@@ -475,26 +492,7 @@
           <el-col :span="24">
             <el-form-item label="闄勪欢鏉愭枡锛�"
                           prop="salesLedgerFiles">
-              <el-upload v-model:file-list="fileList"
-                         :action="upload.url"
-                         multiple
-                         ref="fileUpload"
-                         auto-upload
-                         :headers="upload.headers"
-                         :before-upload="handleBeforeUpload"
-                         :on-error="handleUploadError"
-                         :on-success="handleUploadSuccess"
-                         :on-remove="handleRemove">
-                <el-button type="primary"
-                           v-if="operationType !== 'view'">涓婁紶</el-button>
-                <template #tip
-                          v-if="operationType !== 'view'">
-                  <div class="el-upload__tip">
-                    鏂囦欢鏍煎紡鏀寔
-                    doc锛宒ocx锛寈ls锛寈lsx锛宲pt锛宲ptx锛宲df锛宼xt锛寈ml锛宩pg锛宩peg锛宲ng锛実if锛宐mp锛宺ar锛寊ip锛�7z
-                  </div>
-                </template>
-              </el-upload>
+              <FileUpload v-model:file-list="fileList" />
             </el-form-item>
           </el-col>
         </el-row>
@@ -517,7 +515,8 @@
                   style="max-width: 260px;"
                   @change="fetchQuotationList" />
         <el-button type="primary"
-                   @click="fetchQuotationList">鎼滅储</el-button>
+                   @click="fetchQuotationList">鎼滅储
+        </el-button>
         <el-button @click="resetQuotationSearch">閲嶇疆</el-button>
       </div>
       <el-table :data="quotationList"
@@ -563,7 +562,8 @@
           <template #default="scope">
             <el-button type="primary"
                        link
-                       @click="applyQuotation(scope.row)">閫夋嫨</el-button>
+                       @click="applyQuotation(scope.row)">閫夋嫨
+            </el-button>
           </template>
         </el-table-column>
       </el-table>
@@ -638,12 +638,10 @@
                          placeholder="璇烽�夋嫨"
                          clearable
                          @change="calculateFromTaxRate">
-                <el-option label="1"
-                           value="1" />
-                <el-option label="6"
-                           value="6" />
-                <el-option label="13"
-                           value="13" />
+                <el-option v-for="dict in tax_rate"
+                           :key="dict.value"
+                           :label="dict.label"
+                           :value="dict.value" />
               </el-select>
             </el-form-item>
           </el-col>
@@ -752,15 +750,18 @@
             浠呮敮鎸� xls/xlsx锛屽ぇ灏忎笉瓒呰繃 10MB銆�
             <el-button link
                        type="primary"
-                       @click="downloadTemplate">涓嬭浇瀵煎叆妯℃澘</el-button>
+                       @click="downloadTemplate">涓嬭浇瀵煎叆妯℃澘
+            </el-button>
           </div>
         </template>
       </el-upload>
     </FormDialog>
+    <!-- // todo 闄勪欢棰勮鐩稿叧 -->
     <!-- 闄勪欢鍒楄〃寮圭獥 -->
-    <FileListDialog ref="fileListRef"
-                    v-model="fileListDialogVisible"
-                    title="闄勪欢鍒楄〃" />
+    <FileList v-if="fileDialogVisible"
+              v-model:visible="fileDialogVisible"
+              record-type="sales_ledger"
+              :record-id="recordId" />
     <!-- 鎵撳嵃棰勮寮圭獥 -->
     <el-dialog v-model="printPreviewVisible"
                title="鎵撳嵃棰勮"
@@ -770,7 +771,8 @@
       <div class="print-preview-container">
         <div class="print-preview-header">
           <el-button type="primary"
-                     @click="executePrint">鎵ц鎵撳嵃</el-button>
+                     @click="executePrint">鎵ц鎵撳嵃
+          </el-button>
           <el-button @click="printPreviewVisible = false">鍏抽棴棰勮</el-button>
         </div>
         <div class="print-preview-content">
@@ -833,7 +835,8 @@
                     </tr>
                     <tr v-if="!item.products || item.products.length === 0">
                       <td colspan="6"
-                          style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td>
+                          style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁
+                      </td>
                     </tr>
                   </tbody>
                   <tfoot>
@@ -895,7 +898,8 @@
                           prop="type">
               <el-select v-model="deliveryForm.type"
                          placeholder="璇烽�夋嫨鍙戣揣绫诲瀷"
-                         style="width: 100%">
+                         style="width: 100%"
+                         @change="handleDeliveryTypeChange">
                 <el-option label="璐ц溅"
                            value="璐ц溅" />
                 <el-option label="蹇��"
@@ -903,12 +907,91 @@
               </el-select>
             </el-form-item>
           </el-col>
+          <el-col :span="24">
+            <el-form-item label="寰呭彂璐ф暟閲忥細">
+              <el-input :model-value="currentDeliveryRow?.noQuantity"
+                        disabled />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="24" v-if="deliveryForm.type === '璐ц溅'">
+            <el-form-item label="鍙戣揣杞︾墝鍙凤細"
+                          prop="shippingCarNumber">
+              <el-input v-model="deliveryForm.shippingCarNumber"
+                        placeholder="璇疯緭鍏ュ彂璐ц溅鐗屽彿"
+                        clearable />
+            </el-form-item>
+          </el-col>
+          <el-col :span="24" v-else>
+            <el-form-item label="蹇�掑叕鍙革細"
+                          prop="expressCompany">
+              <el-input v-model="deliveryForm.expressCompany"
+                        placeholder="璇疯緭鍏ュ揩閫掑叕鍙�"
+                        clearable />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30" v-if="deliveryForm.type === '蹇��'">
+          <el-col :span="24">
+            <el-form-item label="蹇�掑崟鍙凤細"
+                          prop="expressNumber">
+              <el-input v-model="deliveryForm.expressNumber"
+                        placeholder="璇疯緭鍏ュ揩閫掑崟鍙�"
+                        clearable />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="24">
+            <el-form-item label="鍙戣揣鍥剧墖锛�">
+              <ImageUpload v-model:file-list="deliveryFileList" :limit="9" />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="24">
+            <el-form-item label="鎵瑰彿锛�"
+                          prop="batchNo">
+              <el-table :data="deliveryForm.batchNoList"
+                        border
+                        size="small"
+                        max-height="260"
+                        style="width: 100%;">
+                <el-table-column label="鎵瑰彿"
+                                 prop="batchNo"
+                                 min-width="180" />
+                <el-table-column label="搴撳瓨鏁伴噺"
+                                 min-width="120"
+                                 align="center">
+                  <template #default="scope">
+                    {{ getDeliveryBatchQuantity(scope.row) }}
+                  </template>
+                </el-table-column>
+                <el-table-column label="鍙戣揣鏁伴噺"
+                                 min-width="160"
+                                 align="center">
+                  <template #default="scope">
+                    <el-input-number v-model="scope.row.deliveryQuantity"
+                                     :min="0"
+                                     :max="getDeliveryBatchDeliveryMax(scope.row)"
+                                     :precision="2"
+                                     :step="0.01"
+                                     controls-position="right"
+                                     @change="handleDeliveryBatchQuantityChange(scope.row)"
+                                     style="width: 100%;" />
+                  </template>
+                </el-table-column>
+              </el-table>
+            </el-form-item>
+          </el-col>
         </el-row>
       </el-form>
       <template #footer>
         <div class="dialog-footer">
           <el-button type="primary"
-                     @click="submitDelivery">纭鍙戣揣</el-button>
+                     @click="submitDelivery">纭鍙戣揣
+          </el-button>
           <el-button @click="closeDeliveryDia">鍙栨秷</el-button>
         </div>
       </template>
@@ -922,10 +1005,8 @@
   import { onMounted, ref, getCurrentInstance } from "vue";
   import { addShippingInfo } from "@/api/salesManagement/deliveryLedger.js";
   import { ElMessageBox, ElMessage } from "element-plus";
-  import { UploadFilled, Download } from "@element-plus/icons-vue";
   import useUserStore from "@/store/modules/user";
   import { userListNoPage } from "@/api/system/user.js";
-  import FileListDialog from "@/components/Dialog/FileListDialog.vue";
   import FormDialog from "@/components/Dialog/FormDialog.vue";
   import { getQuotationList } from "@/api/salesManagement/salesQuotation.js";
   import {
@@ -940,14 +1021,24 @@
     delLedgerFile,
     getProductInventory,
   } from "@/api/salesManagement/salesLedger.js";
+  import { getStockInventoryByModelId } from "@/api/inventoryManagement/stockInventory.js";
   import { modelList, productTreeList } from "@/api/basicData/product.js";
   import useFormData from "@/hooks/useFormData.js";
   import dayjs from "dayjs";
+  import FileUpload from "@/components/AttachmentUpload/file/index.vue";
+  import ImageUpload from "@/components/AttachmentUpload/image/index.vue";
   import { getCurrentDate } from "@/utils/index.js";
-  import { listCustomerPrivatePool } from "@/api/basicData/customerFile.js";
+  import { listCustomer } from "@/api/basicData/customer.js";
 
+  const FileList = defineAsyncComponent(() =>
+    import("@/components/Dialog/FileList.vue")
+  );
+
+  const router = useRouter();
+  const route = useRoute();
   const userStore = useUserStore();
   const { proxy } = getCurrentInstance();
+  const { tax_rate } = proxy.useDict("tax_rate");
   const tableData = ref([]);
   const productData = ref([]);
   const selectedRows = ref([]);
@@ -963,6 +1054,7 @@
   });
   const total = ref(0);
   const fileList = ref([]);
+  const deliveryFileList = ref([]);
 
   // 鐢ㄦ埛淇℃伅琛ㄥ崟寮规鏁版嵁
   const operationType = ref("");
@@ -1040,12 +1132,6 @@
   const { productForm, productRules } = toRefs(productFormData);
   // 闃叉寰幆璁$畻鐨勬爣蹇�
   const isCalculating = ref(false);
-  const upload = reactive({
-    // 涓婁紶鐨勫湴鍧�
-    url: import.meta.env.VITE_APP_BASE_API + "/file/upload",
-    // 璁剧疆涓婁紶鐨勮姹傚ご閮�
-    headers: { Authorization: "Bearer " + getToken() },
-  });
   // 鎵撳嵃鐩稿叧
   const printPreviewVisible = ref(false);
   const printData = ref([]);
@@ -1069,11 +1155,108 @@
   // 鍙戣揣鐩稿叧
   const deliveryFormVisible = ref(false);
   const currentDeliveryRow = ref(null);
+  const getDeliveryBatchQuantity = item => {
+    const quantity =
+      item?.qualitity ??
+      item?.quantity ??
+      item?.unLockedQuantity ??
+      item?.qualifiedUnLockedQuantity ??
+      item?.qualifiedQuantity ??
+      item?.stockQuantity;
+    return quantity ?? 0;
+  };
+  const getCurrentDeliveryRowQuantity = () => {
+    return Number(currentDeliveryRow.value?.noQuantity || 0);
+  };
+  const getDeliveryBatchDeliveryMax = row => {
+    const productQuantity = getCurrentDeliveryRowQuantity();
+    const batchQuantity = Number(getDeliveryBatchQuantity(row) || 0);
+    const otherBatchTotal = (deliveryForm.value.batchNoList || []).reduce(
+      (sum, item) => {
+        if (item?.id === row?.id) return sum;
+        return sum + Number(item?.deliveryQuantity || 0);
+      },
+      0
+    );
+    const remainingProductQuantity = Math.max(
+      0,
+      productQuantity - otherBatchTotal
+    );
+    return Math.max(0, Math.min(batchQuantity, remainingProductQuantity));
+  };
+  const handleDeliveryBatchQuantityChange = row => {
+    const productQuantity = getCurrentDeliveryRowQuantity();
+    const batchQuantity = Number(getDeliveryBatchQuantity(row) || 0);
+    const otherBatchTotal = (deliveryForm.value.batchNoList || []).reduce(
+      (sum, item) => {
+        if (item?.id === row?.id) return sum;
+        return sum + Number(item?.deliveryQuantity || 0);
+      },
+      0
+    );
+    const remainingProductQuantity = Math.max(
+      0,
+      productQuantity - otherBatchTotal
+    );
+    const currentValue = Number(row?.deliveryQuantity || 0);
+
+    if (currentValue > batchQuantity) {
+      row.deliveryQuantity = batchQuantity;
+      proxy.$modal.msgWarning("鍙戣揣鏁伴噺涓嶈兘澶т簬搴撳瓨鏁伴噺");
+    } else if (currentValue > remainingProductQuantity) {
+      row.deliveryQuantity = remainingProductQuantity;
+      proxy.$modal.msgWarning("鎵�鏈夋壒娆″彂璐ф暟閲忎箣鍜屼笉鑳藉ぇ浜庡緟鍙戣揣鏁伴噺");
+    }
+  };
+  const getSelectedDeliveryBatchRows = () => {
+    return (deliveryForm.value.batchNoList || []).filter(
+      item => Number(item?.deliveryQuantity || 0) > 0
+    );
+  };
+  const getDeliveryBatchNoList = async productModelId => {
+    if (!productModelId) return [];
+    const res = await getStockInventoryByModelId(productModelId);
+    const rawList = Array.isArray(res?.data)
+      ? res.data
+      : res?.data?.records || res?.data?.rows || [];
+    const seenIds = new Set();
+    return rawList
+      .filter(item => {
+        if (!item?.id || !item?.batchNo || seenIds.has(item.id)) {
+          return false;
+        }
+        seenIds.add(item.id);
+        return true;
+      })
+      .map(item => ({
+        ...item,
+        deliveryQuantity: 0,
+      }));
+  };
+  const validateDeliveryShippingCarNumber = (_rule, value, callback) => {
+    if (deliveryForm.value.type === "璐ц溅" && !value) {
+      return callback(new Error("璇疯緭鍏ュ彂璐ц溅鐗屽彿"));
+    }
+    callback();
+  };
+  const validateDeliveryExpressCompany = (_rule, value, callback) => {
+    if (deliveryForm.value.type === "蹇��" && !value) {
+      return callback(new Error("璇疯緭鍏ュ揩閫掑叕鍙�"));
+    }
+    callback();
+  };
   const deliveryFormData = reactive({
     deliveryForm: {
+      shippingCarNumber: "",
+      expressCompany: "",
+      expressNumber: "",
       type: "璐ц溅", // 璐ц溅, 蹇��
     },
     deliveryRules: {
+      shippingCarNumber: [
+        { validator: validateDeliveryShippingCarNumber, trigger: "blur" },
+      ],
+      expressCompany: [{ validator: validateDeliveryExpressCompany, trigger: "blur" }],
       type: [{ required: true, message: "璇烽�夋嫨鍙戣揣绫诲瀷", trigger: "change" }],
     },
   });
@@ -1273,6 +1456,7 @@
     }
     return null; // 娌℃湁鎵惧埌鑺傜偣锛岃繑鍥瀗ull
   };
+
   function convertIdToValue(data) {
     return data.map(item => {
       const { id, children, ...rest } = item;
@@ -1287,6 +1471,7 @@
       return newItem;
     });
   }
+
   // 鏍规嵁鍚嶇О鍙嶆煡浜у搧澶х被 id锛屼究浜庝粎瀛樺悕绉版椂鐨勫弽鏄�
   function findNodeIdByLabel(nodes, label) {
     if (!label) return null;
@@ -1300,6 +1485,7 @@
     }
     return null;
   }
+
   // 琛ㄦ牸閫夋嫨鏁版嵁
   const handleSelectionChange = selection => {
     // 杩囨护鎺夊瓙鏁版嵁
@@ -1392,7 +1578,7 @@
     selectedQuotation.value = null;
     let userLists = await userListNoPage();
     userList.value = userLists.data;
-    listCustomerPrivatePool({ current: -1, size: -1 }).then(res => {
+    listCustomer({ current: -1, size: -1 }).then(res => {
       customerOption.value = res.data.records;
     });
     form.value.entryPerson = userStore.id;
@@ -1407,7 +1593,7 @@
         form.value = { ...res };
         form.value.entryPerson = Number(res.entryPerson);
         productData.value = form.value.productData;
-        fileList.value = form.value.salesLedgerFiles;
+        fileList.value = form.value.storageBlobVOs;
       });
     }
     // let userAll = await userStore.getInfo()
@@ -1429,7 +1615,7 @@
     // 鍏堢‘淇濆鎴峰垪琛ㄥ凡鍔犺浇锛屼究浜庡悗缁洖濉� customerId
     if (!customerOption.value || customerOption.value.length === 0) {
       try {
-        listCustomerPrivatePool({ current: -1, size: -1 }).then(res => {
+        listCustomer({ current: -1, size: -1 }).then(res => {
           customerOption.value = res.data.records;
         });
       } catch (e) {
@@ -1524,45 +1710,11 @@
 
     quotationDialogVisible.value = false;
   };
+
   function changs(val) {
     console.log(val);
   }
-  // 涓婁紶鍓嶆牎妫�
-  function handleBeforeUpload(file) {
-    // 鏍℃鏂囦欢澶у皬
-    // if (file.size > 1024 * 1024 * 10) {
-    //   proxy.$modal.msgError("涓婁紶鏂囦欢澶у皬涓嶈兘瓒呰繃10MB!");
-    //   return false;
-    // }
-    proxy.$modal.loading("姝e湪涓婁紶鏂囦欢锛岃绋嶅��...");
-    return true;
-  }
-  // 涓婁紶澶辫触
-  function handleUploadError(err) {
-    proxy.$modal.msgError("涓婁紶鏂囦欢澶辫触");
-    proxy.$modal.closeLoading();
-  }
-  // 涓婁紶鎴愬姛鍥炶皟
-  function handleUploadSuccess(res, file, uploadFiles) {
-    proxy.$modal.closeLoading();
-    if (res.code === 200) {
-      file.tempId = res.data.tempId;
-      proxy.$modal.msgSuccess("涓婁紶鎴愬姛");
-    } else {
-      proxy.$modal.msgError(res.msg);
-      proxy.$refs.fileUpload.handleRemove(file);
-    }
-  }
-  // 绉婚櫎鏂囦欢
-  function handleRemove(file) {
-    if (operationType.value === "edit") {
-      let ids = [];
-      ids.push(file.id);
-      delLedgerFile(ids).then(res => {
-        proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-      });
-    }
-  }
+
   // 鎻愪氦琛ㄥ崟
   const submitForm = () => {
     proxy.$refs["formRef"].validate(valid => {
@@ -1574,11 +1726,7 @@
           proxy.$modal.msgWarning("璇锋坊鍔犱骇鍝佷俊鎭�");
           return;
         }
-        let tempFileIds = [];
-        if (fileList.value !== null && fileList.value.length > 0) {
-          tempFileIds = fileList.value.map(item => item.tempId);
-        }
-        form.value.tempFileIds = tempFileIds;
+        form.value.storageBlobDTOs = fileList;
         form.value.type = 1;
         addOrUpdateSalesLedger(form.value).then(res => {
           proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
@@ -1897,279 +2045,286 @@
 
     // 鏋勫缓鎵撳嵃鍐呭
     let printContent = `
-                                          <!DOCTYPE html>
-                                          <html>
-                                          <head>
-                                            <meta charset="UTF-8">
-                                            <title>鎵撳嵃棰勮</title>
-                                            <style>
-                                              body {
-                                                margin: 0;
-                                                padding: 0;
-                                                font-family: "SimSun", serif;
-                                                background: white;
-                                              }
-                                                                                           .print-page {
-                                                  width: 200mm;
-                                                  height: 75mm;
-                                                  padding: 10mm;
-                                                  padding-left: 20mm;
-                                                  background: white;
-                                                  box-sizing: border-box;
-                                                  page-break-after: always;
-                                                  page-break-inside: avoid;
-                                                }
-                                               .print-page:last-child {
-                                                 page-break-after: avoid;
-                                               }
-                                              .delivery-note {
-                                                width: 100%;
-                                                height: 100%;
-                                                font-size: 12px;
-                                                line-height: 1.2;
-                                                display: flex;
-                                                flex-direction: column;
-                                                color: #000;
-                                              }
-                                              .header {
-                                                text-align: center;
-                                                margin-bottom: 8px;
-                                              }
-                                              .company-name {
-                                                font-size: 18px;
-                                                font-weight: bold;
-                                                margin-bottom: 4px;
-                                              }
-                                              .document-title {
-                                                font-size: 16px;
-                                                font-weight: bold;
-                                              }
-                                              .info-section {
-                                                margin-bottom: 8px;
-                                                display: flex;
-                                                justify-content: space-between;
-                                                align-items: center;
-                                              }
-                                              .info-row {
-                                                line-height: 20px;
-                                              }
-                                              .label {
-                                                font-weight: bold;
-                                                width: 60px;
-                                                font-size: 12px;
-                                              }
-                                              .value {
-                                                margin-right: 20px;
-                                                min-width: 80px;
-                                                font-size: 12px;
-                                              }
-                                                       .table-section {
-                                                       margin-bottom: 40px;
-                                                //  flex: 0.6;
-                                               }
-                                              .product-table {
-                                                width: 100%;
-                                                border-collapse: collapse;
-                                                border: 1px solid #000;
-                                              }
-                                                       .product-table th, .product-table td {
-                                                 border: 1px solid #000;
-                                                 padding: 6px;
-                                                 text-align: center;
-                                                 font-size: 12px;
-                                                 line-height: 1.4;
-                                               }
-                                              .product-table th {
-                                                font-weight: bold;
-                                              }
-                                              .total-value {
-                                                font-weight: bold;
-                                              }
-                                              .footer-section {
-                                                margin-top: auto;
-                                              }
-                                              .footer-row {
-                                                display: flex;
-                                                margin-bottom: 3px;
-                                                line-height: 22px;
-                                                justify-content: space-between;
-                                              }
-                                              .footer-item {
-                                                display: flex;
-                                                margin-right: 20px;
-                                              }
-                                              .footer-item .label {
-                                                font-weight: bold;
-                                                width: 80px;
-                                                font-size: 12px;
-                                              }
-                                              .footer-item .value {
-                                                min-width: 80px;
-                                                font-size: 12px;
-                                              }
-                                              .address-item .address-value {
-                                                min-width: 200px;
-                                              }
-                                              @media print {
-                                                body {
-                                                  margin: 0;
-                                                  padding: 0;
-                                                }
-                                                           .print-page {
-                                                   margin: 0;
-                                                   padding: 10mm;
-                                                   /* padding-left: 20mm; */
-                                                   page-break-inside: avoid;
-                                                   page-break-after: always;
-                                                 }
-                                                 .print-page:last-child {
-                                                   page-break-after: avoid;
-                                                 }
-                                              }
-                                            </style>
-                                          </head>
-                                          <body>
-                                        `;
+                                                                <!DOCTYPE html>
+                                                                <html>
+                                                                <head>
+                                                                  <meta charset="UTF-8">
+                                                                  <title>鎵撳嵃棰勮</title>
+                                                                  <style>
+                                                                    body {
+                                                                      margin: 0;
+                                                                      padding: 0;
+                                                                      font-family: "SimSun", serif;
+                                                                      background: white;
+                                                                    }
+                                                                                                                 .print-page {
+                                                                        width: 200mm;
+                                                                        height: 75mm;
+                                                                        padding: 10mm;
+                                                                        padding-left: 20mm;
+                                                                        background: white;
+                                                                        box-sizing: border-box;
+                                                                        page-break-after: always;
+                                                                        page-break-inside: avoid;
+                                                                      }
+                                                                     .print-page:last-child {
+                                                                       page-break-after: avoid;
+                                                                     }
+                                                                    .delivery-note {
+                                                                      width: 100%;
+                                                                      height: 100%;
+                                                                      font-size: 12px;
+                                                                      line-height: 1.2;
+                                                                      display: flex;
+                                                                      flex-direction: column;
+                                                                      color: #000;
+                                                                    }
+                                                                    .header {
+                                                                      text-align: center;
+                                                                      margin-bottom: 8px;
+                                                                    }
+                                                                    .company-name {
+                                                                      font-size: 18px;
+                                                                      font-weight: bold;
+                                                                      margin-bottom: 4px;
+                                                                    }
+                                                                    .document-title {
+                                                                      font-size: 16px;
+                                                                      font-weight: bold;
+                                                                    }
+                                                                    .info-section {
+                                                                      margin-bottom: 8px;
+                                                                      display: flex;
+                                                                      justify-content: space-between;
+                                                                      align-items: center;
+                                                                    }
+                                                                    .info-row {
+                                                                      line-height: 20px;
+                                                                    }
+                                                                    .label {
+                                                                      font-weight: bold;
+                                                                      width: 60px;
+                                                                      font-size: 12px;
+                                                                    }
+                                                                    .value {
+                                                                      margin-right: 20px;
+                                                                      min-width: 80px;
+                                                                      font-size: 12px;
+                                                                    }
+                                                                             .table-section {
+                                                                             margin-bottom: 40px;
+                                                                      //  flex: 0.6;
+                                                                     }
+                                                                    .product-table {
+                                                                      width: 100%;
+                                                                      border-collapse: collapse;
+                                                                      border: 1px solid #000;
+                                                                    }
+                                                                             .product-table th, .product-table td {
+                                                                       border: 1px solid #000;
+                                                                       padding: 6px;
+                                                                       text-align: center;
+                                                                       font-size: 12px;
+                                                                       line-height: 1.4;
+                                                                     }
+                                                                    .product-table th {
+                                                                      font-weight: bold;
+                                                                    }
+                                                                    .total-value {
+                                                                      font-weight: bold;
+                                                                    }
+                                                                    .footer-section {
+                                                                      margin-top: auto;
+                                                                    }
+                                                                    .footer-row {
+                                                                      display: flex;
+                                                                      margin-bottom: 3px;
+                                                                      line-height: 22px;
+                                                                      justify-content: space-between;
+                                                                    }
+                                                                    .footer-item {
+                                                                      display: flex;
+                                                                      margin-right: 20px;
+                                                                    }
+                                                                    .footer-item .label {
+                                                                      font-weight: bold;
+                                                                      width: 80px;
+                                                                      font-size: 12px;
+                                                                    }
+                                                                    .footer-item .value {
+                                                                      min-width: 80px;
+                                                                      font-size: 12px;
+                                                                    }
+                                                                    .address-item .address-value {
+                                                                      min-width: 200px;
+                                                                    }
+                                                                    @media print {
+                                                                      body {
+                                                                        margin: 0;
+                                                                        padding: 0;
+                                                                      }
+                                                                                 .print-page {
+                                                                         margin: 0;
+                                                                         padding: 10mm;
+                                                                         /* padding-left: 20mm; */
+                                                                         page-break-inside: avoid;
+                                                                         page-break-after: always;
+                                                                       }
+                                                                       .print-page:last-child {
+                                                                         page-break-after: avoid;
+                                                                       }
+                                                                    }
+                                                                  </style>
+                                                                </head>
+                                                                <body>
+                                                              `;
 
     // 涓烘瘡鏉℃暟鎹敓鎴愭墦鍗伴〉闈�
     printData.value.forEach((item, index) => {
       printContent += `
-                                            <div class="print-page">
-                                              <div class="delivery-note">
-                                                <div class="header">
-                                                  <div class="document-title">闆跺敭鍙戣揣鍗�</div>
-                                                </div>
-                                                
-                                                <div class="info-section">
-                                                  <div class="info-row">
-                                                    <div>
-                                                      <span class="label">鍙戣揣鏃ユ湡锛�</span>
-                                                      <span class="value">${formatDate(
-                                                        item.createTime
-                                                      )}</span>
-                                                    </div>
-                                                    <div>
-                                                      <span class="label">瀹㈡埛鍚嶇О锛�</span>
-                                                      <span class="value">${
-                                                        item.customerName
-                                                      }</span>
-                                                    </div>
-                                                  </div>
-                                                  <div class="info-row">
-                                                    <span class="label">鍗曞彿锛�</span>
-                                                    <span class="value">${
-                                                      item.salesContractNo || ""
-                                                    }</span>
-                                                  </div>
-                                                </div>
+                                                                  <div class="print-page">
+                                                                    <div class="delivery-note">
+                                                                      <div class="header">
+                                                                        <div class="document-title">闆跺敭鍙戣揣鍗�</div>
+                                                                      </div>
+                                                                      
+                                                                      <div class="info-section">
+                                                                        <div class="info-row">
+                                                                          <div>
+                                                                            <span class="label">鍙戣揣鏃ユ湡锛�</span>
+                                                                            <span class="value">${formatDate(
+                                                                              item.createTime
+                                                                            )}</span>
+                                                                          </div>
+                                                                          <div>
+                                                                            <span class="label">瀹㈡埛鍚嶇О锛�</span>
+                                                                            <span class="value">${
+                                                                              item.customerName
+                                                                            }</span>
+                                                                          </div>
+                                                                        </div>
+                                                                        <div class="info-row">
+                                                                          <span class="label">鍗曞彿锛�</span>
+                                                                          <span class="value">${
+                                                                            item.salesContractNo ||
+                                                                            ""
+                                                                          }</span>
+                                                                        </div>
+                                                                      </div>
 
-                                                <div class="table-section">
-                                                  <table class="product-table">
-                                                    <thead>
-                                                      <tr>
-                                                        <th>浜у搧鍚嶇О</th>
-                                                        <th>瑙勬牸鍨嬪彿</th>
-                                                        <th>鍗曚綅</th>
-                                                        <th>鍗曚环</th>
-                                                        <th>闆跺敭鏁伴噺</th>
-                                                        <th>闆跺敭閲戦</th>
-                                                      </tr>
-                                                    </thead>
-                                                    <tbody>
-                                                      ${
-                                                        item.products &&
-                                                        item.products.length > 0
-                                                          ? item.products
-                                                              .map(
-                                                                product => `
-                                                          <tr>
-                                                            <td>${
-                                                              product.productCategory ||
-                                                              ""
-                                                            }</td>
-                                                            <td>${
-                                                              product.specificationModel ||
-                                                              ""
-                                                            }</td>
-                                                            <td>${
-                                                              product.unit || ""
-                                                            }</td>
-                                                            <td>${
-                                                              product.taxInclusiveUnitPrice ||
-                                                              "0"
-                                                            }</td>
-                                                            <td>${
-                                                              product.quantity ||
-                                                              "0"
-                                                            }</td>
-                                                            <td>${
-                                                              product.taxInclusiveTotalPrice ||
-                                                              "0"
-                                                            }</td>
-                                                          </tr>
-                                                        `
-                                                              )
-                                                              .join("")
-                                                          : '<tr><td colspan="6" style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td></tr>'
-                                                      }
-                                                    </tbody>
-                                                    <tfoot>
-                                                      <tr>
-                                                        <td class="label">鍚堣</td>
-                                                        <td class="total-value"></td>
-                                                        <td class="total-value"></td>
-                                                        <td class="total-value"></td>
-                                                        <td class="total-value">${getTotalQuantityForPrint(
-                                                          item.products
-                                                        )}</td>
-                                                        <td class="total-value">${getTotalAmountForPrint(
-                                                          item.products
-                                                        )}</td>
-                                                      </tr>
-                                                    </tfoot>
-                                                  </table>
-                                                </div>
+                                                                      <div class="table-section">
+                                                                        <table class="product-table">
+                                                                          <thead>
+                                                                            <tr>
+                                                                              <th>浜у搧鍚嶇О</th>
+                                                                              <th>瑙勬牸鍨嬪彿</th>
+                                                                              <th>鍗曚綅</th>
+                                                                              <th>鍗曚环</th>
+                                                                              <th>闆跺敭鏁伴噺</th>
+                                                                              <th>闆跺敭閲戦</th>
+                                                                            </tr>
+                                                                          </thead>
+                                                                          <tbody>
+                                                                            ${
+                                                                              item.products &&
+                                                                              item
+                                                                                .products
+                                                                                .length >
+                                                                                0
+                                                                                ? item.products
+                                                                                    .map(
+                                                                                      product => `
+                                                                                <tr>
+                                                                                  <td>${
+                                                                                    product.productCategory ||
+                                                                                    ""
+                                                                                  }</td>
+                                                                                  <td>${
+                                                                                    product.specificationModel ||
+                                                                                    ""
+                                                                                  }</td>
+                                                                                  <td>${
+                                                                                    product.unit ||
+                                                                                    ""
+                                                                                  }</td>
+                                                                                  <td>${
+                                                                                    product.taxInclusiveUnitPrice ||
+                                                                                    "0"
+                                                                                  }</td>
+                                                                                  <td>${
+                                                                                    product.quantity ||
+                                                                                    "0"
+                                                                                  }</td>
+                                                                                  <td>${
+                                                                                    product.taxInclusiveTotalPrice ||
+                                                                                    "0"
+                                                                                  }</td>
+                                                                                </tr>
+                                                                              `
+                                                                                    )
+                                                                                    .join(
+                                                                                      ""
+                                                                                    )
+                                                                                : '<tr><td colspan="6" style="text-align: center; color: #999;">鏆傛棤浜у搧鏁版嵁</td></tr>'
+                                                                            }
+                                                                          </tbody>
+                                                                          <tfoot>
+                                                                            <tr>
+                                                                              <td class="label">鍚堣</td>
+                                                                              <td class="total-value"></td>
+                                                                              <td class="total-value"></td>
+                                                                              <td class="total-value"></td>
+                                                                              <td class="total-value">${getTotalQuantityForPrint(
+                                                                                item.products
+                                                                              )}</td>
+                                                                              <td class="total-value">${getTotalAmountForPrint(
+                                                                                item.products
+                                                                              )}</td>
+                                                                            </tr>
+                                                                          </tfoot>
+                                                                        </table>
+                                                                      </div>
 
-                                                <div class="footer-section">
-                                                  <div class="footer-row">
-                                                    <div class="footer-item">
-                                                      <span class="label">鏀惰揣鐢佃瘽锛�</span>
-                                                      <span class="value"></span>
-                                                    </div>
-                                                    <div class="footer-item">
-                                                      <span class="label">鏀惰揣浜猴細</span>
-                                                      <span class="value"></span>
-                                                    </div>
-                                                    <div class="footer-item address-item">
-                                                      <span class="label">鏀惰揣鍦板潃锛�</span>
-                                                      <span class="value address-value"></span>
-                                                    </div>
-                                                  </div>
-                                                  <div class="footer-row">
-                                                    <div class="footer-item">
-                                                      <span class="label">鎿嶄綔鍛橈細</span>
-                                                      <span class="value">${
-                                                        userStore.nickName ||
-                                                        "鎾曞紑鍓�"
-                                                      }</span>
-                                                    </div>
-                                                    <div class="footer-item">
-                                                      <span class="label">鎵撳嵃鏃ユ湡锛�</span>
-                                                      <span class="value">${formatDateTime(
-                                                        new Date()
-                                                      )}</span>
-                                                    </div>
-                                                  </div>
-                                                </div>
-                                              </div>
-                                            </div>
-                                          `;
+                                                                      <div class="footer-section">
+                                                                        <div class="footer-row">
+                                                                          <div class="footer-item">
+                                                                            <span class="label">鏀惰揣鐢佃瘽锛�</span>
+                                                                            <span class="value"></span>
+                                                                          </div>
+                                                                          <div class="footer-item">
+                                                                            <span class="label">鏀惰揣浜猴細</span>
+                                                                            <span class="value"></span>
+                                                                          </div>
+                                                                          <div class="footer-item address-item">
+                                                                            <span class="label">鏀惰揣鍦板潃锛�</span>
+                                                                            <span class="value address-value"></span>
+                                                                          </div>
+                                                                        </div>
+                                                                        <div class="footer-row">
+                                                                          <div class="footer-item">
+                                                                            <span class="label">鎿嶄綔鍛橈細</span>
+                                                                            <span class="value">${
+                                                                              userStore.nickName ||
+                                                                              "鎾曞紑鍓�"
+                                                                            }</span>
+                                                                          </div>
+                                                                          <div class="footer-item">
+                                                                            <span class="label">鎵撳嵃鏃ユ湡锛�</span>
+                                                                            <span class="value">${formatDateTime(
+                                                                              new Date()
+                                                                            )}</span>
+                                                                          </div>
+                                                                        </div>
+                                                                      </div>
+                                                                    </div>
+                                                                  </div>
+                                                                `;
     });
 
     printContent += `
-                                          </body>
-                                          </html>
-                                        `;
+                                                                </body>
+                                                                </html>
+                                                              `;
 
     // 鍐欏叆鍐呭鍒版柊绐楀彛
     printWindow.document.write(printContent);
@@ -2418,9 +2573,9 @@
    */
   const getShippingStatusText = row => {
     // 濡傛灉宸插彂璐э紙鏈夊彂璐ф棩鏈熸垨杞︾墝鍙凤級锛屾樉绀�"宸插彂璐�"
-    if (row.shippingDate || row.shippingCarNumber) {
-      return "宸插彂璐�";
-    }
+    // if (row.shippingDate || row.shippingCarNumber) {
+    //   return "宸插彂璐�";
+    // }
 
     // 鑾峰彇鍙戣揣鐘舵�佸瓧娈�
     const status = row.shippingStatus;
@@ -2449,7 +2604,7 @@
    */
   const getShippingStatusType = row => {
     // 濡傛灉宸插彂璐э紙鏈夊彂璐ф棩鏈熸垨杞︾墝鍙凤級锛屾樉绀虹豢鑹�
-    if (row.shippingDate || row.shippingCarNumber) {
+    if (row.shippingStatus === "宸插彂璐�") {
       return "success";
     }
 
@@ -2489,7 +2644,7 @@
     const shippingStatus = row.shippingStatus;
 
     // 濡傛灉宸插彂璐э紙鏈夊彂璐ф棩鏈熸垨杞︾墝鍙凤級锛屼笉鑳藉啀娆″彂璐�
-    if (row.shippingDate || row.shippingCarNumber) {
+    if (shippingStatus === "宸插彂璐�") {
       return false;
     }
 
@@ -2498,23 +2653,18 @@
     return statusStr === "寰呭彂璐�" || statusStr === "瀹℃牳鎷掔粷";
   };
 
-  /**
-   * 涓嬭浇鏂囦欢
-   *
-   * @param row 涓嬭浇鏂囦欢鐨勭浉鍏充俊鎭璞�
-   */
-  const fileListRef = ref(null);
-  const fileListDialogVisible = ref(false);
-  const downLoadFile = row => {
-    getSalesLedgerWithProducts({ id: row.id, type: 1 }).then(res => {
-      if (fileListRef.value) {
-        fileListRef.value.open(res.salesLedgerFiles);
-      }
-    });
+  // 鎵撳紑闄勪欢寮圭獥
+  const recordId = ref(0);
+  const fileDialogVisible = ref(false);
+
+  // 鎵撳紑闄勪欢寮规
+  const openFileDialog = async row => {
+    recordId.value = row.id;
+    fileDialogVisible.value = true;
   };
 
   // 鎵撳紑鍙戣揣寮规
-  const openDeliveryForm = row => {
+  const openDeliveryForm = async row => {
     // 妫�鏌ユ槸鍚﹀彲浠ュ彂璐�
     if (!canShip(row)) {
       proxy.$modal.msgWarning(
@@ -2524,9 +2674,18 @@
     }
 
     currentDeliveryRow.value = row;
+    const batchNoList = await getDeliveryBatchNoList(
+      row.productModelId || row.modelId
+    );
     deliveryForm.value = {
+      shippingCarNumber: "",
+      expressCompany: "",
+      expressNumber: "",
       type: "璐ц溅",
+      batchNo: [],
+      batchNoList,
     };
+    deliveryFileList.value = [];
     deliveryFormVisible.value = true;
   };
 
@@ -2534,13 +2693,56 @@
   const submitDelivery = () => {
     proxy.$refs["deliveryFormRef"].validate(valid => {
       if (valid) {
+        const selectedBatchRows = getSelectedDeliveryBatchRows();
+        if (selectedBatchRows.length === 0) {
+          proxy.$modal.msgWarning("璇疯嚦灏戝~鍐欎竴涓壒鍙风殑鍙戣揣鏁伴噺");
+          return;
+        }
+        const totalDeliveryQuantity = selectedBatchRows.reduce(
+          (sum, item) => sum + Number(item.deliveryQuantity || 0),
+          0
+        );
+        const currentRowNoQuantity = Number(
+          currentDeliveryRow.value?.noQuantity || 0
+        );
+        if (
+          currentRowNoQuantity > 0 &&
+          totalDeliveryQuantity > currentRowNoQuantity
+        ) {
+          proxy.$modal.msgWarning("鎵瑰彿鍙戣揣鎬绘暟涓嶈兘瓒呰繃寰呭彂璐ф暟閲�");
+          return;
+        }
         // 淇濆瓨褰撳墠灞曞紑鐨勮ID锛屼互渚垮彂璐у悗閲嶆柊鍔犺浇瀛愯〃鏍兼暟鎹�
         const currentExpandedKeys = [...expandedRowKeys.value];
         const salesLedgerId = currentDeliveryRow.value.salesLedgerId;
+        deliveryForm.value.batchNo = selectedBatchRows.map(item => item.id);
+        const productModelId =
+          currentDeliveryRow.value.productModelId ||
+          currentDeliveryRow.value.modelId;
         addShippingInfo({
           salesLedgerId: salesLedgerId,
           salesLedgerProductId: currentDeliveryRow.value.id,
           type: deliveryForm.value.type,
+          shippingCarNumber:
+            deliveryForm.value.type === "璐ц溅"
+              ? deliveryForm.value.shippingCarNumber
+              : "",
+          expressCompany:
+            deliveryForm.value.type === "蹇��"
+              ? deliveryForm.value.expressCompany
+              : "",
+          expressNumber:
+            deliveryForm.value.type === "蹇��"
+              ? deliveryForm.value.expressNumber
+              : "",
+          storageBlobDTOs: deliveryFileList.value || [],
+          batchNo: deliveryForm.value.batchNo,
+          batchNoDetailList: selectedBatchRows.map(item => ({
+            stockInventoryId: item.id,
+            batchNo: item.batchNo,
+            quantity: Number(item.deliveryQuantity || 0),
+            productModelId: productModelId,
+          })),
         }).then(() => {
           proxy.$modal.msgSuccess("鍙戣揣鎴愬姛");
           closeDeliveryDia();
@@ -2573,8 +2775,18 @@
   };
 
   // 鍏抽棴鍙戣揣寮规
+  const handleDeliveryTypeChange = val => {
+    if (val === "璐ц溅") {
+      deliveryForm.value.expressCompany = "";
+      deliveryForm.value.expressNumber = "";
+    } else {
+      deliveryForm.value.shippingCarNumber = "";
+    }
+  };
+
   const closeDeliveryDia = () => {
     proxy.resetForm("deliveryFormRef");
+    deliveryFileList.value = [];
     deliveryFormVisible.value = false;
     currentDeliveryRow.value = null;
   };
@@ -2584,6 +2796,7 @@
     currentFactoryName.value = res.user.currentFactoryName;
   };
   onMounted(() => {
+    searchForm.salesContractNo = route.query.salesContractNo;
     getList();
     userListNoPage().then(res => {
       userList.value = res.data;
@@ -2622,6 +2835,7 @@
     justify-content: space-between;
     margin-bottom: 10px;
   }
+
   .print-preview-dialog {
     .el-dialog__body {
       padding: 0;

--
Gitblit v1.9.3