From 6e62e9acfbb32e73972102df62e63b9e602632f6 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期四, 04 十二月 2025 16:35:42 +0800
Subject: [PATCH] 1.采购台账、销售台账编辑权限放开

---
 src/views/salesManagement/receiptPayment/index.vue |  146 ++++++++++++++++++++++++++++--------------------
 1 files changed, 85 insertions(+), 61 deletions(-)

diff --git a/src/views/salesManagement/receiptPayment/index.vue b/src/views/salesManagement/receiptPayment/index.vue
index 9144186..61f4544 100644
--- a/src/views/salesManagement/receiptPayment/index.vue
+++ b/src/views/salesManagement/receiptPayment/index.vue
@@ -31,13 +31,13 @@
                 prefix-icon="Search"
               />
             </el-form-item>
-            <el-form-item>
+            <!-- <el-form-item>
               <el-checkbox
                 v-model="searchForm.status"
                 label="涓嶆樉绀哄緟鍥炴涓�0"
                 @change="handleQuery"
               />
-            </el-form-item>
+            </el-form-item> -->
             <el-form-item>
               <el-button type="primary" @click="handleQuery"> 鎼滅储 </el-button>
             </el-form-item>
@@ -49,7 +49,7 @@
       <div class="actions">
         <div></div>
         <div>
-          <el-button type="primary" icon="Plus" @click="openForm('add')">
+          <el-button type="primary" @click="openForm('add')">
             鏂板鍥炴
           </el-button>
           <el-button icon="Download" @click="handleOut"> 瀵煎嚭 </el-button>
@@ -65,7 +65,8 @@
         :summary-method="summarizeMainTable"
         :expand-row-keys="expandedRowKeys"
         @expand-change="expandChange"
-        height="calc(100vh - 18.5em)"
+
+        height="calc(100vh - 21.5em)"
       >
         <el-table-column align="center" type="selection" width="55" />
         <el-table-column type="expand">
@@ -82,13 +83,16 @@
                 type="index"
                 width="60"
               />
-              <el-table-column label="鍥炴鏃ユ湡" prop="receiptPaymentDate" />
+              <el-table-column label="鍥炴鏃ユ湡" prop="receiptPaymentDate"  width="130"/>
               <el-table-column label="鍥炴閲戦" prop="receiptPaymentAmount">
                 <template #default="scope">
-                  <el-input
-                    v-model="scope.row.receiptPaymentAmount"
-                    :disabled="!scope.row.editType"
-                  ></el-input>
+									<el-input-number :step="0.01" :min="0" style="width: 100%"
+																	 v-model="scope.row.receiptPaymentAmount"
+																	 :disabled="!scope.row.editType"
+																	 :precision="2"
+																	 placeholder="璇疯緭鍏�"
+																	 clearable
+									/>
                 </template>
               </el-table-column>
               <el-table-column label="鍥炴鏂瑰紡" prop="receiptPaymentType">
@@ -108,9 +112,9 @@
                   </el-select>
                 </template>
               </el-table-column>
-              <el-table-column label="鐧昏浜�" prop="registrant" />
-              <el-table-column label="鐧昏鏃ユ湡" prop="createTime" />
-              <el-table-column label="鎿嶄綔" width="150">
+              <el-table-column label="鐧昏浜�" prop="registrant" width="90"/>
+              <el-table-column label="鐧昏鏃ユ湡" prop="createTime"   width="130"/>
+              <el-table-column label="鎿嶄綔" width="150" align="center">
                 <template #default="scope">
                   <el-button
                     link
@@ -164,8 +168,19 @@
           label="椤圭洰鍚嶇О"
           prop="projectName"
           show-overflow-tooltip
-          width="200"
+          width="340"
         />
+        <!-- <el-table-column
+          label="鍥炴鐘舵��"
+          prop="statusName"
+          width="120"
+        >
+          <template #default="{ row }">
+            <el-tag :type="getStatusTagType(row.statusName)" disable-transitions>
+              {{ row.statusName || "--" }}
+            </el-tag>
+          </template>
+        </el-table-column> -->
         <el-table-column
           label="浜у搧澶х被"
           prop="productCategory"
@@ -183,7 +198,7 @@
           prop="invoiceTotal"
           show-overflow-tooltip
           :formatter="formattedNumber"
-          width="150"
+          width="200"
         />
         <el-table-column label="绋庣巼(%)" prop="taxRate" show-overflow-tooltip />
         <el-table-column
@@ -191,20 +206,20 @@
           prop="receiptPaymentAmountTotal"
           show-overflow-tooltip
           :formatter="formattedNumber"
-          width="150"
+          width="200"
         />
-        <el-table-column
+        <!-- <el-table-column
           label="寰呭洖娆鹃噾棰�(鍏�)"
           prop="noReceiptAmount"
           show-overflow-tooltip
-          width="150"
+          width="200"
         >
           <template #default="{ row, column }">
             <el-text type="danger">
               {{ formattedNumber(row, column, row.noReceiptAmount) }}
             </el-text>
           </template>
-        </el-table-column>
+        </el-table-column> -->
       </el-table>
       <pagination
         v-show="total > 0"
@@ -217,7 +232,7 @@
     </div>
     <el-dialog
       v-model="dialogFormVisible"
-      title="鏂板鍙戠エ鍙烽〉闈�"
+      title="鏂板鍥炴椤甸潰"
       width="70%"
       @close="closeDia"
     >
@@ -233,8 +248,8 @@
             <el-form-item label="閿�鍞悎鍚屽彿锛�" prop="salesContractNo">
               <el-input
                 v-model="form.salesContractNo"
-                placeholder="鑷姩濉厖"
-                disabled
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -242,8 +257,8 @@
             <el-form-item label="瀹㈡埛鍚嶇О锛�" prop="customerName">
               <el-input
                 v-model="form.customerName"
-                placeholder="鑷姩濉厖"
-                disabled
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -253,8 +268,8 @@
             <el-form-item label="鍙戠エ鍙凤細" prop="invoiceNo">
               <el-input
                 v-model="form.invoiceNo"
-                placeholder="鑷姩濉厖"
-                disabled
+                placeholder="璇疯緭鍏�"
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -263,9 +278,9 @@
               <el-input
                 type="number"
                 v-model="form.invoiceTotal"
-                placeholder="鑷姩濉厖"
+                placeholder="璇疯緭鍏�"
                 :step="0.01"
-                disabled
+                clearable
               />
             </el-form-item>
           </el-col>
@@ -276,15 +291,16 @@
               <el-input
                 type="number"
                 v-model="form.taxRate"
-                placeholder="鑷姩濉厖"
+                placeholder="璇疯緭鍏�"
                 :step="0.01"
-                disabled
+                clearable
               />
             </el-form-item>
           </el-col>
           <el-col :span="12">
             <el-form-item label="鏈鍥炴閲戦锛�" prop="receiptPaymentAmount">
-              <el-input-number :step="0.01" :min="0" style="width: 100%" 
+              <el-input-number :step="0.01" :min="0" style="width: 100%"
+											 :precision="2"
                 v-model="form.receiptPaymentAmount"
                 placeholder="璇疯緭鍏�"
                 clearable
@@ -309,31 +325,30 @@
               </el-select>
             </el-form-item>
           </el-col>
-          <el-col :span="12">
-            <el-form-item label="鐧昏浜猴細" prop="registrant">
-              <el-input
-                v-model="form.registrant"
-                placeholder="璇疯緭鍏�"
-                clearable
-                disabled
-              />
-            </el-form-item>
-          </el-col>
+					<el-col :span="12">
+						<el-form-item label="鍥炴鏃ユ湡锛�" prop="receiptPaymentDate">
+							<el-date-picker
+								style="width: 100%"
+								v-model="form.receiptPaymentDate"
+								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="12">
-            <el-form-item label="鏉ユ鏃ユ湡锛�" prop="receiptPaymentDate">
-              <el-date-picker
-                style="width: 100%"
-                v-model="form.receiptPaymentDate"
-                value-format="YYYY-MM-DD"
-                format="YYYY-MM-DD"
-                type="date"
-                placeholder="璇烽�夋嫨"
-                clearable
-              />
-            </el-form-item>
-          </el-col>
+					<el-col :span="12">
+						<el-form-item label="鐧昏浜猴細" prop="registrant">
+							<el-input
+								v-model="form.registrant"
+								placeholder="璇疯緭鍏�"
+								clearable
+							/>
+						</el-form-item>
+					</el-col>
         </el-row>
       </el-form>
       <template #footer>
@@ -377,7 +392,7 @@
 const data = reactive({
   searchForm: {
     searchText: "",
-    status: true,
+    status: false,
     customerName: "",
     customerContractNo: "",
     projectName: "",
@@ -418,6 +433,12 @@
 const formattedNumber = (row, column, cellValue) => {
   return parseFloat(cellValue).toFixed(2);
 };
+
+const getStatusTagType = (statusName = '') => {
+  const normalized = statusName.trim();
+  if (!normalized) return 'info';
+  return normalized === '鏈畬鎴愬洖娆�' ? 'danger' : 'success';
+};
 // 鏌ヨ鍒楄〃
 /** 鎼滅储鎸夐挳鎿嶄綔 */
 const handleQuery = () => {
@@ -430,13 +451,20 @@
   getList();
 };
 const getList = () => {
-  expandedRowKeys.value = [];
   tableLoading.value = true;
   bindInvoiceNoRegPage({ ...searchForm, ...page })
     .then((res) => {
       tableLoading.value = false;
       tableData.value = res.data.records;
       total.value = res.data.total;
+			if (expandedRowKeys.value.length > 0) {
+				const arr = []
+				const index = tableData.value.findIndex(item => item.id === expandedRowKeys.value[0]);
+				if (index > -1) {
+					arr.push(tableData.value[index]);
+					expandChange(tableData.value[index], arr)
+				}
+			}
     })
     .catch(() => {
       tableLoading.value = false;
@@ -496,12 +524,6 @@
   form.value = {};
   if (selectedRows.value.length !== 1) {
     proxy.$modal.msgError("璇烽�夋嫨涓�鏉℃暟鎹�");
-    return;
-  }
-  //
-  console.log("(selectedRows.value", selectedRows.value);
-  if (selectedRows.value[0].noReceiptAmount === 0) {
-    proxy.$modal.msgError("寰呭洖娆鹃噾棰濅负0鍏�");
     return;
   }
   invoiceInfo({ id: selectedRows.value[0].id }).then((res) => {
@@ -569,6 +591,8 @@
   };
   receiptPaymentSaveOrUpdate(updateData).then((res) => {
     row.editType = !row.editType;
+		getList();
+		proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
   });
 };
 

--
Gitblit v1.9.3