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 |  925 +++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 598 insertions(+), 327 deletions(-)

diff --git a/src/views/salesManagement/salesLedger/index.vue b/src/views/salesManagement/salesLedger/index.vue
index dc648be..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>
@@ -498,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"
@@ -544,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>
@@ -619,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>
@@ -733,16 +750,18 @@
             浠呮敮鎸� xls/xlsx锛屽ぇ灏忎笉瓒呰繃 10MB銆�
             <el-button link
                        type="primary"
-                       @click="downloadTemplate">涓嬭浇瀵煎叆妯℃澘</el-button>
+                       @click="downloadTemplate">涓嬭浇瀵煎叆妯℃澘
+            </el-button>
           </div>
         </template>
       </el-upload>
     </FormDialog>
-<!-- // todo 闄勪欢棰勮鐩稿叧 -->
+    <!-- // 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="鎵撳嵃棰勮"
@@ -752,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">
@@ -815,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>
@@ -877,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="蹇��"
@@ -885,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>
@@ -904,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 {
@@ -922,17 +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 { getCurrentDate } from "@/utils/index.js";
-  import { useRouter, useRoute } from "vue-router";
-  import { listCustomerPrivatePool } from "@/api/basicData/customerFile.js";
   import FileUpload from "@/components/AttachmentUpload/file/index.vue";
+  import ImageUpload from "@/components/AttachmentUpload/image/index.vue";
+  import { getCurrentDate } from "@/utils/index.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([]);
@@ -948,6 +1054,7 @@
   });
   const total = ref(0);
   const fileList = ref([]);
+  const deliveryFileList = ref([]);
 
   // 鐢ㄦ埛淇℃伅琛ㄥ崟寮规鏁版嵁
   const operationType = ref("");
@@ -1048,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" }],
     },
   });
@@ -1252,6 +1456,7 @@
     }
     return null; // 娌℃湁鎵惧埌鑺傜偣锛岃繑鍥瀗ull
   };
+
   function convertIdToValue(data) {
     return data.map(item => {
       const { id, children, ...rest } = item;
@@ -1266,6 +1471,7 @@
       return newItem;
     });
   }
+
   // 鏍规嵁鍚嶇О鍙嶆煡浜у搧澶х被 id锛屼究浜庝粎瀛樺悕绉版椂鐨勫弽鏄�
   function findNodeIdByLabel(nodes, label) {
     if (!label) return null;
@@ -1279,6 +1485,7 @@
     }
     return null;
   }
+
   // 琛ㄦ牸閫夋嫨鏁版嵁
   const handleSelectionChange = selection => {
     // 杩囨护鎺夊瓙鏁版嵁
@@ -1371,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;
@@ -1408,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) {
@@ -1503,9 +1710,11 @@
 
     quotationDialogVisible.value = false;
   };
+
   function changs(val) {
     console.log(val);
   }
+
   // 鎻愪氦琛ㄥ崟
   const submitForm = () => {
     proxy.$refs["formRef"].validate(valid => {
@@ -1836,282 +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);
@@ -2360,9 +2573,9 @@
    */
   const getShippingStatusText = row => {
     // 濡傛灉宸插彂璐э紙鏈夊彂璐ф棩鏈熸垨杞︾墝鍙凤級锛屾樉绀�"宸插彂璐�"
-    if (row.shippingDate || row.shippingCarNumber) {
-      return "宸插彂璐�";
-    }
+    // if (row.shippingDate || row.shippingCarNumber) {
+    //   return "宸插彂璐�";
+    // }
 
     // 鑾峰彇鍙戣揣鐘舵�佸瓧娈�
     const status = row.shippingStatus;
@@ -2391,7 +2604,7 @@
    */
   const getShippingStatusType = row => {
     // 濡傛灉宸插彂璐э紙鏈夊彂璐ф棩鏈熸垨杞︾墝鍙凤級锛屾樉绀虹豢鑹�
-    if (row.shippingDate || row.shippingCarNumber) {
+    if (row.shippingStatus === "宸插彂璐�") {
       return "success";
     }
 
@@ -2431,7 +2644,7 @@
     const shippingStatus = row.shippingStatus;
 
     // 濡傛灉宸插彂璐э紙鏈夊彂璐ф棩鏈熸垨杞︾墝鍙凤級锛屼笉鑳藉啀娆″彂璐�
-    if (row.shippingDate || row.shippingCarNumber) {
+    if (shippingStatus === "宸插彂璐�") {
       return false;
     }
 
@@ -2440,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(
@@ -2466,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;
   };
 
@@ -2476,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();
@@ -2515,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;
   };
@@ -2565,6 +2835,7 @@
     justify-content: space-between;
     margin-bottom: 10px;
   }
+
   .print-preview-dialog {
     .el-dialog__body {
       padding: 0;

--
Gitblit v1.9.3