From 661d1a63f7de63dc86b9e3b22f0267acc57cd484 Mon Sep 17 00:00:00 2001
From: 快乐的昕的电脑 <快乐的昕的电脑@DESKTOP-C2BQPQU>
Date: 星期一, 13 十月 2025 15:55:47 +0800
Subject: [PATCH] BUG修改

---
 components/mold.vue |  252 ++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 201 insertions(+), 51 deletions(-)

diff --git a/components/mold.vue b/components/mold.vue
index bd18f5c..919b29f 100644
--- a/components/mold.vue
+++ b/components/mold.vue
@@ -42,8 +42,15 @@
 					</button>
 				</view>
 				<view class="dialog-actions">
-					<button class="btn-blue" @click="confirmTool">纭畾</button>
-					<button class="btn-disabled" @click="showToolDialog = false">鍙栨秷</button>
+					<div style="display: flex; align-items: center;">
+						<button class="btn-blue" @click="prevPage" :disabled="pageIndex === 1">涓婁竴椤�</button>
+						<span style="margin: 0 12px;">绗瑊{ pageIndex }}椤� / 鍏眥{ totalPages }}椤�</span>
+						<button class="btn-blue" @click="nextPage" :disabled="pageIndex === totalPages">涓嬩竴椤�</button>
+					</div>
+					<div>
+						<button class="btn-blue" @click="confirmTool">纭畾</button>
+						<button class="btn-disabled" @click="showToolDialog = false">鍙栨秷</button>
+					</div>
 				</view>
 			</view>
 		</view>
@@ -97,11 +104,12 @@
 	export default {
 		data() {
 			return {
-				toolList: [
-					// 绀轰緥鏁版嵁锛屽疄闄呭簲浠庡悗绔帴鍙h幏鍙�
-					{ no: 'T22050338', name: 'm1.5鍚堥噾闀垮垁', model: 'xxx' },
-					{ no: 'T22050337', name: 'm0.546鍚堥噾闀垮垁', model: 'yyy' }
-				],
+				machineNo: '',//鏈哄彴缂栫爜
+                workOrderNo: '',//宸ュ崟鍙�
+				pageIndex: 1,
+				pageSize: 18,
+				total: 0,
+				toolList: [],
 				selectedToolNo: '',
 				toolName: '',
 				toolModel: '',
@@ -109,30 +117,51 @@
 				searchKey: '',
 				filteredTools: [],
 				useLimitInput: '',
-				toolRecords: [
-					// 绀轰緥鏁版嵁锛屽疄闄呭簲浠庡悗绔帴鍙h幏鍙�
-					{ id: 1, no: 'T22050338', name: 'm1.5鍚堥噾闀垮垁', upTime: '7-13 9:00', upCount: 15, downTime: '7-13 19:00', downCount: 3115, useCount: 3100, useLimit: 8888, lifePercent: '34.88%', lifeWarn: '90%', warnStatus: '姝e父' }
-				]
+				toolRecords: []
 			};
 		},
+		computed: {
+			totalPages() {
+				return Math.ceil(this.total / this.pageSize) || 1;
+			}
+		},
 		methods: {
-            async fetchTools(searchKey) {
-                // 浣跨敤 this.$post 鍙戦�� POST 璇锋眰锛宐ody 鐩存帴浼犲瓧绗︿覆
-                const res = await this.$post({
-                    url: '/MesOrderSta/QueryTools',
-                    data: searchKey // 鐩存帴浼犲瓧绗︿覆
-                });
-                if (res.status === 0) {
-                    this.filteredTools = res.data.tbBillList.map(t => ({
-                        no: t.cutterId || t.no,
-                        name: t.cutterName || t.name,
-                        model: t.cutterModel || t.model
-                    }));
-                } else {
-                    this.$showMessage(res.message || '鏌ヨ澶辫触');
-                }
-            },
+			async fetchTools(searchKey) {
+				const res = await this.$post({
+					url: '/MesCutterLedger/QueryTools',
+					data: JSON.stringify({
+						searchKey,
+						pageIndex: this.pageIndex,
+						pageSize: this.pageSize
+					}),
+					headers: { 'Content-Type': 'application/json' }
+				});
+				if (res.status === 0) {
+					this.filteredTools = res.data.tbBillList.map(t => ({
+						no: t.cutterId || t.no,
+						name: t.cutterName || t.name,
+						model: t.cutterModel || t.model
+					}));
+					this.total = res.data.total || 0; // 鍋囪鍚庣杩斿洖鎬绘暟
+				} else {
+					this.$showMessage(res.message || '鏌ヨ澶辫触');
+				}
+			},
+			//缈婚〉
+			async prevPage() {
+				if (this.pageIndex > 1) {
+					this.pageIndex--;
+					await this.fetchTools(this.searchKey);
+				}
+			},
+			async nextPage() {
+				if (this.pageIndex < this.totalPages) {
+					this.pageIndex++;
+					await this.fetchTools(this.searchKey);
+				}
+			},
 			async searchTool() {
+				this.pageIndex = 1; // 鎼滅储鏃堕噸缃埌绗竴椤�
 				await this.fetchTools(this.searchKey);
 			},
 			selectTool(tool) {
@@ -143,28 +172,145 @@
 			confirmTool() {
 				this.showToolDialog = false;
 			},
-			handleUpTool() {
-				// 涓婂垁鎻愪氦閫昏緫锛岃皟鐢ㄥ悗绔帴鍙�
-				this.$showMessage('涓婂垁鎻愪氦鎴愬姛锛堢ず渚嬶級');
-			},
-			handleDownTool() {
-				// 涓嬪垁鎻愪氦閫昏緫锛岃皟鐢ㄥ悗绔帴鍙�
-				this.$showMessage('涓嬪垁鎻愪氦鎴愬姛锛堢ず渚嬶級');
-			},
+			async handleUpTool() {
+                if (!this.workOrderNo) {
+                    this.$showMessage('宸ュ崟鍙蜂笉鑳戒负绌�');
+                    return;
+                }
+                if (!this.machineNo) {
+                    this.$showMessage('鏈哄彴鍙蜂笉鑳戒负绌�');
+                    return;
+                }
+                if (!this.selectedToolNo) {
+                    this.$showMessage('鍒�鍏风紪鍙蜂笉鑳戒负绌�');
+                    return;
+                }
+                if (!this.useLimitInput) {
+                    this.$showMessage('浣跨敤涓婇檺涓嶈兘涓虹┖');
+                    return;
+				}
+                const useLimit = Number(this.useLimitInput);
+                if (isNaN(useLimit) || useLimit <= 0) {
+                    this.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺');
+                    return;
+                }
+                const payload = {
+                    workOrderNo: this.workOrderNo,   // 宸ュ崟鍙�
+                    machineNo: this.machineNo,       // 鏈哄彴缂栧彿
+                    toolNo: this.selectedToolNo,     // 鍒�鍏风紪鍙�
+                    type: '涓婂垁',                         // 涓婂垁
+                    useLimit: this.useLimitInput ? Number(this.useLimitInput) : null // 浣跨敤涓婇檺
+                };
+                const res = await this.$post({
+                    url: '/MesCutterLedger/SubmitToolAction',
+                    data: JSON.stringify(payload),
+                    headers: { 'Content-Type': 'application/json' }
+                });
+                if (res.status === 0) {
+                    this.$showMessage('涓婂垁鎻愪氦鎴愬姛');
+                } else {
+                    this.$showMessage(res.message || '涓婂垁鎻愪氦澶辫触');
+                }
+            },
+			async handleDownTool() {
+                if (!this.workOrderNo) {
+                    this.$showMessage('宸ュ崟鍙蜂笉鑳戒负绌�');
+                    return;
+                }
+                if (!this.machineNo) {
+                    this.$showMessage('鏈哄彴鍙蜂笉鑳戒负绌�');
+                    return;
+                }
+                if (!this.selectedToolNo) {
+                    this.$showMessage('鍒�鍏风紪鍙蜂笉鑳戒负绌�');
+                    return;
+                }
+                if (!this.useLimitInput) {
+                    this.$showMessage('浣跨敤涓婇檺涓嶈兘涓虹┖');
+                    return;
+				}
+                const useLimit = Number(this.useLimitInput);
+                if (isNaN(useLimit) || useLimit <= 0) {
+                    this.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺');
+                    return;
+                }
+                const payload = {
+                    workOrderNo: this.workOrderNo,
+                    machineNo: this.machineNo,
+                    toolNo: this.selectedToolNo,
+                    type: '涓嬪垁', // 涓嬪垁
+                    useLimit: this.useLimitInput ? Number(this.useLimitInput) : null
+                };
+                const res = await this.$post({
+                    url: '/MesCutterLedger/SubmitToolAction',
+                    data: JSON.stringify(payload),
+                    headers: { 'Content-Type': 'application/json' }
+                });
+                if (res.status === 0) {
+                    this.$showMessage('涓嬪垁鎻愪氦鎴愬姛');
+                } else {
+                    this.$showMessage(res.message || '涓嬪垁鎻愪氦澶辫触');
+                }
+            },
 			cancel() {
 				this.selectedToolNo = '';
 				this.toolName = '';
 				this.toolModel = '';
 			},
-			setUseLimit() {
-				// 淇濆瓨浣跨敤涓婇檺閫昏緫锛屽疄闄呭簲璋冪敤鍚庣鎺ュ彛
-				this.$showMessage('浣跨敤涓婇檺宸蹭繚瀛橈紙绀轰緥锛�');
-			}
+            async fetchFormData() {
+                if (!this.workOrderNo || !this.machineNo) {
+                    console.warn('宸ュ崟鍙锋垨鏈哄彴鍙蜂负绌猴紝璺宠繃鑾峰彇琛ㄥ崟鏁版嵁');
+                    return;
+                }
+
+                const payload = {
+                    workOrderNo: this.workOrderNo.trim(),
+                    machineNo: this.machineNo.trim()
+                };
+
+                try {
+                    console.log('璇锋眰鍙傛暟:', payload); // 娣诲姞璋冭瘯鏃ュ織
+
+                    const res = await this.$post({
+                        url: '/MesCutterLedger/GetFormData',
+                        data: JSON.stringify(payload),
+                        headers: { 'Content-Type': 'application/json' }
+                    });
+
+                    if (res.status === 0) {
+                        console.log('鑾峰彇鏁版嵁鎴愬姛:', res.data);
+                        // ... 澶勭悊鏁版嵁
+                    } else {
+                        this.$showMessage(res.message || '鑾峰彇琛ㄥ崟鏁版嵁澶辫触');
+                    }
+                } catch (error) {
+                    console.error('鑾峰彇琛ㄥ崟鏁版嵁閿欒:', error);
+                    this.$showMessage('鑾峰彇鏁版嵁澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');
+                }
+            }
+            //// 娣诲姞杈呭姪鏂规硶
+            //formatDateTime(dateTimeStr) {
+            //    if (!dateTimeStr) return '';
+            //    // 鏍规嵁鍚庣杩斿洖鐨勬椂闂存牸寮忚繘琛岃皟鏁�
+            //    const date = new Date(dateTimeStr);
+            //    return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${date.getMinutes().toString().padStart(2, '0')}`;
+            //}
 		},
-		mounted() {
-			// 椤甸潰鍔犺浇鏃舵媺鍙栧叏閮ㄥ垁鍏�
-			this.fetchTools('');
-		}
+        mounted() {
+            this.fetchTools('');
+            this.machineNo = uni.getStorageSync('machineNo') || '';
+            this.workOrderNo = uni.getStorageSync('daa001') || '';
+
+            // 娣诲姞璋冭瘯淇℃伅
+            console.log('鏈哄彴鍙�:', this.machineNo);
+            console.log('宸ュ崟鍙�:', this.workOrderNo);
+
+            if (this.machineNo && this.workOrderNo) {
+                this.fetchFormData();
+            } else {
+                console.warn('鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇琛ㄥ崟鏁版嵁');
+            }
+        }
 	};
 </script>
 
@@ -259,16 +405,20 @@
 		display: flex;
 		flex-wrap: wrap;
 		margin: 1vh 0;
+		max-height: 40vh;
+		overflow-y: auto;
 	}
 
-	.tool-btn {
-		margin: 5px 10px 5px 0;
-		padding: 8px 16px;
-		background: #f5f5f5;
-		border: 1px solid #ccc;
-		border-radius: 4px;
-		cursor: pointer;
-	}
+    .tool-btn {
+        margin: 5px 10px 5px 0;
+        padding: 8px 16px;
+        background: #f5f5f5;
+        border: 1px solid #ccc;
+        border-radius: 4px;
+        cursor: pointer;
+        background: #e0e0e0;
+        color: #888;
+    }
 
 	.dialog-actions {
 		display: flex;

--
Gitblit v1.9.3