| ¶Ô±ÈÐÂÎļþ | 
 |  |  | 
 |  |  | <template> | 
 |  |  |   <div class="app-container"> | 
 |  |  |     <div class="search_form"> | 
 |  |  |       <el-form :model="searchForm" :inline="true"> | 
 |  |  |         <el-form-item label="éå®è®¢åå·ï¼"> | 
 |  |  |           <el-input v-model="searchForm.salesContractNo" placeholder="请è¾å
¥" clearable prefix-icon="Search" | 
 |  |  |             @change="handleQuery" /> | 
 |  |  |         </el-form-item> | 
 |  |  |         <el-form-item label="车çå·ï¼"> | 
 |  |  |           <el-input v-model="searchForm.shippingCarNumber" placeholder="请è¾å
¥" clearable prefix-icon="Search" | 
 |  |  |             @change="handleQuery" /> | 
 |  |  |         </el-form-item> | 
 |  |  |         <el-form-item> | 
 |  |  |           <el-button type="primary" @click="handleQuery"> æç´¢ </el-button> | 
 |  |  |         </el-form-item> | 
 |  |  |       </el-form> | 
 |  |  |     </div> | 
 |  |  |     <div class="table_list"> | 
 |  |  |       <div class="actions"> | 
 |  |  |         <div></div> | 
 |  |  |         <div> | 
 |  |  |           <el-button @click="handleOut">导åº</el-button> | 
 |  |  |           <el-button type="danger" plain @click="handleDelete">å é¤</el-button> | 
 |  |  |         </div> | 
 |  |  |       </div> | 
 |  |  |       <el-table :data="tableData" border v-loading="tableLoading" @selection-change="handleSelectionChange" | 
 |  |  |         :row-key="(row) => row.id" style="width: 100%" height="calc(100vh - 18.5em)"> | 
 |  |  |         <el-table-column align="center" type="selection" width="55" /> | 
 |  |  |         <el-table-column align="center" label="åºå·" type="index" width="60" /> | 
 |  |  |         <el-table-column label="éå®è®¢å" prop="salesContractNo" show-overflow-tooltip /> | 
 |  |  |         <el-table-column label="客æ·åç§°" prop="customerName" show-overflow-tooltip /> | 
 |  |  |         <el-table-column label="åè´§æ¶é´" prop="shippingDate" show-overflow-tooltip /> | 
 |  |  |         <el-table-column label="å货车çå·" prop="shippingCarNumber" show-overflow-tooltip /> | 
 |  |  |         <el-table-column fixed="right" label="æä½" width="150" align="center"> | 
 |  |  |           <template #default="scope"> | 
 |  |  |             <el-button link type="primary" size="small" @click="openForm('edit', scope.row)">ç¼è¾</el-button> | 
 |  |  |             <el-button link type="danger" size="small" @click="handleDeleteSingle(scope.row)">å é¤</el-button> | 
 |  |  |           </template> | 
 |  |  |         </el-table-column> | 
 |  |  |       </el-table> | 
 |  |  |       <pagination v-show="total > 0" :total="total" layout="total, sizes, prev, pager, next, jumper" | 
 |  |  |         :page="page.current" :limit="page.size" @pagination="paginationChange" /> | 
 |  |  |     </div> | 
 |  |  |     <el-dialog v-model="dialogFormVisible" :title="operationType === 'add' ? 'æ°å¢åè´§å°è´¦' : 'ç¼è¾åè´§å°è´¦'" width="50%" | 
 |  |  |       @close="closeDia"> | 
 |  |  |       <el-form :model="form" label-width="120px" label-position="top" :rules="rules" ref="formRef"> | 
 |  |  |         <el-row :gutter="30"> | 
 |  |  |           <el-col :span="24"> | 
 |  |  |             <el-form-item label="éå®è®¢åï¼" prop="salesContractNo"> | 
 |  |  |               <el-select v-model="form.salesContractNo" placeholder="è¯·éæ©" clearable filterable  | 
 |  |  |                 @change="handleSalesOrderChange" style="width: 100%" :disabled="operationType === 'edit'"> | 
 |  |  |                 <el-option v-for="item in salesOrderOptions" :key="item.salesContractNo"  | 
 |  |  |                   :label="item.salesContractNo" :value="item.salesContractNo"> | 
 |  |  |                   {{ item.salesContractNo + ' - ' + item.customerName }} | 
 |  |  |                 </el-option> | 
 |  |  |               </el-select> | 
 |  |  |             </el-form-item> | 
 |  |  |           </el-col> | 
 |  |  |         </el-row> | 
 |  |  |         <el-row :gutter="30"> | 
 |  |  |           <el-col :span="24"> | 
 |  |  |             <el-form-item label="客æ·åç§°ï¼" prop="customerName"> | 
 |  |  |               <el-input v-model="form.customerName" placeholder="请è¾å
¥" clearable :disabled="operationType === 'edit'" /> | 
 |  |  |             </el-form-item> | 
 |  |  |           </el-col> | 
 |  |  |         </el-row> | 
 |  |  |         <el-row :gutter="30"> | 
 |  |  |           <el-col :span="24"> | 
 |  |  |             <el-form-item label="åè´§æ¶é´ï¼" prop="shippingDate"> | 
 |  |  |               <el-date-picker style="width: 100%" v-model="form.shippingDate" value-format="YYYY-MM-DD" | 
 |  |  |                 format="YYYY-MM-DD" type="date" placeholder="è¯·éæ©" clearable /> | 
 |  |  |             </el-form-item> | 
 |  |  |           </el-col> | 
 |  |  |         </el-row> | 
 |  |  |         <el-row :gutter="30"> | 
 |  |  |           <el-col :span="24"> | 
 |  |  |             <el-form-item label="å货车çå·ï¼" prop="shippingCarNumber"> | 
 |  |  |               <el-input v-model="form.shippingCarNumber" placeholder="请è¾å
¥" clearable /> | 
 |  |  |             </el-form-item> | 
 |  |  |           </el-col> | 
 |  |  |         </el-row> | 
 |  |  |          | 
 |  |  |       </el-form> | 
 |  |  |       <template #footer> | 
 |  |  |         <div class="dialog-footer"> | 
 |  |  |           <el-button type="primary" @click="submitForm">确认</el-button> | 
 |  |  |           <el-button @click="closeDia">åæ¶</el-button> | 
 |  |  |         </div> | 
 |  |  |       </template> | 
 |  |  |     </el-dialog> | 
 |  |  |   </div> | 
 |  |  | </template> | 
 |  |  |  | 
 |  |  | <script setup> | 
 |  |  | import pagination from "@/components/PIMTable/Pagination.vue"; | 
 |  |  | import { onMounted, ref, reactive, toRefs, getCurrentInstance } from "vue"; | 
 |  |  | import { ElMessageBox } from "element-plus"; | 
 |  |  | import { | 
 |  |  |   deliveryLedgerListPage, | 
 |  |  |   addOrUpdateDeliveryLedger, | 
 |  |  |   delDeliveryLedger, | 
 |  |  | } from "@/api/salesManagement/deliveryLedger.js"; | 
 |  |  |   | 
 |  |  |  | 
 |  |  | const { proxy } = getCurrentInstance(); | 
 |  |  | const tableData = ref([]); | 
 |  |  | const selectedRows = ref([]); | 
 |  |  | const tableLoading = ref(false); | 
 |  |  | const salesOrderOptions = ref([]); | 
 |  |  | const page = reactive({ | 
 |  |  |   current: 1, | 
 |  |  |   size: 100, | 
 |  |  | }); | 
 |  |  | const total = ref(0); | 
 |  |  |  | 
 |  |  | // ç¨æ·ä¿¡æ¯è¡¨åå¼¹æ¡æ°æ® | 
 |  |  | const operationType = ref(""); | 
 |  |  | const dialogFormVisible = ref(false); | 
 |  |  | const data = reactive({ | 
 |  |  |   searchForm: { | 
 |  |  |     salesContractNo: "", // éå®è®¢åå· | 
 |  |  |     shippingCarNumber: "", // è½¦çå· | 
 |  |  |   }, | 
 |  |  |   form: { | 
 |  |  |     id: null, | 
 |  |  |     salesContractNo: "", | 
 |  |  |     customerName: "", | 
 |  |  |     shippingDate: "", | 
 |  |  |     shippingCarNumber: "", | 
 |  |  |   }, | 
 |  |  |   rules: { | 
 |  |  |     salesContractNo: [{ required: true, message: "è¯·éæ©éå®è®¢å", trigger: "change" }], | 
 |  |  |     customerName: [{ required: true, message: "请è¾å
¥å®¢æ·åç§°", trigger: "blur" }], | 
 |  |  |     shippingDate: [{ required: true, message: "è¯·éæ©åè´§æ¶é´", trigger: "change" }], | 
 |  |  |     shippingCarNumber: [{ required: true, message: "请è¾å
¥å货车çå·", trigger: "blur" }], | 
 |  |  |   }, | 
 |  |  | }); | 
 |  |  | const { form, rules } = toRefs(data); | 
 |  |  | const { searchForm } = toRefs(data); | 
 |  |  |  | 
 |  |  |   | 
 |  |  |  | 
 |  |  | // æ¥è¯¢å表 | 
 |  |  | const handleQuery = () => { | 
 |  |  |   page.current = 1; | 
 |  |  |   getList(); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | const paginationChange = (obj) => { | 
 |  |  |   page.current = obj.page; | 
 |  |  |   page.size = obj.limit; | 
 |  |  |   getList(); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | const getList = () => { | 
 |  |  |   tableLoading.value = true; | 
 |  |  |   deliveryLedgerListPage({ ...searchForm.value, ...page }) | 
 |  |  |     .then((res) => { | 
 |  |  |       tableLoading.value = false; | 
 |  |  |       tableData.value = res.data.records || []; | 
 |  |  |       total.value = res.data.total || 0; | 
 |  |  |     }) | 
 |  |  |     .catch(() => { | 
 |  |  |       tableLoading.value = false; | 
 |  |  |     }); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // éå®è®¢åååæ¶èªå¨å¡«å
客æ·åç§° | 
 |  |  | const handleSalesOrderChange = (value) => { | 
 |  |  |   const selectedOrder = salesOrderOptions.value.find(item => item.salesContractNo === value); | 
 |  |  |   if (selectedOrder) { | 
 |  |  |     form.value.customerName = selectedOrder.customerName; | 
 |  |  |   } | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // è¡¨æ ¼éæ©æ°æ® | 
 |  |  | const handleSelectionChange = (selection) => { | 
 |  |  |   selectedRows.value = selection; | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // æå¼å¼¹æ¡ | 
 |  |  | const openForm = async (type, row) => { | 
 |  |  |   operationType.value = type; | 
 |  |  |   if (type === 'edit' && row) { | 
 |  |  |     form.value = { | 
 |  |  |       id: row.id ?? null, | 
 |  |  |       salesContractNo: row.salesContractNo ?? "", | 
 |  |  |       customerName: row.customerName ?? "", | 
 |  |  |       shippingDate: row.shippingDate || getCurrentDate(), | 
 |  |  |       shippingCarNumber: row.shippingCarNumber ?? "", | 
 |  |  |     }; | 
 |  |  |   } else { | 
 |  |  |     form.value = { | 
 |  |  |       id: null, | 
 |  |  |       salesContractNo: "", | 
 |  |  |       customerName: "", | 
 |  |  |       shippingDate: getCurrentDate(), | 
 |  |  |       shippingCarNumber: "", | 
 |  |  |     }; | 
 |  |  |   } | 
 |  |  |    | 
 |  |  |   dialogFormVisible.value = true; | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // æäº¤è¡¨å | 
 |  |  | const submitForm = () => { | 
 |  |  |   proxy.$refs["formRef"].validate((valid) => { | 
 |  |  |     if (valid) { | 
 |  |  |       const payload = { | 
 |  |  |         id: form.value.id, | 
 |  |  |         shippingDate: form.value.shippingDate, | 
 |  |  |         shippingCarNumber: form.value.shippingCarNumber, | 
 |  |  |       }; | 
 |  |  |       addOrUpdateDeliveryLedger(payload).then((res) => { | 
 |  |  |         proxy.$modal.msgSuccess("æä½æå"); | 
 |  |  |         closeDia(); | 
 |  |  |         getList(); | 
 |  |  |       }); | 
 |  |  |     } | 
 |  |  |   }); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // å
³éå¼¹æ¡ | 
 |  |  | const closeDia = () => { | 
 |  |  |   proxy.resetForm("formRef"); | 
 |  |  |   dialogFormVisible.value = false; | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // å¯¼åº | 
 |  |  | const handleOut = () => { | 
 |  |  |   ElMessageBox.confirm("éä¸çå
容å°è¢«å¯¼åºï¼æ¯å¦ç¡®è®¤å¯¼åºï¼", "导åº", { | 
 |  |  |     confirmButtonText: "确认", | 
 |  |  |     cancelButtonText: "åæ¶", | 
 |  |  |     type: "warning", | 
 |  |  |   }) | 
 |  |  |     .then(() => { | 
 |  |  |       proxy.download("/shippingInfo/export", {}, "åè´§å°è´¦.xlsx"); | 
 |  |  |     }) | 
 |  |  |     .catch(() => { | 
 |  |  |       proxy.$modal.msg("已忶"); | 
 |  |  |     }); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // æ¹éå é¤ | 
 |  |  | const handleDelete = () => { | 
 |  |  |   let ids = []; | 
 |  |  |   if (selectedRows.value.length > 0) { | 
 |  |  |     ids = selectedRows.value.map((item) => item.id); | 
 |  |  |   } else { | 
 |  |  |     proxy.$modal.msgWarning("è¯·éæ©æ°æ®"); | 
 |  |  |     return; | 
 |  |  |   } | 
 |  |  |   ElMessageBox.confirm("éä¸çå
容å°è¢«å é¤ï¼æ¯å¦ç¡®è®¤å é¤ï¼", "å é¤", { | 
 |  |  |     confirmButtonText: "确认", | 
 |  |  |     cancelButtonText: "åæ¶", | 
 |  |  |     type: "warning", | 
 |  |  |   }) | 
 |  |  |     .then(() => { | 
 |  |  |       delDeliveryLedger(ids).then((res) => { | 
 |  |  |         proxy.$modal.msgSuccess("å é¤æå"); | 
 |  |  |         getList(); | 
 |  |  |       }); | 
 |  |  |     }) | 
 |  |  |     .catch(() => { | 
 |  |  |       proxy.$modal.msg("已忶"); | 
 |  |  |     }); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // å个å é¤ | 
 |  |  | const handleDeleteSingle = (row) => { | 
 |  |  |   ElMessageBox.confirm("æ¤æä½å°å é¤è¯¥è®°å½ï¼æ¯å¦ç¡®è®¤ï¼", "å é¤", { | 
 |  |  |     confirmButtonText: "确认", | 
 |  |  |     cancelButtonText: "åæ¶", | 
 |  |  |     type: "warning", | 
 |  |  |   }) | 
 |  |  |     .then(() => { | 
 |  |  |       delDeliveryLedger([row.id]).then((res) => { | 
 |  |  |         proxy.$modal.msgSuccess("å é¤æå"); | 
 |  |  |         getList(); | 
 |  |  |       }); | 
 |  |  |     }) | 
 |  |  |     .catch(() => { | 
 |  |  |       proxy.$modal.msg("已忶"); | 
 |  |  |     }); | 
 |  |  | }; | 
 |  |  |  | 
 |  |  | // è·åå½åæ¥æå¹¶æ ¼å¼å为 YYYY-MM-DD | 
 |  |  | function getCurrentDate() { | 
 |  |  |   const today = new Date(); | 
 |  |  |   const year = today.getFullYear(); | 
 |  |  |   const month = String(today.getMonth() + 1).padStart(2, "0"); | 
 |  |  |   const day = String(today.getDate()).padStart(2, "0"); | 
 |  |  |   return `${year}-${month}-${day}`; | 
 |  |  | } | 
 |  |  |  | 
 |  |  | onMounted(() => { | 
 |  |  |   getList(); | 
 |  |  | }); | 
 |  |  | </script> | 
 |  |  |  | 
 |  |  | <style scoped lang="scss"> | 
 |  |  | .table_list { | 
 |  |  |   margin-top: unset; | 
 |  |  | } | 
 |  |  |  | 
 |  |  | .actions { | 
 |  |  |   display: flex; | 
 |  |  |   justify-content: space-between; | 
 |  |  |   margin-bottom: 10px; | 
 |  |  | } | 
 |  |  | </style> | 
 |  |  |  |