From 5d15164521a9343a5ff3860c97f36eae8386d674 Mon Sep 17 00:00:00 2001
From: 快乐的昕的电脑 <快乐的昕的电脑@DESKTOP-C2BQPQU>
Date: 星期三, 24 十二月 2025 15:36:53 +0800
Subject: [PATCH] 调试
---
.vs/前端2/CopilotIndices/17.14.878.3237/SemanticSymbols.db-shm | 0
.vs/前端2/CopilotIndices/17.14.878.3237/CodeChunks.db-shm | 0
pages/index.vue | 2
unpackage/dist/dev/app-plus/app-view.js | 746 ++++++++++---------
.vs/slnx.sqlite | 0
pages/moldRecord.vue | 117 +-
components/mold.vue | 466 ++++++++++++
store/index.js | 8
unpackage/dist/dev/app-plus/app-service.js | 916 ++++++++++++------------
9 files changed, 1,381 insertions(+), 874 deletions(-)
diff --git a/.vs/slnx.sqlite b/.vs/slnx.sqlite
index 91045de..ab21b2e 100644
--- a/.vs/slnx.sqlite
+++ b/.vs/slnx.sqlite
Binary files differ
diff --git "a/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/CodeChunks.db-shm" "b/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/CodeChunks.db-shm"
index e7d07e6..2a4d03f 100644
--- "a/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/CodeChunks.db-shm"
+++ "b/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/CodeChunks.db-shm"
Binary files differ
diff --git "a/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/SemanticSymbols.db-shm" "b/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/SemanticSymbols.db-shm"
index 879f17f..2fe0441 100644
--- "a/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/SemanticSymbols.db-shm"
+++ "b/.vs/\345\211\215\347\253\2572/CopilotIndices/17.14.878.3237/SemanticSymbols.db-shm"
Binary files differ
diff --git a/components/mold.vue b/components/mold.vue
index 6f3e30b..ff12f7e 100644
--- a/components/mold.vue
+++ b/components/mold.vue
@@ -46,9 +46,75 @@
</view> <!-- 杩欓噷闂悎 top-section-grid -->
<!-- 鎿嶄綔鎸夐挳 - 绉诲嚭 top-section-grid -->
<view class="button-row">
- <button class="save-btn" @click="handleUpTool" :disabled="submitting || loadingForm">涓婂垁鎻愪氦(=璋冩満寮�濮�)</button>
+ <button class="save-btn" @click="handleUpTool" :disabled="submitting || loadingForm">涓婂垁鎻愪氦</button>
<button class="save-btn" @click="handleDownTool" :disabled="submitting || loadingForm">涓嬪垁鎻愪氦</button>
<button class="cancel-btn" @click="cancel" :disabled="submitting || loadingForm">娓呯┖鍒�鍏烽�夋嫨</button>
+ </view>
+
+ <!-- 鏂板锛氳皟鏈烘暟鎹緭鍏ュ尯鍩� -->
+ <view class="tiaoji-section">
+ <view class="tiaoji-row">
+ <!-- 褰撳墠璋冩満甯堝倕 -->
+ <view class="current-user-section">
+ <text>褰撳墠璋冩満甯堝倕锛�</text>
+ <text class="current-user-name">{{ tiaojiStaffDisplay || '鏈�夋嫨' }}</text>
+ <button class="select-user-btn" @click="isTiaojiUserSelectShow = true">閫変汉</button>
+ </view>
+
+ <!-- 璋冩満鑹搧鏁� -->
+ <view class="tiaoji-input-section">
+ <text>璋冩満鑹搧鏁帮細</text>
+ <input v-model="tiaojiOkQty" class="inp tiaoji-input" type="number" placeholder="璇疯緭鍏ユ暟閲�" />
+ </view>
+
+ <!-- 璋冩満涓嶈壇鍝佹暟 -->
+ <view class="tiaoji-input-section">
+ <text>璋冩満涓嶈壇鍝佹暟锛�</text>
+ <input v-model="tiaojiBadQty" class="inp tiaoji-input" type="number" placeholder="璇疯緭鍏ユ暟閲�" />
+ </view>
+
+ <!-- 閫佹鍛煎彨鎸夐挳 -->
+ <view class="tiaoji-submit-section">
+ <button class="details-btn" @click="handleInspectionCall">閫佹鍛煎彨</button>
+ </view>
+ </view>
+ </view>
+
+ <!-- 閫夋嫨璋冩満甯堝倕寮圭獥 -->
+ <view v-if="isTiaojiUserSelectShow" class="overlay">
+ <view class="popup user-select-popup">
+ <!-- 鎼滅储鏍� -->
+ <view class="user-search-bar">
+ <input v-model.trim="tiaojiUserSearch"
+ type="text"
+ class="user-search-input"
+ placeholder="杈撳叆宸ュ彿鎴栧鍚嶆悳绱�"
+ @keydown.enter.prevent />
+ <button v-if="tiaojiUserSearch" class="user-search-clear" @click="tiaojiUserSearch=''">娓呯┖</button>
+ <view class="user-search-info">
+ 鍖归厤锛歿{ filteredTiaojiUsers.length }} / {{ tiaojiUsers.length }}
+ </view>
+ </view>
+ <view class="user-list-scroll">
+ <template v-if="filteredTiaojiUsers.length">
+ <view class="user-list-grid">
+ <button v-for="(u, index) in filteredTiaojiUsers"
+ :key="index"
+ :class="['user-list-btn', {'selected': u===tiaojiStaffNo}]"
+ @click="selectTiaojiUser(u)">
+ <span class="user-code">{{ u.split(':')[0] }}</span>
+ <span class="user-name">{{ u.split(':')[1] }}</span>
+ </button>
+ </view>
+ </template>
+ <view v-else class="no-user-result">
+ 鏈壘鍒板尮閰嶄汉鍛�
+ </view>
+ </view>
+ <view class="user-popup-footer">
+ <button class="clean-btn wide-btn" @click="isTiaojiUserSelectShow = false">鍏抽棴</button>
+ </view>
+ </view>
</view>
<!-- 鍒�鍏风洰褰曞脊绐� -->
@@ -81,8 +147,8 @@
</view>
</view>
- <!-- 鍒�鍏蜂娇鐢ㄨ褰曡〃鏍� -->
- <view class="table-section">
+ <!-- 闅愯棌鍒�鍏蜂娇鐢ㄨ褰曡〃鏍� -->
+ <view v-if="false" class="table-section">
<table class="styled-table">
<thead>
<tr>
@@ -208,12 +274,36 @@
isDirty: false, // 琛ㄥ崟鏄惁鏈夋湭淇濆瓨鍙樻洿
autoSaveIntervalMs: 5 * 60 * 1000, // 榛樿 5 鍒嗛挓
autoSaveEnabled: true,
- autoSaveActionName: 'handleUpTool' // 鑷姩瑙﹀彂鐨勬柟娉曞悕锛屽彲鏀逛负鑷畾涔変繚瀛樻柟娉�
+ autoSaveActionName: 'handleUpTool', // 鑷姩瑙﹀彂鐨勬柟娉曞悕锛屽彲鏀逛负鑷畾涔変繚瀛樻柟娉�
+
+ // 鏂板锛氳皟鏈虹浉鍏冲瓧娈�
+ isTiaojiUserSelectShow: false, // 璋冩満甯堝倕閫夋嫨寮圭獥
+ tiaojiStaffNo: '', // 褰撳墠閫変腑鐨勮皟鏈哄笀鍌�(鏍煎紡: 宸ュ彿:濮撳悕)
+ tiaojiOkQty: '', // 璋冩満鑹搧鏁�
+ tiaojiBadQty: '', // 璋冩満涓嶈壇鍝佹暟
+ tiaojiUsers: [], // 璋冩満甯堝倕鍒楄〃
+ tiaojiUserSearch: '', // 鎼滅储鍏抽敭璇�
+
+ // 鏂板锛氭姤璇曚骇鏁版墍闇�瀛楁
+ orderId: null, // 宸ュ崟ID
+ order: {} // 宸ュ崟鏁版嵁
};
},
computed: {
totalPages() {
return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);
+ },
+ // 鏂板锛氳皟鏈哄笀鍌呮樉绀哄悕绉�
+ tiaojiStaffDisplay() {
+ if (!this.tiaojiStaffNo) return '';
+ const segs = this.tiaojiStaffNo.split(':');
+ return segs.length > 1 ? `${segs[0]} ${segs[1]}` : this.tiaojiStaffNo;
+ },
+ // 鏂板锛氳繃婊ゅ悗鐨勮皟鏈哄笀鍌呭垪琛�
+ filteredTiaojiUsers() {
+ if (!this.tiaojiUserSearch) return this.tiaojiUsers;
+ const kw = this.tiaojiUserSearch.trim().toLowerCase();
+ return this.tiaojiUsers.filter(u => u.toLowerCase().includes(kw));
}
},
watch: {
@@ -660,6 +750,11 @@
});
if (res.status === 0 && Array.isArray(res.data?.tbBillList) && res.data.tbBillList.length > 0) {
const order = res.data.tbBillList[0];
+
+ // 鏂板锛氫繚瀛樺伐鍗曟暟鎹紝鐢ㄤ簬鎶ヨ瘯浜ф暟
+ this.order = order;
+ this.orderId = order.id || order.ID || order.orderId || null;
+
this.selectedToolNo = order.cutterId || order.cutteR_ID || '';
this.toolName = order.cutterName || order.cutteR_NAME || '';
this.toolModel = order.cutterModel || order.cutteR_MODEL || '';
@@ -674,10 +769,14 @@
}
} else {
this.workOrderCurrentCjNum = null;
+ this.order = {};
+ this.orderId = null;
}
} catch (e) {
console.warn('鑷姩甯﹀嚭宸ュ崟鍒�鍏峰け璐�', e);
this.workOrderCurrentCjNum = null;
+ this.order = {};
+ this.orderId = null;
}
},
formatDateTime(dateTimeStr) {
@@ -702,12 +801,102 @@
} catch {
return String(dateTimeStr);
}
+ },
+
+ // 鏂板锛氶�夋嫨璋冩満甯堝倕
+ selectTiaojiUser(u) {
+ this.tiaojiStaffNo = u;
+ this.isTiaojiUserSelectShow = false;
+ this.tiaojiUserSearch = '';
+ },
+
+ // 鏂板锛氶�佹鍛煎彨 + 鎶ヨ瘯浜ф暟
+ async handleInspectionCall() {
+ // 楠岃瘉蹇呭~椤�
+ if (!this.tiaojiStaffNo) {
+ this.$showMessage('璇烽�夋嫨璋冩満甯堝倕');
+ return;
+ }
+
+ const okQty = Number(this.tiaojiOkQty);
+ const badQty = Number(this.tiaojiBadQty);
+
+ if (isNaN(okQty) || okQty < 0) {
+ this.$showMessage('璇疯緭鍏ユ湁鏁堢殑璋冩満鑹搧鏁�');
+ return;
+ }
+
+ if (isNaN(badQty) || badQty < 0) {
+ this.$showMessage('璇疯緭鍏ユ湁鏁堢殑璋冩満涓嶈壇鍝佹暟');
+ return;
+ }
+
+ const staffNo = this.tiaojiStaffNo.split(':')[0];
+ const totalQty = okQty + badQty; // 璇曚骇鎬绘暟 = 鑹搧鏁� + 涓嶈壇鍝佹暟
+
+ // 璋冪敤鎶ヨ瘯浜ф暟鎺ュ彛(浣跨敤鎶ュ伐鐣岄潰鐨勬帴鍙�)
+ const payload = {
+ orderNo: this.workOrderNo,
+ orderId: this.orderId, // 闇�瑕佷粠宸ュ崟鏁版嵁涓幏鍙�
+ bf: totalQty, // 璇曚骇鎬绘暟
+ staffNo: staffNo,
+ initCjNum: this.order?.initCjNum || 0,
+ currentCjNum: this.order?.currentCjNum || 0,
+ type: 'tiaoji', // 鏍囪瘑涓鸿皟鏈烘姤宸�
+ tiaojiOkQty: okQty, // 鏂板:鑹搧鏁�
+ tiaojiBadQty: badQty // 鏂板:涓嶈壇鍝佹暟
+ };
+
+ try {
+ this.submitting = true;
+ // 璋冪敤鎶ュ伐鐣岄潰鐨勬姤璇曚骇鏁版帴鍙�
+ const res = await this.$post({
+ url: '/MesInvItemBarcodes/AddBFToBarcodes',
+ data: payload
+ });
+
+ if (res.status == 1) {
+ this.$showMessage(res.message);
+ return;
+ }
+
+ this.$showMessage('璋冩満鎶ュ伐鎴愬姛');
+ // 娓呯┖杈撳叆
+ this.tiaojiOkQty = '';
+ this.tiaojiBadQty = '';
+ // 鍒锋柊鏁版嵁
+ await this.fetchFormData();
+ await this.fetchDefaultToolFromWorkOrder();
+ } catch (err) {
+ console.error('璋冩満鎶ュ伐閿欒:', err);
+ this.$showMessage('璋冩満鎶ュ伐澶辫触锛岃妫�鏌ョ綉缁�');
+ } finally {
+ this.submitting = false;
+ }
+ },
+
+ // 鏂板锛氳幏鍙栬皟鏈哄笀鍌呭垪琛�
+ async fetchTiaojiStaff() {
+ try {
+ const res = await this.$post({
+ url: '/MesStaff/GetAllXS0101BYtj' // 涓庢姤宸ョ晫闈娇鐢ㄧ浉鍚屾帴鍙�
+ });
+ if (res.status === 0 && res.data && res.data.tbBillList) {
+ const staff = res.data.tbBillList;
+ this.tiaojiUsers = staff.map(s => s.staffNo + ':' + s.staffName);
+ }
+ } catch (err) {
+ console.error('鑾峰彇璋冩満甯堝倕鍒楄〃澶辫触:', err);
+ }
}
},
mounted() {
this.fetchTools('');
this.machineNo = uni.getStorageSync('machineNo') || '';
this.workOrderNo = uni.getStorageSync('daa001') || '';
+
+ // 鏂板锛氳幏鍙栬皟鏈哄笀鍌呭垪琛�
+ this.fetchTiaojiStaff();
if (this.machineNo && this.workOrderNo) {
this.fetchFormData().then(async () => {
@@ -1217,4 +1406,273 @@
margin-right: 16px;
flex: none !important; /* 鍏抽敭锛氬交搴曠姝lex鎷変几 */
}
+
+ /* 鏂板锛氳皟鏈哄尯鍩熸牱寮� */
+ .tiaoji-section {
+ width: 100%;
+ margin: 2vh 0;
+ padding: 20px;
+ background: #f8f9fa;
+ border-radius: 8px;
+ border: 1px solid #e9ecef;
+ }
+
+ .tiaoji-row {
+ display: flex;
+ flex-wrap: wrap;
+ align-items: center;
+ gap: 20px;
+ }
+
+ /* 褰撳墠璋冩満甯堝倕鍖哄煙 - 涓庢姤宸ョ晫闈繚鎸佷竴鑷� */
+ .current-user-section {
+ display: flex;
+ align-items: center;
+ font-size: 22px;
+ border: 1.5px solid #f00;
+ border-radius: 10px;
+ padding: 14px 22px;
+ background: #fff;
+ gap: 14px;
+ flex: 0 0 auto;
+ }
+
+ .current-user-name {
+ font-weight: bold;
+ font-size: 22px;
+ }
+
+ /* 閫変汉鎸夐挳 - 钃濊壊涓婚锛屼笌鎶ュ伐鐣岄潰淇濇寔涓�鑷� */
+ .select-user-btn {
+ background: #00a2e9;
+ color: #fff;
+ border: none;
+ padding: 12px 22px;
+ border-radius: 12px;
+ font-size: 22px;
+ cursor: pointer;
+ transition: background 0.15s;
+ height: 66px;
+ box-sizing: border-box;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ }
+
+ .select-user-btn:hover {
+ background: #008ac2;
+ }
+
+ /* 璋冩満鏁伴噺杈撳叆鍖哄煙 */
+ .tiaoji-input-section {
+ display: flex;
+ align-items: center;
+ gap: 14px;
+ font-size: 22px;
+ }
+
+ .tiaoji-input {
+ width: 200px;
+ max-width: 100%;
+ height: 66px;
+ border: 2px solid #808080;
+ font-size: 28px;
+ text-align: center;
+ border-radius: 8px;
+ box-sizing: border-box;
+ }
+
+ /* 閫佹鍛煎彨鎸夐挳 - 涓庢姤宸ョ晫闈㈢殑纭鎻愪氦鎸夐挳淇濇寔涓�鑷� */
+ .details-btn {
+ padding: 12px 34px;
+ background: #00a2e9;
+ color: #fff;
+ font-size: 32px;
+ border: none;
+ cursor: pointer;
+ border-radius: 12px;
+ height: 66px;
+ min-width: 180px;
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+ line-height: 1.1;
+ box-sizing: border-box;
+ transition: background 0.15s;
+ }
+
+ .details-btn:hover {
+ background: #008ac2;
+ }
+
+ .details-btn:disabled {
+ opacity: 0.6;
+ cursor: not-allowed;
+ background: #bae7ff;
+ }
+
+ .tiaoji-submit-section {
+ display: flex;
+ align-items: center;
+ }
+
+ /* 閫変汉寮圭獥鏍峰紡 - 涓庢姤宸ョ晫闈繚鎸佷竴鑷� */
+ .overlay {
+ position: fixed;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ background: rgba(0,0,0,.45);
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ z-index: 1000;
+ }
+
+ .user-select-popup {
+ background: #fff;
+ width: 1600px;
+ max-width: 99vw;
+ min-width: 1000px;
+ height: auto;
+ min-height: 520px;
+ padding: 0;
+ display: flex;
+ flex-direction: column;
+ font-size: 32px;
+ border-radius: 12px;
+ box-shadow: 0 8px 32px rgba(0,0,0,0.12);
+ z-index: 1001;
+ }
+
+ .user-search-bar {
+ display: flex;
+ align-items: center;
+ gap: 18px;
+ padding: 24px 64px 0 64px;
+ background: #fff;
+ flex-wrap: wrap;
+ }
+
+ .user-search-input {
+ flex: 1 1 260px;
+ padding: 16px 20px;
+ font-size: 28px;
+ border: 1px solid #bbb;
+ border-radius: 8px;
+ outline: none;
+ height: 54px;
+ }
+
+ .user-search-input:focus {
+ border-color: #007aff;
+ box-shadow: 0 0 0 2px rgba(0,122,255,.15);
+ }
+
+ .user-search-clear {
+ padding: 12px 28px;
+ background: #ff9f43;
+ color: #fff;
+ border: none;
+ border-radius: 8px;
+ font-size: 24px;
+ cursor: pointer;
+ }
+
+ .user-search-clear:hover {
+ background: #ff8920;
+ }
+
+ .user-search-info {
+ font-size: 22px;
+ color: #555;
+ }
+
+ .user-list-scroll {
+ flex: 1 1 auto;
+ overflow-y: auto;
+ padding: 32px 64px 0 64px;
+ }
+
+ .user-list-grid {
+ display: grid;
+ grid-template-columns: repeat(auto-fill,minmax(200px,1fr));
+ gap: 22px 22px;
+ }
+
+ .user-list-btn {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+ gap: 2px;
+ padding: 10px 10px;
+ height: 100px;
+ font-size: 30px;
+ background: #00a2e9;
+ color: #fff;
+ border: none;
+ border-radius: 8px;
+ cursor: pointer;
+ box-sizing: border-box;
+ word-break: break-word;
+ }
+
+ .user-list-btn .user-code {
+ font-weight: 700;
+ font-size: 36px;
+ line-height: 1.1;
+ }
+
+ .user-list-btn .user-name {
+ font-size: 32px;
+ line-height: 1.1;
+ }
+
+ .user-list-btn.selected {
+ background: #0072c9;
+ box-shadow: 0 0 0 3px rgba(255,255,255,.6) inset;
+ }
+
+ .user-list-btn:hover {
+ background: #008ed0;
+ }
+
+ .no-user-result {
+ padding: 40px 0;
+ text-align: center;
+ font-size: 28px;
+ color: #666;
+ }
+
+ .user-popup-footer {
+ flex-shrink: 0;
+ padding: 24px 64px 32px 64px;
+ background: #fff;
+ text-align: center;
+ }
+
+ .clean-btn {
+ width: 24%;
+ padding: 10px 0;
+ color: #fff;
+ font-size: 20px;
+ border: none;
+ text-align: center;
+ cursor: pointer;
+ border-radius: 0.6vw;
+ background: #007aff;
+ }
+
+ .clean-btn.wide-btn {
+ width: 30%;
+ font-size: 22px;
+ padding: 12px 0;
+ }
+
+ .clean-btn:hover {
+ background: #0062c9;
+ }
</style>
\ No newline at end of file
diff --git a/pages/index.vue b/pages/index.vue
index acfec3d..51880c1 100644
--- a/pages/index.vue
+++ b/pages/index.vue
@@ -462,7 +462,7 @@
getPrintInfo() {
var mac = "";
- mac = "74:24:ca:4f:b2:c3";
+ mac = "74:24:ca:4f:b7:4d";
this.$post({
url: "/DevMachine/GetDevMachineByPdaMac",
data: {
diff --git a/pages/moldRecord.vue b/pages/moldRecord.vue
index f6511d1..176ee81 100644
--- a/pages/moldRecord.vue
+++ b/pages/moldRecord.vue
@@ -6,14 +6,14 @@
</view>
<!-- 鍒�鍏蜂娇鐢ㄨ褰曡〃鏍� -->
- <view class="table-section">
+ <view class="table-section" :class="{'expanded': toolExpanded}">
<view class="table-header">
<h3>涓婁笅鍒�璁板綍</h3>
<button class="expand-btn" @click="toggleExpand('tool')">
{{ toolExpanded ? '鏀惰捣' : '灞曞紑' }}
</button>
</view>
- <table class="styled-table" :class="{'expanded': toolExpanded}">
+ <table class="styled-table">
<thead>
<tr>
<th style="width:7%">鍒�鍏风紪鍙�</th>
@@ -91,7 +91,9 @@
</tr>
<tr v-if="hasMoreToolRecords && !toolExpanded">
<td colspan="12" class="more-records-tip">
- <span>杩樻湁 {{ remainingToolRecords }} 鏉¤褰曪紝鐐瑰嚮"灞曞紑"鎸夐挳鏌ョ湅鍏ㄩ儴</span>
+ <span>杩樻湁 {{ remainingToolRecords }} 鏉¤褰曪紝鐐瑰嚮</span>
+ <button class="inline-expand-btn" @click="toggleExpand('tool')">灞曞紑</button>
+ <span>鎸夐挳鏌ョ湅鍏ㄩ儴</span>
</td>
</tr>
</tbody>
@@ -99,14 +101,14 @@
</view>
<!-- 宸ュ崟棣栨璁板綍琛ㄦ牸 -->
- <view class="table-section">
+ <view class="table-section" :class="{'expanded': inspectionExpanded}">
<view class="table-header">
<h3>宸ュ崟棣栨璁板綍</h3>
<button class="expand-btn" @click="toggleExpand('inspection')">
{{ inspectionExpanded ? '鏀惰捣' : '灞曞紑' }}
</button>
</view>
- <table class="styled-table" :class="{'expanded': inspectionExpanded}">
+ <table class="styled-table">
<thead>
<tr>
<th style="width:10%">妫�楠屽崟鍙�</th>
@@ -136,7 +138,9 @@
</tr>
<tr v-if="hasMoreInspectionRecords && !inspectionExpanded">
<td colspan="10" class="more-records-tip">
- <span>杩樻湁 {{ remainingInspectionRecords }} 鏉¤褰曪紝鐐瑰嚮"灞曞紑"鎸夐挳鏌ョ湅鍏ㄩ儴</span>
+ <span>杩樻湁 {{ remainingInspectionRecords }} 鏉¤褰曪紝鐐瑰嚮</span>
+ <button class="inline-expand-btn" @click="toggleExpand('inspection')">灞曞紑</button>
+ <span>鎸夐挳鏌ョ湅鍏ㄩ儴</span>
</td>
</tr>
</tbody>
@@ -503,11 +507,13 @@
display: flex;
flex-direction: column;
margin: 0;
- overflow-x: auto;
+ overflow: auto; /* 缁熶竴婊氬姩鏉� */
width: 100%;
border: 1px solid #f0f0f0;
border-radius: 8px;
background: #fff;
+ max-height: 220px; /* 榛樿楂樺害 */
+ transition: max-height 0.3s ease;
}
.table-header {
@@ -549,57 +555,24 @@
table.styled-table {
max-width: 1800px;
width: 98vw;
- margin: 0 auto;
+ margin: 0;
border-collapse: separate;
border-spacing: 0;
border: 2px solid #bfbfbf;
background: #fff;
- overflow: hidden;
box-shadow: 0 2px 12px rgba(0,0,0,0.06);
- max-height: 180px; /* 璋冩暣楂樺害浣块〉闈㈤ケ婊� */
- display: block;
- overflow-y: hidden;
- transition: max-height 0.3s ease;
}
- table.styled-table.expanded {
- max-height: 400px; /* 灞曞紑鏃剁殑楂樺害 */
- overflow-y: auto;
- }
-
- table.styled-table thead {
- display: table;
- width: 100%;
- table-layout: fixed;
- }
-
- table.styled-table thead th {
- background: #fafafa;
- border-bottom: 2px solid #bfbfbf;
- padding: 16px 10px;
- font-weight: bold;
- text-align: center;
- font-size: 22px;
- position: sticky;
- top: 0;
- z-index: 10;
- }
-
- table.styled-table tbody {
- display: block;
- max-height: calc(180px - 50px); /* 鍑忓幓琛ㄥご楂樺害 */
- overflow-y: hidden;
- }
-
- table.styled-table.expanded tbody {
- max-height: calc(400px - 50px);
- overflow-y: auto;
- }
-
- table.styled-table tbody tr {
- display: table;
- width: 100%;
- table-layout: fixed;
+ table.styled-table thead th {
+ background: #fafafa;
+ border-bottom: 2px solid #bfbfbf;
+ padding: 16px 10px;
+ font-weight: bold;
+ text-align: center;
+ font-size: 22px;
+ position: sticky; /* 琛ㄥご缃《 */
+ top: 0;
+ z-index: 10;
}
table.styled-table tbody td {
@@ -609,6 +582,11 @@
text-align: center;
font-size: 22px;
}
+
+ /* 灞曞紑鐘舵�� - 鍙敼鍙樺鍣ㄩ珮搴� */
+ .table-section.expanded {
+ max-height: 450px; /* 灞曞紑鏃剁殑瀹瑰櫒楂樺害 */
+ }
table.styled-table tbody .left {
text-align: left;
@@ -656,11 +634,38 @@
}
.more-records-tip span {
- display: inline-block;
- padding: 5px 15px;
- background-color: #f0f0f0;
- border-radius: 4px;
- border: 1px dashed #ccc;
+ display: inline;
+ font-size: 20px;
+ color: #666;
+ }
+
+ /* 琛屽唴灞曞紑鎸夐挳鏍峰紡 - 钃濊壊 */
+ .inline-expand-btn {
+ display: inline-block;
+ padding: 2px 12px; /* 鍑忓皬鍐呰竟璺�,涓庢枃瀛楅珮搴︿竴鑷� */
+ margin: 0 6px;
+ background-color: #00A2E9; /* 钃濊壊 */
+ color: white;
+ border: none;
+ border-radius: 3px;
+ font-size: 20px; /* 涓庢彁绀烘枃瀛楀ぇ灏忎竴鑷� */
+ font-weight: 500;
+ cursor: pointer;
+ transition: all 0.3s;
+ box-shadow: 0 2px 4px rgba(0, 162, 233, 0.2);
+ vertical-align: baseline; /* 涓庢枃瀛楀熀绾垮榻� */
+ line-height: 1.2; /* 鎺у埗琛岄珮 */
+ }
+
+ .inline-expand-btn:hover {
+ background-color: #40a9ff; /* 鎮仠鏃跺彉娣� */
+ box-shadow: 0 4px 8px rgba(0, 162, 233, 0.3);
+ transform: translateY(-1px);
+ }
+
+ .inline-expand-btn:active {
+ background-color: #096dd9; /* 鐐瑰嚮鏃跺彉娣� */
+ transform: translateY(0);
}
/* 鍝嶅簲寮忚皟鏁� */
diff --git a/store/index.js b/store/index.js
index 39e926c..26ee1b0 100644
--- a/store/index.js
+++ b/store/index.js
@@ -8,11 +8,11 @@
id: 'id',
serverInfo:{//鏈嶅姟淇℃伅
networkFlag:'鍐呯綉',
- serverURLInt:'http://192.168.11.251:10054',//鏈嶅姟鍣ㄤ綋妫� 10.0.1.104:10054
- serverURL:'http://localhost:5106',//鏈湴璋冭瘯鍦板潃
+ serverURLInt: 'http://192.168.11.251:10054',//鏈嶅姟鍣ㄤ綋妫� 10.0.1.104:10054
+ serverURL: 'http://localhost:10054',//鏈湴璋冭瘯鍦板潃
//serverAPI:'http://78566b00.r1.cpolar.top/api',//澶栫綉鍦板潃
- //serverAPI:'http://192.168.0.94:8008/api', //鍐呯綉鍦板潃
- serverAPI:'http://localhost:5106/api',//鏈湴璋冭瘯鍦板潃
+ serverAPI: 'http://192.168.0.94:8008/api', //鍐呯綉鍦板潃
+ //serverAPI:'http://localhost:5106/api',//鏈湴璋冭瘯鍦板潃
}
},
mutations: {
diff --git a/unpackage/dist/dev/app-plus/app-service.js b/unpackage/dist/dev/app-plus/app-service.js
index 59b9be8..92a08d4 100644
--- a/unpackage/dist/dev/app-plus/app-service.js
+++ b/unpackage/dist/dev/app-plus/app-service.js
@@ -3549,7 +3549,7 @@
/***/ (function(module, exports, __webpack_require__) {
"use strict";
-eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 6));\nvar _WorkOrderStatus = _interopRequireDefault(__webpack_require__(/*! ../components/WorkOrderStatus.vue */ 53));\nvar _uniTable = _interopRequireDefault(__webpack_require__(/*! ../uni_modules/uni-table/components/uni-table/uni-table.vue */ 14));\nvar _mold = _interopRequireDefault(__webpack_require__(/*! ../components/mold.vue */ 58));\nvar _machine = _interopRequireDefault(__webpack_require__(/*! ../components/machine.vue */ 63));\nvar _WorkOrderPrint = _interopRequireDefault(__webpack_require__(/*! ../components/WorkOrderPrint.vue */ 68));\nvar _WorkOrder = _interopRequireDefault(__webpack_require__(/*! ../components/WorkOrder.vue */ 74));\nvar _Technology = _interopRequireDefault(__webpack_require__(/*! ../components/Technology.vue */ 79));\nvar _PDFShow = _interopRequireDefault(__webpack_require__(/*! ../components/PDFShow.vue */ 84));\nvar _PrintInit = _interopRequireDefault(__webpack_require__(/*! ../components/PrintInit.vue */ 89));\nvar _PrintTest = _interopRequireDefault(__webpack_require__(/*! ../components/PrintTest.vue */ 94));\nvar _EquipmentInspection = _interopRequireDefault(__webpack_require__(/*! ../components/EquipmentInspection.vue */ 99));\nvar _moldRecord = _interopRequireDefault(__webpack_require__(/*! ../pages/moldRecord.vue */ 115));\nvar _methods;\nvar _default = {\n components: {\n Technology: _Technology.default,\n WorkOrder: _WorkOrder.default,\n WorkOrderPrint: _WorkOrderPrint.default,\n Machine: _machine.default,\n Mold: _mold.default,\n UniTable: _uniTable.default,\n WorkOrderStatus: _WorkOrderStatus.default,\n PDFShow: _PDFShow.default,\n PrintInit: _PrintInit.default,\n PrintTest: _PrintTest.default,\n EquipmentInspection: _EquipmentInspection.default,\n MoldRecord: _moldRecord.default\n },\n data: function data() {\n var _ref;\n return _ref = {\n orderStatus: '',\n // 榛樿鍏ㄩ儴\n currentTab: 7,\n productCode: '',\n // 浜у搧缂栫爜\n productSpec: '',\n // 浜у搧瑙勬牸\n\n machineList: [],\n machine: [],\n engineeringNoList: [],\n engineeringNoMapList: [],\n engineeringNo: '',\n machineNo: '',\n machineName: '',\n tableData: [],\n isShowTableData: []\n }, (0, _defineProperty2.default)(_ref, \"orderStatus\", '寮�宸�'), (0, _defineProperty2.default)(_ref, \"selectedOrder\", ''), (0, _defineProperty2.default)(_ref, \"orderId\", 0), (0, _defineProperty2.default)(_ref, \"selectedIndexs\", []), (0, _defineProperty2.default)(_ref, \"isShow\", false), (0, _defineProperty2.default)(_ref, \"autoRedirectTimer\", null), (0, _defineProperty2.default)(_ref, \"autoRedirectTime\", 5 * 60 * 1000), _ref;\n },\n created: function created() {\n //璋冭瘯浣跨敤鐨勪唬鐮乗n // this.machineNo = uni.getStorageSync('machineNo');\n // this.machineName = uni.getStorageSync('machineName');\n //\n // if (this.machineNo) {\n // this.getWomdaaIsShow();\n // }\n\n uni.clearStorageSync();\n this.checkForUpdate();\n\n //宸ユ帶鏈轰娇鐢ㄧ殑浠g爜\n this.getPrintInfo();\n },\n onLoad: function onLoad(options) {\n this.getMachineList();\n },\n onShow: function onShow() {\n this.refresh();\n this.resetAutoRedirectTimer();\n },\n methods: (_methods = {\n onRowClick: function onRowClick(index) {\n this.selectedIndexs = [index]; // 鍗曢�塡n // 鎵嬪姩瑙﹀彂 selectionChange 浠ュ悓姝ュ閫夋\n this.selectionChange({\n detail: {\n index: index\n }\n });\n // 閲嶇疆鑷姩璺宠浆璁℃椂鍣╘n this.resetAutoRedirectTimer();\n },\n // 閲嶇疆鑷姩璺宠浆璁℃椂鍣╘n resetAutoRedirectTimer: function resetAutoRedirectTimer() {\n var _this = this;\n // 娓呴櫎鐜版湁鐨勫畾鏃跺櫒\n if (this.autoRedirectTimer) {\n clearTimeout(this.autoRedirectTimer);\n this.autoRedirectTimer = null;\n }\n\n // 闄や簡涓婚〉(0)銆佸伐鍗曢�夋嫨椤�(7)銆佺敓浜ф姤宸ラ〉(4)涔嬪鐨勯〉闈㈡墠璁剧疆鑷姩璺宠浆\n if (this.currentTab !== 0 && this.currentTab !== 7 && this.currentTab !== 4) {\n this.autoRedirectTimer = setTimeout(function () {\n // 璺宠浆鍥炰富椤礬n _this.currentTab = 0;\n // 鏄剧ず鎻愮ず淇℃伅\n uni.showToast({\n title: '椤甸潰瓒呮椂锛岃嚜鍔ㄨ繑鍥炰富椤�',\n icon: 'none',\n duration: 2000\n });\n }, this.autoRedirectTime);\n }\n },\n checkForUpdate: function checkForUpdate() {\n var _this2 = this;\n this.$post({\n url: \"/DevMachine/getAppUpgradeInfo\",\n data: {}\n }).then(function (res) {\n var newVersion = res.data.version;\n var currentVersion = uni.getSystemInfoSync(); // 鑾峰彇褰撳墠 APK 鐗堟湰鍙穃n\n if (newVersion > currentVersion.appVersion) {\n uni.showModal({\n title: \"鍙戠幇鏂扮増鏈琝",\n content: \"鏄惁涓嬭浇鏈�鏂扮増鏈�?\",\n success: function success(modalRes) {\n if (modalRes.confirm) {\n _this2.downloadNewApk(res.data.apkUrl);\n }\n }\n });\n //this.downloadNewApk(res.data.apkUrl);\n _this2.updateChecked = true; // 鏍囪鏇存柊宸叉鏌ヨ繃\n // // 濡傛灉鏈夋柊鐗堟湰锛屽紑濮嬩笅杞絓n //download(res.data.apkUrl);\n }\n });\n },\n downloadNewApk: function downloadNewApk(apkUrl) {\n uni.showToast({\n title: \"寮�濮嬩笅杞芥洿鏂�...\",\n icon: \"none\",\n duration: 2000\n });\n uni.downloadFile({\n url: apkUrl,\n success: function success(res) {\n if (res.statusCode === 200) {\n plus.runtime.install(res.tempFilePath, {\n force: true\n }, function () {\n __f__(\"log\", \"瀹夎鎴愬姛锛岄噸鍚簲鐢╘", \" at pages/index.vue:437\");\n //plus.runtime.restart();\n //plus.runtime.quit();\n // uni.navigateBack()\n }, function (e) {\n __f__(\"error\", \"瀹夎澶辫触:\", e, \" at pages/index.vue:442\");\n });\n }\n },\n fail: function fail(err) {\n __f__(\"error\", \"涓嬭浇澶辫触:\", err, \" at pages/index.vue:447\");\n uni.showToast({\n title: \"涓嬭浇澶辫触锛岃妫�鏌ョ綉缁淺",\n icon: \"none\",\n duration: 2000\n });\n }\n });\n },\n refresh: function refresh() {\n this.getMachineList();\n this.getPrintInfo();\n this.getWomdaaIsShow();\n },\n getPrintInfo: function getPrintInfo() {\n var _this3 = this;\n var mac = \"\";\n mac = \"74:24:ca:4f:b2:c3\";\n this.$post({\n url: \"/DevMachine/GetDevMachineByPdaMac\",\n data: {\n pdaMac: mac\n }\n }).then(function (res) {\n var devMachine = res.data.tbBillList;\n _this3.machineNo = devMachine.machineNo;\n _this3.machineName = \"璋冭瘯妯″紡锛歕" + _this3.machineNo + \"鍙烽娇杞満\";\n uni.setStorageSync('machineNo', _this3.machineNo);\n uni.setStorageSync('printMac', devMachine.printMac);\n __f__(\"log\", devMachine.printMac, \" at pages/index.vue:479\");\n _this3.getWomdaaIsShow();\n });\n return;\n\n // \t\t\tif (plus.os.name == \"Android\") {\n // \t\t\t\t//鑾峰彇鎵嬫満MAC鍦板潃\n // \t\t\t\tvar Context = plus.android.importClass(\"android.content.Context\");\n // \t\t\t\tvar WifiManager = plus.android.importClass(\"android.net.wifi.WifiManager\");\n // \t\t\t\tvar wifiManager = plus.android.runtimeMainActivity().getSystemService(Context.WIFI_SERVICE);\n // \t\t\t\tvar WifiInfo = plus.android.importClass(\"android.net.wifi.WifiInfo\");\n // \t\t\t\tvar wifiInfo = wifiManager.getConnectionInfo();\n // \t\t\t\tmac = wifiInfo.getMacAddress();\n\n // \t\t\t\t//濡傛灉mac涓衡��02:00:00:00:00:00鈥濓紝鍒欏彲鑳芥槸瀹夊崜6.0浠ヤ笂鐗堟湰锛屽垯浣跨敤鍙︿竴绉嶆柟娉曡幏鍙杕ac鍦板潃\n // \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\n // \t\t\t\t\tmac = this.getMacNew();\n // \t\t\t\t}\n // \t\t\t\t//濡傛灉mac浣跨敤鏂版柟娉曚緷鐒舵槸鈥�02:00:00:00:00:00鈥濆垯涓嶈繘琛屼繚瀛榎n // \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\n // \t\t\t\t\treturn;\n // \t\t\t\t}\n // \t\t\t\tuni.setStorageSync('pdaMac', mac);\n\n // \t\t\t\tthis.$post({\n // \t\t\t\t\turl: \"/DevMachine/GetDevMachineByPdaMac\",\n // \t\t\t\t\tdata: {\n // \t\t\t\t\t\tpdaMac: mac,\n // \t\t\t\t\t}\n // \t\t\t\t}).then(res => {\n // \t\t\t\t\tlet devMachine = res.data.tbBillList;\n // \t\t\t\t\tthis.machineNo = devMachine.machineNo;\n // \t\t\t\t\tthis.machineName = \"褰撳墠鏈哄彴锛歕" + this.machineNo + \"鍙烽娇杞満\";\n\n // \t\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\n // \t\t\t\t\tuni.setStorageSync('printMac', devMachine.printMac);\n\n // \t\t\t\t\tthis.getWomdaaIsShow();\n\n // \t\t\t\t});\n // \t\t\t}\n },\n save: function save() {\n var _this4 = this;\n var data = this.selectedItems();\n if (data.length === 0) {\n this.$showMessage(\"璇烽�夋嫨涓�涓伐鍗昞");\n return;\n }\n if (data.length > 1) {\n this.$showMessage(\"涓�娆″彧鑳介�夊彇涓�涓伐鍗昞");\n return;\n }\n\n //let firstValue = data[0][\"moldId\"]; // 鑾峰彇绗竴涓璞$殑鎸囧畾灞炴�у�糪n\n //// 浣跨敤 every 鏂规硶妫�鏌ユ墍鏈夊璞$殑璇ュ睘鎬у�兼槸鍚︿竴鑷碶n //let flag = data.every(item => item[\"moldId\"] === firstValue);\n //if (!flag) {\n //\tthis.$showMessage(\"閫夊彇鐨刓" + data.length + \"涓伐鍗曚腑鐨勬ā鍏风紪鍙蜂笉涓�鑷碶");\n //\treturn;\n //}\n\n var orderSelect = [];\n data.forEach(function (s) {\n var entity = {\n orderId: s.id,\n orderNo: s.daa001\n };\n orderSelect.push(entity);\n });\n var editDate = this.formatDate(new Date());\n this.$post({\n url: \"/MesOrderSelect/Add\",\n data: {\n machineNo: this.machineNo,\n editDate: editDate,\n item: orderSelect\n }\n }).then(function (res) {\n if (res.data.tbBillList) {\n _this4.getWomdaaIsShow();\n uni.showToast({\n title: '淇濆瓨宸ュ崟鎴愬姛',\n //title: '灏嗘敞濉戞満寮�鍚堟ā鏁版竻0',\n //灏嗗�艰缃负 success 鎴栬�呯洿鎺ヤ笉鐢ㄥ啓icon杩欎釜鍙傛暟\n icon: 'success',\n //鏄剧ず鎸佺画鏃堕棿涓� 5绉抃n duration: 5000\n });\n }\n _this4.isShow = false;\n });\n },\n getMacNew: function getMacNew() {\n var str = \"\";\n try {\n if (plus.os.name == \"Android\") {\n var NetworkInterface = plus.android.importClass(\"java.net.NetworkInterface\");\n var networkInterface = NetworkInterface.getByName(\"wlan0\");\n var bytes = networkInterface.getHardwareAddress();\n\n //灏哹yte[] 杞崲鎴� String\n for (var i = 0; i < bytes.length; i++) {\n var tmp = \"\";\n var num = bytes[i];\n if (num < 0) {\n tmp = (255 + num + 1).toString(16);\n } else {\n tmp = num.toString(16);\n }\n if (tmp.length == 1) {\n tmp = \"0\" + tmp;\n }\n str += i == 0 ? tmp : \":\" + tmp;\n }\n }\n } catch (err) {\n str = \"02:00:00:00:00:00\";\n }\n return str;\n },\n cancel: function cancel() {\n var _this5 = this;\n if (!this.machineNo) {\n return;\n }\n\n // 鐩存帴鐢� flag 鍒ゆ柇\n if (this.hasBindedCutterFlag) {\n uni.showToast({\n title: '褰撳墠宸ュ崟宸茬粦瀹氬垁鍏凤紝涓嶈兘娓呯┖閲嶉��',\n icon: 'error',\n duration: 2000\n });\n return;\n }\n var editDate = this.formatDate(new Date());\n this.selectedIndexs = [];\n this.$post({\n url: \"/MesOrderSelect/Remove\",\n data: {\n machineNo: this.machineNo,\n editDate: editDate\n }\n }).then(function (res) {\n if (res.data.tbBillList > 0) {\n _this5.isShowTableData = [];\n }\n });\n },\n formatDate: function formatDate(date) {\n var year = date.getFullYear(); // 鑾峰彇骞翠唤\n var month = String(date.getMonth() + 1).padStart(2, '0'); // 鑾峰彇鏈堜唤骞惰ˉ闆禱n var day = String(date.getDate()).padStart(2, '0'); // 鑾峰彇鏃ユ湡骞惰ˉ闆禱n return \"\".concat(year, \"-\").concat(month, \"-\").concat(day); // 杩斿洖鏍煎紡鍖栧悗鐨勫瓧绗︿覆\n },\n selectionChange: function selectionChange(e) {\n // 鍗曢�夌洿鎺ヨ祴鍊糪n this.selectedIndexs = [e.detail.index];\n },\n selectedItems: function selectedItems() {\n var _this6 = this;\n return this.selectedIndexs.map(function (i) {\n return _this6.tableData[i];\n });\n },\n changeTab: function changeTab(index) {\n this.currentTab = index;\n // 褰撳垏鎹㈠埌宸ュ崟閫夋嫨椤甸潰(index === 7)鏃惰嚜鍔ㄥ埛鏂癨n if (index === 7) {\n this.refresh();\n }\n // 閲嶇疆鑷姩璺宠浆璁℃椂鍣╘n this.resetAutoRedirectTimer();\n __f__(\"log\", index, \" at pages/index.vue:665\");\n },\n onMachineChange: function onMachineChange(event) {\n this.machineName = event;\n this.machineNo = this.machine[this.machineList.indexOf(event)].machineNo;\n uni.clearStorageSync();\n uni.setStorageSync('machineNo', this.machineNo);\n uni.setStorageSync('machineName', this.machineName);\n this.getWomdaaIsShow();\n },\n onEngineeringNoChange: function onEngineeringNoChange(event) {\n var orde = this.engineeringNoList[this.engineeringNoMapList.indexOf(event)];\n this.engineeringNo = orde.moldId;\n this.getWomdaa();\n },\n getMachineList: function getMachineList() {\n var _this7 = this;\n this.$post({\n url: \"/MesMachine/GetInjectionMachine\"\n }).then(function (res) {\n _this7.machine = res.data.tbBillList;\n _this7.machineList = _this7.machine.map(function (s) {\n return s.machineName;\n });\n });\n },\n //鑾峰彇琛ㄦ牸鐨勬暟鎹簮\n getWomdaaIsShow: function getWomdaaIsShow() {\n var _this8 = this;\n this.$post({\n url: \"/Womdaa/GetWomdaasByShow\",\n data: {\n machineNo: this.machineNo\n }\n }).then(function (res) {\n _this8.isShowTableData = res.data.tbBillList;\n\n // 鍙垽鏂涓�鏉★紙鍙厑璁镐竴鏉″伐鍗曪級\n var order = _this8.isShowTableData[0];\n var hasBindedCutter = false;\n if (order) {\n hasBindedCutter = order.outToolId && order.outToolId.toString().trim() !== '' || order.outToolCode && order.outToolCode.trim() !== '' || order.outToolName && order.outToolName.trim() !== '';\n }\n // 瀛樺偍鍒� data 鍙橀噺\n _this8.hasBindedCutterFlag = hasBindedCutter;\n if (_this8.isShowTableData.length == 1) {\n uni.setStorageSync('daa001', _this8.isShowTableData[0].daa001);\n uni.setStorageSync('id', _this8.isShowTableData[0].id);\n }\n });\n },\n isShowTab: function isShowTab() {\n if (this.isShowTableData.length > 0) {\n uni.showToast({\n title: '宸叉湁姝e湪鎿嶄綔鐨勫伐鍗曪紝涓嶈兘鍐嶆閫夋嫨',\n icon: 'error',\n duration: 2000\n });\n return;\n }\n this.isShow = true;\n // 榛樿閫変腑鈥滃緟寮�宸モ�漒n this.engineeringNo = '寰呭紑宸ャ�佹湭寮�宸ャ�佹殏鍋�';\n this.tableData = [];\n // 涓嬫媺妗嗗彧鏄剧ず鍚堝苟鍚庣殑鐘舵�佸拰鍏跺畠鐘舵�乗n this.engineeringNoMapList = ['寰呭紑宸ャ�佹湭寮�宸ャ�佹殏鍋�', '寮�宸�', '瀹屽伐'];\n // 榛樿鏄剧ず鈥滃緟寮�宸モ�濆伐鍗昞n this.getWomdaaByStatus();\n }\n }, (0, _defineProperty2.default)(_methods, \"onEngineeringNoChange\", function onEngineeringNoChange(status) {\n this.engineeringNo = status;\n this.getWomdaaByStatus();\n }), (0, _defineProperty2.default)(_methods, \"getWomdaa\", function getWomdaa() {\n var _this9 = this;\n var editDate = this.formatDate(new Date());\n this.$post({\n url: \"/Womdaa/GetWomdaasByMachine\",\n data: {\n machineNo: this.machineNo,\n editDate: editDate\n }\n }).then(function (res) {\n _this9.tableData = res.data.tbBillList;\n });\n }), (0, _defineProperty2.default)(_methods, \"getWomdaaByStatus\", function getWomdaaByStatus() {\n var _this10 = this;\n var editDate = this.formatDate(new Date());\n var statusArr = [];\n if (this.engineeringNo === '寰呭紑宸ャ�佹湭寮�宸ャ�佹殏鍋�') {\n statusArr = ['寰呭紑宸�', '鏈紑宸�', '鏆傚仠'];\n } else {\n statusArr = [this.engineeringNo];\n }\n this.$post({\n url: \"/Womdaa/GetWomdaasByEngineeringNo\",\n data: {\n machineNo: this.machineNo,\n orderStatus: statusArr,\n editDate: editDate\n }\n }).then(function (res) {\n _this10.tableData = res.data.tbBillList;\n });\n }), (0, _defineProperty2.default)(_methods, \"toDetail\", function toDetail(item) {\n this.orderId = item.id;\n this.selectedOrder = item.daa001;\n this.productCode = item.daa002; // 浜у搧缂栫爜\n this.productSpec = item.daa004; // 浜у搧瑙勬牸\n this.currentTab = 0;\n }), _methods),\n computed: {}\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 1)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/index.vue"],"names":["components","Technology","WorkOrder","WorkOrderPrint","Machine","Mold","UniTable","WorkOrderStatus","PDFShow","PrintInit","PrintTest","EquipmentInspection","MoldRecord","data","orderStatus","currentTab","productCode","productSpec","machineList","machine","engineeringNoList","engineeringNoMapList","engineeringNo","machineNo","machineName","tableData","isShowTableData","created","uni","onLoad","onShow","methods","onRowClick","detail","index","resetAutoRedirectTimer","clearTimeout","title","icon","duration","checkForUpdate","url","content","success","downloadNewApk","plus","force","fail","refresh","getPrintInfo","mac","pdaMac","save","orderId","orderNo","orderSelect","editDate","item","getMacNew","tmp","str","cancel","formatDate","selectionChange","selectedItems","changeTab","onMachineChange","onEngineeringNoChange","getMachineList","getWomdaaIsShow","hasBindedCutter","order","isShowTab","status","statusArr","computed"],"mappings":";;;;;;;;AAmRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA,eAEA;EACAA;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;EACA;EACAC;IAAA;IACA;MACAC;MAAA;MACAC;MAEAC;MAAA;MACAC;MAAA;;MAEAC;MAEAC;MAEAC;MACAC;MACAC;MAEAC;MACAC;MAEAC;MACAC;IAAA,sDAEA,4DACA,oDACA,0DAEA,mDAEA,iEAGA,+DACA;EAEA;EACAC;IAEA;IACA;IACA;IACA;IACA;IACA;IACA;;IAEAC;IAEA;;IAEA;IACA;EAEA;EACAC;IACA;EACA;EACAC;IACA;IACA;EACA;EACAC;IACAC;MACA;MACA;MACA;QAAAC;UAAAC;QAAA;MAAA;MACA;MACA;IACA;IAEA;IACAC;MAAA;MACA;MACA;QACAC;QACA;MACA;;MAEA;MACA;QACA;UACA;UACA;UACA;UACAR;YACAS;YACAC;YACAC;UACA;QACA;MACA;IACA;IACAC;MAAA;MACA;QACAC;QACA5B;MACA;QAEA;QACA;;QAEA;UACAe;YACAS;YACAK;YACAC;cACA;gBACA;cACA;YACA;UACA;UACA;UACA;UACA;UACA;QACA;MACA;IAEA;IAEAC;MACAhB;QACAS;QACAC;QACAC;MACA;MAEAX;QACAa;QACAE;UACA;YACAE;cACAC;YACA;cACA;cACA;cACA;cACA;YACA;cACA;YACA;UACA;QACA;QACAC;UACA;UACAnB;YACAS;YACAC;YACAC;UACA;QACA;MACA;IACA;IAEAS;MACA;MACA;MACA;IACA;IACAC;MAAA;MACA;MAEAC;MACA;QACAT;QACA5B;UACAsC;QACA;MACA;QACA;QACA;QACA;QAEAvB;QACAA;QAEA;QAEA;MACA;MACA;;MAGA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;;MAEA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;;MAEA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;;MAEA;MACA;;MAGA;;MAEA;MACA;IACA;IACAwB;MAAA;MACA;MAEA;QACA;QACA;MACA;MAEA;QACA;QACA;MACA;;MAEA;;MAEA;MACA;MACA;MACA;MACA;MACA;;MAEA;MAEAvC;QACA;UACAwC;UACAC;QACA;QACAC;MACA;MAEA;MAEA;QACAd;QACA5B;UACAU;UACAiC;UACAC;QACA;MACA;QACA;UACA;UACA7B;YACAS;YACA;YACA;YACAC;YACA;YACAC;UACA;QACA;QACA;MACA;IAEA;IACAmB;MACA;MACA;QACA;UACA;UACA;UACA;;UAEA;UACA;YACA;YACA;YACA;cACAC;YACA;cACAA;YACA;YACA;cACAA;YACA;YACAC;UACA;QACA;MACA;QACAA;MACA;MACA;IACA;IAEAC;MAAA;MACA;QACA;MACA;;MAEA;MACA;QACAjC;UACAS;UACAC;UACAC;QACA;QACA;MACA;MAEA;MACA;MAEA;QACAE;QACA5B;UACAU;UACAiC;QACA;MACA;QACA;UACA;QACA;MACA;IACA;IAEAM;MACA;MACA;MACA;MACA;IACA;IACAC;MACA;MACA;IACA;IAEAC;MAAA;MACA;QAAA;MAAA;IACA;IAGAC;MACA;MACA;MACA;QACA;MACA;MACA;MACA;MACA;IACA;IACAC;MAEA;MAEA;MAEAtC;MAEAA;MACAA;MAEA;IACA;IACAuC;MAEA;MAEA;MAEA;IAEA;IACAC;MAAA;MACA;QACA3B;MACA;QACA;QACA;UAAA;QAAA;MACA;IACA;IACA;IACA4B;MAAA;MACA;QACA5B;QACA5B;UACAU;QACA;MACA;QACA;;QAEA;QACA;QACA;QACA;UACA+C,kBACAC,+DACAA,wDACAA;QACA;QACA;QACA;QAEA;UACA3C;UACAA;QACA;MACA;IACA;IAEA4C;MACA;QACA5C;UACAS;UACAC;UACAC;QACA;QACA;MACA;MAEA;MACA;MACA;MACA;MACA;MACA,6BACA,cACA,MACA,KACA;MACA;MACA;IACA;EAAA,mGAEAkC;IACA;IACA;EACA,8EACA;IAAA;IAEA;IAEA;MACAhC;MACA5B;QACAU;QACAiC;MACA;IACA;MACA;IACA;EACA,8FAEA;IAAA;IACA;IACA;IACA;MACAkB;IACA;MACAA;IACA;IACA;MACAjC;MACA5B;QACAU;QACAT;QACA0C;MACA;IACA;MACA;IACA;EACA,0EACAC;IACA;IACA;IACA;IACA;IACA;EACA,aACA;EACAkB;AACA;AAAA,2B","file":"52.js","sourcesContent":["<template>\r\n\r\n\t<view>\r\n\t\t<view class=\"tab-bar\">\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 7 }\" @click=\"changeTab(7)\">\r\n\t\t\t\t工单选择\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 0 }\" @click=\"changeTab(0)\">\r\n\t\t\t\t主界面\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 2 }\" @click=\"changeTab(2)\">\r\n\t\t\t\t上刀下刀\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 3 }\" @click=\"changeTab(3)\">\r\n\t\t\t\t调机送检\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 10 }\" @click=\"changeTab(10)\">\r\n\t\t\t\t上下刀/首检单记录\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 4 }\" @click=\"changeTab(4)\">\r\n\t\t\t\t生产报工\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 1 }\" @click=\"changeTab(1)\">\r\n\t\t\t\t开工完工\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 5 }\" @click=\"changeTab(5)\">\r\n\t\t\t\te-SOP\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 6 }\" @click=\"changeTab(6)\">\r\n\t\t\t\t工艺参数\r\n\t\t\t</view>\r\n\t\t\t<view class=\"tab-item\" :class=\"{ active: currentTab === 9 }\" @click=\"changeTab(9)\">\r\n\t\t\t\t设备点检\r\n\t\t\t</view>\r\n\t\t\t<!-- <view class=\"tab-item\" :class=\"{ active: currentTab === 8 }\" @click=\"changeTab(8)\">\r\n\t\t\t打印机设置\r\n\t\t</view> -->\r\n\r\n\t\t</view>\r\n\t\t<view class=\"font\"></view>\r\n\t\t<scroll-view class=\"content\">\r\n\t\t\t<view v-if=\"currentTab === 7\" class=\"tab-content\">\r\n\t\t\t\t<view class=\"content\">\r\n\t\t\t\t\t<!--<view class=\"top-right\">\r\n\t\t\t\t\t\t<button class=\"refresh-btn\" @click=\"refresh\">刷新</button>\r\n\t\t\t\t\t</view>-->\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<h4>一台机台只能选择一条工单（多选默认为最后一条）</h4>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view class=\"section top-section\">\r\n\t\t\t\t\t\t<view class=\"form-row align-row\">\r\n\t\t\t\t\t\t\t<input v-model=\"machineName\"\r\n\t\t\t\t\t\t\t\t   disabled=\"true\"\r\n\t\t\t\t\t\t\t\t   type=\"text\"\r\n\t\t\t\t\t\t\t\t   class=\"machine-name-box\" />\r\n\t\t\t\t\t\t\t<view class=\"form-group\">\r\n\t\t\t\t\t\t\t\t<label class=\"order-label\">第一步选择工单:</label>\r\n\t\t\t\t\t\t\t\t<button class=\"print-btn\" @click=\"isShowTab\">选择工单</button>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"top-right\">\r\n\t\t\t\t\t\t\t\t<button class=\"refresh-btn\" @click=\"refresh\">刷新</button>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\r\n\t\t\t\t\t<!--          &lt;!&ndash; 中部：运行状态-->\r\n\t\t\t\t\t<view class=\"section card\">\r\n\t\t\t\t\t\t<uni-table border stripe emptyText=\"暂无更多数据\" @selection-change=\"selectionChange\">\r\n\t\t\t\t\t\t\t<uni-tr>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 100px;\">工序</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 170px;\">工单号</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 150px;\">产品编码</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 190px;\">产品名称</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 190px;\">规格</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 80px;\">已生产数量</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 80px;\">未生产数量</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 80px;\">派工数量</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 80px;\">工单数量</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 90px;\">工单状态</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 90px;\">报工人</uni-th>\r\n\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 90px;\">选择</uni-th>\r\n\t\t\t\t\t\t\t</uni-tr>\r\n\t\t\t\t\t\t\t<uni-tr v-for=\"(item, index) in isShowTableData\" :key=\"index\">\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.procName\" /><!--工序-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa001 }}</div><!--工单号-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa002 }}</div><!--产品编码-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa003 }}</div><!--产品名称-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa004 }}</div><!--规格-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa011\" /><!--已生产数量-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" :value=\"(item.daa008 || 0) - (item.daa011 || 0)\" /><!--未生产数量-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa008\" /><!--派工数量-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t                        <input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa008\" /><!--工单数量-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa018\" /><!--工单状态-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.staffName\" /><!--报工人-->\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t<uni-td>\r\n\t\t\t\t\t\t\t\t\t<view class=\"uni-group\">\r\n\t\t\t\t\t\t\t\t\t\t<button class=\"select-btn\" type=\"default\" @click=\"toDetail(item)\">\r\n\t\t\t\t\t\t\t\t\t\t\t转到主界面\r\n\t\t\t\t\t\t\t\t\t\t</button>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t</uni-tr>\r\n\t\t\t\t\t\t</uni-table>\r\n\t\t\t\t\t</view>\r\n\r\n\t\t\t\t\t<view class=\"bottom-section\">\r\n\t\t\t\t\t\t<button class=\"cancel-btn\" @click=\"cancel\">清空重选</button>\r\n\t\t\t\t\t</view>\r\n\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<!--<text style=\"color: red;\">\r\n\t\t\t\t\t\t说明:只能同时开工一个工单。选择完成，点击保存选择。系统保留选中的工单。\r\n\t\t\t\t\t\t如果要重选，点击清空重选功能。\r\n\t\t\t\t\t</text>-->\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 0\" class=\"tab-content\">\r\n\t\t\t\t<WorkOrder :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\"\r\n\t\t\t\t\t\t   :deviceNumber=\"machineName\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 1\" class=\"tab-content\">\r\n\t\t\t\t<!--        &lt;!&ndash; 调用 WorkOrderStatus 组件 &ndash;&gt;-->\r\n\t\t\t\t<WorkOrderStatus :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 2\" class=\"tab-content\">\r\n\t\t\t\t<!--        &lt;!&ndash; 调用 mold 组件 &ndash;&gt;-->\r\n\t\t\t\t<mold :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 3\" class=\"tab-content\">\r\n\t\t\t\t<!--        &lt;!&ndash; 调用 mold 组件 &ndash;&gt;-->\r\n\t\t\t\t<machine :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 10\" class=\"tab-content\">\r\n\t\t\t\t<!-- 调用 moldRecord 组件 -->\r\n\t\t\t\t<MoldRecord :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 4\" class=\"tab-content\">\r\n\t\t\t\t<!--  调用 mold 组件 -->\r\n\t\t\t\t<WorkOrderPrint :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 8\" class=\"tab-content\">\r\n\t\t\t\t<!-- 调用 mold 组件 -->\r\n\t\t\t\t<PrintInit :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 5\" class=\"tab-content\">\r\n\t\t\t\t<PDFShow :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 6\" class=\"tab-content\">\r\n\t\t\t\t<Technology :orderId=\"orderId\" :orderNo=\"selectedOrder\" :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t\t<view v-if=\"currentTab === 9\" class=\"tab-content\">\r\n\t\t\t\t<!-- 设备点检视图 -->\r\n\t\t\t\t<EquipmentInspection :machineNo=\"machineNo\" />\r\n\t\t\t</view>\r\n\t\t</scroll-view>\r\n\r\n\r\n\t\t<!-- 弹窗下拉框只显示工单状态 -->\r\n\t\t<view v-if=\"isShow\" class=\"overlay\">\r\n\t\t\t<view class=\"popup\">\r\n\t\t\t\t<view class=\"form-row\">\r\n\t\t\t\t\t<view style=\"display: flex; align-items: center;\">\r\n\t\t\t\t\t\t<label style=\"float: left;margin-top: 18px;font-size: 22px;\">点击按钮筛选工单状态:</label>\r\n\t\t\t\t\t\t<superwei-combox :candidates=\"engineeringNoMapList\" placeholder=\"请选择\" v-model=\"engineeringNo\"\r\n\t\t\t\t\t\t\t\t\t\t @select=\"onEngineeringNoChange\" class=\"picker\"\r\n\t\t\t\t\t\t\t\t\t\t style=\"padding: 7px 46px;width: 650px;\"></superwei-combox>\r\n\t\t\t\t\t\t<span style=\"margin-left: 20px; color: #ff6600; font-size: 18px;\">多选时只保留最后一条工单</span>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\r\n\t\t\t\t<div style=\"height: 450px; overflow: auto;\"> <!-- 调整高度为380px，为底部按钮留出更多空间 -->\r\n\t\t\t\t\t<table>\r\n\r\n\t\t\t\t\t\t<view class=\"section card\">\r\n\t\t\t\t\t\t\t<uni-table ref=\"table\" type=\"selection\" border stripe emptyText=\"暂无更多数据\"\r\n\t\t\t\t\t\t\t\t\t   class=\"large-selection-table\" @selection-change=\"selectionChange\">\r\n\t\t\t\t\t\t\t\t<uni-tr>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 100px;\">工序</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 200px;\">工单号</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 150px;\">产品编码</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 240px;\">产品名称</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 200px;\">规格</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 150px;\">已生产数量</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 150px;\">未生产数量</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 150px;\">派工数量</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 150px;\">工单数量</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 90px;\">工单状态</uni-th>\r\n\t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 90px;\">报工人</uni-th>\r\n<!-- \t\t\t\t\t\t\t\t\t<uni-th align=\"center\" class=\"th\" style=\"width: 126px;\">选择</uni-th> -->\r\n\t\t\t\t\t\t\t\t</uni-tr>\r\n\t\t\t\t\t\t\t\t<uni-tr v-for=\"(item, index) in tableData\"\r\n\t\t\t\t\t\t\t\t\t\t:key=\"index\"\r\n\t\t\t\t\t\t\t\t\t\t:class=\"{'row-selected': selectedIndexs.includes(index)}\"\r\n\t\t\t\t\t\t\t\t\t\t@click=\"onRowClick(index)\"\r\n\t\t\t\t\t\t\t\t\t\tstyle=\"cursor: pointer;\">\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.procName\" /><!--工序-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa001 }}</div>\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa002 }}</div>\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa003 }}</div>\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<div class=\"form-input\">{{ item.daa004 }}</div><!--规格-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa011\" /><!--已生产数量-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" :value=\"(item.daa008 || 0) - (item.daa011 || 0)\" /><!--未生产数量-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa008\" /><!--派工数量-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t                            <input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa008\" /><!--工单数量-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.daa018\" /><!--工单状态-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td align=\"center\">\r\n\t\t\t\t\t\t\t\t\t\t<input class=\"form-input\" disabled=\"true\" type=\"text\" v-model=\"item.staffName\" /><!--报工人-->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t\t<uni-td>\r\n<!-- \t\t\t\t\t\t\t\t\t\t<view class=\"uni-group\">\r\n\t\t\t\t\t\t\t\t\t\t\t<button class=\"select-btn\" type=\"default\" @click=\"toDetail(item)\">\r\n\t\t\t\t\t\t\t\t\t\t\t\t转到主界面\r\n\t\t\t\t\t\t\t\t\t\t\t</button>\r\n\t\t\t\t\t\t\t\t\t\t</view> -->\r\n\t\t\t\t\t\t\t\t\t</uni-td>\r\n\t\t\t\t\t\t\t\t</uni-tr>\r\n\t\t\t\t\t\t\t</uni-table>\r\n\t\t\t\t\t\t</view>\r\n\r\n\t\t\t\t\t</table>\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<view class=\"bottom-section\">\r\n\t\t\t\t\t<button class=\"save-btn\" @click=\"save\">保存选择</button>\r\n\t\t\t\t\t<button class=\"cancel-btn\" @click=\"isShow = !isShow\">取消</button>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t</view>\r\n</template>\r\n\r\n<script>\r\nimport WorkOrderStatus from '../components/WorkOrderStatus.vue'; // 确保路径正确\r\nimport UniTable from \"../uni_modules/uni-table/components/uni-table/uni-table.vue\";\r\nimport Mold from \"../components/mold.vue\";\r\nimport Machine from \"../components/machine.vue\";\r\nimport WorkOrderPrint from \"../components/WorkOrderPrint.vue\";\r\nimport WorkOrder from \"../components/WorkOrder.vue\";\r\nimport Technology from \"../components/Technology.vue\";\r\nimport PDFShow from \"../components/PDFShow.vue\";\r\nimport PrintInit from \"../components/PrintInit.vue\";\r\nimport PrintTest from \"../components/PrintTest.vue\";\r\nimport EquipmentInspection from \"../components/EquipmentInspection.vue\";\r\nimport MoldRecord from \"../pages/moldRecord.vue\";\r\n\r\n\texport default {\r\n\t\tcomponents: {\r\n\t\t\tTechnology,\r\n\t\t\tWorkOrder,\r\n\t\t\tWorkOrderPrint,\r\n\t\t\tMachine,\r\n\t\t\tMold,\r\n\t\t\tUniTable,\r\n\t\t\tWorkOrderStatus,\r\n\t\t\tPDFShow,\r\n\t\t\tPrintInit,\r\n\t\t\tPrintTest,\r\n\t\t\tEquipmentInspection,\r\n\t\t\tMoldRecord\r\n\t\t},\r\n\t\tdata() {\r\n\t\t\treturn {\r\n                orderStatus: '', // 默认全部\r\n\t\t\t\tcurrentTab: 7,\r\n\r\n                productCode: '', // 产品编码\r\n                productSpec: '', // 产品规格\r\n\r\n\t\t\t\tmachineList: [],\r\n\r\n\t\t\t\tmachine: [],\r\n\r\n\t\t\t\tengineeringNoList: [],\r\n\t\t\t\tengineeringNoMapList: [],\r\n\t\t\t\tengineeringNo: '',\r\n\r\n\t\t\t\tmachineNo: '',\r\n\t\t\t\tmachineName: '',\r\n\r\n\t\t\t\ttableData: [],\r\n\t\t\t\tisShowTableData: [],\r\n\r\n\t\t\t\torderStatus: '开工',\r\n\t\t\t\tselectedOrder: '',\r\n\t\t\t\torderId: 0,\r\n\r\n\t\t\t\tselectedIndexs: [],\r\n\r\n\t\t\t\tisShow: false,\r\n\t\t\t\t\r\n\t\t\t\t// 自动跳转相关\r\n\t\t\t\tautoRedirectTimer: null,\r\n\t\t\t\tautoRedirectTime: 5 * 60 * 1000, // 5分钟\r\n\t\t\t};\r\n\t\t},\r\n\t\tcreated() {\r\n\r\n\t\t\t//调试使用的代码\r\n\t\t\t// this.machineNo = uni.getStorageSync('machineNo');\r\n\t\t\t// this.machineName = uni.getStorageSync('machineName');\r\n\t\t\t//\r\n\t\t\t// if (this.machineNo) {\r\n\t\t\t//   this.getWomdaaIsShow();\r\n\t\t\t// }\r\n\r\n\t\t\tuni.clearStorageSync();\r\n\t\t\t\r\n\t\t\tthis.checkForUpdate();\r\n\t\t\t\r\n\t\t\t//工控机使用的代码\r\n\t\t\tthis.getPrintInfo();\r\n\t\t\t\r\n\t\t},\r\n\t\tonLoad(options) {\r\n\t\t\tthis.getMachineList();\r\n\t\t},\r\n\t\tonShow() {\r\n\t\t\tthis.refresh();\r\n\t\t\tthis.resetAutoRedirectTimer();\r\n\t\t},\r\n\t\tmethods: {\r\n            onRowClick(index) {\r\n                this.selectedIndexs = [index]; // 单选\r\n                // 手动触发 selectionChange 以同步复选框\r\n                this.selectionChange({ detail: { index } });\r\n                // 重置自动跳转计时器\r\n                this.resetAutoRedirectTimer();\r\n            },\r\n            \r\n            // 重置自动跳转计时器\r\n            resetAutoRedirectTimer() {\r\n                // 清除现有的定时器\r\n                if (this.autoRedirectTimer) {\r\n                    clearTimeout(this.autoRedirectTimer);\r\n                    this.autoRedirectTimer = null;\r\n                }\r\n                \r\n                // 除了主页(0)、工单选择页(7)、生产报工页(4)之外的页面才设置自动跳转\r\n                if (this.currentTab !== 0 && this.currentTab !== 7 && this.currentTab !== 4) {\r\n                    this.autoRedirectTimer = setTimeout(() => {\r\n                        // 跳转回主页\r\n                        this.currentTab = 0;\r\n                        // 显示提示信息\r\n                        uni.showToast({\r\n                            title: '页面超时，自动返回主页',\r\n                            icon: 'none',\r\n                            duration: 2000\r\n                        });\r\n                    }, this.autoRedirectTime);\r\n                }\r\n            },\r\n\t\t\tcheckForUpdate() {\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/DevMachine/getAppUpgradeInfo\",\r\n\t\t\t\t\tdata: {}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\t\r\n\t\t\t\t\tlet newVersion = res.data.version;\r\n\t\t\t\t\tlet currentVersion = uni.getSystemInfoSync(); // 获取当前 APK 版本号\r\n\t\t\t\t\t \r\n\t\t\t\t\tif (newVersion > currentVersion.appVersion) {\r\n\t\t\t\t\t\tuni.showModal({\r\n\t\t\t\t\t\t\ttitle: \"发现新版本\",\r\n\t\t\t\t\t\t\tcontent: \"是否下载最新版本?\",\r\n\t\t\t\t\t\t\tsuccess: (modalRes) => {\r\n\t\t\t\t\t\t\t\tif (modalRes.confirm) {\r\n\t\t\t\t\t\t\t\t\tthis.downloadNewApk(res.data.apkUrl);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\t//this.downloadNewApk(res.data.apkUrl);\r\n\t\t\t\t\t\tthis.updateChecked = true; // 标记更新已检查过\r\n\t\t\t\t\t\t//      // 如果有新版本，开始下载\r\n\t\t\t\t\t\t//download(res.data.apkUrl);\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t\t\r\n\t\t\t},\r\n\t\t\t\r\n\t\t\tdownloadNewApk(apkUrl) {\r\n\t\t\t\tuni.showToast({\r\n\t\t\t\t\ttitle: \"开始下载更新...\",\r\n\t\t\t\t\ticon: \"none\",\r\n\t\t\t\t\tduration: 2000\r\n\t\t\t\t});\r\n\t\t\t\r\n\t\t\t\tuni.downloadFile({\r\n\t\t\t\t\turl: apkUrl,\r\n\t\t\t\t\tsuccess: (res) => {\r\n\t\t\t\t\t\tif (res.statusCode === 200) {\r\n\t\t\t\t\t\t\tplus.runtime.install(res.tempFilePath, {\r\n\t\t\t\t\t\t\t\tforce: true\r\n\t\t\t\t\t\t\t}, function() {\r\n\t\t\t\t\t\t\t\tconsole.log(\"安装成功，重启应用\");\r\n\t\t\t\t\t\t\t\t//plus.runtime.restart();\r\n\t\t\t\t\t\t\t\t//plus.runtime.quit();\r\n\t\t\t\t\t\t\t\t// uni.navigateBack()\r\n\t\t\t\t\t\t\t}, function(e) {\r\n\t\t\t\t\t\t\t\tconsole.error(\"安装失败:\", e);\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t},\r\n\t\t\t\t\tfail: (err) => {\r\n\t\t\t\t\t\tconsole.error(\"下载失败:\", err);\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: \"下载失败，请检查网络\",\r\n\t\t\t\t\t\t\ticon: \"none\",\r\n\t\t\t\t\t\t\tduration: 2000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t},\r\n\t\t\t\r\n\t\t\trefresh() {\r\n\t\t\t\tthis.getMachineList();\r\n\t\t\t\tthis.getPrintInfo();\r\n\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t},\r\n\t\t\tgetPrintInfo() {\r\n\t\t\t\tvar mac = \"\";\r\n\t\t\t\t\r\n\t\t\t\tmac = \"74:24:ca:4f:b2:c3\";\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/DevMachine/GetDevMachineByPdaMac\",\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\tpdaMac: mac,\r\n\t\t\t\t\t}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tlet devMachine = res.data.tbBillList;\r\n\t\t\t\t\tthis.machineNo = devMachine.machineNo;\r\n                    this.machineName = \"调试模式：\" + this.machineNo + \"号齿轮机\"\r\n\r\n\t\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\r\n\t\t\t\t\tuni.setStorageSync('printMac', devMachine.printMac);\r\n\r\n\t\t\t\t\tconsole.log(devMachine.printMac);\r\n\r\n\t\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t\t});\r\n\t\t\t\treturn;\r\n\t\t\t\t\r\n\t\t\t\t\r\n\t//  \t\t\tif (plus.os.name == \"Android\") {\r\n\t//  \t\t\t\t//获取手机MAC地址\r\n\t//  \t\t\t\tvar Context = plus.android.importClass(\"android.content.Context\");\r\n\t//  \t\t\t\tvar WifiManager = plus.android.importClass(\"android.net.wifi.WifiManager\");\r\n\t//  \t\t\t\tvar wifiManager = plus.android.runtimeMainActivity().getSystemService(Context.WIFI_SERVICE);\r\n\t//  \t\t\t\tvar WifiInfo = plus.android.importClass(\"android.net.wifi.WifiInfo\");\r\n\t//  \t\t\t\tvar wifiInfo = wifiManager.getConnectionInfo();\r\n\t//  \t\t\t\tmac = wifiInfo.getMacAddress();\r\n\t\t\t\t\t\r\n\t//  \t\t\t\t//如果mac为“02:00:00:00:00:00”，则可能是安卓6.0以上版本，则使用另一种方法获取mac地址\r\n\t//  \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\r\n\t//  \t\t\t\t\tmac = this.getMacNew();\r\n\t//  \t\t\t\t}\r\n\t//  \t\t\t\t//如果mac使用新方法依然是“02:00:00:00:00:00”则不进行保存\r\n\t//  \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\r\n\t//  \t\t\t\t\treturn;\r\n\t//  \t\t\t\t}\r\n\t//  \t\t\t\tuni.setStorageSync('pdaMac', mac);\r\n\r\n\t//  \t\t\t\tthis.$post({\r\n\t//  \t\t\t\t\turl: \"/DevMachine/GetDevMachineByPdaMac\",\r\n\t//  \t\t\t\t\tdata: {\r\n\t//  \t\t\t\t\t\tpdaMac: mac,\r\n\t//  \t\t\t\t\t}\r\n\t//  \t\t\t\t}).then(res => {\r\n\t//  \t\t\t\t\tlet devMachine = res.data.tbBillList;\r\n\t//  \t\t\t\t\tthis.machineNo = devMachine.machineNo;\r\n\t//  \t\t\t\t\tthis.machineName = \"当前机台：\" + this.machineNo + \"号齿轮机\";\r\n\r\n\t//  \t\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\r\n\t//  \t\t\t\t\tuni.setStorageSync('printMac', devMachine.printMac);\r\n \r\n\r\n\t//  \t\t\t\t\tthis.getWomdaaIsShow();\r\n\r\n\t//  \t\t\t\t});\r\n\t//  \t\t\t}\r\n\t\t\t},\r\n\t\t\tsave() {\r\n\t\t\t\tlet data = this.selectedItems();\r\n\r\n\t\t\t\tif (data.length === 0) {\r\n                    this.$showMessage(\"请选择一个工单\");\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n                if (data.length > 1) {\r\n                    this.$showMessage(\"一次只能选取一个工单\");\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t//let firstValue = data[0][\"moldId\"]; // 获取第一个对象的指定属性值\r\n\r\n\t\t\t\t//// 使用 every 方法检查所有对象的该属性值是否一致\r\n\t\t\t\t//let flag = data.every(item => item[\"moldId\"] === firstValue);\r\n\t\t\t\t//if (!flag) {\r\n\t\t\t\t//\tthis.$showMessage(\"选取的\" + data.length + \"个工单中的模具编号不一致\");\r\n\t\t\t\t//\treturn;\r\n\t\t\t\t//}\r\n\r\n\t\t\t\tlet orderSelect = [];\r\n\r\n\t\t\t\tdata.forEach(s => {\r\n\t\t\t\t\tlet entity = {\r\n\t\t\t\t\t\torderId: s.id,\r\n\t\t\t\t\t\torderNo: s.daa001,\r\n\t\t\t\t\t}\r\n\t\t\t\t\torderSelect.push(entity);\r\n\t\t\t\t});\r\n\r\n\t\t\t\tlet editDate = this.formatDate(new Date());\r\n\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/MesOrderSelect/Add\",\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\tmachineNo: this.machineNo,\r\n\t\t\t\t\t\teditDate: editDate,\r\n\t\t\t\t\t\titem: orderSelect\r\n\t\t\t\t\t}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tif (res.data.tbBillList) {\r\n\t\t\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t\t\t\tuni.showToast({\r\n                            title: '保存工单成功',\r\n\t\t\t\t\t\t\t//title: '将注塑机开合模数清0',\r\n\t\t\t\t\t\t\t//将值设置为 success 或者直接不用写icon这个参数\r\n\t\t\t\t\t\t\ticon: 'success',\r\n\t\t\t\t\t\t\t//显示持续时间为 5秒\r\n\t\t\t\t\t\t\tduration: 5000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.isShow = false;\r\n\t\t\t\t})\r\n\r\n\t\t\t},\r\n\t\t\tgetMacNew() {\r\n\t\t\t\tvar str = \"\";\r\n\t\t\t\ttry {\r\n\t\t\t\t\tif (plus.os.name == \"Android\") {\r\n\t\t\t\t\t\tvar NetworkInterface = plus.android.importClass(\"java.net.NetworkInterface\");\r\n\t\t\t\t\t\tvar networkInterface = NetworkInterface.getByName(\"wlan0\");\r\n\t\t\t\t\t\tvar bytes = networkInterface.getHardwareAddress();\r\n\t\t\t\r\n\t\t\t\t\t\t//将byte[] 转换成 String\r\n\t\t\t\t\t\tfor (var i = 0; i < bytes.length; i++) {\r\n\t\t\t\t\t\t\tvar tmp = \"\";\r\n\t\t\t\t\t\t\tvar num = bytes[i];\r\n\t\t\t\t\t\t\tif (num < 0) {\r\n\t\t\t\t\t\t\t\ttmp = (255 + num + 1).toString(16);\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\ttmp = num.toString(16);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tif (tmp.length == 1) {\r\n\t\t\t\t\t\t\t\ttmp = \"0\" + tmp;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tstr += (i == 0) ? (tmp) : (\":\" + tmp);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t} catch (err) {\r\n\t\t\t\t\tstr = \"02:00:00:00:00:00\";\r\n\t\t\t\t}\r\n\t\t\t\treturn str;\r\n\t\t\t},\r\n\r\n            cancel() {\r\n                if (!this.machineNo) {\r\n                    return;\r\n                }\r\n\r\n                // 直接用 flag 判断\r\n                if (this.hasBindedCutterFlag) {\r\n                    uni.showToast({\r\n                        title: '当前工单已绑定刀具，不能清空重选',\r\n                        icon: 'error',\r\n                        duration: 2000\r\n                    });\r\n                    return;\r\n                }\r\n\r\n                let editDate = this.formatDate(new Date());\r\n                this.selectedIndexs = [];\r\n\r\n                this.$post({\r\n                    url: \"/MesOrderSelect/Remove\",\r\n                    data: {\r\n                        machineNo: this.machineNo,\r\n                        editDate: editDate\r\n                    },\r\n                }).then(res => {\r\n                    if (res.data.tbBillList > 0) {\r\n                        this.isShowTableData = [];\r\n                    }\r\n                });\r\n            },\r\n\r\n\t\t\tformatDate(date) {\r\n\t\t\t\tlet year = date.getFullYear(); // 获取年份\r\n\t\t\t\tlet month = String(date.getMonth() + 1).padStart(2, '0'); // 获取月份并补零\r\n\t\t\t\tlet day = String(date.getDate()).padStart(2, '0'); // 获取日期并补零\r\n\t\t\t\treturn `${year}-${month}-${day}`; // 返回格式化后的字符串\r\n\t\t\t},\r\n\t\t\tselectionChange(e) {\r\n                // 单选直接赋值\r\n                this.selectedIndexs = [e.detail.index];\r\n\t\t\t},\r\n\r\n\t\t\tselectedItems() {\r\n\t\t\t\treturn this.selectedIndexs.map(i => this.tableData[i])\r\n\t\t\t},\r\n\r\n\r\n\t\t\tchangeTab(index) {\r\n\t\t\t\tthis.currentTab = index;\r\n\t\t\t\t// 当切换到工单选择页面(index === 7)时自动刷新\r\n\t\t\t\tif (index === 7) {\r\n\t\t\t\t\tthis.refresh();\r\n\t\t\t\t}\r\n\t\t\t\t// 重置自动跳转计时器\r\n\t\t\t\tthis.resetAutoRedirectTimer();\r\n\t\t\t\tconsole.log(index);\r\n\t\t\t},\r\n\t\t\tonMachineChange(event) {\r\n\r\n\t\t\t\tthis.machineName = event;\r\n\r\n\t\t\t\tthis.machineNo = this.machine[this.machineList.indexOf(event)].machineNo;\r\n\r\n\t\t\t\tuni.clearStorageSync();\r\n\r\n\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\r\n\t\t\t\tuni.setStorageSync('machineName', this.machineName);\r\n\r\n\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t},\r\n\t\t\tonEngineeringNoChange(event) {\r\n\r\n\t\t\t\tlet orde = this.engineeringNoList[this.engineeringNoMapList.indexOf(event)];\r\n\r\n\t\t\t\tthis.engineeringNo = orde.moldId;\r\n\r\n\t\t\t\tthis.getWomdaa();\r\n\r\n\t\t\t},\r\n\t\t\tgetMachineList() {\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/MesMachine/GetInjectionMachine\",\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tthis.machine = res.data.tbBillList;\r\n\t\t\t\t\tthis.machineList = this.machine.map(s => s.machineName);\r\n\t\t\t\t})\r\n\t\t\t},\r\n            //获取表格的数据源\r\n            getWomdaaIsShow() {\r\n                this.$post({\r\n                    url: \"/Womdaa/GetWomdaasByShow\",\r\n                    data: {\r\n                        machineNo: this.machineNo,\r\n                    }\r\n                }).then(res => {\r\n                    this.isShowTableData = res.data.tbBillList;\r\n\r\n                    // 只判断第一条（只允许一条工单）\r\n                    const order = this.isShowTableData[0];\r\n                    let hasBindedCutter = false;\r\n                    if (order) {\r\n                        hasBindedCutter =\r\n                            (order.outToolId && order.outToolId.toString().trim() !== '') ||\r\n                            (order.outToolCode && order.outToolCode.trim() !== '') ||\r\n                            (order.outToolName && order.outToolName.trim() !== '');\r\n                    }\r\n                    // 存储到 data 变量\r\n                    this.hasBindedCutterFlag = hasBindedCutter;\r\n\r\n                    if (this.isShowTableData.length == 1) {\r\n                        uni.setStorageSync('daa001', this.isShowTableData[0].daa001);\r\n                        uni.setStorageSync('id', this.isShowTableData[0].id);\r\n                    }\r\n                });\r\n            },\r\n\r\n            isShowTab() {\r\n                if (this.isShowTableData.length > 0) {\r\n                    uni.showToast({\r\n                        title: '已有正在操作的工单，不能再次选择',\r\n                        icon: 'error',\r\n                        duration: 2000\r\n                    });\r\n                    return;\r\n                }\r\n\r\n                this.isShow = true;\r\n                // 默认选中“待开工”\r\n                this.engineeringNo = '待开工、未开工、暂停';\r\n                this.tableData = [];\r\n                // 下拉框只显示合并后的状态和其它状态\r\n                this.engineeringNoMapList = [\r\n                    '待开工、未开工、暂停',\r\n                    '开工',\r\n                    '完工'\r\n                ];\r\n                // 默认显示“待开工”工单\r\n                this.getWomdaaByStatus();\r\n            },\r\n            // 下拉框选中后，按状态筛选工单\r\n            onEngineeringNoChange(status) {\r\n                this.engineeringNo = status;\r\n                this.getWomdaaByStatus();\r\n            },\r\n\t\t\tgetWomdaa() {\r\n\r\n\t\t\t\tlet editDate = this.formatDate(new Date());\r\n\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/Womdaa/GetWomdaasByMachine\",\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\tmachineNo: this.machineNo,\r\n\t\t\t\t\t\teditDate: editDate\r\n\t\t\t\t\t}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tthis.tableData = res.data.tbBillList;\r\n\t\t\t\t})\r\n\t\t\t},\r\n            // 按工单状态筛选工单\r\n            getWomdaaByStatus() {\r\n                let editDate = this.formatDate(new Date());\r\n                let statusArr = [];\r\n                if (this.engineeringNo === '待开工、未开工、暂停') {\r\n                    statusArr = ['待开工', '未开工', '暂停'];\r\n                } else {\r\n                    statusArr = [this.engineeringNo];\r\n                }\r\n                this.$post({\r\n                    url: \"/Womdaa/GetWomdaasByEngineeringNo\",\r\n                    data: {\r\n                        machineNo: this.machineNo,\r\n                        orderStatus: statusArr,\r\n                        editDate: editDate\r\n                    }\r\n                }).then(res => {\r\n                    this.tableData = res.data.tbBillList;\r\n                });\r\n            },\r\n\t\t\ttoDetail(item) {\r\n\t\t\t\tthis.orderId = item.id;\r\n\t\t\t\tthis.selectedOrder = item.daa001;\r\n                this.productCode = item.daa002; // 产品编码\r\n                this.productSpec = item.daa004; // 产品规格\r\n\t\t\t\tthis.currentTab = 0;\r\n\t\t\t}\r\n\t\t},\r\n\t\tcomputed: {}\r\n\t};\r\n</script>\r\n\r\n<style lang=\"scss\">\r\n\r\n    :deep(.checkbox),\r\n    :deep(.checkbox__inner) {\r\n        width: 60px !important;\r\n        height: 60px !important;\r\n        min-width: 60px !important;\r\n        min-height: 60px !important;\r\n        padding: 16px !important;\r\n        margin-right: 20px !important;\r\n    }\r\n\r\n    .popup .large-selection-table {\r\n        width: 100% !important;\r\n        table-layout: auto !important; // 让表格自动分配宽度\r\n    }\r\n\r\n    .row-selected {\r\n        background-color: #e0f3ff !important;\r\n    }\r\n\r\n\t.font {\r\n\t\tbackground-color: #666666;\r\n\t\theight: 30px;\r\n\t\twidth: 100vw;\r\n\t}\r\n\r\n\r\n\t/* 上部区域样式，左70% 右30% */\r\n\t.top-section {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-around;\r\n\t\tmargin-bottom: 20px;\r\n\t\tpadding: 20px 10px;\r\n\t\tflex-direction: row;\r\n\t\tflex-wrap: wrap;\r\n\t\talign-content: center;\r\n\t\talign-items: stretch;\r\n\t\t/* 增加上下的padding */\r\n\t}\r\n\r\n\t.right-side {\r\n\t\tbackground-color: #f3f3f3;\r\n\t\tpadding: 16px;\r\n\t\ttext-align: center;\r\n\t\tborder-radius: 8px;\r\n\t\twidth: 25%;\r\n\t\tfont-size: 14px;\r\n\t}\r\n\r\n\t.form-row {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-between;\r\n\t\tmargin-bottom: 1.2vh;\r\n\t}\r\n\r\n\t.form-item {\r\n\t\twidth: 30%;\r\n\t}\r\n\r\n\t.inp {\r\n\t\twidth: 90%;\r\n\t\tpadding: 4px;\r\n\t\tborder: 1px solid #ccc;\r\n\t\tborder-radius: 4px;\r\n\t\tmargin-top: 4px;\r\n\t}\r\n\r\n\t.status-block {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t\talign-items: center;\r\n\t}\r\n\r\n\t.status-block p {\r\n\t\tmargin: 8px 0;\r\n\t\tfont-size: 16px;\r\n\t\tfont-weight: bold;\r\n\t}\r\n\r\n\t.left-side {\r\n\t\twidth: 65%;\r\n\t}\r\n\r\n\t.table-row {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-between;\r\n\t\tpadding: 8px;\r\n\t\tborder: 1px solid #000000;\r\n\t\tfont-size: 20px;\r\n\t\tfont-weight: bold;\r\n\t}\r\n\r\n\t.table-cell {\r\n\t\twidth: 50%;\r\n\t\ttext-align: center;\r\n\t}\r\n\r\n\t/* 卡片样式 */\r\n    .card {\r\n        background-color: #fff;\r\n        border-radius: 10px;\r\n        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);\r\n        padding: 0; // 去除多余内边距\r\n        position: relative;\r\n        margin-bottom: 25px;\r\n        width: 100%; // 填满父容器\r\n        box-sizing: border-box;\r\n    }\r\n\r\n/*    //.content {\r\n    //    flex: 1;\r\n    //    padding: 1vh 1vw; // 保证整体有左右留白\r\n    //    background-color: white;\r\n    //    font-size: 1.5vw;\r\n    //}*/\r\n\r\n\t/* 卡片标题在左上角 */\r\n\t.card-header {\r\n\t\tposition: absolute;\r\n\t\ttop: -10px;\r\n\t\tleft: 16px;\r\n\t\tbackground-color: #ffffff;\r\n\t\tpadding: 2px 8px;\r\n\t\tborder-radius: 4px;\r\n\t\tfont-weight: bold;\r\n\t}\r\n\r\n\t/* 中部区域，每行3个字段 */\r\n\t.status-row,\r\n\t.check-row {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-between;\r\n\t\tmargin-bottom: 10px;\r\n\t}\r\n\r\n\t.status-row label,\r\n\t.check-row label {\r\n\t\twidth: 30%;\r\n\t\tpadding-right: 10px;\r\n\t\ttext-align: right;\r\n\t}\r\n\r\n\t.status-row input,\r\n\t.check-row input {\r\n\t\twidth: 65%;\r\n\t}\r\n\r\n\t//基础样式\r\n\t.container {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t}\r\n\r\n\t.tab-bar {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-around;\r\n\t\tbackground-color: #f5f5f5;\r\n\t\tpadding: 1vh;\r\n\t\tpadding-top: 30px;\r\n\t\tborder-bottom: 1px solid #ccc;\r\n\t}\r\n\r\n\t.top-right {\r\n\t\tposition: absolute;\r\n\t\ttop: 10px;\r\n\t\tright: 50px;\r\n\t\tz-index: 1000;\r\n\t}\r\n\r\n\t.refresh-btn {\r\n\t\tpadding: 10px;\r\n\t\tbackground-color: #00A2E9;\r\n\t\tcolor: white;\r\n\t\tborder: none;\r\n\t\tfont-size: 22px;\r\n\t\tborder-radius: 5px;\r\n\t}\r\n\r\n\t.tab-item {\r\n\t\tflex: 1;\r\n\t\ttext-align: center;\r\n\t\tmargin-right: 0.5vw;\r\n\t\tpadding: 1vh;\r\n\t\tborder-radius: 0.5vw;\r\n\t\tbackground-color: #fff;\r\n\t\tcolor: #007aff;\r\n\t\tcursor: pointer;\r\n\t\tfont-size: 22px;\r\n\t\tfont-weight: 500;\r\n\t\ttransition: background-color 0.3s, color 0.3s;\r\n\t\tbox-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\r\n\t}\r\n\r\n\t.tab-item.active {\r\n\t\tbackground-color: #007aff;\r\n\t\tcolor: #fff;\r\n\t\tfont-weight: 600;\r\n\t\tbox-shadow: 0 4px 8px rgba(0, 122, 255, 0.3);\r\n\t}\r\n\r\n\t.content {\r\n\t\tflex: 1;\r\n\t\tpadding: 1vh 1vw;\r\n\t\tbackground-color: white;\r\n\t\tfont-size: 16px;\r\n\t}\r\n\r\n    .picker {\r\n        float: left;\r\n        margin-top: 7px;\r\n        margin-left: 10px;\r\n        text-align: center;\r\n        font-size: 32px !important; // 强制大字体，适配低密度\r\n        min-height: 60px; // 让选择框高度也变大\r\n        line-height: 60px;\r\n        padding: 5.5px 1px;\r\n        background-color: #fff; // 这里改为蓝色\r\n        border: 2px solid #007aff; // 边框也改为蓝色\r\n        color: #007aff; // 字体颜色改为白色，保证可读性\r\n        border-radius: 6px;\r\n        transition: background 0.2s;\r\n    }\r\n\r\n    .th {\r\n        background-color: white;\r\n        color: black;\r\n        height: 6vh;\r\n        font-size: 22px;\r\n        font-weight: 600;\r\n        border: 1px solid #555;\r\n        padding: 6px 8px;\r\n        text-align: center;\r\n        white-space: normal;\r\n        word-break: break-all;\r\n    }\r\n    \r\n    /* 主表格边框样式 */\r\n    uni-table {\r\n        border: 2px solid #d00 !important;\r\n        border-collapse: separate !important;\r\n        border-spacing: 0 !important;\r\n    }\r\n    \r\n    .uni-th, .uni-td {\r\n        border: 1px solid #555 !important;\r\n        position: relative !important;\r\n        z-index: 1 !important;\r\n    }\r\n\r\n    .form-input {\r\n        word-break: break-all;\r\n        white-space: normal;\r\n        line-height: 1.4;\r\n        text-align: center;\r\n        vertical-align: middle;\r\n        max-width: 180px;\r\n        overflow-wrap: break-word;\r\n        font-size: 22px;\r\n        padding: 6px 8px;\r\n        background-color: transparent; /* 设置背景为透明 */\r\n    }\r\n\r\n\t/* 底部保存和取消按钮 */\r\n    .bottom-section {\r\n        display: flex;\r\n        justify-content: space-around;\r\n        margin-bottom: 2vh;\r\n        padding: 2vh 1vw;\r\n        margin-top: 20px; // 减小顶部边距，确保按钮在弹窗内正确显示\r\n    }\r\n\r\n\t.save-btn,\r\n\t.cancel-btn {\r\n\t\twidth: 48%;\r\n\t\tpadding: 1.5vh;\r\n\t\tbackground-color: #00a2e9;\r\n\t\tcolor: white;\r\n\t\tfont-size: 22px;\r\n\t\tfont-weight: 500;\r\n\t\tborder: none;\r\n\t\ttext-align: center;\r\n\t\tcursor: pointer;\r\n\t\tborder-radius: 4px;\r\n\t\tbox-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\r\n\t\ttransition: all 0.3s;\r\n\t}\r\n\t\r\n\t.cancel-btn {\r\n\t\tbackground-color: #00A2E9;\r\n\t\tcolor: white;\r\n\t}\r\n\r\n    .overlay {\r\n        position: fixed;\r\n        top: 0;\r\n        left: 0;\r\n        width: 100%;\r\n        height: 100%;\r\n        background-color: rgba(0, 0, 0, 0.5);\r\n        display: flex;\r\n        justify-content: center;\r\n        align-items: center;\r\n        z-index: 2000; // 增加z-index，确保弹窗在刷新按钮之上\r\n    }\r\n\r\n    .popup {\r\n        background-color: #fff;\r\n        padding: 2vh 2vh 8vh 2vh; // 增加底部内边距，为按钮留出空间\r\n        border: 1px solid #ccc;\r\n        box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);\r\n        width: 90.16vw; // 原来的98vw缩小8% (98vw * 0.92)\r\n        height: 68vh; // 原来的85vh缩小20% (85vh * 0.8)\r\n        font-size: 1.6vw;\r\n        box-sizing: border-box; // 确保内边距不影响总尺寸\r\n    }\r\n\r\n\t.print-btn {\r\n\t\tfloat: left;\r\n\t\tmargin-top: 4px;\r\n\t\tmargin-left: 10px;\r\n\t\ttext-align: center;\r\n\t\tfont-size: 22px;\r\n\t\tcolor: white;\r\n\t\tbackground-color: #00A2E9;\r\n\t\tpadding: 0px 90px;\r\n\t\tborder: 2px solid #00A2E9;\r\n\t\tcursor: pointer;\r\n\t\tborder-radius: 0.8vw;\r\n\t}\r\n\r\n    .machine-name-box {\r\n        border: 2px solid #007aff; /* 蓝色边框 */\r\n        border-radius: 8px;\r\n        font-family: fantasy;\r\n        font-size: 33px;\r\n        margin-top: 20px;\r\n        padding: 15px 28px; /* 上下20px，左右48px，增加内边距 */\r\n        width: 300px; /* 更宽，保证内容完整显示 */\r\n        height: 70px; /* 增加高度 */\r\n        box-sizing: border-box;\r\n        background: #fff;\r\n        color: #222;\r\n        font-weight: bold;\r\n        text-align: left;\r\n        display: block;\r\n    }\r\n\r\n/*    //v-deep .checkbox {\r\n    //    padding: 10 10px;\r\n    //    width: 26px;\r\n    //    padding-left: 12px;\r\n    //    display: table-cell;\r\n    //    vertical-align: middle;\r\n    //    color: #333;\r\n    //    font-weight: 500;\r\n    //    border-bottom: 1px #ebeef5 solid;\r\n    //    font-size: 14px;\r\n    //}*/\r\n\r\n    .popup .card {\r\n        margin-bottom: 40px !important; // 原来250px，改为40px，空白明显减少\r\n    }\r\n\r\n\t@media screen and (max-width: 1920px) {\r\n\t\t.tab-item {\r\n\t\t\tfont-size: 22px;\r\n\t\t}\r\n\r\n\t\t.content {\r\n\t\t\tpadding: 1vw;\r\n\t\t\tfont-size: 22px;\r\n\t\t}\r\n\r\n\t\t.form-input {\r\n\t\t\tfont-size: 22px;\r\n\t\t}\r\n\t}\r\n\r\n    .uni-td,\r\n    td {\r\n        white-space: normal !important; // 允许自动换行\r\n        word-break: break-all !important; // 单词/中文都能断行\r\n        line-height: 1.4; // 行高适当，便于多行显示\r\n        text-align: center; // 居中显示（如需左对齐可改为 left）\r\n        vertical-align: middle; // 垂直居中\r\n        max-width: 180px; // 保持单元格最大宽度\r\n        overflow-wrap: break-word; // 兼容性更好\r\n        background-color: transparent; /* 设置背景为透明 */\r\n    }\r\n\r\n    // 弹窗内表格样式与生产报工页面历史报工记录表格一致\r\n    .popup .large-selection-table .uni-th,\r\n    .popup .large-selection-table .uni-td {\r\n        padding: 6px 8px;\r\n        text-align: center;\r\n        white-space: normal;\r\n        word-break: break-all;\r\n        font-size: 22px;\r\n        background-color: transparent; /* 设置背景为透明 */\r\n        border: 1px solid #555 !important;\r\n    }\r\n    \r\n    .popup .large-selection-table .uni-th {\r\n        background-color: white;\r\n        color: black;\r\n        font-weight: 600;\r\n        font-size: 22px;\r\n    }\r\n    \r\n    /* 弹窗表格外框线 */\r\n    .popup .large-selection-table {\r\n        border: 2px solid #d00 !important;\r\n        border-collapse: separate !important;\r\n        border-spacing: 0 !important;\r\n    }\r\n\r\n    .select-btn {\r\n        width: 150px; // 原来的70% (180px * 0.7)\r\n        height: 75px; // 原来的65% (80px * 0.65)\r\n        font-size: 22px; // 字体也略大\r\n        //font-weight: 200;\r\n        border-radius: 10px;\r\n        background-color: #00A2E9;\r\n        color: white;\r\n        border: 2px solid #00A2E9;\r\n        margin: 0 auto;\r\n        display: block;\r\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\r\n        transition: all 0.3s;\r\n    }\r\n\r\n    .top-section {\r\n        position: relative;\r\n        display: flex;\r\n        flex-direction: column;\r\n        margin-bottom: 20px;\r\n        padding: 20px 10px;\r\n    }\r\n\r\n    .form-row.align-row {\r\n        display: flex;\r\n        align-items: center;\r\n        justify-content: space-between;\r\n        position: relative;\r\n        width: 100%;\r\n    }\r\n\r\n    .machine-name-box {\r\n        flex: 1 1 45%;\r\n        margin-right: 20px;\r\n    }\r\n\r\n    .form-group {\r\n        display: flex;\r\n        align-items: center;\r\n        flex: 1 1 45%;\r\n        justify-content: flex-start;\r\n    }\r\n\r\n    .order-label {\r\n        font-family: fantasy;\r\n        font-size: 22px;\r\n        margin-top: 20px;\r\n        margin-right: 10px;\r\n        float: none;\r\n    }\r\n\r\n    .print-btn {\r\n        margin-top: 20px;\r\n    }\r\n\r\n    .top-right {\r\n        position: absolute;\r\n        top: -30px; // 往上移\r\n        right: 0;\r\n        z-index: 1000;\r\n    }\r\n\r\n/* 放大表头和表格内容字体 */\r\n    .th,\r\n    .uni-th,\r\n    th {\r\n        font-size: 22px !important;\r\n        color: black !important;\r\n        font-weight: 600;\r\n        letter-spacing: 1px;\r\n    }\r\n\r\n    .popup .large-selection-table .th,\r\n    .popup .large-selection-table .uni-th,\r\n    .popup .large-selection-table th {\r\n        font-size: 22px !important;\r\n        color: black !important;\r\n    }\r\n\r\n\t/* 针对1280x800的平板使用媒体查询进行适配 */\r\n\t@media screen and (min-width: 1280px) and (max-width: 1920px) {\r\n\t\t.right-side {\r\n\t\t\twidth: 30%;\r\n\t\t}\r\n\r\n\t\t.save-btn,\r\n\t\t.cancel-btn {\r\n\t\t\tfont-size: 16px;\r\n\t\t}\r\n\r\n\t\t.inp {\r\n\t\t\twidth: 85%;\r\n\t\t\tfont-size: 16px;\r\n\t\t}\r\n\r\n\t\t.status-block p {\r\n\t\t\tfont-size: 16px;\r\n\t\t}\r\n\r\n\t\t.uni-tr,\r\n\t\t.uni-td {\r\n\t\t\tfont-size: 22px;\r\n\t\t}\r\n\t}\r\n\r\n</style>\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///52\n");
+eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 6));\nvar _WorkOrderStatus = _interopRequireDefault(__webpack_require__(/*! ../components/WorkOrderStatus.vue */ 53));\nvar _uniTable = _interopRequireDefault(__webpack_require__(/*! ../uni_modules/uni-table/components/uni-table/uni-table.vue */ 14));\nvar _mold = _interopRequireDefault(__webpack_require__(/*! ../components/mold.vue */ 58));\nvar _machine = _interopRequireDefault(__webpack_require__(/*! ../components/machine.vue */ 63));\nvar _WorkOrderPrint = _interopRequireDefault(__webpack_require__(/*! ../components/WorkOrderPrint.vue */ 68));\nvar _WorkOrder = _interopRequireDefault(__webpack_require__(/*! ../components/WorkOrder.vue */ 74));\nvar _Technology = _interopRequireDefault(__webpack_require__(/*! ../components/Technology.vue */ 79));\nvar _PDFShow = _interopRequireDefault(__webpack_require__(/*! ../components/PDFShow.vue */ 84));\nvar _PrintInit = _interopRequireDefault(__webpack_require__(/*! ../components/PrintInit.vue */ 89));\nvar _PrintTest = _interopRequireDefault(__webpack_require__(/*! ../components/PrintTest.vue */ 94));\nvar _EquipmentInspection = _interopRequireDefault(__webpack_require__(/*! ../components/EquipmentInspection.vue */ 99));\nvar _moldRecord = _interopRequireDefault(__webpack_require__(/*! ../pages/moldRecord.vue */ 115));\nvar _methods;\nvar _default = {\n components: {\n Technology: _Technology.default,\n WorkOrder: _WorkOrder.default,\n WorkOrderPrint: _WorkOrderPrint.default,\n Machine: _machine.default,\n Mold: _mold.default,\n UniTable: _uniTable.default,\n WorkOrderStatus: _WorkOrderStatus.default,\n PDFShow: _PDFShow.default,\n PrintInit: _PrintInit.default,\n PrintTest: _PrintTest.default,\n EquipmentInspection: _EquipmentInspection.default,\n MoldRecord: _moldRecord.default\n },\n data: function data() {\n var _ref;\n return _ref = {\n orderStatus: '',\n // 榛樿鍏ㄩ儴\n currentTab: 7,\n productCode: '',\n // 浜у搧缂栫爜\n productSpec: '',\n // 浜у搧瑙勬牸\n\n machineList: [],\n machine: [],\n engineeringNoList: [],\n engineeringNoMapList: [],\n engineeringNo: '',\n machineNo: '',\n machineName: '',\n tableData: [],\n isShowTableData: []\n }, (0, _defineProperty2.default)(_ref, \"orderStatus\", '寮�宸�'), (0, _defineProperty2.default)(_ref, \"selectedOrder\", ''), (0, _defineProperty2.default)(_ref, \"orderId\", 0), (0, _defineProperty2.default)(_ref, \"selectedIndexs\", []), (0, _defineProperty2.default)(_ref, \"isShow\", false), (0, _defineProperty2.default)(_ref, \"autoRedirectTimer\", null), (0, _defineProperty2.default)(_ref, \"autoRedirectTime\", 5 * 60 * 1000), _ref;\n },\n created: function created() {\n //璋冭瘯浣跨敤鐨勪唬鐮乗n // this.machineNo = uni.getStorageSync('machineNo');\n // this.machineName = uni.getStorageSync('machineName');\n //\n // if (this.machineNo) {\n // this.getWomdaaIsShow();\n // }\n\n uni.clearStorageSync();\n this.checkForUpdate();\n\n //宸ユ帶鏈轰娇鐢ㄧ殑浠g爜\n this.getPrintInfo();\n },\n onLoad: function onLoad(options) {\n this.getMachineList();\n },\n onShow: function onShow() {\n this.refresh();\n this.resetAutoRedirectTimer();\n },\n methods: (_methods = {\n onRowClick: function onRowClick(index) {\n this.selectedIndexs = [index]; // 鍗曢�塡n // 鎵嬪姩瑙﹀彂 selectionChange 浠ュ悓姝ュ閫夋\n this.selectionChange({\n detail: {\n index: index\n }\n });\n // 閲嶇疆鑷姩璺宠浆璁℃椂鍣╘n this.resetAutoRedirectTimer();\n },\n // 閲嶇疆鑷姩璺宠浆璁℃椂鍣╘n resetAutoRedirectTimer: function resetAutoRedirectTimer() {\n var _this = this;\n // 娓呴櫎鐜版湁鐨勫畾鏃跺櫒\n if (this.autoRedirectTimer) {\n clearTimeout(this.autoRedirectTimer);\n this.autoRedirectTimer = null;\n }\n\n // 闄や簡涓婚〉(0)銆佸伐鍗曢�夋嫨椤�(7)銆佺敓浜ф姤宸ラ〉(4)涔嬪鐨勯〉闈㈡墠璁剧疆鑷姩璺宠浆\n if (this.currentTab !== 0 && this.currentTab !== 7 && this.currentTab !== 4) {\n this.autoRedirectTimer = setTimeout(function () {\n // 璺宠浆鍥炰富椤礬n _this.currentTab = 0;\n // 鏄剧ず鎻愮ず淇℃伅\n uni.showToast({\n title: '椤甸潰瓒呮椂锛岃嚜鍔ㄨ繑鍥炰富椤�',\n icon: 'none',\n duration: 2000\n });\n }, this.autoRedirectTime);\n }\n },\n checkForUpdate: function checkForUpdate() {\n var _this2 = this;\n this.$post({\n url: \"/DevMachine/getAppUpgradeInfo\",\n data: {}\n }).then(function (res) {\n var newVersion = res.data.version;\n var currentVersion = uni.getSystemInfoSync(); // 鑾峰彇褰撳墠 APK 鐗堟湰鍙穃n\n if (newVersion > currentVersion.appVersion) {\n uni.showModal({\n title: \"鍙戠幇鏂扮増鏈琝",\n content: \"鏄惁涓嬭浇鏈�鏂扮増鏈�?\",\n success: function success(modalRes) {\n if (modalRes.confirm) {\n _this2.downloadNewApk(res.data.apkUrl);\n }\n }\n });\n //this.downloadNewApk(res.data.apkUrl);\n _this2.updateChecked = true; // 鏍囪鏇存柊宸叉鏌ヨ繃\n // // 濡傛灉鏈夋柊鐗堟湰锛屽紑濮嬩笅杞絓n //download(res.data.apkUrl);\n }\n });\n },\n downloadNewApk: function downloadNewApk(apkUrl) {\n uni.showToast({\n title: \"寮�濮嬩笅杞芥洿鏂�...\",\n icon: \"none\",\n duration: 2000\n });\n uni.downloadFile({\n url: apkUrl,\n success: function success(res) {\n if (res.statusCode === 200) {\n plus.runtime.install(res.tempFilePath, {\n force: true\n }, function () {\n __f__(\"log\", \"瀹夎鎴愬姛锛岄噸鍚簲鐢╘", \" at pages/index.vue:437\");\n //plus.runtime.restart();\n //plus.runtime.quit();\n // uni.navigateBack()\n }, function (e) {\n __f__(\"error\", \"瀹夎澶辫触:\", e, \" at pages/index.vue:442\");\n });\n }\n },\n fail: function fail(err) {\n __f__(\"error\", \"涓嬭浇澶辫触:\", err, \" at pages/index.vue:447\");\n uni.showToast({\n title: \"涓嬭浇澶辫触锛岃妫�鏌ョ綉缁淺",\n icon: \"none\",\n duration: 2000\n });\n }\n });\n },\n refresh: function refresh() {\n this.getMachineList();\n this.getPrintInfo();\n this.getWomdaaIsShow();\n },\n getPrintInfo: function getPrintInfo() {\n var _this3 = this;\n var mac = \"\";\n mac = \"74:24:ca:4f:b7:4d\";\n this.$post({\n url: \"/DevMachine/GetDevMachineByPdaMac\",\n data: {\n pdaMac: mac\n }\n }).then(function (res) {\n var devMachine = res.data.tbBillList;\n _this3.machineNo = devMachine.machineNo;\n _this3.machineName = \"璋冭瘯妯″紡锛歕" + _this3.machineNo + \"鍙烽娇杞満\";\n uni.setStorageSync('machineNo', _this3.machineNo);\n uni.setStorageSync('printMac', devMachine.printMac);\n __f__(\"log\", devMachine.printMac, \" at pages/index.vue:479\");\n _this3.getWomdaaIsShow();\n });\n return;\n\n // \t\t\tif (plus.os.name == \"Android\") {\n // \t\t\t\t//鑾峰彇鎵嬫満MAC鍦板潃\n // \t\t\t\tvar Context = plus.android.importClass(\"android.content.Context\");\n // \t\t\t\tvar WifiManager = plus.android.importClass(\"android.net.wifi.WifiManager\");\n // \t\t\t\tvar wifiManager = plus.android.runtimeMainActivity().getSystemService(Context.WIFI_SERVICE);\n // \t\t\t\tvar WifiInfo = plus.android.importClass(\"android.net.wifi.WifiInfo\");\n // \t\t\t\tvar wifiInfo = wifiManager.getConnectionInfo();\n // \t\t\t\tmac = wifiInfo.getMacAddress();\n\n // \t\t\t\t//濡傛灉mac涓衡��02:00:00:00:00:00鈥濓紝鍒欏彲鑳芥槸瀹夊崜6.0浠ヤ笂鐗堟湰锛屽垯浣跨敤鍙︿竴绉嶆柟娉曡幏鍙杕ac鍦板潃\n // \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\n // \t\t\t\t\tmac = this.getMacNew();\n // \t\t\t\t}\n // \t\t\t\t//濡傛灉mac浣跨敤鏂版柟娉曚緷鐒舵槸鈥�02:00:00:00:00:00鈥濆垯涓嶈繘琛屼繚瀛榎n // \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\n // \t\t\t\t\treturn;\n // \t\t\t\t}\n // \t\t\t\tuni.setStorageSync('pdaMac', mac);\n\n // \t\t\t\tthis.$post({\n // \t\t\t\t\turl: \"/DevMachine/GetDevMachineByPdaMac\",\n // \t\t\t\t\tdata: {\n // \t\t\t\t\t\tpdaMac: mac,\n // \t\t\t\t\t}\n // \t\t\t\t}).then(res => {\n // \t\t\t\t\tlet devMachine = res.data.tbBillList;\n // \t\t\t\t\tthis.machineNo = devMachine.machineNo;\n // \t\t\t\t\tthis.machineName = \"褰撳墠鏈哄彴锛歕" + this.machineNo + \"鍙烽娇杞満\";\n\n // \t\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\n // \t\t\t\t\tuni.setStorageSync('printMac', devMachine.printMac);\n\n // \t\t\t\t\tthis.getWomdaaIsShow();\n\n // \t\t\t\t});\n // \t\t\t}\n },\n save: function save() {\n var _this4 = this;\n var data = this.selectedItems();\n if (data.length === 0) {\n this.$showMessage(\"璇烽�夋嫨涓�涓伐鍗昞");\n return;\n }\n if (data.length > 1) {\n this.$showMessage(\"涓�娆″彧鑳介�夊彇涓�涓伐鍗昞");\n return;\n }\n\n //let firstValue = data[0][\"moldId\"]; // 鑾峰彇绗竴涓璞$殑鎸囧畾灞炴�у�糪n\n //// 浣跨敤 every 鏂规硶妫�鏌ユ墍鏈夊璞$殑璇ュ睘鎬у�兼槸鍚︿竴鑷碶n //let flag = data.every(item => item[\"moldId\"] === firstValue);\n //if (!flag) {\n //\tthis.$showMessage(\"閫夊彇鐨刓" + data.length + \"涓伐鍗曚腑鐨勬ā鍏风紪鍙蜂笉涓�鑷碶");\n //\treturn;\n //}\n\n var orderSelect = [];\n data.forEach(function (s) {\n var entity = {\n orderId: s.id,\n orderNo: s.daa001\n };\n orderSelect.push(entity);\n });\n var editDate = this.formatDate(new Date());\n this.$post({\n url: \"/MesOrderSelect/Add\",\n data: {\n machineNo: this.machineNo,\n editDate: editDate,\n item: orderSelect\n }\n }).then(function (res) {\n if (res.data.tbBillList) {\n _this4.getWomdaaIsShow();\n uni.showToast({\n title: '淇濆瓨宸ュ崟鎴愬姛',\n //title: '灏嗘敞濉戞満寮�鍚堟ā鏁版竻0',\n //灏嗗�艰缃负 success 鎴栬�呯洿鎺ヤ笉鐢ㄥ啓icon杩欎釜鍙傛暟\n icon: 'success',\n //鏄剧ず鎸佺画鏃堕棿涓� 5绉抃n duration: 5000\n });\n }\n _this4.isShow = false;\n });\n },\n getMacNew: function getMacNew() {\n var str = \"\";\n try {\n if (plus.os.name == \"Android\") {\n var NetworkInterface = plus.android.importClass(\"java.net.NetworkInterface\");\n var networkInterface = NetworkInterface.getByName(\"wlan0\");\n var bytes = networkInterface.getHardwareAddress();\n\n //灏哹yte[] 杞崲鎴� String\n for (var i = 0; i < bytes.length; i++) {\n var tmp = \"\";\n var num = bytes[i];\n if (num < 0) {\n tmp = (255 + num + 1).toString(16);\n } else {\n tmp = num.toString(16);\n }\n if (tmp.length == 1) {\n tmp = \"0\" + tmp;\n }\n str += i == 0 ? tmp : \":\" + tmp;\n }\n }\n } catch (err) {\n str = \"02:00:00:00:00:00\";\n }\n return str;\n },\n cancel: function cancel() {\n var _this5 = this;\n if (!this.machineNo) {\n return;\n }\n\n // 鐩存帴鐢� flag 鍒ゆ柇\n if (this.hasBindedCutterFlag) {\n uni.showToast({\n title: '褰撳墠宸ュ崟宸茬粦瀹氬垁鍏凤紝涓嶈兘娓呯┖閲嶉��',\n icon: 'error',\n duration: 2000\n });\n return;\n }\n var editDate = this.formatDate(new Date());\n this.selectedIndexs = [];\n this.$post({\n url: \"/MesOrderSelect/Remove\",\n data: {\n machineNo: this.machineNo,\n editDate: editDate\n }\n }).then(function (res) {\n if (res.data.tbBillList > 0) {\n _this5.isShowTableData = [];\n }\n });\n },\n formatDate: function formatDate(date) {\n var year = date.getFullYear(); // 鑾峰彇骞翠唤\n var month = String(date.getMonth() + 1).padStart(2, '0'); // 鑾峰彇鏈堜唤骞惰ˉ闆禱n var day = String(date.getDate()).padStart(2, '0'); // 鑾峰彇鏃ユ湡骞惰ˉ闆禱n return \"\".concat(year, \"-\").concat(month, \"-\").concat(day); // 杩斿洖鏍煎紡鍖栧悗鐨勫瓧绗︿覆\n },\n selectionChange: function selectionChange(e) {\n // 鍗曢�夌洿鎺ヨ祴鍊糪n this.selectedIndexs = [e.detail.index];\n },\n selectedItems: function selectedItems() {\n var _this6 = this;\n return this.selectedIndexs.map(function (i) {\n return _this6.tableData[i];\n });\n },\n changeTab: function changeTab(index) {\n this.currentTab = index;\n // 褰撳垏鎹㈠埌宸ュ崟閫夋嫨椤甸潰(index === 7)鏃惰嚜鍔ㄥ埛鏂癨n if (index === 7) {\n this.refresh();\n }\n // 閲嶇疆鑷姩璺宠浆璁℃椂鍣╘n this.resetAutoRedirectTimer();\n __f__(\"log\", index, \" at pages/index.vue:665\");\n },\n onMachineChange: function onMachineChange(event) {\n this.machineName = event;\n this.machineNo = this.machine[this.machineList.indexOf(event)].machineNo;\n uni.clearStorageSync();\n uni.setStorageSync('machineNo', this.machineNo);\n uni.setStorageSync('machineName', this.machineName);\n this.getWomdaaIsShow();\n },\n onEngineeringNoChange: function onEngineeringNoChange(event) {\n var orde = this.engineeringNoList[this.engineeringNoMapList.indexOf(event)];\n this.engineeringNo = orde.moldId;\n this.getWomdaa();\n },\n getMachineList: function getMachineList() {\n var _this7 = this;\n this.$post({\n url: \"/MesMachine/GetInjectionMachine\"\n }).then(function (res) {\n _this7.machine = res.data.tbBillList;\n _this7.machineList = _this7.machine.map(function (s) {\n return s.machineName;\n });\n });\n },\n //鑾峰彇琛ㄦ牸鐨勬暟鎹簮\n getWomdaaIsShow: function getWomdaaIsShow() {\n var _this8 = this;\n this.$post({\n url: \"/Womdaa/GetWomdaasByShow\",\n data: {\n machineNo: this.machineNo\n }\n }).then(function (res) {\n _this8.isShowTableData = res.data.tbBillList;\n\n // 鍙垽鏂涓�鏉★紙鍙厑璁镐竴鏉″伐鍗曪級\n var order = _this8.isShowTableData[0];\n var hasBindedCutter = false;\n if (order) {\n hasBindedCutter = order.outToolId && order.outToolId.toString().trim() !== '' || order.outToolCode && order.outToolCode.trim() !== '' || order.outToolName && order.outToolName.trim() !== '';\n }\n // 瀛樺偍鍒� data 鍙橀噺\n _this8.hasBindedCutterFlag = hasBindedCutter;\n if (_this8.isShowTableData.length == 1) {\n uni.setStorageSync('daa001', _this8.isShowTableData[0].daa001);\n uni.setStorageSync('id', _this8.isShowTableData[0].id);\n }\n });\n },\n isShowTab: function isShowTab() {\n if (this.isShowTableData.length > 0) {\n uni.showToast({\n title: '宸叉湁姝e湪鎿嶄綔鐨勫伐鍗曪紝涓嶈兘鍐嶆閫夋嫨',\n icon: 'error',\n duration: 2000\n });\n return;\n }\n this.isShow = true;\n // 榛樿閫変腑鈥滃緟寮�宸モ�漒n this.engineeringNo = '寰呭紑宸ャ�佹湭寮�宸ャ�佹殏鍋�';\n this.tableData = [];\n // 涓嬫媺妗嗗彧鏄剧ず鍚堝苟鍚庣殑鐘舵�佸拰鍏跺畠鐘舵�乗n this.engineeringNoMapList = ['寰呭紑宸ャ�佹湭寮�宸ャ�佹殏鍋�', '寮�宸�', '瀹屽伐'];\n // 榛樿鏄剧ず鈥滃緟寮�宸モ�濆伐鍗昞n this.getWomdaaByStatus();\n }\n }, (0, _defineProperty2.default)(_methods, \"onEngineeringNoChange\", function onEngineeringNoChange(status) {\n this.engineeringNo = status;\n this.getWomdaaByStatus();\n }), (0, _defineProperty2.default)(_methods, \"getWomdaa\", function getWomdaa() {\n var _this9 = this;\n var editDate = this.formatDate(new Date());\n this.$post({\n url: \"/Womdaa/GetWomdaasByMachine\",\n data: {\n machineNo: this.machineNo,\n editDate: editDate\n }\n }).then(function (res) {\n _this9.tableData = res.data.tbBillList;\n });\n }), (0, _defineProperty2.default)(_methods, \"getWomdaaByStatus\", function getWomdaaByStatus() {\n var _this10 = this;\n var editDate = this.formatDate(new Date());\n var statusArr = [];\n if (this.engineeringNo === '寰呭紑宸ャ�佹湭寮�宸ャ�佹殏鍋�') {\n statusArr = ['寰呭紑宸�', '鏈紑宸�', '鏆傚仠'];\n } else {\n statusArr = [this.engineeringNo];\n }\n this.$post({\n url: \"/Womdaa/GetWomdaasByEngineeringNo\",\n data: {\n machineNo: this.machineNo,\n orderStatus: statusArr,\n editDate: editDate\n }\n }).then(function (res) {\n _this10.tableData = res.data.tbBillList;\n });\n }), (0, _defineProperty2.default)(_methods, \"toDetail\", function toDetail(item) {\n this.orderId = item.id;\n this.selectedOrder = item.daa001;\n this.productCode = item.daa002; // 浜у搧缂栫爜\n this.productSpec = item.daa004; // 浜у搧瑙勬牸\n this.currentTab = 0;\n }), _methods),\n computed: {}\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 1)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/index.vue"],"names":["components","Technology","WorkOrder","WorkOrderPrint","Machine","Mold","UniTable","WorkOrderStatus","PDFShow","PrintInit","PrintTest","EquipmentInspection","MoldRecord","data","orderStatus","currentTab","productCode","productSpec","machineList","machine","engineeringNoList","engineeringNoMapList","engineeringNo","machineNo","machineName","tableData","isShowTableData","created","uni","clearStorageSync","checkForUpdate","getPrintInfo","onLoad","options","getMachineList","onShow","refresh","resetAutoRedirectTimer","methods","onRowClick","index","selectedIndexs","selectionChange","detail","autoRedirectTimer","clearTimeout","setTimeout","showToast","title","icon","duration","autoRedirectTime","$post","url","then","res","newVersion","version","currentVersion","getSystemInfoSync","appVersion","showModal","content","success","modalRes","confirm","downloadNewApk","apkUrl","updateChecked","downloadFile","statusCode","plus","runtime","install","tempFilePath","force","e","fail","err","getWomdaaIsShow","mac","pdaMac","devMachine","tbBillList","setStorageSync","printMac","save","selectedItems","length","$showMessage","orderSelect","forEach","s","entity","orderId","id","orderNo","daa001","push","editDate","formatDate","Date","item","isShow","getMacNew","str","os","name","NetworkInterface","android","importClass","networkInterface","getByName","bytes","getHardwareAddress","i","tmp","num","toString","cancel","hasBindedCutterFlag","date","year","getFullYear","month","String","getMonth","padStart","day","getDate","map","changeTab","onMachineChange","event","indexOf","onEngineeringNoChange","orde","moldId","getWomdaa","order","hasBindedCutter","outToolId","trim","outToolCode","outToolName","isShowTab","getWomdaaByStatus","status","statusArr","selectedOrder","daa002","daa004","computed"],"mappings":"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","file":"52.js","sourcesContent":["//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n//\r\n\r\nimport WorkOrderStatus from '../components/WorkOrderStatus.vue'; // 确保路径正确\r\nimport UniTable from \"../uni_modules/uni-table/components/uni-table/uni-table.vue\";\r\nimport Mold from \"../components/mold.vue\";\r\nimport Machine from \"../components/machine.vue\";\r\nimport WorkOrderPrint from \"../components/WorkOrderPrint.vue\";\r\nimport WorkOrder from \"../components/WorkOrder.vue\";\r\nimport Technology from \"../components/Technology.vue\";\r\nimport PDFShow from \"../components/PDFShow.vue\";\r\nimport PrintInit from \"../components/PrintInit.vue\";\r\nimport PrintTest from \"../components/PrintTest.vue\";\r\nimport EquipmentInspection from \"../components/EquipmentInspection.vue\";\r\nimport MoldRecord from \"../pages/moldRecord.vue\";\r\n\r\n\texport default {\r\n\t\tcomponents: {\r\n\t\t\tTechnology,\r\n\t\t\tWorkOrder,\r\n\t\t\tWorkOrderPrint,\r\n\t\t\tMachine,\r\n\t\t\tMold,\r\n\t\t\tUniTable,\r\n\t\t\tWorkOrderStatus,\r\n\t\t\tPDFShow,\r\n\t\t\tPrintInit,\r\n\t\t\tPrintTest,\r\n\t\t\tEquipmentInspection,\r\n\t\t\tMoldRecord\r\n\t\t},\r\n\t\tdata() {\r\n\t\t\treturn {\r\n                orderStatus: '', // 默认全部\r\n\t\t\t\tcurrentTab: 7,\r\n\r\n                productCode: '', // 产品编码\r\n                productSpec: '', // 产品规格\r\n\r\n\t\t\t\tmachineList: [],\r\n\r\n\t\t\t\tmachine: [],\r\n\r\n\t\t\t\tengineeringNoList: [],\r\n\t\t\t\tengineeringNoMapList: [],\r\n\t\t\t\tengineeringNo: '',\r\n\r\n\t\t\t\tmachineNo: '',\r\n\t\t\t\tmachineName: '',\r\n\r\n\t\t\t\ttableData: [],\r\n\t\t\t\tisShowTableData: [],\r\n\r\n\t\t\t\torderStatus: '开工',\r\n\t\t\t\tselectedOrder: '',\r\n\t\t\t\torderId: 0,\r\n\r\n\t\t\t\tselectedIndexs: [],\r\n\r\n\t\t\t\tisShow: false,\r\n\t\t\t\t\r\n\t\t\t\t// 自动跳转相关\r\n\t\t\t\tautoRedirectTimer: null,\r\n\t\t\t\tautoRedirectTime: 5 * 60 * 1000, // 5分钟\r\n\t\t\t};\r\n\t\t},\r\n\t\tcreated() {\r\n\r\n\t\t\t//调试使用的代码\r\n\t\t\t// this.machineNo = uni.getStorageSync('machineNo');\r\n\t\t\t// this.machineName = uni.getStorageSync('machineName');\r\n\t\t\t//\r\n\t\t\t// if (this.machineNo) {\r\n\t\t\t//   this.getWomdaaIsShow();\r\n\t\t\t// }\r\n\r\n\t\t\tuni.clearStorageSync();\r\n\t\t\t\r\n\t\t\tthis.checkForUpdate();\r\n\t\t\t\r\n\t\t\t//工控机使用的代码\r\n\t\t\tthis.getPrintInfo();\r\n\t\t\t\r\n\t\t},\r\n\t\tonLoad(options) {\r\n\t\t\tthis.getMachineList();\r\n\t\t},\r\n\t\tonShow() {\r\n\t\t\tthis.refresh();\r\n\t\t\tthis.resetAutoRedirectTimer();\r\n\t\t},\r\n\t\tmethods: {\r\n            onRowClick(index) {\r\n                this.selectedIndexs = [index]; // 单选\r\n                // 手动触发 selectionChange 以同步复选框\r\n                this.selectionChange({ detail: { index } });\r\n                // 重置自动跳转计时器\r\n                this.resetAutoRedirectTimer();\r\n            },\r\n            \r\n            // 重置自动跳转计时器\r\n            resetAutoRedirectTimer() {\r\n                // 清除现有的定时器\r\n                if (this.autoRedirectTimer) {\r\n                    clearTimeout(this.autoRedirectTimer);\r\n                    this.autoRedirectTimer = null;\r\n                }\r\n                \r\n                // 除了主页(0)、工单选择页(7)、生产报工页(4)之外的页面才设置自动跳转\r\n                if (this.currentTab !== 0 && this.currentTab !== 7 && this.currentTab !== 4) {\r\n                    this.autoRedirectTimer = setTimeout(() => {\r\n                        // 跳转回主页\r\n                        this.currentTab = 0;\r\n                        // 显示提示信息\r\n                        uni.showToast({\r\n                            title: '页面超时，自动返回主页',\r\n                            icon: 'none',\r\n                            duration: 2000\r\n                        });\r\n                    }, this.autoRedirectTime);\r\n                }\r\n            },\r\n\t\t\tcheckForUpdate() {\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/DevMachine/getAppUpgradeInfo\",\r\n\t\t\t\t\tdata: {}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\t\r\n\t\t\t\t\tlet newVersion = res.data.version;\r\n\t\t\t\t\tlet currentVersion = uni.getSystemInfoSync(); // 获取当前 APK 版本号\r\n\t\t\t\t\t \r\n\t\t\t\t\tif (newVersion > currentVersion.appVersion) {\r\n\t\t\t\t\t\tuni.showModal({\r\n\t\t\t\t\t\t\ttitle: \"发现新版本\",\r\n\t\t\t\t\t\t\tcontent: \"是否下载最新版本?\",\r\n\t\t\t\t\t\t\tsuccess: (modalRes) => {\r\n\t\t\t\t\t\t\t\tif (modalRes.confirm) {\r\n\t\t\t\t\t\t\t\t\tthis.downloadNewApk(res.data.apkUrl);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\t//this.downloadNewApk(res.data.apkUrl);\r\n\t\t\t\t\t\tthis.updateChecked = true; // 标记更新已检查过\r\n\t\t\t\t\t\t//      // 如果有新版本，开始下载\r\n\t\t\t\t\t\t//download(res.data.apkUrl);\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t\t\r\n\t\t\t},\r\n\t\t\t\r\n\t\t\tdownloadNewApk(apkUrl) {\r\n\t\t\t\tuni.showToast({\r\n\t\t\t\t\ttitle: \"开始下载更新...\",\r\n\t\t\t\t\ticon: \"none\",\r\n\t\t\t\t\tduration: 2000\r\n\t\t\t\t});\r\n\t\t\t\r\n\t\t\t\tuni.downloadFile({\r\n\t\t\t\t\turl: apkUrl,\r\n\t\t\t\t\tsuccess: (res) => {\r\n\t\t\t\t\t\tif (res.statusCode === 200) {\r\n\t\t\t\t\t\t\tplus.runtime.install(res.tempFilePath, {\r\n\t\t\t\t\t\t\t\tforce: true\r\n\t\t\t\t\t\t\t}, function() {\r\n\t\t\t\t\t\t\t\tconsole.log(\"安装成功，重启应用\");\r\n\t\t\t\t\t\t\t\t//plus.runtime.restart();\r\n\t\t\t\t\t\t\t\t//plus.runtime.quit();\r\n\t\t\t\t\t\t\t\t// uni.navigateBack()\r\n\t\t\t\t\t\t\t}, function(e) {\r\n\t\t\t\t\t\t\t\tconsole.error(\"安装失败:\", e);\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t},\r\n\t\t\t\t\tfail: (err) => {\r\n\t\t\t\t\t\tconsole.error(\"下载失败:\", err);\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: \"下载失败，请检查网络\",\r\n\t\t\t\t\t\t\ticon: \"none\",\r\n\t\t\t\t\t\t\tduration: 2000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t},\r\n\t\t\t\r\n\t\t\trefresh() {\r\n\t\t\t\tthis.getMachineList();\r\n\t\t\t\tthis.getPrintInfo();\r\n\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t},\r\n\t\t\tgetPrintInfo() {\r\n\t\t\t\tvar mac = \"\";\r\n\t\t\t\t\r\n\t\t\t\tmac = \"74:24:ca:4f:b7:4d\";\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/DevMachine/GetDevMachineByPdaMac\",\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\tpdaMac: mac,\r\n\t\t\t\t\t}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tlet devMachine = res.data.tbBillList;\r\n\t\t\t\t\tthis.machineNo = devMachine.machineNo;\r\n                    this.machineName = \"调试模式：\" + this.machineNo + \"号齿轮机\"\r\n\r\n\t\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\r\n\t\t\t\t\tuni.setStorageSync('printMac', devMachine.printMac);\r\n\r\n\t\t\t\t\tconsole.log(devMachine.printMac);\r\n\r\n\t\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t\t});\r\n\t\t\t\treturn;\r\n\t\t\t\t\r\n\t\t\t\t\r\n\t//  \t\t\tif (plus.os.name == \"Android\") {\r\n\t//  \t\t\t\t//获取手机MAC地址\r\n\t//  \t\t\t\tvar Context = plus.android.importClass(\"android.content.Context\");\r\n\t//  \t\t\t\tvar WifiManager = plus.android.importClass(\"android.net.wifi.WifiManager\");\r\n\t//  \t\t\t\tvar wifiManager = plus.android.runtimeMainActivity().getSystemService(Context.WIFI_SERVICE);\r\n\t//  \t\t\t\tvar WifiInfo = plus.android.importClass(\"android.net.wifi.WifiInfo\");\r\n\t//  \t\t\t\tvar wifiInfo = wifiManager.getConnectionInfo();\r\n\t//  \t\t\t\tmac = wifiInfo.getMacAddress();\r\n\t\t\t\t\t\r\n\t//  \t\t\t\t//如果mac为“02:00:00:00:00:00”，则可能是安卓6.0以上版本，则使用另一种方法获取mac地址\r\n\t//  \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\r\n\t//  \t\t\t\t\tmac = this.getMacNew();\r\n\t//  \t\t\t\t}\r\n\t//  \t\t\t\t//如果mac使用新方法依然是“02:00:00:00:00:00”则不进行保存\r\n\t//  \t\t\t\tif (mac == \"02:00:00:00:00:00\") {\r\n\t//  \t\t\t\t\treturn;\r\n\t//  \t\t\t\t}\r\n\t//  \t\t\t\tuni.setStorageSync('pdaMac', mac);\r\n\r\n\t//  \t\t\t\tthis.$post({\r\n\t//  \t\t\t\t\turl: \"/DevMachine/GetDevMachineByPdaMac\",\r\n\t//  \t\t\t\t\tdata: {\r\n\t//  \t\t\t\t\t\tpdaMac: mac,\r\n\t//  \t\t\t\t\t}\r\n\t//  \t\t\t\t}).then(res => {\r\n\t//  \t\t\t\t\tlet devMachine = res.data.tbBillList;\r\n\t//  \t\t\t\t\tthis.machineNo = devMachine.machineNo;\r\n\t//  \t\t\t\t\tthis.machineName = \"当前机台：\" + this.machineNo + \"号齿轮机\";\r\n\r\n\t//  \t\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\r\n\t//  \t\t\t\t\tuni.setStorageSync('printMac', devMachine.printMac);\r\n \r\n\r\n\t//  \t\t\t\t\tthis.getWomdaaIsShow();\r\n\r\n\t//  \t\t\t\t});\r\n\t//  \t\t\t}\r\n\t\t\t},\r\n\t\t\tsave() {\r\n\t\t\t\tlet data = this.selectedItems();\r\n\r\n\t\t\t\tif (data.length === 0) {\r\n                    this.$showMessage(\"请选择一个工单\");\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n                if (data.length > 1) {\r\n                    this.$showMessage(\"一次只能选取一个工单\");\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\r\n\t\t\t\t//let firstValue = data[0][\"moldId\"]; // 获取第一个对象的指定属性值\r\n\r\n\t\t\t\t//// 使用 every 方法检查所有对象的该属性值是否一致\r\n\t\t\t\t//let flag = data.every(item => item[\"moldId\"] === firstValue);\r\n\t\t\t\t//if (!flag) {\r\n\t\t\t\t//\tthis.$showMessage(\"选取的\" + data.length + \"个工单中的模具编号不一致\");\r\n\t\t\t\t//\treturn;\r\n\t\t\t\t//}\r\n\r\n\t\t\t\tlet orderSelect = [];\r\n\r\n\t\t\t\tdata.forEach(s => {\r\n\t\t\t\t\tlet entity = {\r\n\t\t\t\t\t\torderId: s.id,\r\n\t\t\t\t\t\torderNo: s.daa001,\r\n\t\t\t\t\t}\r\n\t\t\t\t\torderSelect.push(entity);\r\n\t\t\t\t});\r\n\r\n\t\t\t\tlet editDate = this.formatDate(new Date());\r\n\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/MesOrderSelect/Add\",\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\tmachineNo: this.machineNo,\r\n\t\t\t\t\t\teditDate: editDate,\r\n\t\t\t\t\t\titem: orderSelect\r\n\t\t\t\t\t}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tif (res.data.tbBillList) {\r\n\t\t\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t\t\t\tuni.showToast({\r\n                            title: '保存工单成功',\r\n\t\t\t\t\t\t\t//title: '将注塑机开合模数清0',\r\n\t\t\t\t\t\t\t//将值设置为 success 或者直接不用写icon这个参数\r\n\t\t\t\t\t\t\ticon: 'success',\r\n\t\t\t\t\t\t\t//显示持续时间为 5秒\r\n\t\t\t\t\t\t\tduration: 5000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.isShow = false;\r\n\t\t\t\t})\r\n\r\n\t\t\t},\r\n\t\t\tgetMacNew() {\r\n\t\t\t\tvar str = \"\";\r\n\t\t\t\ttry {\r\n\t\t\t\t\tif (plus.os.name == \"Android\") {\r\n\t\t\t\t\t\tvar NetworkInterface = plus.android.importClass(\"java.net.NetworkInterface\");\r\n\t\t\t\t\t\tvar networkInterface = NetworkInterface.getByName(\"wlan0\");\r\n\t\t\t\t\t\tvar bytes = networkInterface.getHardwareAddress();\r\n\t\t\t\r\n\t\t\t\t\t\t//将byte[] 转换成 String\r\n\t\t\t\t\t\tfor (var i = 0; i < bytes.length; i++) {\r\n\t\t\t\t\t\t\tvar tmp = \"\";\r\n\t\t\t\t\t\t\tvar num = bytes[i];\r\n\t\t\t\t\t\t\tif (num < 0) {\r\n\t\t\t\t\t\t\t\ttmp = (255 + num + 1).toString(16);\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\ttmp = num.toString(16);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tif (tmp.length == 1) {\r\n\t\t\t\t\t\t\t\ttmp = \"0\" + tmp;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tstr += (i == 0) ? (tmp) : (\":\" + tmp);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t} catch (err) {\r\n\t\t\t\t\tstr = \"02:00:00:00:00:00\";\r\n\t\t\t\t}\r\n\t\t\t\treturn str;\r\n\t\t\t},\r\n\r\n            cancel() {\r\n                if (!this.machineNo) {\r\n                    return;\r\n                }\r\n\r\n                // 直接用 flag 判断\r\n                if (this.hasBindedCutterFlag) {\r\n                    uni.showToast({\r\n                        title: '当前工单已绑定刀具，不能清空重选',\r\n                        icon: 'error',\r\n                        duration: 2000\r\n                    });\r\n                    return;\r\n                }\r\n\r\n                let editDate = this.formatDate(new Date());\r\n                this.selectedIndexs = [];\r\n\r\n                this.$post({\r\n                    url: \"/MesOrderSelect/Remove\",\r\n                    data: {\r\n                        machineNo: this.machineNo,\r\n                        editDate: editDate\r\n                    },\r\n                }).then(res => {\r\n                    if (res.data.tbBillList > 0) {\r\n                        this.isShowTableData = [];\r\n                    }\r\n                });\r\n            },\r\n\r\n\t\t\tformatDate(date) {\r\n\t\t\t\tlet year = date.getFullYear(); // 获取年份\r\n\t\t\t\tlet month = String(date.getMonth() + 1).padStart(2, '0'); // 获取月份并补零\r\n\t\t\t\tlet day = String(date.getDate()).padStart(2, '0'); // 获取日期并补零\r\n\t\t\t\treturn `${year}-${month}-${day}`; // 返回格式化后的字符串\r\n\t\t\t},\r\n\t\t\tselectionChange(e) {\r\n                // 单选直接赋值\r\n                this.selectedIndexs = [e.detail.index];\r\n\t\t\t},\r\n\r\n\t\t\tselectedItems() {\r\n\t\t\t\treturn this.selectedIndexs.map(i => this.tableData[i])\r\n\t\t\t},\r\n\r\n\r\n\t\t\tchangeTab(index) {\r\n\t\t\t\tthis.currentTab = index;\r\n\t\t\t\t// 当切换到工单选择页面(index === 7)时自动刷新\r\n\t\t\t\tif (index === 7) {\r\n\t\t\t\t\tthis.refresh();\r\n\t\t\t\t}\r\n\t\t\t\t// 重置自动跳转计时器\r\n\t\t\t\tthis.resetAutoRedirectTimer();\r\n\t\t\t\tconsole.log(index);\r\n\t\t\t},\r\n\t\t\tonMachineChange(event) {\r\n\r\n\t\t\t\tthis.machineName = event;\r\n\r\n\t\t\t\tthis.machineNo = this.machine[this.machineList.indexOf(event)].machineNo;\r\n\r\n\t\t\t\tuni.clearStorageSync();\r\n\r\n\t\t\t\tuni.setStorageSync('machineNo', this.machineNo);\r\n\t\t\t\tuni.setStorageSync('machineName', this.machineName);\r\n\r\n\t\t\t\tthis.getWomdaaIsShow();\r\n\t\t\t},\r\n\t\t\tonEngineeringNoChange(event) {\r\n\r\n\t\t\t\tlet orde = this.engineeringNoList[this.engineeringNoMapList.indexOf(event)];\r\n\r\n\t\t\t\tthis.engineeringNo = orde.moldId;\r\n\r\n\t\t\t\tthis.getWomdaa();\r\n\r\n\t\t\t},\r\n\t\t\tgetMachineList() {\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/MesMachine/GetInjectionMachine\",\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tthis.machine = res.data.tbBillList;\r\n\t\t\t\t\tthis.machineList = this.machine.map(s => s.machineName);\r\n\t\t\t\t})\r\n\t\t\t},\r\n            //获取表格的数据源\r\n            getWomdaaIsShow() {\r\n                this.$post({\r\n                    url: \"/Womdaa/GetWomdaasByShow\",\r\n                    data: {\r\n                        machineNo: this.machineNo,\r\n                    }\r\n                }).then(res => {\r\n                    this.isShowTableData = res.data.tbBillList;\r\n\r\n                    // 只判断第一条（只允许一条工单）\r\n                    const order = this.isShowTableData[0];\r\n                    let hasBindedCutter = false;\r\n                    if (order) {\r\n                        hasBindedCutter =\r\n                            (order.outToolId && order.outToolId.toString().trim() !== '') ||\r\n                            (order.outToolCode && order.outToolCode.trim() !== '') ||\r\n                            (order.outToolName && order.outToolName.trim() !== '');\r\n                    }\r\n                    // 存储到 data 变量\r\n                    this.hasBindedCutterFlag = hasBindedCutter;\r\n\r\n                    if (this.isShowTableData.length == 1) {\r\n                        uni.setStorageSync('daa001', this.isShowTableData[0].daa001);\r\n                        uni.setStorageSync('id', this.isShowTableData[0].id);\r\n                    }\r\n                });\r\n            },\r\n\r\n            isShowTab() {\r\n                if (this.isShowTableData.length > 0) {\r\n                    uni.showToast({\r\n                        title: '已有正在操作的工单，不能再次选择',\r\n                        icon: 'error',\r\n                        duration: 2000\r\n                    });\r\n                    return;\r\n                }\r\n\r\n                this.isShow = true;\r\n                // 默认选中“待开工”\r\n                this.engineeringNo = '待开工、未开工、暂停';\r\n                this.tableData = [];\r\n                // 下拉框只显示合并后的状态和其它状态\r\n                this.engineeringNoMapList = [\r\n                    '待开工、未开工、暂停',\r\n                    '开工',\r\n                    '完工'\r\n                ];\r\n                // 默认显示“待开工”工单\r\n                this.getWomdaaByStatus();\r\n            },\r\n            // 下拉框选中后，按状态筛选工单\r\n            onEngineeringNoChange(status) {\r\n                this.engineeringNo = status;\r\n                this.getWomdaaByStatus();\r\n            },\r\n\t\t\tgetWomdaa() {\r\n\r\n\t\t\t\tlet editDate = this.formatDate(new Date());\r\n\r\n\t\t\t\tthis.$post({\r\n\t\t\t\t\turl: \"/Womdaa/GetWomdaasByMachine\",\r\n\t\t\t\t\tdata: {\r\n\t\t\t\t\t\tmachineNo: this.machineNo,\r\n\t\t\t\t\t\teditDate: editDate\r\n\t\t\t\t\t}\r\n\t\t\t\t}).then(res => {\r\n\t\t\t\t\tthis.tableData = res.data.tbBillList;\r\n\t\t\t\t})\r\n\t\t\t},\r\n            // 按工单状态筛选工单\r\n            getWomdaaByStatus() {\r\n                let editDate = this.formatDate(new Date());\r\n                let statusArr = [];\r\n                if (this.engineeringNo === '待开工、未开工、暂停') {\r\n                    statusArr = ['待开工', '未开工', '暂停'];\r\n                } else {\r\n                    statusArr = [this.engineeringNo];\r\n                }\r\n                this.$post({\r\n                    url: \"/Womdaa/GetWomdaasByEngineeringNo\",\r\n                    data: {\r\n                        machineNo: this.machineNo,\r\n                        orderStatus: statusArr,\r\n                        editDate: editDate\r\n                    }\r\n                }).then(res => {\r\n                    this.tableData = res.data.tbBillList;\r\n                });\r\n            },\r\n\t\t\ttoDetail(item) {\r\n\t\t\t\tthis.orderId = item.id;\r\n\t\t\t\tthis.selectedOrder = item.daa001;\r\n                this.productCode = item.daa002; // 产品编码\r\n                this.productSpec = item.daa004; // 产品规格\r\n\t\t\t\tthis.currentTab = 0;\r\n\t\t\t}\r\n\t\t},\r\n\t\tcomputed: {}\r\n\t};\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///52\n");
/***/ }),
/* 53 */
@@ -4257,23 +4257,365 @@
}),
]
),
- _vm._$s(28, "i", _vm.showToolDialog)
- ? _c(
+ _c(
+ "view",
+ { staticClass: _vm._$s(28, "sc", "tiaoji-section"), attrs: { _i: 28 } },
+ [
+ _c(
"view",
- {
- staticClass: _vm._$s(28, "sc", "dialog-overlay"),
- attrs: { _i: 28 },
- },
+ { staticClass: _vm._$s(29, "sc", "tiaoji-row"), attrs: { _i: 29 } },
[
_c(
"view",
- { staticClass: _vm._$s(29, "sc", "dialog"), attrs: { _i: 29 } },
+ {
+ staticClass: _vm._$s(30, "sc", "current-user-section"),
+ attrs: { _i: 30 },
+ },
+ [
+ _c("text"),
+ _c(
+ "text",
+ {
+ staticClass: _vm._$s(32, "sc", "current-user-name"),
+ attrs: { _i: 32 },
+ },
+ [
+ _vm._v(
+ _vm._$s(
+ 32,
+ "t0-0",
+ _vm._s(_vm.tiaojiStaffDisplay || "鏈�夋嫨")
+ )
+ ),
+ ]
+ ),
+ _c("button", {
+ staticClass: _vm._$s(33, "sc", "select-user-btn"),
+ attrs: { _i: 33 },
+ on: {
+ click: function ($event) {
+ _vm.isTiaojiUserSelectShow = true
+ },
+ },
+ }),
+ ]
+ ),
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(34, "sc", "tiaoji-input-section"),
+ attrs: { _i: 34 },
+ },
+ [
+ _c("text"),
+ _c("input", {
+ directives: [
+ {
+ name: "model",
+ rawName: "v-model",
+ value: _vm.tiaojiOkQty,
+ expression: "tiaojiOkQty",
+ },
+ ],
+ staticClass: _vm._$s(36, "sc", "inp tiaoji-input"),
+ attrs: { _i: 36 },
+ domProps: {
+ value: _vm._$s(36, "v-model", _vm.tiaojiOkQty),
+ },
+ on: {
+ input: function ($event) {
+ if ($event.target.composing) {
+ return
+ }
+ _vm.tiaojiOkQty = $event.target.value
+ },
+ },
+ }),
+ ]
+ ),
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(37, "sc", "tiaoji-input-section"),
+ attrs: { _i: 37 },
+ },
+ [
+ _c("text"),
+ _c("input", {
+ directives: [
+ {
+ name: "model",
+ rawName: "v-model",
+ value: _vm.tiaojiBadQty,
+ expression: "tiaojiBadQty",
+ },
+ ],
+ staticClass: _vm._$s(39, "sc", "inp tiaoji-input"),
+ attrs: { _i: 39 },
+ domProps: {
+ value: _vm._$s(39, "v-model", _vm.tiaojiBadQty),
+ },
+ on: {
+ input: function ($event) {
+ if ($event.target.composing) {
+ return
+ }
+ _vm.tiaojiBadQty = $event.target.value
+ },
+ },
+ }),
+ ]
+ ),
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(40, "sc", "tiaoji-submit-section"),
+ attrs: { _i: 40 },
+ },
+ [
+ _c("button", {
+ staticClass: _vm._$s(41, "sc", "details-btn"),
+ attrs: { _i: 41 },
+ on: { click: _vm.handleInspectionCall },
+ }),
+ ]
+ ),
+ ]
+ ),
+ ]
+ ),
+ _vm._$s(42, "i", _vm.isTiaojiUserSelectShow)
+ ? _c(
+ "view",
+ { staticClass: _vm._$s(42, "sc", "overlay"), attrs: { _i: 42 } },
+ [
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(43, "sc", "popup user-select-popup"),
+ attrs: { _i: 43 },
+ },
[
_c(
"view",
{
- staticClass: _vm._$s(30, "sc", "form-group"),
- attrs: { _i: 30 },
+ staticClass: _vm._$s(44, "sc", "user-search-bar"),
+ attrs: { _i: 44 },
+ },
+ [
+ _c("input", {
+ directives: [
+ {
+ name: "model",
+ rawName: "v-model.trim",
+ value: _vm.tiaojiUserSearch,
+ expression: "tiaojiUserSearch",
+ modifiers: { trim: true },
+ },
+ ],
+ staticClass: _vm._$s(45, "sc", "user-search-input"),
+ attrs: { _i: 45 },
+ domProps: {
+ value: _vm._$s(45, "v-model", _vm.tiaojiUserSearch),
+ },
+ on: {
+ keydown: function ($event) {
+ if (
+ !$event.type.indexOf("key") &&
+ _vm._k(
+ $event.keyCode,
+ "enter",
+ 13,
+ $event.key,
+ "Enter"
+ )
+ ) {
+ return null
+ }
+ $event.preventDefault()
+ },
+ input: function ($event) {
+ if ($event.target.composing) {
+ return
+ }
+ _vm.tiaojiUserSearch = $event.target.value.trim()
+ },
+ blur: function ($event) {
+ return _vm.$forceUpdate()
+ },
+ },
+ }),
+ _vm._$s(46, "i", _vm.tiaojiUserSearch)
+ ? _c("button", {
+ staticClass: _vm._$s(46, "sc", "user-search-clear"),
+ attrs: { _i: 46 },
+ on: {
+ click: function ($event) {
+ _vm.tiaojiUserSearch = ""
+ },
+ },
+ })
+ : _vm._e(),
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(47, "sc", "user-search-info"),
+ attrs: { _i: 47 },
+ },
+ [
+ _vm._v(
+ _vm._$s(
+ 47,
+ "t0-0",
+ _vm._s(_vm.filteredTiaojiUsers.length)
+ ) +
+ _vm._$s(
+ 47,
+ "t0-1",
+ _vm._s(_vm.tiaojiUsers.length)
+ )
+ ),
+ ]
+ ),
+ ]
+ ),
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(48, "sc", "user-list-scroll"),
+ attrs: { _i: 48 },
+ },
+ [
+ _vm._$s(49, "i", _vm.filteredTiaojiUsers.length)
+ ? [
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(
+ 50,
+ "sc",
+ "user-list-grid"
+ ),
+ attrs: { _i: 50 },
+ },
+ _vm._l(
+ _vm._$s(51, "f", {
+ forItems: _vm.filteredTiaojiUsers,
+ }),
+ function (u, index, $20, $30) {
+ return _c(
+ "button",
+ {
+ key: _vm._$s(51, "f", {
+ forIndex: $20,
+ key: index,
+ }),
+ class: _vm._$s("51-" + $30, "c", [
+ "user-list-btn",
+ { selected: u === _vm.tiaojiStaffNo },
+ ]),
+ attrs: { _i: "51-" + $30 },
+ on: {
+ click: function ($event) {
+ return _vm.selectTiaojiUser(u)
+ },
+ },
+ },
+ [
+ _c(
+ "span",
+ {
+ staticClass: _vm._$s(
+ "52-" + $30,
+ "sc",
+ "user-code"
+ ),
+ attrs: { _i: "52-" + $30 },
+ },
+ [
+ _vm._v(
+ _vm._$s(
+ "52-" + $30,
+ "t0-0",
+ _vm._s(u.split(":")[0])
+ )
+ ),
+ ]
+ ),
+ _c(
+ "span",
+ {
+ staticClass: _vm._$s(
+ "53-" + $30,
+ "sc",
+ "user-name"
+ ),
+ attrs: { _i: "53-" + $30 },
+ },
+ [
+ _vm._v(
+ _vm._$s(
+ "53-" + $30,
+ "t0-0",
+ _vm._s(u.split(":")[1])
+ )
+ ),
+ ]
+ ),
+ ]
+ )
+ }
+ ),
+ 0
+ ),
+ ]
+ : _c("view", {
+ staticClass: _vm._$s(54, "sc", "no-user-result"),
+ attrs: { _i: 54 },
+ }),
+ ],
+ 2
+ ),
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(55, "sc", "user-popup-footer"),
+ attrs: { _i: 55 },
+ },
+ [
+ _c("button", {
+ staticClass: _vm._$s(56, "sc", "clean-btn wide-btn"),
+ attrs: { _i: 56 },
+ on: {
+ click: function ($event) {
+ _vm.isTiaojiUserSelectShow = false
+ },
+ },
+ }),
+ ]
+ ),
+ ]
+ ),
+ ]
+ )
+ : _vm._e(),
+ _vm._$s(57, "i", _vm.showToolDialog)
+ ? _c(
+ "view",
+ {
+ staticClass: _vm._$s(57, "sc", "dialog-overlay"),
+ attrs: { _i: 57 },
+ },
+ [
+ _c(
+ "view",
+ { staticClass: _vm._$s(58, "sc", "dialog"), attrs: { _i: 58 } },
+ [
+ _c(
+ "view",
+ {
+ staticClass: _vm._$s(59, "sc", "form-group"),
+ attrs: { _i: 59 },
},
[
_c("input", {
@@ -4285,10 +4627,10 @@
expression: "searchKey",
},
],
- staticClass: _vm._$s(31, "sc", "input"),
- attrs: { _i: 31 },
+ staticClass: _vm._$s(60, "sc", "input"),
+ attrs: { _i: 60 },
domProps: {
- value: _vm._$s(31, "v-model", _vm.searchKey),
+ value: _vm._$s(60, "v-model", _vm.searchKey),
},
on: {
input: [
@@ -4303,10 +4645,10 @@
},
}),
_c("button", {
- staticClass: _vm._$s(32, "sc", "btn-blue"),
+ staticClass: _vm._$s(61, "sc", "btn-blue"),
attrs: {
- disabled: _vm._$s(32, "a-disabled", _vm.loadingTools),
- _i: 32,
+ disabled: _vm._$s(61, "a-disabled", _vm.loadingTools),
+ _i: 61,
},
on: { click: _vm.searchTool },
}),
@@ -4315,24 +4657,24 @@
_c(
"view",
{
- staticClass: _vm._$s(33, "sc", "tool-list"),
- attrs: { _i: 33 },
+ staticClass: _vm._$s(62, "sc", "tool-list"),
+ attrs: { _i: 62 },
},
_vm._l(
- _vm._$s(34, "f", { forItems: _vm.filteredTools }),
- function (tool, $10, $20, $30) {
+ _vm._$s(63, "f", { forItems: _vm.filteredTools }),
+ function (tool, $11, $21, $31) {
return _c(
"button",
{
- key: _vm._$s(34, "f", {
- forIndex: $20,
+ key: _vm._$s(63, "f", {
+ forIndex: $21,
key: tool.no,
}),
- staticClass: _vm._$s("34-" + $30, "sc", "tool-btn"),
- class: _vm._$s("34-" + $30, "c", {
+ staticClass: _vm._$s("63-" + $31, "sc", "tool-btn"),
+ class: _vm._$s("63-" + $31, "c", {
active: _vm.activeToolNo === tool.no,
}),
- attrs: { _i: "34-" + $30 },
+ attrs: { _i: "63-" + $31 },
on: {
click: function ($event) {
return _vm.selectTool(tool)
@@ -4341,8 +4683,8 @@
},
[
_vm._v(
- _vm._$s("34-" + $30, "t0-0", _vm._s(tool.no)) +
- _vm._$s("34-" + $30, "t0-1", _vm._s(tool.name))
+ _vm._$s("63-" + $31, "t0-0", _vm._s(tool.no)) +
+ _vm._$s("63-" + $31, "t0-1", _vm._s(tool.name))
),
]
)
@@ -4353,52 +4695,52 @@
_c(
"view",
{
- staticClass: _vm._$s(35, "sc", "dialog-actions"),
- attrs: { _i: 35 },
+ staticClass: _vm._$s(64, "sc", "dialog-actions"),
+ attrs: { _i: 64 },
},
[
_c("div", [
_c("button", {
- staticClass: _vm._$s(37, "sc", "btn-blue"),
+ staticClass: _vm._$s(66, "sc", "btn-blue"),
attrs: {
disabled: _vm._$s(
- 37,
+ 66,
"a-disabled",
_vm.pageIndex === 1 || _vm.loadingTools
),
- _i: 37,
+ _i: 66,
},
on: { click: _vm.prevPage },
}),
_c("span", [
_vm._v(
- _vm._$s(38, "t0-0", _vm._s(_vm.pageIndex)) +
- _vm._$s(38, "t0-1", _vm._s(_vm.totalPages))
+ _vm._$s(67, "t0-0", _vm._s(_vm.pageIndex)) +
+ _vm._$s(67, "t0-1", _vm._s(_vm.totalPages))
),
]),
_c("button", {
- staticClass: _vm._$s(39, "sc", "btn-blue"),
+ staticClass: _vm._$s(68, "sc", "btn-blue"),
attrs: {
disabled: _vm._$s(
- 39,
+ 68,
"a-disabled",
_vm.pageIndex === _vm.totalPages ||
_vm.loadingTools
),
- _i: 39,
+ _i: 68,
},
on: { click: _vm.nextPage },
}),
]),
_c("div", [
_c("button", {
- staticClass: _vm._$s(41, "sc", "btn-blue"),
- attrs: { _i: 41 },
+ staticClass: _vm._$s(70, "sc", "btn-blue"),
+ attrs: { _i: 70 },
on: { click: _vm.confirmTool },
}),
_c("button", {
- staticClass: _vm._$s(42, "sc", "btn-disabled"),
- attrs: { _i: 42 },
+ staticClass: _vm._$s(71, "sc", "btn-disabled"),
+ attrs: { _i: 71 },
on: { click: _vm.closeToolDialog },
}),
]),
@@ -4409,386 +4751,9 @@
]
)
: _vm._e(),
- _c(
- "view",
- { staticClass: _vm._$s(43, "sc", "table-section"), attrs: { _i: 43 } },
- [
- _c(
- "table",
- {
- staticClass: _vm._$s(44, "sc", "styled-table"),
- attrs: { _i: 44 },
- },
- [
- _c("thead", [
- _c("tr", [
- _c("th"),
- _c("th"),
- _c("th"),
- _c("th", {
- staticClass: _vm._$s(50, "sc", "num"),
- attrs: { _i: 50 },
- }),
- _c("th"),
- _c("th", {
- staticClass: _vm._$s(52, "sc", "num"),
- attrs: { _i: 52 },
- }),
- _c("th", {
- staticClass: _vm._$s(53, "sc", "num"),
- attrs: { _i: 53 },
- }),
- _c("th", {
- staticClass: _vm._$s(54, "sc", "num"),
- attrs: { _i: 54 },
- }),
- _c("th", {
- staticClass: _vm._$s(55, "sc", "num"),
- attrs: { _i: 55 },
- }),
- _c("th", {
- staticClass: _vm._$s(56, "sc", "num"),
- attrs: { _i: 56 },
- }),
- _c("th"),
- _c("th"),
- ]),
- ]),
- _c(
- "tbody",
- [
- _vm._l(
- _vm._$s(60, "f", { forItems: _vm.toolRecords }),
- function (item, idx, $21, $31) {
- return _c(
- "tr",
- {
- key: _vm._$s(60, "f", {
- forIndex: $21,
- key: item.id,
- }),
- class: _vm._$s("60-" + $31, "c", {
- "row-odd": idx % 2 === 0,
- }),
- attrs: { _i: "60-" + $31 },
- },
- [
- _c("td", [
- _vm._v(
- _vm._$s("61-" + $31, "t0-0", _vm._s(item.no))
- ),
- ]),
- _c(
- "td",
- {
- staticClass: _vm._$s("62-" + $31, "sc", "left"),
- attrs: { _i: "62-" + $31 },
- },
- [
- _vm._v(
- _vm._$s("62-" + $31, "t0-0", _vm._s(item.name))
- ),
- ]
- ),
- _c("td", [
- _vm._v(
- _vm._$s("63-" + $31, "t0-0", _vm._s(item.upTime))
- ),
- ]),
- _c(
- "td",
- {
- staticClass: _vm._$s("64-" + $31, "sc", "num"),
- attrs: { _i: "64-" + $31 },
- },
- [
- _vm._v(
- _vm._$s(
- "64-" + $31,
- "t0-0",
- _vm._s(
- item.upCount != null ? item.upCount : ""
- )
- )
- ),
- ]
- ),
- _c("td", [
- _vm._v(
- _vm._$s(
- "65-" + $31,
- "t0-0",
- _vm._s(item.downTime)
- )
- ),
- ]),
- _c(
- "td",
- {
- staticClass: _vm._$s("66-" + $31, "sc", "num"),
- attrs: { _i: "66-" + $31 },
- },
- [
- _vm._$s("67-" + $31, "i", idx === 0)
- ? [
- _vm._$s("68-" + $31, "i", !item.downTime)
- ? [
- _vm._v(
- _vm._$s(
- "68-" + $31,
- "t0-0",
- _vm._s(
- item.currentCjNum != null
- ? item.currentCjNum
- : ""
- )
- )
- ),
- ]
- : [
- _vm._v(
- _vm._$s(
- "69-" + $31,
- "t0-0",
- _vm._s(
- item.downCount != null
- ? item.downCount
- : ""
- )
- )
- ),
- ],
- ]
- : [
- _vm._v(
- _vm._$s(
- "70-" + $31,
- "t0-0",
- _vm._s(
- item.downCount != null
- ? item.downCount
- : ""
- )
- )
- ),
- ],
- ],
- 2
- ),
- _c(
- "td",
- {
- staticClass: _vm._$s("71-" + $31, "sc", "num"),
- attrs: { _i: "71-" + $31 },
- },
- [
- _vm._$s("72-" + $31, "i", idx === 0)
- ? [
- _vm._$s("73-" + $31, "i", !item.downTime)
- ? [
- _vm._v(
- _vm._$s(
- "73-" + $31,
- "t0-0",
- _vm._s(
- item.currentCjNum != null &&
- item.upCount != null
- ? Number(item.currentCjNum) -
- Number(item.upCount)
- : item.useCount != null
- ? item.useCount
- : ""
- )
- )
- ),
- ]
- : [
- _vm._v(
- _vm._$s(
- "74-" + $31,
- "t0-0",
- _vm._s(
- item.useCount != null
- ? item.useCount
- : ""
- )
- )
- ),
- ],
- ]
- : [
- _vm._v(
- _vm._$s(
- "75-" + $31,
- "t0-0",
- _vm._s(
- item.useCount != null
- ? item.useCount
- : ""
- )
- )
- ),
- ],
- ],
- 2
- ),
- _c(
- "td",
- {
- staticClass: _vm._$s("76-" + $31, "sc", "num"),
- attrs: { _i: "76-" + $31 },
- },
- [
- _vm._v(
- _vm._$s(
- "76-" + $31,
- "t0-0",
- _vm._s(
- item.useLimit != null ? item.useLimit : ""
- )
- )
- ),
- ]
- ),
- _c(
- "td",
- {
- staticClass: _vm._$s("77-" + $31, "sc", "num"),
- attrs: { _i: "77-" + $31 },
- },
- [
- _vm._$s("78-" + $31, "i", idx === 0)
- ? [
- _vm._$s("79-" + $31, "i", !item.downTime)
- ? [
- _vm._v(
- _vm._$s(
- "79-" + $31,
- "t0-0",
- _vm._s(
- item.currentCjNum != null &&
- item.upCount != null &&
- item.useLimit != null &&
- Number(item.useLimit) > 0
- ? Math.round(
- ((Number(
- item.currentCjNum
- ) -
- Number(item.upCount)) /
- Number(item.useLimit)) *
- 100
- ) + "%"
- : item.lifePercent != null
- ? item.lifePercent
- : ""
- )
- )
- ),
- ]
- : [
- _vm._v(
- _vm._$s(
- "80-" + $31,
- "t0-0",
- _vm._s(
- item.lifePercent != null
- ? item.lifePercent
- : ""
- )
- )
- ),
- ],
- ]
- : [
- _vm._v(
- _vm._$s(
- "81-" + $31,
- "t0-0",
- _vm._s(item.lifePercent)
- )
- ),
- ],
- ],
- 2
- ),
- _c(
- "td",
- {
- staticClass: _vm._$s("82-" + $31, "sc", "num"),
- attrs: { _i: "82-" + $31 },
- },
- [
- _vm._v(
- _vm._$s(
- "82-" + $31,
- "t0-0",
- _vm._s(item.lifeWarn)
- )
- ),
- ]
- ),
- _c(
- "td",
- {
- class: _vm._$s(
- "83-" + $31,
- "c",
- item.warnStatus === "棰勮"
- ? "warn-cell"
- : item.warnStatus === "姝e父"
- ? "ok-cell"
- : ""
- ),
- attrs: { _i: "83-" + $31 },
- },
- [
- _vm._$s(
- "84-" + $31,
- "i",
- item.warnStatus === "棰勮"
- )
- ? _c("span", {
- staticClass: _vm._$s(
- "84-" + $31,
- "sc",
- "warn-badge"
- ),
- attrs: { _i: "84-" + $31 },
- })
- : _c("span", { attrs: { _i: "85-" + $31 } }, [
- _vm._v(
- _vm._$s(
- "85-" + $31,
- "t0-0",
- _vm._s(item.warnStatus)
- )
- ),
- ]),
- ]
- ),
- _c("td", [
- _vm._v(
- _vm._$s(
- "86-" + $31,
- "t0-0",
- _vm._s(item.downTime ? "涓嬫満" : "鍦ㄦ満")
- )
- ),
- ]),
- ]
- )
- }
- ),
- _vm._$s(87, "i", !_vm.toolRecords.length)
- ? _c("tr", { attrs: { _i: 87 } }, [_c("td", {})])
- : _vm._e(),
- ],
- 2
- ),
- ]
- ),
- ]
- ),
+ false
+ ? undefined
+ : _vm._e(),
]
)
}
@@ -4818,7 +4783,7 @@
/***/ (function(module, exports, __webpack_require__) {
"use strict";
-eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 3));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 6));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 9));\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n data: function data() {\n return {\n machineNo: '',\n //鏈哄彴缂栫爜\n workOrderNo: '',\n //宸ュ崟鍙穃n activeToolNo: '',\n // 褰撳墠閫変腑鐨勫垁鍏风紪鍙穃n pageIndex: 1,\n pageSize: 20,\n //鍗曢〉鏄剧ず鐨勫垁鍏锋暟閲廫n total: 0,\n toolList: [],\n selectedToolNo: '',\n toolName: '',\n toolModel: '',\n showToolDialog: false,\n searchKey: '',\n filteredTools: [],\n useLimitInput: '',\n lifeWarnInput: '',\n // 鏂板锛氬鍛芥瘮棰勮鍊煎師濮嬭緭鍏n toolRecords: [],\n loadingTools: false,\n loadingForm: false,\n submitting: false,\n _searchTimer: null,\n workOrderCurrentCjNum: null,\n // 宸ュ崟褰撳墠鏁伴噰\n\n // 鑷姩淇濆瓨鐩稿叧\n autoSaveTimer: null,\n isDirty: false,\n // 琛ㄥ崟鏄惁鏈夋湭淇濆瓨鍙樻洿\n autoSaveIntervalMs: 5 * 60 * 1000,\n // 榛樿 5 鍒嗛挓\n autoSaveEnabled: true,\n autoSaveActionName: 'handleUpTool' // 鑷姩瑙﹀彂鐨勬柟娉曞悕锛屽彲鏀逛负鑷畾涔変繚瀛樻柟娉昞n };\n },\n\n computed: {\n totalPages: function totalPages() {\n return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);\n }\n },\n watch: {\n // 鏍囪鑴忔暟鎹細鎸夐渶鐩戝惉瀛楁鍙樺寲\n selectedToolNo: function selectedToolNo() {\n this.isDirty = true;\n },\n useLimitInput: function useLimitInput() {\n this.isDirty = true;\n },\n lifeWarnInput: function lifeWarnInput() {\n this.isDirty = true;\n },\n toolName: function toolName() {\n this.isDirty = true;\n },\n toolModel: function toolModel() {\n this.isDirty = true;\n }\n },\n methods: {\n //鏌ヨ褰撳墠鏁伴噰鏁帮紝浣滀负涓嬪垁璁℃暟瀹炴椂鏄剧ず\n fetchCurrentCjNum: function fetchCurrentCjNum(toolNo) {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var _res$data, res, _ref, _found$CurrentCjNum, found;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (_this.machineNo) {\n _context.next = 2;\n break;\n }\n return _context.abrupt(\"return\", null);\n case 2:\n _context.prev = 2;\n _context.next = 5;\n return _this.$post({\n url: '/Womdaa/GetWomdaasByShow',\n data: JSON.stringify({\n machineNo: _this.machineNo\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 5:\n res = _context.sent;\n if (!(res.status === 0 && Array.isArray((_res$data = res.data) === null || _res$data === void 0 ? void 0 : _res$data.tbBillList))) {\n _context.next = 9;\n break;\n }\n found = res.data.tbBillList.find(function (x) {\n return x.cutterId === toolNo || x.cutteR_ID === toolNo;\n });\n return _context.abrupt(\"return\", found ? (_ref = (_found$CurrentCjNum = found.CurrentCjNum) !== null && _found$CurrentCjNum !== void 0 ? _found$CurrentCjNum : found.currentCjNum) !== null && _ref !== void 0 ? _ref : null : null);\n case 9:\n _context.next = 14;\n break;\n case 11:\n _context.prev = 11;\n _context.t0 = _context[\"catch\"](2);\n __f__(\"warn\", '鑾峰彇currentCjNum澶辫触', _context.t0, \" at components/mold.vue:244\");\n case 14:\n return _context.abrupt(\"return\", null);\n case 15:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, null, [[2, 11]]);\n }))();\n },\n // 鏂板锛氬埛鏂版寜閽鐞嗘柟娉昞n handleRefresh: function handleRefresh() {\n var _this2 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {\n return _regenerator.default.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n _this2.fetchTools('');\n if (!(_this2.machineNo && _this2.workOrderNo)) {\n _context2.next = 7;\n break;\n }\n _context2.next = 4;\n return _this2.fetchFormData();\n case 4:\n _context2.next = 6;\n return _this2.fetchDefaultToolFromWorkOrder();\n case 6:\n // 鍒锋柊鍚庤祴鍊肩涓�琛� currentCjNum\n if (_this2.toolRecords.length > 0) {\n _this2.$set(_this2.toolRecords[0], 'currentCjNum', _this2.workOrderCurrentCjNum);\n }\n case 7:\n _this2.$showMessage('鍒锋柊瀹屾垚');\n case 8:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }))();\n },\n // 鑷姩淇濆瓨锛氬惎鍔╘n startAutoSave: function startAutoSave() {\n var _this3 = this;\n if (!this.autoSaveEnabled) return;\n this.stopAutoSave();\n this.autoSaveTimer = setInterval(function () {\n _this3.autoSaveTick();\n }, this.autoSaveIntervalMs);\n },\n // 鑷姩淇濆瓨锛氬仠姝n stopAutoSave: function stopAutoSave() {\n if (this.autoSaveTimer) {\n clearInterval(this.autoSaveTimer);\n this.autoSaveTimer = null;\n }\n },\n // 鑷姩淇濆瓨锛氭瘡娆″畾鏃舵墽琛屾椂鐨勯�昏緫\n autoSaveTick: function autoSaveTick() {\n var _this4 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {\n var fn;\n return _regenerator.default.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n if (_this4.autoSaveEnabled) {\n _context3.next = 2;\n break;\n }\n return _context3.abrupt(\"return\");\n case 2:\n if (_this4.isDirty) {\n _context3.next = 4;\n break;\n }\n return _context3.abrupt(\"return\");\n case 4:\n if (!(_this4.submitting || _this4.loadingForm)) {\n _context3.next = 6;\n break;\n }\n return _context3.abrupt(\"return\");\n case 6:\n fn = _this4.autoSaveActionName && typeof _this4[_this4.autoSaveActionName] === 'function' ? _this4[_this4.autoSaveActionName] : null;\n if (fn) {\n _context3.next = 10;\n break;\n }\n __f__(\"warn\", '鑷姩淇濆瓨锛氭湭鎵惧埌鏂规硶', _this4.autoSaveActionName, \" at components/mold.vue:287\");\n return _context3.abrupt(\"return\");\n case 10:\n _context3.prev = 10;\n _this4.submitting = true;\n _context3.next = 14;\n return fn.call(_this4);\n case 14:\n // 璋冪敤淇濆瓨鏂规硶锛堜緥濡� handleUpTool锛塡n // 濡傛灉淇濆瓨鎴愬姛锛屾竻鑴忔爣璁帮紙淇濆瓨鏂规硶鍐呴儴鑻ュけ璐ユ病鏈夋姏鍑哄彲淇濇寔姝ゆ柟寮忥級\n _this4.isDirty = false;\n _context3.next = 20;\n break;\n case 17:\n _context3.prev = 17;\n _context3.t0 = _context3[\"catch\"](10);\n __f__(\"error\", '鑷姩淇濆瓨澶辫触锛�', _context3.t0, \" at components/mold.vue:297\");\n case 20:\n _context3.prev = 20;\n _this4.submitting = false;\n return _context3.finish(20);\n case 23:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, null, [[10, 17, 20, 23]]);\n }))();\n },\n // 鏂板锛氬鍛芥瘮棰勮鍊煎綊涓�鍖� (杩斿洖 0~1 鎴� null)\n normalizeLifeWarn: function normalizeLifeWarn(v) {\n if (v == null) return null;\n var raw = String(v).trim().replace(/[%锛匽/g, '');\n if (raw === '') return null;\n var num = Number(raw);\n if (!isFinite(num) || num <= 0) return null;\n return num > 1 ? num / 100 : num;\n },\n openToolDialog: function openToolDialog() {\n this.showToolDialog = true;\n this.pageIndex = 1;\n this.fetchTools(this.searchKey);\n },\n closeToolDialog: function closeToolDialog() {\n this.showToolDialog = false;\n },\n fetchTools: function fetchTools(searchKey) {\n var _this5 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4() {\n var res, _ref2, _ref3, _ref4, _res$data$total, _res$data2, _res$data3, payload, getField, mapped, totalFromRes;\n return _regenerator.default.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n _this5.loadingTools = true;\n _context4.prev = 1;\n _context4.next = 4;\n return _this5.$post({\n url: '/MesCutterLedger/QueryTools',\n data: JSON.stringify({\n searchKey: searchKey,\n pageIndex: _this5.pageIndex,\n pageSize: _this5.pageSize\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 4:\n res = _context4.sent;\n if (res.status === 0) {\n payload = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : [];\n getField = function getField(obj) {\n for (var _len = arguments.length, keys = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n keys[_key - 1] = arguments[_key];\n }\n for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {\n var k = _keys[_i];\n if ((obj === null || obj === void 0 ? void 0 : obj[k]) !== undefined && (obj === null || obj === void 0 ? void 0 : obj[k]) !== null) return obj[k];\n }\n return null;\n }; // 杩欓噷闇�瑕佹妸 lifeWarn 瀛楁涔熷甫鍑烘潵\n mapped = (payload || []).map(function (t) {\n return {\n no: getField(t, 'cutterId', 'CUTTER_ID', 'cutteR_ID', 'daA001', 'no'),\n name: getField(t, 'cutterName', 'CUTTER_NAME', 'cutteR_NAME', 'name'),\n model: getField(t, 'cutterModel', 'CUTTER_MODEL', 'cutteR_MODEL', 'model'),\n lifeWarn: getField(t, 'modlLifeWorning', 'lifeWarn', 'LIFE_WARN', 'lifE_WARN')\n };\n });\n _this5.filteredTools = mapped;\n _this5.toolList = mapped.slice();\n totalFromRes = Number((_ref2 = (_ref3 = (_ref4 = (_res$data$total = (_res$data2 = res.data) === null || _res$data2 === void 0 ? void 0 : _res$data2.total) !== null && _res$data$total !== void 0 ? _res$data$total : (_res$data3 = res.data) === null || _res$data3 === void 0 ? void 0 : _res$data3.totalCount) !== null && _ref4 !== void 0 ? _ref4 : res.total) !== null && _ref3 !== void 0 ? _ref3 : res.totalCount) !== null && _ref2 !== void 0 ? _ref2 : mapped.length);\n _this5.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n if (_this5.pageIndex > _this5.totalPages) {\n _this5.pageIndex = _this5.totalPages;\n }\n } else {\n _this5.$showMessage(res.message || '鏌ヨ澶辫触');\n }\n _context4.next = 12;\n break;\n case 8:\n _context4.prev = 8;\n _context4.t0 = _context4[\"catch\"](1);\n __f__(\"error\", 'fetchTools 閿欒锛�', _context4.t0, \" at components/mold.vue:366\");\n _this5.$showMessage('鏌ヨ鍒�鍏峰け璐ワ紝璇锋鏌ョ綉缁滄垨鎺ュ彛');\n case 12:\n _context4.prev = 12;\n _this5.loadingTools = false;\n return _context4.finish(12);\n case 15:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, null, [[1, 8, 12, 15]]);\n }))();\n },\n prevPage: function prevPage() {\n var _this6 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5() {\n return _regenerator.default.wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n if (!(_this6.pageIndex > 1)) {\n _context5.next = 4;\n break;\n }\n _this6.pageIndex--;\n _context5.next = 4;\n return _this6.fetchTools(_this6.searchKey);\n case 4:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5);\n }))();\n },\n nextPage: function nextPage() {\n var _this7 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee6() {\n return _regenerator.default.wrap(function _callee6$(_context6) {\n while (1) {\n switch (_context6.prev = _context6.next) {\n case 0:\n if (!(_this7.pageIndex < _this7.totalPages)) {\n _context6.next = 4;\n break;\n }\n _this7.pageIndex++;\n _context6.next = 4;\n return _this7.fetchTools(_this7.searchKey);\n case 4:\n case \"end\":\n return _context6.stop();\n }\n }\n }, _callee6);\n }))();\n },\n onSearchKeyInput: function onSearchKeyInput() {\n var _this8 = this;\n clearTimeout(this._searchTimer);\n this._searchTimer = setTimeout(function () {\n _this8.searchTool();\n }, 300);\n },\n searchTool: function searchTool() {\n var _this9 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee7() {\n return _regenerator.default.wrap(function _callee7$(_context7) {\n while (1) {\n switch (_context7.prev = _context7.next) {\n case 0:\n _this9.pageIndex = 1;\n _context7.next = 3;\n return _this9.fetchTools(_this9.searchKey);\n case 3:\n case \"end\":\n return _context7.stop();\n }\n }\n }, _callee7);\n }))();\n },\n selectTool: function selectTool(tool) {\n this.selectedToolNo = tool.no;\n this.toolName = tool.name;\n this.toolModel = tool.model;\n this.activeToolNo = tool.no;\n // 鏂板锛氬甫鍑哄鍛芥瘮棰勮鍊糪n if (tool.lifeWarn !== undefined && tool.lifeWarn !== null) {\n // 鏍煎紡鍖栦负鐧惧垎姣斿瓧绗︿覆\n var warn = Number(tool.lifeWarn);\n this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n } else {\n this.lifeWarnInput = '';\n }\n },\n confirmTool: function confirmTool() {\n this.showToolDialog = false;\n },\n setUseLimit: function setUseLimit() {\n var _this10 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee8() {\n var v;\n return _regenerator.default.wrap(function _callee8$(_context8) {\n while (1) {\n switch (_context8.prev = _context8.next) {\n case 0:\n if (_this10.selectedToolNo) {\n _context8.next = 3;\n break;\n }\n _this10.$showMessage('璇烽�夋嫨鍒�鍏峰悗鍐嶈缃笂闄�');\n return _context8.abrupt(\"return\");\n case 3:\n v = Number(_this10.useLimitInput);\n if (!(isNaN(v) || v <= 0)) {\n _context8.next = 7;\n break;\n }\n _this10.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺');\n return _context8.abrupt(\"return\");\n case 7:\n _this10.toolRecords = _this10.toolRecords.map(function (r) {\n if (r.no === _this10.selectedToolNo) {\n return _objectSpread(_objectSpread({}, r), {}, {\n useLimit: v\n });\n }\n return r;\n });\n _this10.toolList = _this10.toolList.map(function (t) {\n return t.no === _this10.selectedToolNo ? _objectSpread(_objectSpread({}, t), {}, {\n useLimit: v\n }) : t;\n });\n _this10.$showMessage('浣跨敤涓婇檺宸茶缃紙浠呭墠绔樉绀猴級');\n case 10:\n case \"end\":\n return _context8.stop();\n }\n }\n }, _callee8);\n }))();\n },\n // 涓婂垁鏃朵紶閫� sdjs = 宸ュ崟 currentCjNum\n handleUpTool: function handleUpTool() {\n var _this11 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee9() {\n var useLimit, sdjs, lifeWarnRatio, payload, res;\n return _regenerator.default.wrap(function _callee9$(_context9) {\n while (1) {\n switch (_context9.prev = _context9.next) {\n case 0:\n if (_this11.workOrderNo) {\n _context9.next = 3;\n break;\n }\n _this11.$showMessage('宸ュ崟鍙蜂笉鑳戒负绌�');\n return _context9.abrupt(\"return\");\n case 3:\n if (_this11.machineNo) {\n _context9.next = 6;\n break;\n }\n _this11.$showMessage('鏈哄彴鍙蜂笉鑳戒负绌�');\n return _context9.abrupt(\"return\");\n case 6:\n if (_this11.selectedToolNo) {\n _context9.next = 9;\n break;\n }\n _this11.$showMessage('鍒�鍏风紪鍙蜂笉鑳戒负绌�');\n return _context9.abrupt(\"return\");\n case 9:\n if (_this11.useLimitInput) {\n _context9.next = 12;\n break;\n }\n _this11.$showMessage('浣跨敤涓婇檺涓嶈兘涓虹┖');\n return _context9.abrupt(\"return\");\n case 12:\n useLimit = Number(_this11.useLimitInput);\n if (!(isNaN(useLimit) || useLimit <= 0)) {\n _context9.next = 16;\n break;\n }\n _this11.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺');\n return _context9.abrupt(\"return\");\n case 16:\n // sdjs 浣跨敤宸ュ崟 currentCjNum\n sdjs = _this11.workOrderCurrentCjNum != null ? Number(_this11.workOrderCurrentCjNum) : null;\n lifeWarnRatio = _this11.normalizeLifeWarn(_this11.lifeWarnInput);\n payload = {\n workOrderNo: _this11.workOrderNo,\n machineNo: _this11.machineNo,\n toolNo: _this11.selectedToolNo,\n type: '涓婃満',\n useLimit: useLimit,\n sdjs: sdjs,\n // 涓婂垁璁℃暟锛堝伐鍗曞綋鍓嶆暟閲囷級\n modlLifeWorning: lifeWarnRatio // 鏂板\n };\n _context9.prev = 19;\n _this11.submitting = true;\n _context9.next = 23;\n return _this11.$post({\n url: '/MesCutterLedger/SubmitToolAction',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 23:\n res = _context9.sent;\n if (!(res.data && res.data.outSum === \"0\")) {\n _context9.next = 29;\n break;\n }\n uni.showToast({\n title: res.data.outMsg || '',\n icon: 'error'\n });\n return _context9.abrupt(\"return\");\n case 29:\n if (res.data && res.data.outMsg) {\n uni.showToast({\n title: res.data.outMsg,\n icon: 'none'\n });\n }\n case 30:\n if (!(res.status === 0)) {\n _context9.next = 33;\n break;\n }\n _context9.next = 33;\n return _this11.fetchFormData();\n case 33:\n _context9.next = 40;\n break;\n case 35:\n _context9.prev = 35;\n _context9.t0 = _context9[\"catch\"](19);\n __f__(\"error\", _context9.t0, \" at components/mold.vue:476\");\n _this11.$showMessage('涓婂垁鎻愪氦澶辫触锛岃妫�鏌ョ綉缁�');\n throw _context9.t0;\n case 40:\n _context9.prev = 40;\n _this11.submitting = false;\n return _context9.finish(40);\n case 43:\n case \"end\":\n return _context9.stop();\n }\n }\n }, _callee9, null, [[19, 35, 40, 43]]);\n }))();\n },\n // 涓嬪垁鏃朵紶閫� xdjs = 宸ュ崟 currentCjNum\n handleDownTool: function handleDownTool() {\n var _this12 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee10() {\n var useLimit, xdjs, lifeWarnRatio, payload, res;\n return _regenerator.default.wrap(function _callee10$(_context10) {\n while (1) {\n switch (_context10.prev = _context10.next) {\n case 0:\n if (_this12.workOrderNo) {\n _context10.next = 3;\n break;\n }\n _this12.$showMessage('宸ュ崟鍙蜂笉鑳戒负绌�');\n return _context10.abrupt(\"return\");\n case 3:\n if (_this12.machineNo) {\n _context10.next = 6;\n break;\n }\n _this12.$showMessage('鏈哄彴鍙蜂笉鑳戒负绌�');\n return _context10.abrupt(\"return\");\n case 6:\n if (_this12.selectedToolNo) {\n _context10.next = 9;\n break;\n }\n _this12.$showMessage('鍒�鍏风紪鍙蜂笉鑳戒负绌�');\n return _context10.abrupt(\"return\");\n case 9:\n //涓嬪垁涓嶅己鍒跺綍鍏ヤ娇鐢ㄤ笂闄怽n //if (!this.useLimitInput) { this.$showMessage('浣跨敤涓婇檺涓嶈兘涓虹┖'); return; }\n useLimit = Number(_this12.useLimitInput); //if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺'); return; }\n // 涓嬪垁璁℃暟鍚屾牱鍙栧伐鍗曟渶鏂伴噰闆嗘暟\n xdjs = _this12.workOrderCurrentCjNum != null ? Number(_this12.workOrderCurrentCjNum) : null;\n lifeWarnRatio = _this12.normalizeLifeWarn(_this12.lifeWarnInput);\n payload = {\n workOrderNo: _this12.workOrderNo,\n machineNo: _this12.machineNo,\n toolNo: _this12.selectedToolNo,\n type: '涓嬫満',\n useLimit: useLimit,\n xdjs: xdjs,\n // 涓嬪垁璁℃暟\n modlLifeWorning: lifeWarnRatio // 鏂板\n };\n _context10.prev = 13;\n _this12.submitting = true;\n _context10.next = 17;\n return _this12.$post({\n url: '/MesCutterLedger/SubmitToolAction',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 17:\n res = _context10.sent;\n if (!(res.data && res.data.outSum === \"0\")) {\n _context10.next = 23;\n break;\n }\n uni.showToast({\n title: res.data.outMsg || '',\n icon: 'error'\n });\n return _context10.abrupt(\"return\");\n case 23:\n if (res.data && res.data.outMsg) {\n uni.showToast({\n title: res.data.outMsg,\n icon: 'none'\n });\n }\n case 24:\n if (!(res.status === 0)) {\n _context10.next = 27;\n break;\n }\n _context10.next = 27;\n return _this12.fetchFormData();\n case 27:\n _context10.next = 34;\n break;\n case 29:\n _context10.prev = 29;\n _context10.t0 = _context10[\"catch\"](13);\n __f__(\"error\", _context10.t0, \" at components/mold.vue:529\");\n _this12.$showMessage('涓嬪垁鎻愪氦澶辫触锛岃妫�鏌ョ綉缁�');\n throw _context10.t0;\n case 34:\n _context10.prev = 34;\n _this12.submitting = false;\n return _context10.finish(34);\n case 37:\n case \"end\":\n return _context10.stop();\n }\n }\n }, _callee10, null, [[13, 29, 34, 37]]);\n }))();\n },\n cancel: function cancel() {\n this.selectedToolNo = '';\n this.toolName = '';\n this.toolModel = '';\n this.useLimitInput = '';\n this.lifeWarnInput = ''; // 鏂板锛氭竻绌篭n this.isDirty = false;\n },\n fetchFormData: function fetchFormData() {\n var _this13 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee11() {\n var payload, _ref5, _ref6, _ref7, _res$data$total2, _res$data4, _res$data5, res, list, getField, mapped, totalFromRes;\n return _regenerator.default.wrap(function _callee11$(_context11) {\n while (1) {\n switch (_context11.prev = _context11.next) {\n case 0:\n if (!(!_this13.workOrderNo || !_this13.machineNo)) {\n _context11.next = 3;\n break;\n }\n __f__(\"warn\", '宸ュ崟鍙锋垨鏈哄彴鍙蜂负绌猴紝璺宠繃鑾峰彇琛ㄥ崟鏁版嵁', \" at components/mold.vue:546\");\n return _context11.abrupt(\"return\");\n case 3:\n _this13.loadingForm = true;\n payload = {\n workOrderNo: _this13.workOrderNo.trim(),\n machineNo: _this13.machineNo.trim()\n };\n _context11.prev = 5;\n _context11.next = 8;\n return _this13.$post({\n url: '/MesCutterLedger/GetFormData',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 8:\n res = _context11.sent;\n if (!(res.status !== 0)) {\n _context11.next = 13;\n break;\n }\n _this13.$showMessage(res.message || '鑾峰彇琛ㄥ崟鏁版嵁澶辫触');\n _this13.toolRecords = [];\n return _context11.abrupt(\"return\");\n case 13:\n list = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : [];\n getField = function getField(obj) {\n for (var _len2 = arguments.length, keys = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n keys[_key2 - 1] = arguments[_key2];\n }\n for (var _i2 = 0, _keys2 = keys; _i2 < _keys2.length; _i2++) {\n var k = _keys2[_i2];\n if ((obj === null || obj === void 0 ? void 0 : obj[k]) !== undefined && (obj === null || obj === void 0 ? void 0 : obj[k]) !== null) return obj[k];\n }\n return null;\n };\n mapped = (list || []).map(function (t) {\n var _getField, _getField2;\n var upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\n var downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\n var lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\n var currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\n var useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\n var useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\n var percent = '';\n if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n percent = (Number(useCount) / Number(useLimit) * 100).toFixed(0) + '%';\n }\n var parseNumber = function parseNumber(v) {\n if (v === null || v === undefined || v === '') return null;\n var s = String(v).replace(/[,锛�%]/g, '').trim();\n var n = parseFloat(s);\n return Number.isFinite(n) ? n : null;\n };\n var formatPercent = function formatPercent(n) {\n if (n === null || n === undefined || isNaN(n)) return '';\n if (n <= 1) return \"\".concat((n * 100).toFixed(0), \"%\");\n return \"\".concat(Number(n).toFixed(0), \"%\");\n };\n var lifeWarnNum = parseNumber(lifeWarnRaw);\n var warnStatus = getField(t, 'status', 'STATUS') || '';\n if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n var percentNum = Number(useCount) / Number(useLimit);\n warnStatus = percentNum >= lifeWarnNum ? '棰勮' : '姝e父';\n } else {\n warnStatus = warnStatus || '鏈煡';\n }\n return {\n id: getField(t, 'id', 'ID') || \"\".concat(getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || '', \"-\").concat(upTimeRaw || ''),\n no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\n name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\n upTime: _this13.formatDateTime(upTimeRaw),\n upCount: (_getField = getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount')) !== null && _getField !== void 0 ? _getField : '',\n downTime: _this13.formatDateTime(downTimeRaw),\n downCount: (_getField2 = getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount')) !== null && _getField2 !== void 0 ? _getField2 : '',\n useCount: useCount !== null && useCount !== void 0 ? useCount : '',\n useLimit: useLimit !== null && useLimit !== void 0 ? useLimit : '',\n lifePercent: percent,\n lifeWarn: formatPercent(lifeWarnNum),\n warnStatus: warnStatus,\n currentCjNum: currentCjNum\n };\n }); // 鏂板锛氭寜涓婂垁鏃堕棿闄嶅簭鎺掑簭锛堣秺鏅氱殑瓒婁笂闈級\n mapped.sort(function (a, b) {\n // 鏃堕棿鏍煎紡濡� \"10-24 16:03\"锛岃浆涓� Date 瀵硅薄姣旇緝\n var parse = function parse(s) {\n if (!s) return 0;\n // 琛ュ勾浠斤紝鍋囪閮芥槸浠婂勾\n var year = new Date().getFullYear();\n return new Date(\"\".concat(year, \"-\").concat(s.replace(/-/g, '-'), \":00\")).getTime();\n };\n return parse(b.upTime) - parse(a.upTime); // 娉ㄦ剰杩欓噷椤哄簭鍙嶈繃鏉n });\n\n _this13.toolRecords = mapped;\n totalFromRes = Number((_ref5 = (_ref6 = (_ref7 = (_res$data$total2 = (_res$data4 = res.data) === null || _res$data4 === void 0 ? void 0 : _res$data4.total) !== null && _res$data$total2 !== void 0 ? _res$data$total2 : (_res$data5 = res.data) === null || _res$data5 === void 0 ? void 0 : _res$data5.totalCount) !== null && _ref7 !== void 0 ? _ref7 : res.total) !== null && _ref6 !== void 0 ? _ref6 : res.totalCount) !== null && _ref5 !== void 0 ? _ref5 : mapped.length);\n _this13.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n _context11.next = 27;\n break;\n case 22:\n _context11.prev = 22;\n _context11.t0 = _context11[\"catch\"](5);\n __f__(\"error\", '鑾峰彇琛ㄥ崟鏁版嵁閿欒:', _context11.t0, \" at components/mold.vue:645\");\n _this13.$showMessage('鑾峰彇鏁版嵁澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');\n _this13.toolRecords = [];\n case 27:\n _context11.prev = 27;\n _this13.loadingForm = false;\n return _context11.finish(27);\n case 30:\n case \"end\":\n return _context11.stop();\n }\n }\n }, _callee11, null, [[5, 22, 27, 30]]);\n }))();\n },\n // 鑷姩甯﹀嚭宸ュ崟鍒�鍏蜂俊鎭紝骞惰幏鍙栧伐鍗曟渶鏂伴噰闆嗘暟\n fetchDefaultToolFromWorkOrder: function fetchDefaultToolFromWorkOrder() {\n var _this14 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee12() {\n var _res$data6, res, _ref8, _order$CurrentCjNum, order, warn;\n return _regenerator.default.wrap(function _callee12$(_context12) {\n while (1) {\n switch (_context12.prev = _context12.next) {\n case 0:\n if (_this14.machineNo) {\n _context12.next = 2;\n break;\n }\n return _context12.abrupt(\"return\");\n case 2:\n _context12.prev = 2;\n _context12.next = 5;\n return _this14.$post({\n url: '/Womdaa/GetWomdaasByShow',\n data: JSON.stringify({\n machineNo: _this14.machineNo\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 5:\n res = _context12.sent;\n if (res.status === 0 && Array.isArray((_res$data6 = res.data) === null || _res$data6 === void 0 ? void 0 : _res$data6.tbBillList) && res.data.tbBillList.length > 0) {\n order = res.data.tbBillList[0];\n _this14.selectedToolNo = order.cutterId || order.cutteR_ID || '';\n _this14.toolName = order.cutterName || order.cutteR_NAME || '';\n _this14.toolModel = order.cutterModel || order.cutteR_MODEL || '';\n // 鍏抽敭锛氳幏鍙栧伐鍗曟渶鏂伴噰闆嗘暟\n _this14.workOrderCurrentCjNum = (_ref8 = (_order$CurrentCjNum = order.CurrentCjNum) !== null && _order$CurrentCjNum !== void 0 ? _order$CurrentCjNum : order.currentCjNum) !== null && _ref8 !== void 0 ? _ref8 : null;\n // 鏂板锛氳嚜鍔ㄥ~鍏呭鍛芥瘮棰勮鍊糪n if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\n warn = Number(order.modlLifeWorning);\n _this14.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n } else {\n _this14.lifeWarnInput = '';\n }\n } else {\n _this14.workOrderCurrentCjNum = null;\n }\n _context12.next = 13;\n break;\n case 9:\n _context12.prev = 9;\n _context12.t0 = _context12[\"catch\"](2);\n __f__(\"warn\", '鑷姩甯﹀嚭宸ュ崟鍒�鍏峰け璐�', _context12.t0, \" at components/mold.vue:679\");\n _this14.workOrderCurrentCjNum = null;\n case 13:\n case \"end\":\n return _context12.stop();\n }\n }\n }, _callee12, null, [[2, 9]]);\n }))();\n },\n formatDateTime: function formatDateTime(dateTimeStr) {\n if (!dateTimeStr) return '';\n try {\n var s = String(dateTimeStr).trim();\n if (/^\\d{10}$/.test(s)) {\n var d = new Date(Number(s) * 1000);\n return \"\".concat(d.getMonth() + 1, \"-\").concat(d.getDate(), \" \").concat(d.getHours(), \":\").concat(String(d.getMinutes()).padStart(2, '0'));\n }\n if (/^\\d{13}$/.test(s)) {\n var _d = new Date(Number(s));\n return \"\".concat(_d.getMonth() + 1, \"-\").concat(_d.getDate(), \" \").concat(_d.getHours(), \":\").concat(String(_d.getMinutes()).padStart(2, '0'));\n }\n var date = new Date(dateTimeStr);\n if (!isNaN(date.getTime())) {\n return \"\".concat(date.getMonth() + 1, \"-\").concat(date.getDate(), \" \").concat(date.getHours(), \":\").concat(String(date.getMinutes()).padStart(2, '0'));\n }\n var match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\n if (match) return \"\".concat(match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, function (m) {\n return m;\n }), \" \").concat(match[2]);\n return String(dateTimeStr);\n } catch (_unused) {\n return String(dateTimeStr);\n }\n }\n },\n mounted: function mounted() {\n var _this15 = this;\n this.fetchTools('');\n this.machineNo = uni.getStorageSync('machineNo') || '';\n this.workOrderNo = uni.getStorageSync('daa001') || '';\n if (this.machineNo && this.workOrderNo) {\n this.fetchFormData().then( /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee13() {\n return _regenerator.default.wrap(function _callee13$(_context13) {\n while (1) {\n switch (_context13.prev = _context13.next) {\n case 0:\n _context13.next = 2;\n return _this15.fetchDefaultToolFromWorkOrder();\n case 2:\n // 杩涘叆椤甸潰鏃惰祴鍊肩涓�琛� currentCjNum\n if (_this15.toolRecords.length > 0) {\n _this15.$set(_this15.toolRecords[0], 'currentCjNum', _this15.workOrderCurrentCjNum);\n }\n case 3:\n case \"end\":\n return _context13.stop();\n }\n }\n }, _callee13);\n })));\n } else {\n __f__(\"warn\", '鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇琛ㄥ崟鏁版嵁', \" at components/mold.vue:721\");\n }\n\n // 鍚姩鑷姩淇濆瓨瀹氭椂鍣╘n //this.startAutoSave();\n },\n beforeDestroy: function beforeDestroy() {\n // 娓呯悊瀹氭椂鍣紝闃叉鍐呭瓨娉勬紡\n this.stopAutoSave();\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 1)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/mold.vue"],"names":["data","machineNo","workOrderNo","activeToolNo","pageIndex","pageSize","total","toolList","selectedToolNo","toolName","toolModel","showToolDialog","searchKey","filteredTools","useLimitInput","lifeWarnInput","toolRecords","loadingTools","loadingForm","submitting","_searchTimer","workOrderCurrentCjNum","autoSaveTimer","isDirty","autoSaveIntervalMs","autoSaveEnabled","autoSaveActionName","computed","totalPages","watch","methods","fetchCurrentCjNum","url","headers","res","found","x","handleRefresh","startAutoSave","stopAutoSave","clearInterval","autoSaveTick","fn","normalizeLifeWarn","openToolDialog","closeToolDialog","fetchTools","payload","getField","keys","mapped","no","name","model","lifeWarn","totalFromRes","prevPage","nextPage","onSearchKeyInput","clearTimeout","searchTool","selectTool","confirmTool","setUseLimit","v","isNaN","useLimit","handleUpTool","sdjs","lifeWarnRatio","toolNo","type","modlLifeWorning","uni","title","icon","handleDownTool","xdjs","cancel","fetchFormData","list","percent","warnStatus","id","upTime","upCount","downTime","downCount","useCount","lifePercent","currentCjNum","fetchDefaultToolFromWorkOrder","order","warn","formatDateTime","mounted","beforeDestroy"],"mappings":"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BACA;kBACA;kBAEA;kBACA;oBACA;oBACAC;kBACA;oBACAA;kBACA;kBAEA;oBACAC;oBACAhC;oBACAC;oBACAgC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAtB;oBACAuB;oBACAnC;oBACA4B;oBACAQ;kBACA;gBACA,IAEA;gBACAxC;kBACA;kBACA;oBACA;oBACA;oBACA;oBACA;kBACA;kBACA;gBACA;;gBAEA;gBACAK,mFACArB,gYACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACA;IACAyD;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACA3D;kBACAhC;oBAAAC;kBAAA;kBACAgC;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAKA;kBACA0D;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;oBACAC;oBACA;kBACA;oBACA;kBACA;gBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAC;MACA;MACA;QACA;QACA;UACA;UACA;QACA;QACA;UACA;UACA;QACA;QACA;QACA;UACA;QACA;QACA;QACA;UAAA;QAAA;QACA;MACA;QACA;MACA;IACA;EACA;EACAC;IAAA;IACA;IACA;IACA;IAEA;MACA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBACA;gBACA;kBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CACA;IACA;MACA;IACA;;IAEA;IACA;EACA;EACAC;IACA;IACA;EACA;AACA;AAAA,2B","file":"62.js","sourcesContent":["<template>\n    <view class=\"page\">\n        <!-- 刀具选择区 -->\n        <view class=\"top-section-grid\">\n            <!-- 第一行：移除刀具目录按钮 -->\n            <view class=\"form-row\">\n                <view class=\"form-cell\">\n                    <label class=\"form-label\">刀具编号：</label>\n                    <input class=\"input small-font\" v-model=\"selectedToolNo\" placeholder=\"请通过刀具目录选择\" disabled />\n                </view>\n                <view class=\"form-cell form-cell-flex\">\n                    <label class=\"form-label highlight-label\">使用上限：</label>\n                    <input class=\"input small-font input-use-limit\" type=\"number\" v-model=\"useLimitInput\" placeholder=\"每次上刀时手填上限\" :disabled=\"!selectedToolNo || loadingForm\" />\n                    <label class=\"form-label\" style=\"margin-left:16px;\">寿命比预警值：</label>\n                    <view class=\"input-with-unit\">\n                        <input class=\"input small-font input-life-warn\"\n                               v-model=\"lifeWarnInput\"\n                               placeholder=\"如90\"\n                               :disabled=\"!selectedToolNo || loadingForm\" />\n                        <span class=\"unit-text\">%</span>\n                    </view>\n                </view>\n            </view>\n\n            <!-- 第二行：在最后添加刀具目录按钮 -->\n            <view class=\"form-row\">\n                <!-- 刀具名称 -->\n                <view class=\"form-cell\">\n                    <label class=\"form-label\">刀具名称：</label>\n                    <input class=\"input small-font input-tool-name\" v-model=\"toolName\" placeholder=\"刀具带出\" disabled />\n                </view>\n                <!-- 规格型号 -->\n                <view class=\"form-cell\">\n                    <label class=\"form-label\">规格型号：</label>\n                    <input class=\"input small-font input-tool-model\" v-model=\"toolModel\" placeholder=\"刀具带出\" disabled />\n                </view>\n                <!-- 刀具目录按钮右移 -->\n                <view class=\"form-cell tool-dir-cell\">\n                    <button class=\"btn-blue large-btn\" @click=\"openToolDialog\" :disabled=\"loadingTools\">刀具目录</button>\n                </view>\n                <!-- 新增：刷新按钮 -->\n                <view class=\"form-cell\" style=\"flex:0 0 auto; margin-left:16px;\">\n                    <button class=\"btn-blue large-btn\" @click=\"handleRefresh\" :disabled=\"loadingForm || submitting\">刷新</button>\n                </view>\n            </view>\n        </view>  <!-- 这里闭合 top-section-grid -->\n        <!-- 操作按钮 - 移出 top-section-grid -->\n        <view class=\"button-row\">\n            <button class=\"save-btn\" @click=\"handleUpTool\" :disabled=\"submitting || loadingForm\">上刀提交(=调机开始)</button>\n            <button class=\"save-btn\" @click=\"handleDownTool\" :disabled=\"submitting || loadingForm\">下刀提交</button>\n            <button class=\"cancel-btn\" @click=\"cancel\" :disabled=\"submitting || loadingForm\">清空刀具选择</button>\n        </view>\n\n        <!-- 刀具目录弹窗 -->\n        <view v-if=\"showToolDialog\" class=\"dialog-overlay\">\n            <view class=\"dialog\">\n                <view class=\"form-group\">\n                    <input v-model=\"searchKey\" placeholder=\"输入刀具编码、名称模糊搜索\" class=\"input\" @input=\"onSearchKeyInput\" />\n                    <button class=\"btn-blue\" @click=\"searchTool\" :disabled=\"loadingTools\">搜索</button>\n                </view>\n                <view class=\"tool-list\">\n                    <button v-for=\"tool in filteredTools\"\n                            :key=\"tool.no\"\n                            class=\"tool-btn\"\n                            :class=\"{ active: activeToolNo === tool.no }\"\n                            @click=\"selectTool(tool)\">\n                        {{ tool.no }} | {{ tool.name }}\n                    </button>\n                </view>\n                <view class=\"dialog-actions\">\n                    <div style=\"display: flex; align-items: center;\">\n                        <button class=\"btn-blue\" @click=\"prevPage\" :disabled=\"pageIndex === 1 || loadingTools\">上一页</button>\n                        <span style=\"margin: 0 12px;\">第{{ pageIndex }}页 / 共{{ totalPages }}页</span>\n                        <button class=\"btn-blue\" @click=\"nextPage\" :disabled=\"pageIndex === totalPages || loadingTools\">下一页</button>\n                    </div>\n                    <div style=\"display: flex; gap: 18px; align-items: center;\">\n                        <button class=\"btn-blue\" @click=\"confirmTool\">确定</button>\n                        <button class=\"btn-disabled\" @click=\"closeToolDialog\">取消</button>\n                    </div>\n                </view>\n            </view>\n        </view>\n\n        <!-- 刀具使用记录表格 -->\n        <view class=\"table-section\">\n            <table class=\"styled-table\">\n                <thead>\n                    <tr>\n                        <th style=\"width:7%\">刀具编号</th>\n                        <th style=\"width:12%\">刀具名称</th>\n                        <th style=\"width:10%\">上刀时间</th>\n                        <th class=\"num\" style=\"width:7%\">上刀计数</th>\n                        <th style=\"width:10%\">下刀时间</th>\n                        <th class=\"num\" style=\"width:7%\">下刀计数</th>\n                        <th class=\"num\" style=\"width:7%\">使用次数</th>\n                        <th class=\"num\" style=\"width:7%\">使用上限</th>\n                        <th class=\"num\" style=\"width:7%\">寿命比%</th>\n                        <th class=\"num\" style=\"width:7%\">寿命比预警值</th>\n                        <th style=\"width:7%\">预警状态</th>\n                        <th style=\"width:7%\">刀具在机状态</th>\n                    </tr>\n                </thead>\n                <tbody>\n                    <tr v-for=\"(item, idx) in toolRecords\" :key=\"item.id\" :class=\"{'row-odd': idx % 2 === 0}\">\n                        <td>{{ item.no }}</td>\n                        <td class=\"left\">{{ item.name }}</td>\n                        <td>{{ item.upTime }}</td>\n                        <td class=\"num\">{{ item.upCount != null ? item.upCount : '' }}</td>\n                        <td>{{ item.downTime }}</td>\n                        <!-- 只有第一行显示 currentCjNum，其它行显示 downCount -->\n                        <td class=\"num\">\n                            <template v-if=\"idx === 0\">\n                                <!-- 第一行：下机时不实时显示 currentCjNum，显示 downCount -->\n                                <template v-if=\"!item.downTime\">\n                                    {{ item.currentCjNum != null ? item.currentCjNum : '' }}\n                                </template>\n                                <template v-else>\n                                    {{ item.downCount != null ? item.downCount : '' }}\n                                </template>\n                            </template>\n                            <template v-else>\n                                {{ item.downCount != null ? item.downCount : '' }}\n                            </template>\n                        </td>\n                        <!--使用次数-->\n                        <td class=\"num\">\n                            <template v-if=\"idx === 0\">\n                                <!-- 第一行实时计算使用次数，若为下机则不实时显示 -->\n                                <template v-if=\"!item.downTime\">\n                                    {{item.currentCjNum != null && item.upCount != null ? (Number(item.currentCjNum) - Number(item.upCount)) : (item.useCount != null ? item.useCount : '') }}\n                                </template>\n                                <template v-else>\n                                    {{ item.useCount != null ? item.useCount : '' }}\n                                </template>\n                            </template>\n                            <template v-else>\n                                {{ item.useCount != null ? item.useCount : '' }}\n                            </template>\n                        </td>\n                        <td class=\"num\">{{ item.useLimit != null ? item.useLimit : '' }}</td>\n                        <!--寿命比%-->\n                        <td class=\"num\">\n                            <template v-if=\"idx === 0\">\n                                <!-- 第一行实时计算寿命比%，若为下机则不实时显示 -->\n                                <template v-if=\"!item.downTime\">\n                                    {{item.currentCjNum != null && item.upCount != null && item.useLimit != null && Number(item.useLimit) > 0 ? Math.round((Number(item.currentCjNum) - Number(item.upCount)) / Number(item.useLimit) * 100) + '%' : (item.lifePercent != null ? item.lifePercent : '') }}\n                                </template>\n                                <template v-else>\n                                    {{ item.lifePercent != null ? item.lifePercent : '' }}\n                                </template>\n                            </template>\n                            <template v-else>\n                                {{ item.lifePercent }}\n                            </template>\n                        </td>\n                        <td class=\"num\">{{ item.lifeWarn }}</td>\n                        <td :class=\"item.warnStatus === '预警' ? 'warn-cell' : (item.warnStatus === '正常' ? 'ok-cell' : '')\">\n                            <span v-if=\"item.warnStatus === '预警'\" class=\"warn-badge\">警告</span>\n                            <span v-else>{{ item.warnStatus }}</span>\n                        </td>\n                        <td>\n                            {{ item.downTime ? '下机' : '在机' }}<!--在机状态-->\n                        </td>\n                    </tr>\n                    <tr v-if=\"!toolRecords.length\">\n                        <td colspan=\"12\">暂无数据</td>\n                    </tr>\n                </tbody>\n            </table>\n        </view>\n\n        <!-- 说明 -->\n        <!--<view class=\"tool-desc\">\n            <p style=\"color:red;\">'使用上限'以下刀时的'使用上限'为计算标准</p>\n            <p style=\"color:red;\">寿命比预警值默认为90%</p>\n        </view>-->\n    </view>\n</template>\n\n<script>\n    export default {\n        data() {\n            return {\n                machineNo: '',//机台编码\n                workOrderNo: '',//工单号\n                activeToolNo: '', // 当前选中的刀具编号\n                pageIndex: 1,\n                pageSize: 20, //单页显示的刀具数量\n                total: 0,\n                toolList: [],\n                selectedToolNo: '',\n                toolName: '',\n                toolModel: '',\n                showToolDialog: false,\n                searchKey: '',\n                filteredTools: [],\n                useLimitInput: '',\n                lifeWarnInput: '', // 新增：寿命比预警值原始输入\n                toolRecords: [],\n                loadingTools: false,\n                loadingForm: false,\n                submitting: false,\n                _searchTimer: null,\n                workOrderCurrentCjNum: null, // 工单当前数采\n\n                // 自动保存相关\n                autoSaveTimer: null,\n                isDirty: false, // 表单是否有未保存变更\n                autoSaveIntervalMs: 5 * 60 * 1000, // 默认 5 分钟\n                autoSaveEnabled: true,\n                autoSaveActionName: 'handleUpTool' // 自动触发的方法名，可改为自定义保存方法\n            };\n        },\n        computed: {\n            totalPages() {\n                return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);\n            }\n        },\n        watch: {\n            // 标记脏数据：按需监听字段变化\n            selectedToolNo() { this.isDirty = true; },\n            useLimitInput() { this.isDirty = true; },\n            lifeWarnInput() { this.isDirty = true; },\n            toolName() { this.isDirty = true; },\n            toolModel() { this.isDirty = true; }\n        },\n        methods: {\n            //查询当前数采数，作为下刀计数实时显示\n            async fetchCurrentCjNum(toolNo) {\n                if (!this.machineNo) return null;\n                try {\n                    const res = await this.$post({\n                        url: '/Womdaa/GetWomdaasByShow',\n                        data: JSON.stringify({ machineNo: this.machineNo }),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.status === 0 && Array.isArray(res.data?.tbBillList)) {\n                        const found = res.data.tbBillList.find(x =>\n                            x.cutterId === toolNo || x.cutteR_ID === toolNo\n                        );\n                        return found ? (found.CurrentCjNum ?? found.currentCjNum ?? null) : null;\n                    }\n                } catch (e) {\n                    console.warn('获取currentCjNum失败', e);\n                }\n                return null;\n            },\n\n            // 新增：刷新按钮处理方法\n            async handleRefresh() {\n                this.fetchTools('');\n                if (this.machineNo && this.workOrderNo) {\n                    await this.fetchFormData();\n                    await this.fetchDefaultToolFromWorkOrder();\n                    // 刷新后赋值第一行 currentCjNum\n                    if (this.toolRecords.length > 0) {\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\n                    }\n                }\n                this.$showMessage('刷新完成');\n            },\n            // 自动保存：启动\n            startAutoSave() {\n                if (!this.autoSaveEnabled) return;\n                this.stopAutoSave();\n                this.autoSaveTimer = setInterval(() => {\n                    this.autoSaveTick();\n                }, this.autoSaveIntervalMs);\n            },\n            // 自动保存：停止\n            stopAutoSave() {\n                if (this.autoSaveTimer) {\n                    clearInterval(this.autoSaveTimer);\n                    this.autoSaveTimer = null;\n                }\n            },\n            // 自动保存：每次定时执行时的逻辑\n            async autoSaveTick() {\n                if (!this.autoSaveEnabled) return;\n                if (!this.isDirty) return;\n                if (this.submitting || this.loadingForm) return;\n\n                const fn = this.autoSaveActionName && typeof this[this.autoSaveActionName] === 'function'\n                    ? this[this.autoSaveActionName]\n                    : null;\n                if (!fn) {\n                    console.warn('自动保存：未找到方法', this.autoSaveActionName);\n                    return;\n                }\n\n                try {\n                    this.submitting = true;\n                    await fn.call(this); // 调用保存方法（例如 handleUpTool）\n                    // 如果保存成功，清脏标记（保存方法内部若失败没有抛出可保持此方式）\n                    this.isDirty = false;\n                } catch (e) {\n                    console.error('自动保存失败：', e);\n                } finally {\n                    this.submitting = false;\n                }\n            },\n\n            // 新增：寿命比预警值归一化 (返回 0~1 或 null)\n            normalizeLifeWarn(v) {\n                if (v == null) return null;\n                const raw = String(v).trim().replace(/[%％]/g, '');\n                if (raw === '') return null;\n                const num = Number(raw);\n                if (!isFinite(num) || num <= 0) return null;\n                return num > 1 ? (num / 100) : num;\n            },\n            openToolDialog() {\n                this.showToolDialog = true;\n                this.pageIndex = 1;\n                this.fetchTools(this.searchKey);\n            },\n            closeToolDialog() {\n                this.showToolDialog = false;\n            },\n            async fetchTools(searchKey) {\n                this.loadingTools = true;\n                try {\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/QueryTools',\n                        data: JSON.stringify({\n                            searchKey,\n                            pageIndex: this.pageIndex,\n                            pageSize: this.pageSize\n                        }),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n\n                    if (res.status === 0) {\n                        const payload = Array.isArray(res.data) ? res.data\n                            : (res.data && res.data.tbBillList) ? res.data.tbBillList\n                                : (res.data && res.data.data) ? res.data.data\n                                    : [];\n\n                        const getField = (obj, ...keys) => {\n                            for (const k of keys) if (obj?.[k] !== undefined && obj?.[k] !== null) return obj[k];\n                            return null;\n                        };\n\n                        // 这里需要把 lifeWarn 字段也带出来\n                        const mapped = (payload || []).map(t => ({\n                            no: getField(t, 'cutterId', 'CUTTER_ID', 'cutteR_ID', 'daA001', 'no'),\n                            name: getField(t, 'cutterName', 'CUTTER_NAME', 'cutteR_NAME', 'name'),\n                            model: getField(t, 'cutterModel', 'CUTTER_MODEL', 'cutteR_MODEL', 'model'),\n                            lifeWarn: getField(t, 'modlLifeWorning', 'lifeWarn', 'LIFE_WARN', 'lifE_WARN')\n                        }));\n\n                        this.filteredTools = mapped;\n                        this.toolList = mapped.slice();\n\n                        const totalFromRes = Number(\n                            res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\n                        );\n                        this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n                        if (this.pageIndex > this.totalPages) {\n                            this.pageIndex = this.totalPages;\n                        }\n                    } else {\n                        this.$showMessage(res.message || '查询失败');\n                    }\n                } catch (err) {\n                    console.error('fetchTools 错误：', err);\n                    this.$showMessage('查询刀具失败，请检查网络或接口');\n                } finally {\n                    this.loadingTools = false;\n                }\n            },\n            async prevPage() {\n                if (this.pageIndex > 1) {\n                    this.pageIndex--;\n                    await this.fetchTools(this.searchKey);\n                }\n            },\n            async nextPage() {\n                if (this.pageIndex < this.totalPages) {\n                    this.pageIndex++;\n                    await this.fetchTools(this.searchKey);\n                }\n            },\n            onSearchKeyInput() {\n                clearTimeout(this._searchTimer);\n                this._searchTimer = setTimeout(() => {\n                    this.searchTool();\n                }, 300);\n            },\n            async searchTool() {\n                this.pageIndex = 1;\n                await this.fetchTools(this.searchKey);\n            },\n            selectTool(tool) {\n                this.selectedToolNo = tool.no;\n                this.toolName = tool.name;\n                this.toolModel = tool.model;\n                this.activeToolNo = tool.no;\n                // 新增：带出寿命比预警值\n                if (tool.lifeWarn !== undefined && tool.lifeWarn !== null) {\n                    // 格式化为百分比字符串\n                    const warn = Number(tool.lifeWarn);\n                    this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n                } else {\n                    this.lifeWarnInput = '';\n                }\n            },\n            confirmTool() {\n                this.showToolDialog = false;\n            },\n            async setUseLimit() {\n                if (!this.selectedToolNo) {\n                    this.$showMessage('请选择刀具后再设置上限');\n                    return;\n                }\n                const v = Number(this.useLimitInput);\n                if (isNaN(v) || v <= 0) {\n                    this.$showMessage('请输入有效的使用上限');\n                    return;\n                }\n                this.toolRecords = this.toolRecords.map(r => {\n                    if (r.no === this.selectedToolNo) {\n                        return { ...r, useLimit: v };\n                    }\n                    return r;\n                });\n                this.toolList = this.toolList.map(t => t.no === this.selectedToolNo ? { ...t, useLimit: v } : t);\n                this.$showMessage('使用上限已设置（仅前端显示）');\n            },\n            // 上刀时传递 sdjs = 工单 currentCjNum\n            async handleUpTool() {\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\n                //上刀强制录入使用上限\n                if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\n                const useLimit = Number(this.useLimitInput);\n                if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\n\n                // sdjs 使用工单 currentCjNum\n                const sdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\n                const payload = {\n                    workOrderNo: this.workOrderNo,\n                    machineNo: this.machineNo,\n                    toolNo: this.selectedToolNo,\n                    type: '上机',\n                    useLimit,\n                    sdjs,// 上刀计数（工单当前数采）\n                    modlLifeWorning: lifeWarnRatio // 新增\n                };\n                try {\n                    this.submitting = true;\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/SubmitToolAction',\n                        data: JSON.stringify(payload),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.data && res.data.outSum === \"0\") {\n                        uni.showToast({\n                            title: res.data.outMsg || '',\n                            icon: 'error'\n                        });\n                        return;\n                    } else if (res.data && res.data.outMsg) {\n                        uni.showToast({\n                            title: res.data.outMsg,\n                            icon: 'none'\n                        });\n                    }\n                    // 后续逻辑继续执行\n                    if (res.status === 0) {\n                        await this.fetchFormData();\n                    }\n                } catch (err) {\n                    console.error(err);\n                    this.$showMessage('上刀提交失败，请检查网络');\n                    throw err; // 抛出以便自动保存逻辑捕获并保留 isDirty\n                } finally {\n                    this.submitting = false;\n                }\n            },\n            // 下刀时传递 xdjs = 工单 currentCjNum\n            async handleDownTool() {\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\n                //下刀不强制录入使用上限\n                //if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\n                const useLimit = Number(this.useLimitInput);\n                //if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\n\n                // 下刀计数同样取工单最新采集数\n                const xdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\n                const payload = {\n                    workOrderNo: this.workOrderNo,\n                    machineNo: this.machineNo,\n                    toolNo: this.selectedToolNo,\n                    type: '下机',\n                    useLimit,\n                    xdjs,// 下刀计数\n                    modlLifeWorning: lifeWarnRatio // 新增\n                };\n                try {\n                    this.submitting = true;\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/SubmitToolAction',\n                        data: JSON.stringify(payload),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.data && res.data.outSum === \"0\") {\n                        uni.showToast({\n                            title: res.data.outMsg || '',\n                            icon: 'error'\n                        });\n                        return;\n                    } else if (res.data && res.data.outMsg) {\n                        uni.showToast({\n                            title: res.data.outMsg,\n                            icon: 'none'\n                        });\n                    }\n                    // 后续逻辑继续执行\n                    if (res.status === 0) {\n                        await this.fetchFormData();\n                    }\n                } catch (err) {\n                    console.error(err);\n                    this.$showMessage('下刀提交失败，请检查网络');\n                    throw err;\n                } finally {\n                    this.submitting = false;\n                }\n            },\n            cancel() {\n                this.selectedToolNo = '';\n                this.toolName = '';\n                this.toolModel = '';\n                this.useLimitInput = '';\n                this.lifeWarnInput = ''; // 新增：清空\n                this.isDirty = false;\n            },\n            async fetchFormData() {\n                if (!this.workOrderNo || !this.machineNo) {\n                    console.warn('工单号或机台号为空，跳过获取表单数据');\n                    return;\n                }\n                this.loadingForm = true;\n                const payload = {\n                    workOrderNo: this.workOrderNo.trim(),\n                    machineNo: this.machineNo.trim()\n                };\n                try {\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/GetFormData',\n                        data: JSON.stringify(payload),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.status !== 0) {\n                        this.$showMessage(res.message || '获取表单数据失败');\n                        this.toolRecords = [];\n                        return;\n                    }\n                    const list = Array.isArray(res.data) ? res.data\n                        : (res.data && res.data.tbBillList) ? res.data.tbBillList\n                            : (res.data && res.data.data) ? res.data.data\n                                : [];\n\n                    const getField = (obj, ...keys) => {\n                        for (const k of keys) if (obj?.[k] !== undefined && obj?.[k] !== null) return obj[k];\n                        return null;\n                    };\n\n                    const mapped = (list || []).map(t => {\n                        const upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\n                        const downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\n                        const lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\n                        const currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\n\n                        const useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\n                        const useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\n\n                        let percent = '';\n                        if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n                            percent = ((Number(useCount) / Number(useLimit)) * 100).toFixed(0) + '%';\n                        }\n\n                        const parseNumber = v => {\n                            if (v === null || v === undefined || v === '') return null;\n                            const s = String(v).replace(/[,％%]/g, '').trim();\n                            const n = parseFloat(s);\n                            return Number.isFinite(n) ? n : null;\n                        };\n                        const formatPercent = n => {\n                            if (n === null || n === undefined || isNaN(n)) return '';\n                            if (n <= 1) return `${(n * 100).toFixed(0)}%`;\n                            return `${Number(n).toFixed(0)}%`;\n                        };\n                        const lifeWarnNum = parseNumber(lifeWarnRaw);\n\n                        let warnStatus = getField(t, 'status', 'STATUS') || '';\n                        if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n                            const percentNum = Number(useCount) / Number(useLimit);\n                            warnStatus = (percentNum >= lifeWarnNum) ? '预警' : '正常';\n                        } else {\n                            warnStatus = warnStatus || '未知';\n                        }\n\n                        return {\n                            id: getField(t, 'id', 'ID') || `${getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || ''}-${upTimeRaw || ''}`,\n                            no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\n                            name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\n                            upTime: this.formatDateTime(upTimeRaw),\n                            upCount: getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount') ?? '',\n                            downTime: this.formatDateTime(downTimeRaw),\n                            downCount: getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount') ?? '',\n                            useCount: useCount ?? '',\n                            useLimit: useLimit ?? '',\n                            lifePercent: percent,\n                            lifeWarn: formatPercent(lifeWarnNum),\n                            warnStatus,\n                            currentCjNum\n                        };\n                    });\n\n                    // 新增：按上刀时间降序排序（越晚的越上面）\n                    mapped.sort((a, b) => {\n                        // 时间格式如 \"10-24 16:03\"，转为 Date 对象比较\n                        const parse = s => {\n                            if (!s) return 0;\n                            // 补年份，假设都是今年\n                            const year = new Date().getFullYear();\n                            return new Date(`${year}-${s.replace(/-/g, '-')}:00`).getTime();\n                        };\n                        return parse(b.upTime) - parse(a.upTime); // 注意这里顺序反过来\n                    });\n\n                    this.toolRecords = mapped;\n                    const totalFromRes = Number(\n                        res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\n                    );\n                    this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n                } catch (error) {\n                    console.error('获取表单数据错误:', error);\n                    this.$showMessage('获取数据失败，请检查网络连接');\n                    this.toolRecords = [];\n                } finally {\n                    this.loadingForm = false;\n                }\n            },\n            // 自动带出工单刀具信息，并获取工单最新采集数\n            async fetchDefaultToolFromWorkOrder() {\n                if (!this.machineNo) return;\n                try {\n                    const res = await this.$post({\n                        url: '/Womdaa/GetWomdaasByShow',\n                        data: JSON.stringify({ machineNo: this.machineNo }),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.status === 0 && Array.isArray(res.data?.tbBillList) && res.data.tbBillList.length > 0) {\n                        const order = res.data.tbBillList[0];\n                        this.selectedToolNo = order.cutterId || order.cutteR_ID || '';\n                        this.toolName = order.cutterName || order.cutteR_NAME || '';\n                        this.toolModel = order.cutterModel || order.cutteR_MODEL || '';\n                        // 关键：获取工单最新采集数\n                        this.workOrderCurrentCjNum = order.CurrentCjNum ?? order.currentCjNum ?? null;\n                        // 新增：自动填充寿命比预警值\n                        if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\n                            const warn = Number(order.modlLifeWorning);\n                            this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n                        } else {\n                            this.lifeWarnInput = '';\n                        }\n                    } else {\n                        this.workOrderCurrentCjNum = null;\n                    }\n                } catch (e) {\n                    console.warn('自动带出工单刀具失败', e);\n                    this.workOrderCurrentCjNum = null;\n                }\n            },\n            formatDateTime(dateTimeStr) {\n                if (!dateTimeStr) return '';\n                try {\n                    const s = String(dateTimeStr).trim();\n                    if (/^\\d{10}$/.test(s)) {\n                        const d = new Date(Number(s) * 1000);\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\n                    }\n                    if (/^\\d{13}$/.test(s)) {\n                        const d = new Date(Number(s));\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\n                    }\n                    const date = new Date(dateTimeStr);\n                    if (!isNaN(date.getTime())) {\n                        return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${String(date.getMinutes()).padStart(2, '0')}`;\n                    }\n                    const match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\n                    if (match) return `${match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, (m) => m)} ${match[2]}`;\n                    return String(dateTimeStr);\n                } catch {\n                    return String(dateTimeStr);\n                }\n            }\n        },\n        mounted() {\n            this.fetchTools('');\n            this.machineNo = uni.getStorageSync('machineNo') || '';\n            this.workOrderNo = uni.getStorageSync('daa001') || '';\n\n            if (this.machineNo && this.workOrderNo) {\n                this.fetchFormData().then(async () => {\n                    await this.fetchDefaultToolFromWorkOrder();\n                    // 进入页面时赋值第一行 currentCjNum\n                    if (this.toolRecords.length > 0) {\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\n                    }\n                });\n            } else {\n                console.warn('机台号或工单号为空，无法获取表单数据');\n            }\n\n            // 启动自动保存定时器\n            //this.startAutoSave();\n        },\n        beforeDestroy() {\n            // 清理定时器，防止内存泄漏\n            this.stopAutoSave();\n        }\n    };\n</script>\n\n<style scoped>\n    .top-section-grid {\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: flex-start;\n        gap: 12px;\n        margin-bottom: 2vh;\n        width: 99vw;\n        max-width: 1920px;\n        margin-left: auto;\n        margin-right: auto;\n        padding: 12px;\n        background: #f8f9fa;\n        border-radius: 8px;\n        border: 1px solid #e9ecef;\n    }\n\n    .form-row {\n        display: flex;\n        flex-direction: row;\n        justify-content: flex-start;\n        align-items: center;\n        width: 100%;\n        margin-bottom: 12px;\n    }\n\n        .form-row:last-child {\n            margin-bottom: 0;\n        }\n\n    .form-cell {\n        display: flex;\n        align-items: center;\n        min-width: 0;\n        margin-right: 0;\n    }\n\n        .form-cell:nth-child(1) {\n            flex: 0 0 28%;\n            min-width: 180px;\n        }\n\n        .form-cell:nth-child(2) {\n            flex: 0 0 32%;\n            min-width: 180px;\n            justify-content: flex-start;\n        }\n\n        .form-cell:nth-child(3) {\n            flex: 0 0 auto;\n            min-width: 0;\n            max-width: 220px; /* 限制最大宽度，避免撑开 */\n            justify-content: flex-end;\n        }\n\n    .form-label {\n        width: auto;\n        font-weight: 500;\n        color: #333;\n        white-space: nowrap;\n        margin-right: 4px;\n        flex-shrink: 0;\n        font-size: 22px;\n    }\n\n    .input {\n        padding: 14px 20px;\n        border: 1px solid #dcdfe6;\n        flex: 1;\n        margin-right: 0;\n        border-radius: 4px;\n        background: #fff;\n        min-width: 0;\n        height: 56px !important;\n        box-sizing: border-box;\n        font-size: 22px;\n    }\n\n        .input.small-font {\n            /* 不设置字体大小 */\n        }\n\n        .input:disabled {\n            background-color: #f5f7fa;\n            color: #c0c4cc;\n            cursor: not-allowed;\n        }\n\n    .input-with-unit {\n        display: flex;\n        align-items: center;\n        gap: 0;\n    }\n\n        .input-with-unit .input {\n            width: 60px !important;\n            min-width: 0 !important;\n            margin-right: 2px !important;\n            text-align: center;\n            padding-left: 2px;\n            padding-right: 2px;\n        }\n\n        .input-with-unit .input {\n            margin-right: 4px !important;\n            width: 60px !important;\n            min-width: 0 !important;\n            text-align: center;\n        }\n\n    .unit-text {\n        margin-left: 0 !important;\n        padding-left: 0 !important;\n        font-size: 22px !important;\n    }\n\n    .btn-blue, .btn-blue.large-btn {\n        background-color: #1890ff;\n        color: white;\n        border: none;\n        padding: 14px 32px;\n        border-radius: 4px;\n        cursor: pointer;\n        font-weight: 500;\n        white-space: nowrap;\n        height: 70px !important;\n        box-sizing: border-box;\n        transition: all 0.3s;\n        flex-shrink: 0;\n        min-width: 140px;\n        margin-left: 24px;\n    }\n\n        .btn-blue.large-btn {\n            padding: 0 60px;\n            min-width: 180px;\n            height: 72px !important;\n            margin-left: 0 !important;\n            font-size: 1.3em;\n            box-shadow: 0 2px 8px rgba(24,144,255,0.08);\n            line-height: 72px; /* 垂直居中 */\n            display: inline-block; /* 保证line-height生效 */\n            vertical-align: middle;\n        }\n\n        .btn-blue:hover {\n            background-color: #40a9ff;\n        }\n\n        .btn-blue:active {\n            background-color: #096dd9;\n        }\n\n        .btn-blue:disabled {\n            background: #bae7ff;\n            color: #91d5ff;\n            cursor: not-allowed;\n        }\n\n    .button-row {\n        display: flex;\n        justify-content: center;\n        gap: 32px;\n        margin: 2vh 0;\n    }\n\n    .save-btn, .cancel-btn {\n        width: 28%;\n        padding: 1.5vh;\n        background-color: #00A2E9;\n        color: white;\n        border: none;\n        text-align: center;\n        border-radius: 4px;\n        transition: all 0.3s;\n        font-size: 22px;\n        font-weight: 500;\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n    }\n\n    .cancel-btn {\n        background-color: #f5f5f5;\n        color: #333;\n    }\n\n    .save-btn:hover {\n        background-color: #40a9ff;\n    }\n\n    .save-btn:active {\n        background-color: #096dd9;\n    }\n\n    .save-btn:disabled, .cancel-btn:disabled {\n        opacity: 0.6;\n        cursor: not-allowed;\n    }\n\n    /* 弹窗样式 */\n    .dialog-overlay {\n        position: fixed;\n        top: 0;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        background: rgba(0,0,0,0.18);\n        display: flex;\n        justify-content: center;\n        align-items: center;\n        z-index: 1000;\n    }\n\n    .dialog {\n        background: #fff;\n        padding: 3vh 3vw;\n        border-radius: 18px;\n        width: 90vw;\n        max-width: 1600px;\n        min-height: 70vh;\n        max-height: 85vh;\n        box-sizing: border-box;\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\n        display: flex;\n        flex-direction: column;\n    }\n\n    .form-group {\n        display: flex;\n        gap: 12px;\n        align-items: center;\n        margin-bottom: 2vh;\n        flex-shrink: 0;\n    }\n\n        .form-group .input {\n            flex: 1;\n            min-width: 300px;\n            border-radius: 6px;\n            background: #f8f8f8;\n        }\n\n    .tool-list {\n        display: flex;\n        flex-wrap: wrap;\n        margin: 1vh 0;\n        flex: 1;\n        overflow-y: auto;\n        gap: 12px;\n        align-content: flex-start;\n    }\n\n    .tool-btn {\n        flex: 0 0 calc(20% - 10px);\n        box-sizing: border-box;\n        padding: 10px 12px;\n        background: #f5f5f5;\n        border: 1px solid #d0d0d0;\n        border-radius: 8px;\n        cursor: pointer;\n        color: #333;\n        text-align: left;\n        min-height: 50px;\n        transition: background 0.15s, color 0.15s;\n        overflow: hidden;\n        text-overflow: ellipsis;\n        white-space: nowrap;\n        line-height: 1.4;\n    }\n\n        .tool-btn.active {\n            background: #00A2E9;\n            color: #fff;\n            font-weight: bold;\n            border: 1.5px solid #0086c2;\n        }\n\n    .dialog-actions {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n        margin-top: 2vh;\n        padding-top: 2vh;\n        border-top: 1px solid #eee;\n        flex-shrink: 0;\n    }\n\n        .dialog-actions > div:first-child {\n            display: flex;\n            align-items: center;\n            gap: 24px;\n        }\n\n        .dialog-actions > div:last-child {\n            display: flex;\n            flex-direction: row;\n            gap: 18px;\n            align-items: center;\n        }\n\n        .dialog-actions .btn-blue {\n            padding: 10px 24px;\n            min-width: 120px;\n            font-size: 22px;\n        }\n\n    .btn-disabled {\n        background: #f2f2f2;\n        color: #999;\n        border: none;\n        padding: 10px 24px;\n        border-radius: 4px;\n        font-weight: 500;\n        cursor: not-allowed;\n        box-shadow: none;\n        min-width: 120px;\n    }\n\n    .table-section {\n        display: flex;\n        justify-content: center;\n        margin: 1vh 0;\n        overflow-x: auto;\n        width: 100%; /* 确保表格容器占满宽度 */\n    }\n\n    table.styled-table {\n        max-width: 1800px; /* 从1600px增加到1800px */\n        width: 98vw; /* 从95vw增加到98vw */\n        margin: 0 auto;\n        border-collapse: separate;\n        border-spacing: 0;\n        border: 2px solid #bfbfbf;\n        background: #fff;\n        border-radius: 12px;\n        overflow: hidden;\n        box-shadow: 0 2px 12px rgba(0,0,0,0.06);\n    }\n\n        table.styled-table thead th {\n            background: #fafafa;\n            border-bottom: 2px solid #bfbfbf;\n            padding: 16px 10px;\n            font-weight: bold;\n            text-align: center;\n            font-size: 22px;\n        }\n\n        table.styled-table tbody td {\n            border-bottom: 1px solid #e8e8e8;\n            padding: 14px 10px;\n            vertical-align: middle;\n            text-align: center;\n            font-size: 22px;\n        }\n\n    .table-section table th:first-child, .table-section table td:first-child {\n        border-left: 2px solid #bfbfbf;\n    }\n\n    .table-section table th:last-child, .table-section table td:last-child {\n        border-right: 2px solid #bfbfbf;\n    }\n\n    .row-odd {\n        background: #fff;\n    }\n\n        .row-odd + tr {\n            background: #fafafa;\n        }\n\n    .num {\n        text-align: center;\n        padding-right: 0;\n        font-variant-numeric: tabular-nums;\n    }\n\n    .left {\n        text-align: left;\n        padding-left: 8px;\n    }\n\n    .warn-cell {\n        color: #d93025;\n        font-weight: bold;\n    }\n\n    .ok-cell {\n        color: #333;\n    }\n\n    .warn-badge {\n        display: inline-block;\n        background: #ff4d4f;\n        color: #fff;\n        padding: 2px 6px;\n        border-radius: 3px;\n        font-weight: bold;\n    }\n\n    /* 响应式调整 */\n    @media (max-width: 1200px) {\n        .form-cell {\n            margin: 0 4px;\n        }\n\n        .form-label {\n            width: 90px;\n        }\n\n        .input {\n            padding: 10px 14px;\n        }\n\n        .btn-blue {\n            padding: 10px 18px;\n        }\n    }\n\n    .input-life-warn {\n        width: 48px !important; /* 稍微放宽，避免字体溢出 */\n        min-width: 0 !important;\n        margin-right: 4px;\n        padding-left: 2px;\n        padding-right: 2px;\n        font-size: 22px !important;\n        text-align: center;\n        box-sizing: border-box;\n    }\n\n    .input,\n    .input.small-font,\n    .input-use-limit,\n    .input-tool-model,\n    .input-tool-name,\n    .input-life-warn {\n        font-size: 22px !important;\n    }\n\n    .input-tool-model {\n        width: 320px !important; /* 原为200px，现加长 */\n        min-width: 0 !important;\n        margin-right: 16px;\n    }\n\n    .input-tool-name {\n        width: 120px !important;\n        min-width: 0 !important;\n        margin-right: 16px;\n    }\n\n    .highlight-label {\n        color: #1890ff !important;\n    }\n\n    .tool-dir-cell {\n        flex: 0 0 auto !important;\n        justify-content: flex-start !important;\n        display: flex !important;\n        align-items: center;\n        margin-left: 16px; /* 与规格型号输入框拉开距离 */\n    }\n\n    .form-cell-flex {\n        display: flex;\n        align-items: center;\n        flex: 0 0 60%;\n        min-width: 320px;\n    }\n\n        .form-cell-flex .form-label {\n            margin-right: 4px;\n            width: auto;\n        }\n\n        .form-cell-flex .input-use-limit {\n            margin-right: 12px;\n        }\n\n    .input-use-limit {\n        width: 450px !important;\n        min-width: 0 !important;\n        margin-right: 16px;\n        flex: none !important; /* 关键：彻底禁止flex拉伸 */\n    }\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///62\n");
+eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 3));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 6));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 9));\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n data: function data() {\n return {\n machineNo: '',\n //鏈哄彴缂栫爜\n workOrderNo: '',\n //宸ュ崟鍙穃n activeToolNo: '',\n // 褰撳墠閫変腑鐨勫垁鍏风紪鍙穃n pageIndex: 1,\n pageSize: 20,\n //鍗曢〉鏄剧ず鐨勫垁鍏锋暟閲廫n total: 0,\n toolList: [],\n selectedToolNo: '',\n toolName: '',\n toolModel: '',\n showToolDialog: false,\n searchKey: '',\n filteredTools: [],\n useLimitInput: '',\n lifeWarnInput: '',\n // 鏂板锛氬鍛芥瘮棰勮鍊煎師濮嬭緭鍏n toolRecords: [],\n loadingTools: false,\n loadingForm: false,\n submitting: false,\n _searchTimer: null,\n workOrderCurrentCjNum: null,\n // 宸ュ崟褰撳墠鏁伴噰\n\n // 鑷姩淇濆瓨鐩稿叧\n autoSaveTimer: null,\n isDirty: false,\n // 琛ㄥ崟鏄惁鏈夋湭淇濆瓨鍙樻洿\n autoSaveIntervalMs: 5 * 60 * 1000,\n // 榛樿 5 鍒嗛挓\n autoSaveEnabled: true,\n autoSaveActionName: 'handleUpTool',\n // 鑷姩瑙﹀彂鐨勬柟娉曞悕锛屽彲鏀逛负鑷畾涔変繚瀛樻柟娉昞n\n // 鏂板锛氳皟鏈虹浉鍏冲瓧娈礬n isTiaojiUserSelectShow: false,\n // 璋冩満甯堝倕閫夋嫨寮圭獥\n tiaojiStaffNo: '',\n // 褰撳墠閫変腑鐨勮皟鏈哄笀鍌�(鏍煎紡: 宸ュ彿:濮撳悕)\n tiaojiOkQty: '',\n // 璋冩満鑹搧鏁癨n tiaojiBadQty: '',\n // 璋冩満涓嶈壇鍝佹暟\n tiaojiUsers: [],\n // 璋冩満甯堝倕鍒楄〃\n tiaojiUserSearch: '',\n // 鎼滅储鍏抽敭璇峔n\n // 鏂板锛氭姤璇曚骇鏁版墍闇�瀛楁\n orderId: null,\n // 宸ュ崟ID\n order: {} // 宸ュ崟鏁版嵁\n };\n },\n\n computed: {\n totalPages: function totalPages() {\n return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);\n },\n // 鏂板锛氳皟鏈哄笀鍌呮樉绀哄悕绉癨n tiaojiStaffDisplay: function tiaojiStaffDisplay() {\n if (!this.tiaojiStaffNo) return '';\n var segs = this.tiaojiStaffNo.split(':');\n return segs.length > 1 ? \"\".concat(segs[0], \" \").concat(segs[1]) : this.tiaojiStaffNo;\n },\n // 鏂板锛氳繃婊ゅ悗鐨勮皟鏈哄笀鍌呭垪琛╘n filteredTiaojiUsers: function filteredTiaojiUsers() {\n if (!this.tiaojiUserSearch) return this.tiaojiUsers;\n var kw = this.tiaojiUserSearch.trim().toLowerCase();\n return this.tiaojiUsers.filter(function (u) {\n return u.toLowerCase().includes(kw);\n });\n }\n },\n watch: {\n // 鏍囪鑴忔暟鎹細鎸夐渶鐩戝惉瀛楁鍙樺寲\n selectedToolNo: function selectedToolNo() {\n this.isDirty = true;\n },\n useLimitInput: function useLimitInput() {\n this.isDirty = true;\n },\n lifeWarnInput: function lifeWarnInput() {\n this.isDirty = true;\n },\n toolName: function toolName() {\n this.isDirty = true;\n },\n toolModel: function toolModel() {\n this.isDirty = true;\n }\n },\n methods: {\n //鏌ヨ褰撳墠鏁伴噰鏁帮紝浣滀负涓嬪垁璁℃暟瀹炴椂鏄剧ず\n fetchCurrentCjNum: function fetchCurrentCjNum(toolNo) {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var _res$data, res, _ref, _found$CurrentCjNum, found;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (_this.machineNo) {\n _context.next = 2;\n break;\n }\n return _context.abrupt(\"return\", null);\n case 2:\n _context.prev = 2;\n _context.next = 5;\n return _this.$post({\n url: '/Womdaa/GetWomdaasByShow',\n data: JSON.stringify({\n machineNo: _this.machineNo\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 5:\n res = _context.sent;\n if (!(res.status === 0 && Array.isArray((_res$data = res.data) === null || _res$data === void 0 ? void 0 : _res$data.tbBillList))) {\n _context.next = 9;\n break;\n }\n found = res.data.tbBillList.find(function (x) {\n return x.cutterId === toolNo || x.cutteR_ID === toolNo;\n });\n return _context.abrupt(\"return\", found ? (_ref = (_found$CurrentCjNum = found.CurrentCjNum) !== null && _found$CurrentCjNum !== void 0 ? _found$CurrentCjNum : found.currentCjNum) !== null && _ref !== void 0 ? _ref : null : null);\n case 9:\n _context.next = 14;\n break;\n case 11:\n _context.prev = 11;\n _context.t0 = _context[\"catch\"](2);\n __f__(\"warn\", '鑾峰彇currentCjNum澶辫触', _context.t0, \" at components/mold.vue:334\");\n case 14:\n return _context.abrupt(\"return\", null);\n case 15:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, null, [[2, 11]]);\n }))();\n },\n // 鏂板锛氬埛鏂版寜閽鐞嗘柟娉昞n handleRefresh: function handleRefresh() {\n var _this2 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {\n return _regenerator.default.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n _this2.fetchTools('');\n if (!(_this2.machineNo && _this2.workOrderNo)) {\n _context2.next = 7;\n break;\n }\n _context2.next = 4;\n return _this2.fetchFormData();\n case 4:\n _context2.next = 6;\n return _this2.fetchDefaultToolFromWorkOrder();\n case 6:\n // 鍒锋柊鍚庤祴鍊肩涓�琛� currentCjNum\n if (_this2.toolRecords.length > 0) {\n _this2.$set(_this2.toolRecords[0], 'currentCjNum', _this2.workOrderCurrentCjNum);\n }\n case 7:\n _this2.$showMessage('鍒锋柊瀹屾垚');\n case 8:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }))();\n },\n // 鑷姩淇濆瓨锛氬惎鍔╘n startAutoSave: function startAutoSave() {\n var _this3 = this;\n if (!this.autoSaveEnabled) return;\n this.stopAutoSave();\n this.autoSaveTimer = setInterval(function () {\n _this3.autoSaveTick();\n }, this.autoSaveIntervalMs);\n },\n // 鑷姩淇濆瓨锛氬仠姝n stopAutoSave: function stopAutoSave() {\n if (this.autoSaveTimer) {\n clearInterval(this.autoSaveTimer);\n this.autoSaveTimer = null;\n }\n },\n // 鑷姩淇濆瓨锛氭瘡娆″畾鏃舵墽琛屾椂鐨勯�昏緫\n autoSaveTick: function autoSaveTick() {\n var _this4 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {\n var fn;\n return _regenerator.default.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n if (_this4.autoSaveEnabled) {\n _context3.next = 2;\n break;\n }\n return _context3.abrupt(\"return\");\n case 2:\n if (_this4.isDirty) {\n _context3.next = 4;\n break;\n }\n return _context3.abrupt(\"return\");\n case 4:\n if (!(_this4.submitting || _this4.loadingForm)) {\n _context3.next = 6;\n break;\n }\n return _context3.abrupt(\"return\");\n case 6:\n fn = _this4.autoSaveActionName && typeof _this4[_this4.autoSaveActionName] === 'function' ? _this4[_this4.autoSaveActionName] : null;\n if (fn) {\n _context3.next = 10;\n break;\n }\n __f__(\"warn\", '鑷姩淇濆瓨锛氭湭鎵惧埌鏂规硶', _this4.autoSaveActionName, \" at components/mold.vue:377\");\n return _context3.abrupt(\"return\");\n case 10:\n _context3.prev = 10;\n _this4.submitting = true;\n _context3.next = 14;\n return fn.call(_this4);\n case 14:\n // 璋冪敤淇濆瓨鏂规硶锛堜緥濡� handleUpTool锛塡n // 濡傛灉淇濆瓨鎴愬姛锛屾竻鑴忔爣璁帮紙淇濆瓨鏂规硶鍐呴儴鑻ュけ璐ユ病鏈夋姏鍑哄彲淇濇寔姝ゆ柟寮忥級\n _this4.isDirty = false;\n _context3.next = 20;\n break;\n case 17:\n _context3.prev = 17;\n _context3.t0 = _context3[\"catch\"](10);\n __f__(\"error\", '鑷姩淇濆瓨澶辫触锛�', _context3.t0, \" at components/mold.vue:387\");\n case 20:\n _context3.prev = 20;\n _this4.submitting = false;\n return _context3.finish(20);\n case 23:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, null, [[10, 17, 20, 23]]);\n }))();\n },\n // 鏂板锛氬鍛芥瘮棰勮鍊煎綊涓�鍖� (杩斿洖 0~1 鎴� null)\n normalizeLifeWarn: function normalizeLifeWarn(v) {\n if (v == null) return null;\n var raw = String(v).trim().replace(/[%锛匽/g, '');\n if (raw === '') return null;\n var num = Number(raw);\n if (!isFinite(num) || num <= 0) return null;\n return num > 1 ? num / 100 : num;\n },\n openToolDialog: function openToolDialog() {\n this.showToolDialog = true;\n this.pageIndex = 1;\n this.fetchTools(this.searchKey);\n },\n closeToolDialog: function closeToolDialog() {\n this.showToolDialog = false;\n },\n fetchTools: function fetchTools(searchKey) {\n var _this5 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4() {\n var res, _ref2, _ref3, _ref4, _res$data$total, _res$data2, _res$data3, payload, getField, mapped, totalFromRes;\n return _regenerator.default.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n _this5.loadingTools = true;\n _context4.prev = 1;\n _context4.next = 4;\n return _this5.$post({\n url: '/MesCutterLedger/QueryTools',\n data: JSON.stringify({\n searchKey: searchKey,\n pageIndex: _this5.pageIndex,\n pageSize: _this5.pageSize\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 4:\n res = _context4.sent;\n if (res.status === 0) {\n payload = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : [];\n getField = function getField(obj) {\n for (var _len = arguments.length, keys = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n keys[_key - 1] = arguments[_key];\n }\n for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {\n var k = _keys[_i];\n if ((obj === null || obj === void 0 ? void 0 : obj[k]) !== undefined && (obj === null || obj === void 0 ? void 0 : obj[k]) !== null) return obj[k];\n }\n return null;\n }; // 杩欓噷闇�瑕佹妸 lifeWarn 瀛楁涔熷甫鍑烘潵\n mapped = (payload || []).map(function (t) {\n return {\n no: getField(t, 'cutterId', 'CUTTER_ID', 'cutteR_ID', 'daA001', 'no'),\n name: getField(t, 'cutterName', 'CUTTER_NAME', 'cutteR_NAME', 'name'),\n model: getField(t, 'cutterModel', 'CUTTER_MODEL', 'cutteR_MODEL', 'model'),\n lifeWarn: getField(t, 'modlLifeWorning', 'lifeWarn', 'LIFE_WARN', 'lifE_WARN')\n };\n });\n _this5.filteredTools = mapped;\n _this5.toolList = mapped.slice();\n totalFromRes = Number((_ref2 = (_ref3 = (_ref4 = (_res$data$total = (_res$data2 = res.data) === null || _res$data2 === void 0 ? void 0 : _res$data2.total) !== null && _res$data$total !== void 0 ? _res$data$total : (_res$data3 = res.data) === null || _res$data3 === void 0 ? void 0 : _res$data3.totalCount) !== null && _ref4 !== void 0 ? _ref4 : res.total) !== null && _ref3 !== void 0 ? _ref3 : res.totalCount) !== null && _ref2 !== void 0 ? _ref2 : mapped.length);\n _this5.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n if (_this5.pageIndex > _this5.totalPages) {\n _this5.pageIndex = _this5.totalPages;\n }\n } else {\n _this5.$showMessage(res.message || '鏌ヨ澶辫触');\n }\n _context4.next = 12;\n break;\n case 8:\n _context4.prev = 8;\n _context4.t0 = _context4[\"catch\"](1);\n __f__(\"error\", 'fetchTools 閿欒锛�', _context4.t0, \" at components/mold.vue:456\");\n _this5.$showMessage('鏌ヨ鍒�鍏峰け璐ワ紝璇锋鏌ョ綉缁滄垨鎺ュ彛');\n case 12:\n _context4.prev = 12;\n _this5.loadingTools = false;\n return _context4.finish(12);\n case 15:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, null, [[1, 8, 12, 15]]);\n }))();\n },\n prevPage: function prevPage() {\n var _this6 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5() {\n return _regenerator.default.wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n if (!(_this6.pageIndex > 1)) {\n _context5.next = 4;\n break;\n }\n _this6.pageIndex--;\n _context5.next = 4;\n return _this6.fetchTools(_this6.searchKey);\n case 4:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5);\n }))();\n },\n nextPage: function nextPage() {\n var _this7 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee6() {\n return _regenerator.default.wrap(function _callee6$(_context6) {\n while (1) {\n switch (_context6.prev = _context6.next) {\n case 0:\n if (!(_this7.pageIndex < _this7.totalPages)) {\n _context6.next = 4;\n break;\n }\n _this7.pageIndex++;\n _context6.next = 4;\n return _this7.fetchTools(_this7.searchKey);\n case 4:\n case \"end\":\n return _context6.stop();\n }\n }\n }, _callee6);\n }))();\n },\n onSearchKeyInput: function onSearchKeyInput() {\n var _this8 = this;\n clearTimeout(this._searchTimer);\n this._searchTimer = setTimeout(function () {\n _this8.searchTool();\n }, 300);\n },\n searchTool: function searchTool() {\n var _this9 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee7() {\n return _regenerator.default.wrap(function _callee7$(_context7) {\n while (1) {\n switch (_context7.prev = _context7.next) {\n case 0:\n _this9.pageIndex = 1;\n _context7.next = 3;\n return _this9.fetchTools(_this9.searchKey);\n case 3:\n case \"end\":\n return _context7.stop();\n }\n }\n }, _callee7);\n }))();\n },\n selectTool: function selectTool(tool) {\n this.selectedToolNo = tool.no;\n this.toolName = tool.name;\n this.toolModel = tool.model;\n this.activeToolNo = tool.no;\n // 鏂板锛氬甫鍑哄鍛芥瘮棰勮鍊糪n if (tool.lifeWarn !== undefined && tool.lifeWarn !== null) {\n // 鏍煎紡鍖栦负鐧惧垎姣斿瓧绗︿覆\n var warn = Number(tool.lifeWarn);\n this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n } else {\n this.lifeWarnInput = '';\n }\n },\n confirmTool: function confirmTool() {\n this.showToolDialog = false;\n },\n setUseLimit: function setUseLimit() {\n var _this10 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee8() {\n var v;\n return _regenerator.default.wrap(function _callee8$(_context8) {\n while (1) {\n switch (_context8.prev = _context8.next) {\n case 0:\n if (_this10.selectedToolNo) {\n _context8.next = 3;\n break;\n }\n _this10.$showMessage('璇烽�夋嫨鍒�鍏峰悗鍐嶈缃笂闄�');\n return _context8.abrupt(\"return\");\n case 3:\n v = Number(_this10.useLimitInput);\n if (!(isNaN(v) || v <= 0)) {\n _context8.next = 7;\n break;\n }\n _this10.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺');\n return _context8.abrupt(\"return\");\n case 7:\n _this10.toolRecords = _this10.toolRecords.map(function (r) {\n if (r.no === _this10.selectedToolNo) {\n return _objectSpread(_objectSpread({}, r), {}, {\n useLimit: v\n });\n }\n return r;\n });\n _this10.toolList = _this10.toolList.map(function (t) {\n return t.no === _this10.selectedToolNo ? _objectSpread(_objectSpread({}, t), {}, {\n useLimit: v\n }) : t;\n });\n _this10.$showMessage('浣跨敤涓婇檺宸茶缃紙浠呭墠绔樉绀猴級');\n case 10:\n case \"end\":\n return _context8.stop();\n }\n }\n }, _callee8);\n }))();\n },\n // 涓婂垁鏃朵紶閫� sdjs = 宸ュ崟 currentCjNum\n handleUpTool: function handleUpTool() {\n var _this11 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee9() {\n var useLimit, sdjs, lifeWarnRatio, payload, res;\n return _regenerator.default.wrap(function _callee9$(_context9) {\n while (1) {\n switch (_context9.prev = _context9.next) {\n case 0:\n if (_this11.workOrderNo) {\n _context9.next = 3;\n break;\n }\n _this11.$showMessage('宸ュ崟鍙蜂笉鑳戒负绌�');\n return _context9.abrupt(\"return\");\n case 3:\n if (_this11.machineNo) {\n _context9.next = 6;\n break;\n }\n _this11.$showMessage('鏈哄彴鍙蜂笉鑳戒负绌�');\n return _context9.abrupt(\"return\");\n case 6:\n if (_this11.selectedToolNo) {\n _context9.next = 9;\n break;\n }\n _this11.$showMessage('鍒�鍏风紪鍙蜂笉鑳戒负绌�');\n return _context9.abrupt(\"return\");\n case 9:\n if (_this11.useLimitInput) {\n _context9.next = 12;\n break;\n }\n _this11.$showMessage('浣跨敤涓婇檺涓嶈兘涓虹┖');\n return _context9.abrupt(\"return\");\n case 12:\n useLimit = Number(_this11.useLimitInput);\n if (!(isNaN(useLimit) || useLimit <= 0)) {\n _context9.next = 16;\n break;\n }\n _this11.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺');\n return _context9.abrupt(\"return\");\n case 16:\n // sdjs 浣跨敤宸ュ崟 currentCjNum\n sdjs = _this11.workOrderCurrentCjNum != null ? Number(_this11.workOrderCurrentCjNum) : null;\n lifeWarnRatio = _this11.normalizeLifeWarn(_this11.lifeWarnInput);\n payload = {\n workOrderNo: _this11.workOrderNo,\n machineNo: _this11.machineNo,\n toolNo: _this11.selectedToolNo,\n type: '涓婃満',\n useLimit: useLimit,\n sdjs: sdjs,\n // 涓婂垁璁℃暟锛堝伐鍗曞綋鍓嶆暟閲囷級\n modlLifeWorning: lifeWarnRatio // 鏂板\n };\n _context9.prev = 19;\n _this11.submitting = true;\n _context9.next = 23;\n return _this11.$post({\n url: '/MesCutterLedger/SubmitToolAction',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 23:\n res = _context9.sent;\n if (!(res.data && res.data.outSum === \"0\")) {\n _context9.next = 29;\n break;\n }\n uni.showToast({\n title: res.data.outMsg || '',\n icon: 'error'\n });\n return _context9.abrupt(\"return\");\n case 29:\n if (res.data && res.data.outMsg) {\n uni.showToast({\n title: res.data.outMsg,\n icon: 'none'\n });\n }\n case 30:\n if (!(res.status === 0)) {\n _context9.next = 33;\n break;\n }\n _context9.next = 33;\n return _this11.fetchFormData();\n case 33:\n _context9.next = 40;\n break;\n case 35:\n _context9.prev = 35;\n _context9.t0 = _context9[\"catch\"](19);\n __f__(\"error\", _context9.t0, \" at components/mold.vue:566\");\n _this11.$showMessage('涓婂垁鎻愪氦澶辫触锛岃妫�鏌ョ綉缁�');\n throw _context9.t0;\n case 40:\n _context9.prev = 40;\n _this11.submitting = false;\n return _context9.finish(40);\n case 43:\n case \"end\":\n return _context9.stop();\n }\n }\n }, _callee9, null, [[19, 35, 40, 43]]);\n }))();\n },\n // 涓嬪垁鏃朵紶閫� xdjs = 宸ュ崟 currentCjNum\n handleDownTool: function handleDownTool() {\n var _this12 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee10() {\n var useLimit, xdjs, lifeWarnRatio, payload, res;\n return _regenerator.default.wrap(function _callee10$(_context10) {\n while (1) {\n switch (_context10.prev = _context10.next) {\n case 0:\n if (_this12.workOrderNo) {\n _context10.next = 3;\n break;\n }\n _this12.$showMessage('宸ュ崟鍙蜂笉鑳戒负绌�');\n return _context10.abrupt(\"return\");\n case 3:\n if (_this12.machineNo) {\n _context10.next = 6;\n break;\n }\n _this12.$showMessage('鏈哄彴鍙蜂笉鑳戒负绌�');\n return _context10.abrupt(\"return\");\n case 6:\n if (_this12.selectedToolNo) {\n _context10.next = 9;\n break;\n }\n _this12.$showMessage('鍒�鍏风紪鍙蜂笉鑳戒负绌�');\n return _context10.abrupt(\"return\");\n case 9:\n //涓嬪垁涓嶅己鍒跺綍鍏ヤ娇鐢ㄤ笂闄怽n //if (!this.useLimitInput) { this.$showMessage('浣跨敤涓婇檺涓嶈兘涓虹┖'); return; }\n useLimit = Number(_this12.useLimitInput); //if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('璇疯緭鍏ユ湁鏁堢殑浣跨敤涓婇檺'); return; }\n // 涓嬪垁璁℃暟鍚屾牱鍙栧伐鍗曟渶鏂伴噰闆嗘暟\n xdjs = _this12.workOrderCurrentCjNum != null ? Number(_this12.workOrderCurrentCjNum) : null;\n lifeWarnRatio = _this12.normalizeLifeWarn(_this12.lifeWarnInput);\n payload = {\n workOrderNo: _this12.workOrderNo,\n machineNo: _this12.machineNo,\n toolNo: _this12.selectedToolNo,\n type: '涓嬫満',\n useLimit: useLimit,\n xdjs: xdjs,\n // 涓嬪垁璁℃暟\n modlLifeWorning: lifeWarnRatio // 鏂板\n };\n _context10.prev = 13;\n _this12.submitting = true;\n _context10.next = 17;\n return _this12.$post({\n url: '/MesCutterLedger/SubmitToolAction',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 17:\n res = _context10.sent;\n if (!(res.data && res.data.outSum === \"0\")) {\n _context10.next = 23;\n break;\n }\n uni.showToast({\n title: res.data.outMsg || '',\n icon: 'error'\n });\n return _context10.abrupt(\"return\");\n case 23:\n if (res.data && res.data.outMsg) {\n uni.showToast({\n title: res.data.outMsg,\n icon: 'none'\n });\n }\n case 24:\n if (!(res.status === 0)) {\n _context10.next = 27;\n break;\n }\n _context10.next = 27;\n return _this12.fetchFormData();\n case 27:\n _context10.next = 34;\n break;\n case 29:\n _context10.prev = 29;\n _context10.t0 = _context10[\"catch\"](13);\n __f__(\"error\", _context10.t0, \" at components/mold.vue:619\");\n _this12.$showMessage('涓嬪垁鎻愪氦澶辫触锛岃妫�鏌ョ綉缁�');\n throw _context10.t0;\n case 34:\n _context10.prev = 34;\n _this12.submitting = false;\n return _context10.finish(34);\n case 37:\n case \"end\":\n return _context10.stop();\n }\n }\n }, _callee10, null, [[13, 29, 34, 37]]);\n }))();\n },\n cancel: function cancel() {\n this.selectedToolNo = '';\n this.toolName = '';\n this.toolModel = '';\n this.useLimitInput = '';\n this.lifeWarnInput = ''; // 鏂板锛氭竻绌篭n this.isDirty = false;\n },\n fetchFormData: function fetchFormData() {\n var _this13 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee11() {\n var payload, _ref5, _ref6, _ref7, _res$data$total2, _res$data4, _res$data5, res, list, getField, mapped, totalFromRes;\n return _regenerator.default.wrap(function _callee11$(_context11) {\n while (1) {\n switch (_context11.prev = _context11.next) {\n case 0:\n if (!(!_this13.workOrderNo || !_this13.machineNo)) {\n _context11.next = 3;\n break;\n }\n __f__(\"warn\", '宸ュ崟鍙锋垨鏈哄彴鍙蜂负绌猴紝璺宠繃鑾峰彇琛ㄥ崟鏁版嵁', \" at components/mold.vue:636\");\n return _context11.abrupt(\"return\");\n case 3:\n _this13.loadingForm = true;\n payload = {\n workOrderNo: _this13.workOrderNo.trim(),\n machineNo: _this13.machineNo.trim()\n };\n _context11.prev = 5;\n _context11.next = 8;\n return _this13.$post({\n url: '/MesCutterLedger/GetFormData',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 8:\n res = _context11.sent;\n if (!(res.status !== 0)) {\n _context11.next = 13;\n break;\n }\n _this13.$showMessage(res.message || '鑾峰彇琛ㄥ崟鏁版嵁澶辫触');\n _this13.toolRecords = [];\n return _context11.abrupt(\"return\");\n case 13:\n list = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : [];\n getField = function getField(obj) {\n for (var _len2 = arguments.length, keys = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n keys[_key2 - 1] = arguments[_key2];\n }\n for (var _i2 = 0, _keys2 = keys; _i2 < _keys2.length; _i2++) {\n var k = _keys2[_i2];\n if ((obj === null || obj === void 0 ? void 0 : obj[k]) !== undefined && (obj === null || obj === void 0 ? void 0 : obj[k]) !== null) return obj[k];\n }\n return null;\n };\n mapped = (list || []).map(function (t) {\n var _getField, _getField2;\n var upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\n var downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\n var lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\n var currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\n var useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\n var useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\n var percent = '';\n if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n percent = (Number(useCount) / Number(useLimit) * 100).toFixed(0) + '%';\n }\n var parseNumber = function parseNumber(v) {\n if (v === null || v === undefined || v === '') return null;\n var s = String(v).replace(/[,锛�%]/g, '').trim();\n var n = parseFloat(s);\n return Number.isFinite(n) ? n : null;\n };\n var formatPercent = function formatPercent(n) {\n if (n === null || n === undefined || isNaN(n)) return '';\n if (n <= 1) return \"\".concat((n * 100).toFixed(0), \"%\");\n return \"\".concat(Number(n).toFixed(0), \"%\");\n };\n var lifeWarnNum = parseNumber(lifeWarnRaw);\n var warnStatus = getField(t, 'status', 'STATUS') || '';\n if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n var percentNum = Number(useCount) / Number(useLimit);\n warnStatus = percentNum >= lifeWarnNum ? '棰勮' : '姝e父';\n } else {\n warnStatus = warnStatus || '鏈煡';\n }\n return {\n id: getField(t, 'id', 'ID') || \"\".concat(getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || '', \"-\").concat(upTimeRaw || ''),\n no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\n name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\n upTime: _this13.formatDateTime(upTimeRaw),\n upCount: (_getField = getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount')) !== null && _getField !== void 0 ? _getField : '',\n downTime: _this13.formatDateTime(downTimeRaw),\n downCount: (_getField2 = getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount')) !== null && _getField2 !== void 0 ? _getField2 : '',\n useCount: useCount !== null && useCount !== void 0 ? useCount : '',\n useLimit: useLimit !== null && useLimit !== void 0 ? useLimit : '',\n lifePercent: percent,\n lifeWarn: formatPercent(lifeWarnNum),\n warnStatus: warnStatus,\n currentCjNum: currentCjNum\n };\n }); // 鏂板锛氭寜涓婂垁鏃堕棿闄嶅簭鎺掑簭锛堣秺鏅氱殑瓒婁笂闈級\n mapped.sort(function (a, b) {\n // 鏃堕棿鏍煎紡濡� \"10-24 16:03\"锛岃浆涓� Date 瀵硅薄姣旇緝\n var parse = function parse(s) {\n if (!s) return 0;\n // 琛ュ勾浠斤紝鍋囪閮芥槸浠婂勾\n var year = new Date().getFullYear();\n return new Date(\"\".concat(year, \"-\").concat(s.replace(/-/g, '-'), \":00\")).getTime();\n };\n return parse(b.upTime) - parse(a.upTime); // 娉ㄦ剰杩欓噷椤哄簭鍙嶈繃鏉n });\n\n _this13.toolRecords = mapped;\n totalFromRes = Number((_ref5 = (_ref6 = (_ref7 = (_res$data$total2 = (_res$data4 = res.data) === null || _res$data4 === void 0 ? void 0 : _res$data4.total) !== null && _res$data$total2 !== void 0 ? _res$data$total2 : (_res$data5 = res.data) === null || _res$data5 === void 0 ? void 0 : _res$data5.totalCount) !== null && _ref7 !== void 0 ? _ref7 : res.total) !== null && _ref6 !== void 0 ? _ref6 : res.totalCount) !== null && _ref5 !== void 0 ? _ref5 : mapped.length);\n _this13.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n _context11.next = 27;\n break;\n case 22:\n _context11.prev = 22;\n _context11.t0 = _context11[\"catch\"](5);\n __f__(\"error\", '鑾峰彇琛ㄥ崟鏁版嵁閿欒:', _context11.t0, \" at components/mold.vue:735\");\n _this13.$showMessage('鑾峰彇鏁版嵁澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');\n _this13.toolRecords = [];\n case 27:\n _context11.prev = 27;\n _this13.loadingForm = false;\n return _context11.finish(27);\n case 30:\n case \"end\":\n return _context11.stop();\n }\n }\n }, _callee11, null, [[5, 22, 27, 30]]);\n }))();\n },\n // 鑷姩甯﹀嚭宸ュ崟鍒�鍏蜂俊鎭紝骞惰幏鍙栧伐鍗曟渶鏂伴噰闆嗘暟\n fetchDefaultToolFromWorkOrder: function fetchDefaultToolFromWorkOrder() {\n var _this14 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee12() {\n var _res$data6, res, _ref8, _order$CurrentCjNum, order, warn;\n return _regenerator.default.wrap(function _callee12$(_context12) {\n while (1) {\n switch (_context12.prev = _context12.next) {\n case 0:\n if (_this14.machineNo) {\n _context12.next = 2;\n break;\n }\n return _context12.abrupt(\"return\");\n case 2:\n _context12.prev = 2;\n _context12.next = 5;\n return _this14.$post({\n url: '/Womdaa/GetWomdaasByShow',\n data: JSON.stringify({\n machineNo: _this14.machineNo\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 5:\n res = _context12.sent;\n if (res.status === 0 && Array.isArray((_res$data6 = res.data) === null || _res$data6 === void 0 ? void 0 : _res$data6.tbBillList) && res.data.tbBillList.length > 0) {\n order = res.data.tbBillList[0]; // 鏂板锛氫繚瀛樺伐鍗曟暟鎹紝鐢ㄤ簬鎶ヨ瘯浜ф暟\n _this14.order = order;\n _this14.orderId = order.id || order.ID || order.orderId || null;\n _this14.selectedToolNo = order.cutterId || order.cutteR_ID || '';\n _this14.toolName = order.cutterName || order.cutteR_NAME || '';\n _this14.toolModel = order.cutterModel || order.cutteR_MODEL || '';\n // 鍏抽敭锛氳幏鍙栧伐鍗曟渶鏂伴噰闆嗘暟\n _this14.workOrderCurrentCjNum = (_ref8 = (_order$CurrentCjNum = order.CurrentCjNum) !== null && _order$CurrentCjNum !== void 0 ? _order$CurrentCjNum : order.currentCjNum) !== null && _ref8 !== void 0 ? _ref8 : null;\n // 鏂板锛氳嚜鍔ㄥ~鍏呭鍛芥瘮棰勮鍊糪n if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\n warn = Number(order.modlLifeWorning);\n _this14.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n } else {\n _this14.lifeWarnInput = '';\n }\n } else {\n _this14.workOrderCurrentCjNum = null;\n _this14.order = {};\n _this14.orderId = null;\n }\n _context12.next = 15;\n break;\n case 9:\n _context12.prev = 9;\n _context12.t0 = _context12[\"catch\"](2);\n __f__(\"warn\", '鑷姩甯﹀嚭宸ュ崟鍒�鍏峰け璐�', _context12.t0, \" at components/mold.vue:776\");\n _this14.workOrderCurrentCjNum = null;\n _this14.order = {};\n _this14.orderId = null;\n case 15:\n case \"end\":\n return _context12.stop();\n }\n }\n }, _callee12, null, [[2, 9]]);\n }))();\n },\n formatDateTime: function formatDateTime(dateTimeStr) {\n if (!dateTimeStr) return '';\n try {\n var s = String(dateTimeStr).trim();\n if (/^\\d{10}$/.test(s)) {\n var d = new Date(Number(s) * 1000);\n return \"\".concat(d.getMonth() + 1, \"-\").concat(d.getDate(), \" \").concat(d.getHours(), \":\").concat(String(d.getMinutes()).padStart(2, '0'));\n }\n if (/^\\d{13}$/.test(s)) {\n var _d = new Date(Number(s));\n return \"\".concat(_d.getMonth() + 1, \"-\").concat(_d.getDate(), \" \").concat(_d.getHours(), \":\").concat(String(_d.getMinutes()).padStart(2, '0'));\n }\n var date = new Date(dateTimeStr);\n if (!isNaN(date.getTime())) {\n return \"\".concat(date.getMonth() + 1, \"-\").concat(date.getDate(), \" \").concat(date.getHours(), \":\").concat(String(date.getMinutes()).padStart(2, '0'));\n }\n var match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\n if (match) return \"\".concat(match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, function (m) {\n return m;\n }), \" \").concat(match[2]);\n return String(dateTimeStr);\n } catch (_unused) {\n return String(dateTimeStr);\n }\n },\n // 鏂板锛氶�夋嫨璋冩満甯堝倕\n selectTiaojiUser: function selectTiaojiUser(u) {\n this.tiaojiStaffNo = u;\n this.isTiaojiUserSelectShow = false;\n this.tiaojiUserSearch = '';\n },\n // 鏂板锛氶�佹鍛煎彨 + 鎶ヨ瘯浜ф暟\n handleInspectionCall: function handleInspectionCall() {\n var _this15 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee13() {\n var _this15$order, _this15$order2;\n var okQty, badQty, staffNo, totalQty, payload, res;\n return _regenerator.default.wrap(function _callee13$(_context13) {\n while (1) {\n switch (_context13.prev = _context13.next) {\n case 0:\n if (_this15.tiaojiStaffNo) {\n _context13.next = 3;\n break;\n }\n _this15.$showMessage('璇烽�夋嫨璋冩満甯堝倕');\n return _context13.abrupt(\"return\");\n case 3:\n okQty = Number(_this15.tiaojiOkQty);\n badQty = Number(_this15.tiaojiBadQty);\n if (!(isNaN(okQty) || okQty < 0)) {\n _context13.next = 8;\n break;\n }\n _this15.$showMessage('璇疯緭鍏ユ湁鏁堢殑璋冩満鑹搧鏁�');\n return _context13.abrupt(\"return\");\n case 8:\n if (!(isNaN(badQty) || badQty < 0)) {\n _context13.next = 11;\n break;\n }\n _this15.$showMessage('璇疯緭鍏ユ湁鏁堢殑璋冩満涓嶈壇鍝佹暟');\n return _context13.abrupt(\"return\");\n case 11:\n staffNo = _this15.tiaojiStaffNo.split(':')[0];\n totalQty = okQty + badQty; // 璇曚骇鎬绘暟 = 鑹搧鏁� + 涓嶈壇鍝佹暟\n // 璋冪敤鎶ヨ瘯浜ф暟鎺ュ彛(浣跨敤鎶ュ伐鐣岄潰鐨勬帴鍙�)\n payload = {\n orderNo: _this15.workOrderNo,\n orderId: _this15.orderId,\n // 闇�瑕佷粠宸ュ崟鏁版嵁涓幏鍙朶n bf: totalQty,\n // 璇曚骇鎬绘暟\n staffNo: staffNo,\n initCjNum: ((_this15$order = _this15.order) === null || _this15$order === void 0 ? void 0 : _this15$order.initCjNum) || 0,\n currentCjNum: ((_this15$order2 = _this15.order) === null || _this15$order2 === void 0 ? void 0 : _this15$order2.currentCjNum) || 0,\n type: 'tiaoji',\n // 鏍囪瘑涓鸿皟鏈烘姤宸n tiaojiOkQty: okQty,\n // 鏂板:鑹搧鏁癨n tiaojiBadQty: badQty // 鏂板:涓嶈壇鍝佹暟\n };\n _context13.prev = 14;\n _this15.submitting = true;\n // 璋冪敤鎶ュ伐鐣岄潰鐨勬姤璇曚骇鏁版帴鍙n _context13.next = 18;\n return _this15.$post({\n url: '/MesInvItemBarcodes/AddBFToBarcodes',\n data: payload\n });\n case 18:\n res = _context13.sent;\n if (!(res.status == 1)) {\n _context13.next = 22;\n break;\n }\n _this15.$showMessage(res.message);\n return _context13.abrupt(\"return\");\n case 22:\n _this15.$showMessage('璋冩満鎶ュ伐鎴愬姛');\n // 娓呯┖杈撳叆\n _this15.tiaojiOkQty = '';\n _this15.tiaojiBadQty = '';\n // 鍒锋柊鏁版嵁\n _context13.next = 27;\n return _this15.fetchFormData();\n case 27:\n _context13.next = 29;\n return _this15.fetchDefaultToolFromWorkOrder();\n case 29:\n _context13.next = 35;\n break;\n case 31:\n _context13.prev = 31;\n _context13.t0 = _context13[\"catch\"](14);\n __f__(\"error\", '璋冩満鎶ュ伐閿欒:', _context13.t0, \" at components/mold.vue:871\");\n _this15.$showMessage('璋冩満鎶ュ伐澶辫触锛岃妫�鏌ョ綉缁�');\n case 35:\n _context13.prev = 35;\n _this15.submitting = false;\n return _context13.finish(35);\n case 38:\n case \"end\":\n return _context13.stop();\n }\n }\n }, _callee13, null, [[14, 31, 35, 38]]);\n }))();\n },\n // 鏂板锛氳幏鍙栬皟鏈哄笀鍌呭垪琛╘n fetchTiaojiStaff: function fetchTiaojiStaff() {\n var _this16 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee14() {\n var res, staff;\n return _regenerator.default.wrap(function _callee14$(_context14) {\n while (1) {\n switch (_context14.prev = _context14.next) {\n case 0:\n _context14.prev = 0;\n _context14.next = 3;\n return _this16.$post({\n url: '/MesStaff/GetAllXS0101BYtj' // 涓庢姤宸ョ晫闈娇鐢ㄧ浉鍚屾帴鍙n });\n case 3:\n res = _context14.sent;\n if (res.status === 0 && res.data && res.data.tbBillList) {\n staff = res.data.tbBillList;\n _this16.tiaojiUsers = staff.map(function (s) {\n return s.staffNo + ':' + s.staffName;\n });\n }\n _context14.next = 10;\n break;\n case 7:\n _context14.prev = 7;\n _context14.t0 = _context14[\"catch\"](0);\n __f__(\"error\", '鑾峰彇璋冩満甯堝倕鍒楄〃澶辫触:', _context14.t0, \" at components/mold.vue:889\");\n case 10:\n case \"end\":\n return _context14.stop();\n }\n }\n }, _callee14, null, [[0, 7]]);\n }))();\n }\n },\n mounted: function mounted() {\n var _this17 = this;\n this.fetchTools('');\n this.machineNo = uni.getStorageSync('machineNo') || '';\n this.workOrderNo = uni.getStorageSync('daa001') || '';\n\n // 鏂板锛氳幏鍙栬皟鏈哄笀鍌呭垪琛╘n this.fetchTiaojiStaff();\n if (this.machineNo && this.workOrderNo) {\n this.fetchFormData().then( /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee15() {\n return _regenerator.default.wrap(function _callee15$(_context15) {\n while (1) {\n switch (_context15.prev = _context15.next) {\n case 0:\n _context15.next = 2;\n return _this17.fetchDefaultToolFromWorkOrder();\n case 2:\n // 杩涘叆椤甸潰鏃惰祴鍊肩涓�琛� currentCjNum\n if (_this17.toolRecords.length > 0) {\n _this17.$set(_this17.toolRecords[0], 'currentCjNum', _this17.workOrderCurrentCjNum);\n }\n case 3:\n case \"end\":\n return _context15.stop();\n }\n }\n }, _callee15);\n })));\n } else {\n __f__(\"warn\", '鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇琛ㄥ崟鏁版嵁', \" at components/mold.vue:910\");\n }\n\n // 鍚姩鑷姩淇濆瓨瀹氭椂鍣╘n //this.startAutoSave();\n },\n beforeDestroy: function beforeDestroy() {\n // 娓呯悊瀹氭椂鍣紝闃叉鍐呭瓨娉勬紡\n this.stopAutoSave();\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 1)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/mold.vue"],"names":["data","machineNo","workOrderNo","activeToolNo","pageIndex","pageSize","total","toolList","selectedToolNo","toolName","toolModel","showToolDialog","searchKey","filteredTools","useLimitInput","lifeWarnInput","toolRecords","loadingTools","loadingForm","submitting","_searchTimer","workOrderCurrentCjNum","autoSaveTimer","isDirty","autoSaveIntervalMs","autoSaveEnabled","autoSaveActionName","isTiaojiUserSelectShow","tiaojiStaffNo","tiaojiOkQty","tiaojiBadQty","tiaojiUsers","tiaojiUserSearch","orderId","order","computed","totalPages","tiaojiStaffDisplay","filteredTiaojiUsers","watch","methods","fetchCurrentCjNum","url","headers","res","found","x","handleRefresh","startAutoSave","stopAutoSave","clearInterval","autoSaveTick","fn","normalizeLifeWarn","openToolDialog","closeToolDialog","fetchTools","payload","getField","keys","mapped","no","name","model","lifeWarn","totalFromRes","prevPage","nextPage","onSearchKeyInput","clearTimeout","searchTool","selectTool","confirmTool","setUseLimit","v","isNaN","useLimit","handleUpTool","sdjs","lifeWarnRatio","toolNo","type","modlLifeWorning","uni","title","icon","handleDownTool","xdjs","cancel","fetchFormData","list","percent","warnStatus","id","upTime","upCount","downTime","downCount","useCount","lifePercent","currentCjNum","fetchDefaultToolFromWorkOrder","warn","formatDateTime","selectTiaojiUser","handleInspectionCall","okQty","badQty","staffNo","totalQty","orderNo","bf","initCjNum","fetchTiaojiStaff","staff","mounted","beforeDestroy"],"mappings":"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gBAAA;cAAA;gBAGA8C,4CACA9C,wDACAA,4CACA;gBAEAc;kBAAA;oBAAAC;kBAAA;kBACA;oBAAA;oBAAA;kBAAA;kBACA;gBACA;gBAEAC;kBAAA;kBACA;kBACA;kBACA;kBACA;kBAEA;kBACA;kBAEA;kBACA;oBACA+B;kBACA;kBAEA;oBACA;oBACA;oBACA;oBACA;kBACA;kBACA;oBACA;oBACA;oBACA;kBACA;kBACA;kBAEA;kBACA;oBACA;oBACAC;kBACA;oBACAA;kBACA;kBAEA;oBACAC;oBACAhC;oBACAC;oBACAgC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAtB;oBACAuB;oBACAnC;oBACA4B;oBACAQ;kBACA;gBACA,IAEA;gBACAxC;kBACA;kBACA;oBACA;oBACA;oBACA;oBACA;kBACA;kBACA;gBACA;;gBAEA;gBACAK,mFACArB,gYACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACA;IACAyD;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACA3D;kBACA1C;oBAAAC;kBAAA;kBACA0C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAKA;kBACAV,gCAEA;kBACA;kBACA;kBAEA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;oBACAoE;oBACA;kBACA;oBACA;kBACA;gBACA;kBACA;kBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAC;MACA;MACA;QACA;QACA;UACA;UACA;QACA;QACA;UACA;UACA;QACA;QACA;QACA;UACA;QACA;QACA;QACA;UAAA;QAAA;QACA;MACA;QACA;MACA;IACA;IAEA;IACAC;MACA;MACA;MACA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IAEA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAIAC;gBACAC;gBAAA,MAEAhC;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAAA,MAIAA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAIAiC;gBACAC;gBAEA;gBACApD;kBACAqD;kBACA7E;kBAAA;kBACA8E;kBAAA;kBACAH;kBACAI;kBACAZ;kBACAnB;kBAAA;kBACApD;kBAAA;kBACAC;gBACA;gBAAA;gBAGA;gBACA;gBAAA;gBAAA,OACA;kBACAY;kBACA1C;gBACA;cAAA;gBAHA4C;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAIA;gBACA;gBACA;gBACA;gBACA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAqE;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAvE;gBACA;cAAA;gBAFAE;gBAGA;kBACAsE;kBACA;oBAAA;kBAAA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;EACA;EACAC;IAAA;IACA;IACA;IACA;;IAEA;IACA;IAEA;MACA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBACA;gBACA;kBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CACA;IACA;MACA;IACA;;IAEA;IACA;EACA;EACAC;IACA;IACA;EACA;AACA;AAAA,2B","file":"62.js","sourcesContent":["<template>\n    <view class=\"page\">\n        <!-- 刀具选择区 -->\n        <view class=\"top-section-grid\">\n            <!-- 第一行：移除刀具目录按钮 -->\n            <view class=\"form-row\">\n                <view class=\"form-cell\">\n                    <label class=\"form-label\">刀具编号：</label>\n                    <input class=\"input small-font\" v-model=\"selectedToolNo\" placeholder=\"请通过刀具目录选择\" disabled />\n                </view>\n                <view class=\"form-cell form-cell-flex\">\n                    <label class=\"form-label highlight-label\">使用上限：</label>\n                    <input class=\"input small-font input-use-limit\" type=\"number\" v-model=\"useLimitInput\" placeholder=\"每次上刀时手填上限\" :disabled=\"!selectedToolNo || loadingForm\" />\n                    <label class=\"form-label\" style=\"margin-left:16px;\">寿命比预警值：</label>\n                    <view class=\"input-with-unit\">\n                        <input class=\"input small-font input-life-warn\"\n                               v-model=\"lifeWarnInput\"\n                               placeholder=\"如90\"\n                               :disabled=\"!selectedToolNo || loadingForm\" />\n                        <span class=\"unit-text\">%</span>\n                    </view>\n                </view>\n            </view>\n\n            <!-- 第二行：在最后添加刀具目录按钮 -->\n            <view class=\"form-row\">\n                <!-- 刀具名称 -->\n                <view class=\"form-cell\">\n                    <label class=\"form-label\">刀具名称：</label>\n                    <input class=\"input small-font input-tool-name\" v-model=\"toolName\" placeholder=\"刀具带出\" disabled />\n                </view>\n                <!-- 规格型号 -->\n                <view class=\"form-cell\">\n                    <label class=\"form-label\">规格型号：</label>\n                    <input class=\"input small-font input-tool-model\" v-model=\"toolModel\" placeholder=\"刀具带出\" disabled />\n                </view>\n                <!-- 刀具目录按钮右移 -->\n                <view class=\"form-cell tool-dir-cell\">\n                    <button class=\"btn-blue large-btn\" @click=\"openToolDialog\" :disabled=\"loadingTools\">刀具目录</button>\n                </view>\n                <!-- 新增：刷新按钮 -->\n                <view class=\"form-cell\" style=\"flex:0 0 auto; margin-left:16px;\">\n                    <button class=\"btn-blue large-btn\" @click=\"handleRefresh\" :disabled=\"loadingForm || submitting\">刷新</button>\n                </view>\n            </view>\n        </view>  <!-- 这里闭合 top-section-grid -->\n        <!-- 操作按钮 - 移出 top-section-grid -->\n        <view class=\"button-row\">\n            <button class=\"save-btn\" @click=\"handleUpTool\" :disabled=\"submitting || loadingForm\">上刀提交</button>\n            <button class=\"save-btn\" @click=\"handleDownTool\" :disabled=\"submitting || loadingForm\">下刀提交</button>\n            <button class=\"cancel-btn\" @click=\"cancel\" :disabled=\"submitting || loadingForm\">清空刀具选择</button>\n        </view>\n\n        <!-- 新增：调机数据输入区域 -->\n        <view class=\"tiaoji-section\">\n            <view class=\"tiaoji-row\">\n                <!-- 当前调机师傅 -->\n                <view class=\"current-user-section\">\n                    <text>当前调机师傅：</text>\n                    <text class=\"current-user-name\">{{ tiaojiStaffDisplay || '未选择' }}</text>\n                    <button class=\"select-user-btn\" @click=\"isTiaojiUserSelectShow = true\">选人</button>\n                </view>\n\n                <!-- 调机良品数 -->\n                <view class=\"tiaoji-input-section\">\n                    <text>调机良品数：</text>\n                    <input v-model=\"tiaojiOkQty\" class=\"inp tiaoji-input\" type=\"number\" placeholder=\"请输入数量\" />\n                </view>\n\n                <!-- 调机不良品数 -->\n                <view class=\"tiaoji-input-section\">\n                    <text>调机不良品数：</text>\n                    <input v-model=\"tiaojiBadQty\" class=\"inp tiaoji-input\" type=\"number\" placeholder=\"请输入数量\" />\n                </view>\n\n                <!-- 送检呼叫按钮 -->\n                <view class=\"tiaoji-submit-section\">\n                    <button class=\"details-btn\" @click=\"handleInspectionCall\">送检呼叫</button>\n                </view>\n            </view>\n        </view>\n\n        <!-- 选择调机师傅弹窗 -->\n        <view v-if=\"isTiaojiUserSelectShow\" class=\"overlay\">\n            <view class=\"popup user-select-popup\">\n                <!-- 搜索栏 -->\n                <view class=\"user-search-bar\">\n                    <input v-model.trim=\"tiaojiUserSearch\"\n                           type=\"text\"\n                           class=\"user-search-input\"\n                           placeholder=\"输入工号或姓名搜索\"\n                           @keydown.enter.prevent />\n                    <button v-if=\"tiaojiUserSearch\" class=\"user-search-clear\" @click=\"tiaojiUserSearch=''\">清空</button>\n                    <view class=\"user-search-info\">\n                        匹配：{{ filteredTiaojiUsers.length }} / {{ tiaojiUsers.length }}\n                    </view>\n                </view>\n                <view class=\"user-list-scroll\">\n                    <template v-if=\"filteredTiaojiUsers.length\">\n                        <view class=\"user-list-grid\">\n                            <button v-for=\"(u, index) in filteredTiaojiUsers\"\n                                    :key=\"index\"\n                                    :class=\"['user-list-btn', {'selected': u===tiaojiStaffNo}]\"\n                                    @click=\"selectTiaojiUser(u)\">\n                                <span class=\"user-code\">{{ u.split(':')[0] }}</span>\n                                <span class=\"user-name\">{{ u.split(':')[1] }}</span>\n                            </button>\n                        </view>\n                    </template>\n                    <view v-else class=\"no-user-result\">\n                        未找到匹配人员\n                    </view>\n                </view>\n                <view class=\"user-popup-footer\">\n                    <button class=\"clean-btn wide-btn\" @click=\"isTiaojiUserSelectShow = false\">关闭</button>\n                </view>\n            </view>\n        </view>\n\n        <!-- 刀具目录弹窗 -->\n        <view v-if=\"showToolDialog\" class=\"dialog-overlay\">\n            <view class=\"dialog\">\n                <view class=\"form-group\">\n                    <input v-model=\"searchKey\" placeholder=\"输入刀具编码、名称模糊搜索\" class=\"input\" @input=\"onSearchKeyInput\" />\n                    <button class=\"btn-blue\" @click=\"searchTool\" :disabled=\"loadingTools\">搜索</button>\n                </view>\n                <view class=\"tool-list\">\n                    <button v-for=\"tool in filteredTools\"\n                            :key=\"tool.no\"\n                            class=\"tool-btn\"\n                            :class=\"{ active: activeToolNo === tool.no }\"\n                            @click=\"selectTool(tool)\">\n                        {{ tool.no }} | {{ tool.name }}\n                    </button>\n                </view>\n                <view class=\"dialog-actions\">\n                    <div style=\"display: flex; align-items: center;\">\n                        <button class=\"btn-blue\" @click=\"prevPage\" :disabled=\"pageIndex === 1 || loadingTools\">上一页</button>\n                        <span style=\"margin: 0 12px;\">第{{ pageIndex }}页 / 共{{ totalPages }}页</span>\n                        <button class=\"btn-blue\" @click=\"nextPage\" :disabled=\"pageIndex === totalPages || loadingTools\">下一页</button>\n                    </div>\n                    <div style=\"display: flex; gap: 18px; align-items: center;\">\n                        <button class=\"btn-blue\" @click=\"confirmTool\">确定</button>\n                        <button class=\"btn-disabled\" @click=\"closeToolDialog\">取消</button>\n                    </div>\n                </view>\n            </view>\n        </view>\n\n        <!-- 隐藏刀具使用记录表格 -->\n        <view v-if=\"false\" class=\"table-section\">\n            <table class=\"styled-table\">\n                <thead>\n                    <tr>\n                        <th style=\"width:7%\">刀具编号</th>\n                        <th style=\"width:12%\">刀具名称</th>\n                        <th style=\"width:10%\">上刀时间</th>\n                        <th class=\"num\" style=\"width:7%\">上刀计数</th>\n                        <th style=\"width:10%\">下刀时间</th>\n                        <th class=\"num\" style=\"width:7%\">下刀计数</th>\n                        <th class=\"num\" style=\"width:7%\">使用次数</th>\n                        <th class=\"num\" style=\"width:7%\">使用上限</th>\n                        <th class=\"num\" style=\"width:7%\">寿命比%</th>\n                        <th class=\"num\" style=\"width:7%\">寿命比预警值</th>\n                        <th style=\"width:7%\">预警状态</th>\n                        <th style=\"width:7%\">刀具在机状态</th>\n                    </tr>\n                </thead>\n                <tbody>\n                    <tr v-for=\"(item, idx) in toolRecords\" :key=\"item.id\" :class=\"{'row-odd': idx % 2 === 0}\">\n                        <td>{{ item.no }}</td>\n                        <td class=\"left\">{{ item.name }}</td>\n                        <td>{{ item.upTime }}</td>\n                        <td class=\"num\">{{ item.upCount != null ? item.upCount : '' }}</td>\n                        <td>{{ item.downTime }}</td>\n                        <!-- 只有第一行显示 currentCjNum，其它行显示 downCount -->\n                        <td class=\"num\">\n                            <template v-if=\"idx === 0\">\n                                <!-- 第一行：下机时不实时显示 currentCjNum，显示 downCount -->\n                                <template v-if=\"!item.downTime\">\n                                    {{ item.currentCjNum != null ? item.currentCjNum : '' }}\n                                </template>\n                                <template v-else>\n                                    {{ item.downCount != null ? item.downCount : '' }}\n                                </template>\n                            </template>\n                            <template v-else>\n                                {{ item.downCount != null ? item.downCount : '' }}\n                            </template>\n                        </td>\n                        <!--使用次数-->\n                        <td class=\"num\">\n                            <template v-if=\"idx === 0\">\n                                <!-- 第一行实时计算使用次数，若为下机则不实时显示 -->\n                                <template v-if=\"!item.downTime\">\n                                    {{item.currentCjNum != null && item.upCount != null ? (Number(item.currentCjNum) - Number(item.upCount)) : (item.useCount != null ? item.useCount : '') }}\n                                </template>\n                                <template v-else>\n                                    {{ item.useCount != null ? item.useCount : '' }}\n                                </template>\n                            </template>\n                            <template v-else>\n                                {{ item.useCount != null ? item.useCount : '' }}\n                            </template>\n                        </td>\n                        <td class=\"num\">{{ item.useLimit != null ? item.useLimit : '' }}</td>\n                        <!--寿命比%-->\n                        <td class=\"num\">\n                            <template v-if=\"idx === 0\">\n                                <!-- 第一行实时计算寿命比%，若为下机则不实时显示 -->\n                                <template v-if=\"!item.downTime\">\n                                    {{item.currentCjNum != null && item.upCount != null && item.useLimit != null && Number(item.useLimit) > 0 ? Math.round((Number(item.currentCjNum) - Number(item.upCount)) / Number(item.useLimit) * 100) + '%' : (item.lifePercent != null ? item.lifePercent : '') }}\n                                </template>\n                                <template v-else>\n                                    {{ item.lifePercent != null ? item.lifePercent : '' }}\n                                </template>\n                            </template>\n                            <template v-else>\n                                {{ item.lifePercent }}\n                            </template>\n                        </td>\n                        <td class=\"num\">{{ item.lifeWarn }}</td>\n                        <td :class=\"item.warnStatus === '预警' ? 'warn-cell' : (item.warnStatus === '正常' ? 'ok-cell' : '')\">\n                            <span v-if=\"item.warnStatus === '预警'\" class=\"warn-badge\">警告</span>\n                            <span v-else>{{ item.warnStatus }}</span>\n                        </td>\n                        <td>\n                            {{ item.downTime ? '下机' : '在机' }}<!--在机状态-->\n                        </td>\n                    </tr>\n                    <tr v-if=\"!toolRecords.length\">\n                        <td colspan=\"12\">暂无数据</td>\n                    </tr>\n                </tbody>\n            </table>\n        </view>\n\n        <!-- 说明 -->\n        <!--<view class=\"tool-desc\">\n            <p style=\"color:red;\">'使用上限'以下刀时的'使用上限'为计算标准</p>\n            <p style=\"color:red;\">寿命比预警值默认为90%</p>\n        </view>-->\n    </view>\n</template>\n\n<script>\n    export default {\n        data() {\n            return {\n                machineNo: '',//机台编码\n                workOrderNo: '',//工单号\n                activeToolNo: '', // 当前选中的刀具编号\n                pageIndex: 1,\n                pageSize: 20, //单页显示的刀具数量\n                total: 0,\n                toolList: [],\n                selectedToolNo: '',\n                toolName: '',\n                toolModel: '',\n                showToolDialog: false,\n                searchKey: '',\n                filteredTools: [],\n                useLimitInput: '',\n                lifeWarnInput: '', // 新增：寿命比预警值原始输入\n                toolRecords: [],\n                loadingTools: false,\n                loadingForm: false,\n                submitting: false,\n                _searchTimer: null,\n                workOrderCurrentCjNum: null, // 工单当前数采\n\n                // 自动保存相关\n                autoSaveTimer: null,\n                isDirty: false, // 表单是否有未保存变更\n                autoSaveIntervalMs: 5 * 60 * 1000, // 默认 5 分钟\n                autoSaveEnabled: true,\n                autoSaveActionName: 'handleUpTool', // 自动触发的方法名，可改为自定义保存方法\n\n                // 新增：调机相关字段\n                isTiaojiUserSelectShow: false, // 调机师傅选择弹窗\n                tiaojiStaffNo: '', // 当前选中的调机师傅(格式: 工号:姓名)\n                tiaojiOkQty: '', // 调机良品数\n                tiaojiBadQty: '', // 调机不良品数\n                tiaojiUsers: [], // 调机师傅列表\n                tiaojiUserSearch: '', // 搜索关键词\n                                \n                // 新增：报试产数所需字段\n                orderId: null, // 工单ID\n                order: {} // 工单数据\n            };\n        },\n        computed: {\n            totalPages() {\n                return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);\n            },\n            // 新增：调机师傅显示名称\n            tiaojiStaffDisplay() {\n                if (!this.tiaojiStaffNo) return '';\n                const segs = this.tiaojiStaffNo.split(':');\n                return segs.length > 1 ? `${segs[0]} ${segs[1]}` : this.tiaojiStaffNo;\n            },\n            // 新增：过滤后的调机师傅列表\n            filteredTiaojiUsers() {\n                if (!this.tiaojiUserSearch) return this.tiaojiUsers;\n                const kw = this.tiaojiUserSearch.trim().toLowerCase();\n                return this.tiaojiUsers.filter(u => u.toLowerCase().includes(kw));\n            }\n        },\n        watch: {\n            // 标记脏数据：按需监听字段变化\n            selectedToolNo() { this.isDirty = true; },\n            useLimitInput() { this.isDirty = true; },\n            lifeWarnInput() { this.isDirty = true; },\n            toolName() { this.isDirty = true; },\n            toolModel() { this.isDirty = true; }\n        },\n        methods: {\n            //查询当前数采数，作为下刀计数实时显示\n            async fetchCurrentCjNum(toolNo) {\n                if (!this.machineNo) return null;\n                try {\n                    const res = await this.$post({\n                        url: '/Womdaa/GetWomdaasByShow',\n                        data: JSON.stringify({ machineNo: this.machineNo }),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.status === 0 && Array.isArray(res.data?.tbBillList)) {\n                        const found = res.data.tbBillList.find(x =>\n                            x.cutterId === toolNo || x.cutteR_ID === toolNo\n                        );\n                        return found ? (found.CurrentCjNum ?? found.currentCjNum ?? null) : null;\n                    }\n                } catch (e) {\n                    console.warn('获取currentCjNum失败', e);\n                }\n                return null;\n            },\n\n            // 新增：刷新按钮处理方法\n            async handleRefresh() {\n                this.fetchTools('');\n                if (this.machineNo && this.workOrderNo) {\n                    await this.fetchFormData();\n                    await this.fetchDefaultToolFromWorkOrder();\n                    // 刷新后赋值第一行 currentCjNum\n                    if (this.toolRecords.length > 0) {\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\n                    }\n                }\n                this.$showMessage('刷新完成');\n            },\n            // 自动保存：启动\n            startAutoSave() {\n                if (!this.autoSaveEnabled) return;\n                this.stopAutoSave();\n                this.autoSaveTimer = setInterval(() => {\n                    this.autoSaveTick();\n                }, this.autoSaveIntervalMs);\n            },\n            // 自动保存：停止\n            stopAutoSave() {\n                if (this.autoSaveTimer) {\n                    clearInterval(this.autoSaveTimer);\n                    this.autoSaveTimer = null;\n                }\n            },\n            // 自动保存：每次定时执行时的逻辑\n            async autoSaveTick() {\n                if (!this.autoSaveEnabled) return;\n                if (!this.isDirty) return;\n                if (this.submitting || this.loadingForm) return;\n\n                const fn = this.autoSaveActionName && typeof this[this.autoSaveActionName] === 'function'\n                    ? this[this.autoSaveActionName]\n                    : null;\n                if (!fn) {\n                    console.warn('自动保存：未找到方法', this.autoSaveActionName);\n                    return;\n                }\n\n                try {\n                    this.submitting = true;\n                    await fn.call(this); // 调用保存方法（例如 handleUpTool）\n                    // 如果保存成功，清脏标记（保存方法内部若失败没有抛出可保持此方式）\n                    this.isDirty = false;\n                } catch (e) {\n                    console.error('自动保存失败：', e);\n                } finally {\n                    this.submitting = false;\n                }\n            },\n\n            // 新增：寿命比预警值归一化 (返回 0~1 或 null)\n            normalizeLifeWarn(v) {\n                if (v == null) return null;\n                const raw = String(v).trim().replace(/[%％]/g, '');\n                if (raw === '') return null;\n                const num = Number(raw);\n                if (!isFinite(num) || num <= 0) return null;\n                return num > 1 ? (num / 100) : num;\n            },\n            openToolDialog() {\n                this.showToolDialog = true;\n                this.pageIndex = 1;\n                this.fetchTools(this.searchKey);\n            },\n            closeToolDialog() {\n                this.showToolDialog = false;\n            },\n            async fetchTools(searchKey) {\n                this.loadingTools = true;\n                try {\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/QueryTools',\n                        data: JSON.stringify({\n                            searchKey,\n                            pageIndex: this.pageIndex,\n                            pageSize: this.pageSize\n                        }),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n\n                    if (res.status === 0) {\n                        const payload = Array.isArray(res.data) ? res.data\n                            : (res.data && res.data.tbBillList) ? res.data.tbBillList\n                                : (res.data && res.data.data) ? res.data.data\n                                    : [];\n\n                        const getField = (obj, ...keys) => {\n                            for (const k of keys) if (obj?.[k] !== undefined && obj?.[k] !== null) return obj[k];\n                            return null;\n                        };\n\n                        // 这里需要把 lifeWarn 字段也带出来\n                        const mapped = (payload || []).map(t => ({\n                            no: getField(t, 'cutterId', 'CUTTER_ID', 'cutteR_ID', 'daA001', 'no'),\n                            name: getField(t, 'cutterName', 'CUTTER_NAME', 'cutteR_NAME', 'name'),\n                            model: getField(t, 'cutterModel', 'CUTTER_MODEL', 'cutteR_MODEL', 'model'),\n                            lifeWarn: getField(t, 'modlLifeWorning', 'lifeWarn', 'LIFE_WARN', 'lifE_WARN')\n                        }));\n\n                        this.filteredTools = mapped;\n                        this.toolList = mapped.slice();\n\n                        const totalFromRes = Number(\n                            res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\n                        );\n                        this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n                        if (this.pageIndex > this.totalPages) {\n                            this.pageIndex = this.totalPages;\n                        }\n                    } else {\n                        this.$showMessage(res.message || '查询失败');\n                    }\n                } catch (err) {\n                    console.error('fetchTools 错误：', err);\n                    this.$showMessage('查询刀具失败，请检查网络或接口');\n                } finally {\n                    this.loadingTools = false;\n                }\n            },\n            async prevPage() {\n                if (this.pageIndex > 1) {\n                    this.pageIndex--;\n                    await this.fetchTools(this.searchKey);\n                }\n            },\n            async nextPage() {\n                if (this.pageIndex < this.totalPages) {\n                    this.pageIndex++;\n                    await this.fetchTools(this.searchKey);\n                }\n            },\n            onSearchKeyInput() {\n                clearTimeout(this._searchTimer);\n                this._searchTimer = setTimeout(() => {\n                    this.searchTool();\n                }, 300);\n            },\n            async searchTool() {\n                this.pageIndex = 1;\n                await this.fetchTools(this.searchKey);\n            },\n            selectTool(tool) {\n                this.selectedToolNo = tool.no;\n                this.toolName = tool.name;\n                this.toolModel = tool.model;\n                this.activeToolNo = tool.no;\n                // 新增：带出寿命比预警值\n                if (tool.lifeWarn !== undefined && tool.lifeWarn !== null) {\n                    // 格式化为百分比字符串\n                    const warn = Number(tool.lifeWarn);\n                    this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n                } else {\n                    this.lifeWarnInput = '';\n                }\n            },\n            confirmTool() {\n                this.showToolDialog = false;\n            },\n            async setUseLimit() {\n                if (!this.selectedToolNo) {\n                    this.$showMessage('请选择刀具后再设置上限');\n                    return;\n                }\n                const v = Number(this.useLimitInput);\n                if (isNaN(v) || v <= 0) {\n                    this.$showMessage('请输入有效的使用上限');\n                    return;\n                }\n                this.toolRecords = this.toolRecords.map(r => {\n                    if (r.no === this.selectedToolNo) {\n                        return { ...r, useLimit: v };\n                    }\n                    return r;\n                });\n                this.toolList = this.toolList.map(t => t.no === this.selectedToolNo ? { ...t, useLimit: v } : t);\n                this.$showMessage('使用上限已设置（仅前端显示）');\n            },\n            // 上刀时传递 sdjs = 工单 currentCjNum\n            async handleUpTool() {\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\n                //上刀强制录入使用上限\n                if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\n                const useLimit = Number(this.useLimitInput);\n                if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\n\n                // sdjs 使用工单 currentCjNum\n                const sdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\n                const payload = {\n                    workOrderNo: this.workOrderNo,\n                    machineNo: this.machineNo,\n                    toolNo: this.selectedToolNo,\n                    type: '上机',\n                    useLimit,\n                    sdjs,// 上刀计数（工单当前数采）\n                    modlLifeWorning: lifeWarnRatio // 新增\n                };\n                try {\n                    this.submitting = true;\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/SubmitToolAction',\n                        data: JSON.stringify(payload),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.data && res.data.outSum === \"0\") {\n                        uni.showToast({\n                            title: res.data.outMsg || '',\n                            icon: 'error'\n                        });\n                        return;\n                    } else if (res.data && res.data.outMsg) {\n                        uni.showToast({\n                            title: res.data.outMsg,\n                            icon: 'none'\n                        });\n                    }\n                    // 后续逻辑继续执行\n                    if (res.status === 0) {\n                        await this.fetchFormData();\n                    }\n                } catch (err) {\n                    console.error(err);\n                    this.$showMessage('上刀提交失败，请检查网络');\n                    throw err; // 抛出以便自动保存逻辑捕获并保留 isDirty\n                } finally {\n                    this.submitting = false;\n                }\n            },\n            // 下刀时传递 xdjs = 工单 currentCjNum\n            async handleDownTool() {\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\n                //下刀不强制录入使用上限\n                //if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\n                const useLimit = Number(this.useLimitInput);\n                //if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\n\n                // 下刀计数同样取工单最新采集数\n                const xdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\n                const payload = {\n                    workOrderNo: this.workOrderNo,\n                    machineNo: this.machineNo,\n                    toolNo: this.selectedToolNo,\n                    type: '下机',\n                    useLimit,\n                    xdjs,// 下刀计数\n                    modlLifeWorning: lifeWarnRatio // 新增\n                };\n                try {\n                    this.submitting = true;\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/SubmitToolAction',\n                        data: JSON.stringify(payload),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.data && res.data.outSum === \"0\") {\n                        uni.showToast({\n                            title: res.data.outMsg || '',\n                            icon: 'error'\n                        });\n                        return;\n                    } else if (res.data && res.data.outMsg) {\n                        uni.showToast({\n                            title: res.data.outMsg,\n                            icon: 'none'\n                        });\n                    }\n                    // 后续逻辑继续执行\n                    if (res.status === 0) {\n                        await this.fetchFormData();\n                    }\n                } catch (err) {\n                    console.error(err);\n                    this.$showMessage('下刀提交失败，请检查网络');\n                    throw err;\n                } finally {\n                    this.submitting = false;\n                }\n            },\n            cancel() {\n                this.selectedToolNo = '';\n                this.toolName = '';\n                this.toolModel = '';\n                this.useLimitInput = '';\n                this.lifeWarnInput = ''; // 新增：清空\n                this.isDirty = false;\n            },\n            async fetchFormData() {\n                if (!this.workOrderNo || !this.machineNo) {\n                    console.warn('工单号或机台号为空，跳过获取表单数据');\n                    return;\n                }\n                this.loadingForm = true;\n                const payload = {\n                    workOrderNo: this.workOrderNo.trim(),\n                    machineNo: this.machineNo.trim()\n                };\n                try {\n                    const res = await this.$post({\n                        url: '/MesCutterLedger/GetFormData',\n                        data: JSON.stringify(payload),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.status !== 0) {\n                        this.$showMessage(res.message || '获取表单数据失败');\n                        this.toolRecords = [];\n                        return;\n                    }\n                    const list = Array.isArray(res.data) ? res.data\n                        : (res.data && res.data.tbBillList) ? res.data.tbBillList\n                            : (res.data && res.data.data) ? res.data.data\n                                : [];\n\n                    const getField = (obj, ...keys) => {\n                        for (const k of keys) if (obj?.[k] !== undefined && obj?.[k] !== null) return obj[k];\n                        return null;\n                    };\n\n                    const mapped = (list || []).map(t => {\n                        const upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\n                        const downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\n                        const lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\n                        const currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\n\n                        const useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\n                        const useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\n\n                        let percent = '';\n                        if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n                            percent = ((Number(useCount) / Number(useLimit)) * 100).toFixed(0) + '%';\n                        }\n\n                        const parseNumber = v => {\n                            if (v === null || v === undefined || v === '') return null;\n                            const s = String(v).replace(/[,％%]/g, '').trim();\n                            const n = parseFloat(s);\n                            return Number.isFinite(n) ? n : null;\n                        };\n                        const formatPercent = n => {\n                            if (n === null || n === undefined || isNaN(n)) return '';\n                            if (n <= 1) return `${(n * 100).toFixed(0)}%`;\n                            return `${Number(n).toFixed(0)}%`;\n                        };\n                        const lifeWarnNum = parseNumber(lifeWarnRaw);\n\n                        let warnStatus = getField(t, 'status', 'STATUS') || '';\n                        if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n                            const percentNum = Number(useCount) / Number(useLimit);\n                            warnStatus = (percentNum >= lifeWarnNum) ? '预警' : '正常';\n                        } else {\n                            warnStatus = warnStatus || '未知';\n                        }\n\n                        return {\n                            id: getField(t, 'id', 'ID') || `${getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || ''}-${upTimeRaw || ''}`,\n                            no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\n                            name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\n                            upTime: this.formatDateTime(upTimeRaw),\n                            upCount: getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount') ?? '',\n                            downTime: this.formatDateTime(downTimeRaw),\n                            downCount: getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount') ?? '',\n                            useCount: useCount ?? '',\n                            useLimit: useLimit ?? '',\n                            lifePercent: percent,\n                            lifeWarn: formatPercent(lifeWarnNum),\n                            warnStatus,\n                            currentCjNum\n                        };\n                    });\n\n                    // 新增：按上刀时间降序排序（越晚的越上面）\n                    mapped.sort((a, b) => {\n                        // 时间格式如 \"10-24 16:03\"，转为 Date 对象比较\n                        const parse = s => {\n                            if (!s) return 0;\n                            // 补年份，假设都是今年\n                            const year = new Date().getFullYear();\n                            return new Date(`${year}-${s.replace(/-/g, '-')}:00`).getTime();\n                        };\n                        return parse(b.upTime) - parse(a.upTime); // 注意这里顺序反过来\n                    });\n\n                    this.toolRecords = mapped;\n                    const totalFromRes = Number(\n                        res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\n                    );\n                    this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\n                } catch (error) {\n                    console.error('获取表单数据错误:', error);\n                    this.$showMessage('获取数据失败，请检查网络连接');\n                    this.toolRecords = [];\n                } finally {\n                    this.loadingForm = false;\n                }\n            },\n            // 自动带出工单刀具信息，并获取工单最新采集数\n            async fetchDefaultToolFromWorkOrder() {\n                if (!this.machineNo) return;\n                try {\n                    const res = await this.$post({\n                        url: '/Womdaa/GetWomdaasByShow',\n                        data: JSON.stringify({ machineNo: this.machineNo }),\n                        headers: { 'Content-Type': 'application/json' }\n                    });\n                    if (res.status === 0 && Array.isArray(res.data?.tbBillList) && res.data.tbBillList.length > 0) {\n                        const order = res.data.tbBillList[0];\n                        \n                        // 新增：保存工单数据，用于报试产数\n                        this.order = order;\n                        this.orderId = order.id || order.ID || order.orderId || null;\n                        \n                        this.selectedToolNo = order.cutterId || order.cutteR_ID || '';\n                        this.toolName = order.cutterName || order.cutteR_NAME || '';\n                        this.toolModel = order.cutterModel || order.cutteR_MODEL || '';\n                        // 关键：获取工单最新采集数\n                        this.workOrderCurrentCjNum = order.CurrentCjNum ?? order.currentCjNum ?? null;\n                        // 新增：自动填充寿命比预警值\n                        if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\n                            const warn = Number(order.modlLifeWorning);\n                            this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n                        } else {\n                            this.lifeWarnInput = '';\n                        }\n                    } else {\n                        this.workOrderCurrentCjNum = null;\n                        this.order = {};\n                        this.orderId = null;\n                    }\n                } catch (e) {\n                    console.warn('自动带出工单刀具失败', e);\n                    this.workOrderCurrentCjNum = null;\n                    this.order = {};\n                    this.orderId = null;\n                }\n            },\n            formatDateTime(dateTimeStr) {\n                if (!dateTimeStr) return '';\n                try {\n                    const s = String(dateTimeStr).trim();\n                    if (/^\\d{10}$/.test(s)) {\n                        const d = new Date(Number(s) * 1000);\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\n                    }\n                    if (/^\\d{13}$/.test(s)) {\n                        const d = new Date(Number(s));\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\n                    }\n                    const date = new Date(dateTimeStr);\n                    if (!isNaN(date.getTime())) {\n                        return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${String(date.getMinutes()).padStart(2, '0')}`;\n                    }\n                    const match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\n                    if (match) return `${match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, (m) => m)} ${match[2]}`;\n                    return String(dateTimeStr);\n                } catch {\n                    return String(dateTimeStr);\n                }\n            },\n            \n            // 新增：选择调机师傅\n            selectTiaojiUser(u) {\n                this.tiaojiStaffNo = u;\n                this.isTiaojiUserSelectShow = false;\n                this.tiaojiUserSearch = '';\n            },\n            \n            // 新增：送检呼叫 + 报试产数\n            async handleInspectionCall() {\n                // 验证必填项\n                if (!this.tiaojiStaffNo) {\n                    this.$showMessage('请选择调机师傅');\n                    return;\n                }\n                \n                const okQty = Number(this.tiaojiOkQty);\n                const badQty = Number(this.tiaojiBadQty);\n                \n                if (isNaN(okQty) || okQty < 0) {\n                    this.$showMessage('请输入有效的调机良品数');\n                    return;\n                }\n                \n                if (isNaN(badQty) || badQty < 0) {\n                    this.$showMessage('请输入有效的调机不良品数');\n                    return;\n                }\n                \n                const staffNo = this.tiaojiStaffNo.split(':')[0];\n                const totalQty = okQty + badQty; // 试产总数 = 良品数 + 不良品数\n                \n                // 调用报试产数接口(使用报工界面的接口)\n                const payload = {\n                    orderNo: this.workOrderNo,\n                    orderId: this.orderId, // 需要从工单数据中获取\n                    bf: totalQty, // 试产总数\n                    staffNo: staffNo,\n                    initCjNum: this.order?.initCjNum || 0,\n                    currentCjNum: this.order?.currentCjNum || 0,\n                    type: 'tiaoji', // 标识为调机报工\n                    tiaojiOkQty: okQty, // 新增:良品数\n                    tiaojiBadQty: badQty // 新增:不良品数\n                };\n                \n                try {\n                    this.submitting = true;\n                    // 调用报工界面的报试产数接口\n                    const res = await this.$post({\n                        url: '/MesInvItemBarcodes/AddBFToBarcodes',\n                        data: payload\n                    });\n                    \n                    if (res.status == 1) {\n                        this.$showMessage(res.message);\n                        return;\n                    }\n                    \n                    this.$showMessage('调机报工成功');\n                    // 清空输入\n                    this.tiaojiOkQty = '';\n                    this.tiaojiBadQty = '';\n                    // 刷新数据\n                    await this.fetchFormData();\n                    await this.fetchDefaultToolFromWorkOrder();\n                } catch (err) {\n                    console.error('调机报工错误:', err);\n                    this.$showMessage('调机报工失败，请检查网络');\n                } finally {\n                    this.submitting = false;\n                }\n            },\n            \n            // 新增：获取调机师傅列表\n            async fetchTiaojiStaff() {\n                try {\n                    const res = await this.$post({\n                        url: '/MesStaff/GetAllXS0101BYtj' // 与报工界面使用相同接口\n                    });\n                    if (res.status === 0 && res.data && res.data.tbBillList) {\n                        const staff = res.data.tbBillList;\n                        this.tiaojiUsers = staff.map(s => s.staffNo + ':' + s.staffName);\n                    }\n                } catch (err) {\n                    console.error('获取调机师傅列表失败:', err);\n                }\n            }\n        },\n        mounted() {\n            this.fetchTools('');\n            this.machineNo = uni.getStorageSync('machineNo') || '';\n            this.workOrderNo = uni.getStorageSync('daa001') || '';\n            \n            // 新增：获取调机师傅列表\n            this.fetchTiaojiStaff();\n\n            if (this.machineNo && this.workOrderNo) {\n                this.fetchFormData().then(async () => {\n                    await this.fetchDefaultToolFromWorkOrder();\n                    // 进入页面时赋值第一行 currentCjNum\n                    if (this.toolRecords.length > 0) {\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\n                    }\n                });\n            } else {\n                console.warn('机台号或工单号为空，无法获取表单数据');\n            }\n\n            // 启动自动保存定时器\n            //this.startAutoSave();\n        },\n        beforeDestroy() {\n            // 清理定时器，防止内存泄漏\n            this.stopAutoSave();\n        }\n    };\n</script>\n\n<style scoped>\n    .top-section-grid {\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: flex-start;\n        gap: 12px;\n        margin-bottom: 2vh;\n        width: 99vw;\n        max-width: 1920px;\n        margin-left: auto;\n        margin-right: auto;\n        padding: 12px;\n        background: #f8f9fa;\n        border-radius: 8px;\n        border: 1px solid #e9ecef;\n    }\n\n    .form-row {\n        display: flex;\n        flex-direction: row;\n        justify-content: flex-start;\n        align-items: center;\n        width: 100%;\n        margin-bottom: 12px;\n    }\n\n        .form-row:last-child {\n            margin-bottom: 0;\n        }\n\n    .form-cell {\n        display: flex;\n        align-items: center;\n        min-width: 0;\n        margin-right: 0;\n    }\n\n        .form-cell:nth-child(1) {\n            flex: 0 0 28%;\n            min-width: 180px;\n        }\n\n        .form-cell:nth-child(2) {\n            flex: 0 0 32%;\n            min-width: 180px;\n            justify-content: flex-start;\n        }\n\n        .form-cell:nth-child(3) {\n            flex: 0 0 auto;\n            min-width: 0;\n            max-width: 220px; /* 限制最大宽度，避免撑开 */\n            justify-content: flex-end;\n        }\n\n    .form-label {\n        width: auto;\n        font-weight: 500;\n        color: #333;\n        white-space: nowrap;\n        margin-right: 4px;\n        flex-shrink: 0;\n        font-size: 22px;\n    }\n\n    .input {\n        padding: 14px 20px;\n        border: 1px solid #dcdfe6;\n        flex: 1;\n        margin-right: 0;\n        border-radius: 4px;\n        background: #fff;\n        min-width: 0;\n        height: 56px !important;\n        box-sizing: border-box;\n        font-size: 22px;\n    }\n\n        .input.small-font {\n            /* 不设置字体大小 */\n        }\n\n        .input:disabled {\n            background-color: #f5f7fa;\n            color: #c0c4cc;\n            cursor: not-allowed;\n        }\n\n    .input-with-unit {\n        display: flex;\n        align-items: center;\n        gap: 0;\n    }\n\n        .input-with-unit .input {\n            width: 60px !important;\n            min-width: 0 !important;\n            margin-right: 2px !important;\n            text-align: center;\n            padding-left: 2px;\n            padding-right: 2px;\n        }\n\n        .input-with-unit .input {\n            margin-right: 4px !important;\n            width: 60px !important;\n            min-width: 0 !important;\n            text-align: center;\n        }\n\n    .unit-text {\n        margin-left: 0 !important;\n        padding-left: 0 !important;\n        font-size: 22px !important;\n    }\n\n    .btn-blue, .btn-blue.large-btn {\n        background-color: #1890ff;\n        color: white;\n        border: none;\n        padding: 14px 32px;\n        border-radius: 4px;\n        cursor: pointer;\n        font-weight: 500;\n        white-space: nowrap;\n        height: 70px !important;\n        box-sizing: border-box;\n        transition: all 0.3s;\n        flex-shrink: 0;\n        min-width: 140px;\n        margin-left: 24px;\n    }\n\n        .btn-blue.large-btn {\n            padding: 0 60px;\n            min-width: 180px;\n            height: 72px !important;\n            margin-left: 0 !important;\n            font-size: 1.3em;\n            box-shadow: 0 2px 8px rgba(24,144,255,0.08);\n            line-height: 72px; /* 垂直居中 */\n            display: inline-block; /* 保证line-height生效 */\n            vertical-align: middle;\n        }\n\n        .btn-blue:hover {\n            background-color: #40a9ff;\n        }\n\n        .btn-blue:active {\n            background-color: #096dd9;\n        }\n\n        .btn-blue:disabled {\n            background: #bae7ff;\n            color: #91d5ff;\n            cursor: not-allowed;\n        }\n\n    .button-row {\n        display: flex;\n        justify-content: center;\n        gap: 32px;\n        margin: 2vh 0;\n    }\n\n    .save-btn, .cancel-btn {\n        width: 28%;\n        padding: 1.5vh;\n        background-color: #00A2E9;\n        color: white;\n        border: none;\n        text-align: center;\n        border-radius: 4px;\n        transition: all 0.3s;\n        font-size: 22px;\n        font-weight: 500;\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n    }\n\n    .cancel-btn {\n        background-color: #f5f5f5;\n        color: #333;\n    }\n\n    .save-btn:hover {\n        background-color: #40a9ff;\n    }\n\n    .save-btn:active {\n        background-color: #096dd9;\n    }\n\n    .save-btn:disabled, .cancel-btn:disabled {\n        opacity: 0.6;\n        cursor: not-allowed;\n    }\n\n    /* 弹窗样式 */\n    .dialog-overlay {\n        position: fixed;\n        top: 0;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        background: rgba(0,0,0,0.18);\n        display: flex;\n        justify-content: center;\n        align-items: center;\n        z-index: 1000;\n    }\n\n    .dialog {\n        background: #fff;\n        padding: 3vh 3vw;\n        border-radius: 18px;\n        width: 90vw;\n        max-width: 1600px;\n        min-height: 70vh;\n        max-height: 85vh;\n        box-sizing: border-box;\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\n        display: flex;\n        flex-direction: column;\n    }\n\n    .form-group {\n        display: flex;\n        gap: 12px;\n        align-items: center;\n        margin-bottom: 2vh;\n        flex-shrink: 0;\n    }\n\n        .form-group .input {\n            flex: 1;\n            min-width: 300px;\n            border-radius: 6px;\n            background: #f8f8f8;\n        }\n\n    .tool-list {\n        display: flex;\n        flex-wrap: wrap;\n        margin: 1vh 0;\n        flex: 1;\n        overflow-y: auto;\n        gap: 12px;\n        align-content: flex-start;\n    }\n\n    .tool-btn {\n        flex: 0 0 calc(20% - 10px);\n        box-sizing: border-box;\n        padding: 10px 12px;\n        background: #f5f5f5;\n        border: 1px solid #d0d0d0;\n        border-radius: 8px;\n        cursor: pointer;\n        color: #333;\n        text-align: left;\n        min-height: 50px;\n        transition: background 0.15s, color 0.15s;\n        overflow: hidden;\n        text-overflow: ellipsis;\n        white-space: nowrap;\n        line-height: 1.4;\n    }\n\n        .tool-btn.active {\n            background: #00A2E9;\n            color: #fff;\n            font-weight: bold;\n            border: 1.5px solid #0086c2;\n        }\n\n    .dialog-actions {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n        margin-top: 2vh;\n        padding-top: 2vh;\n        border-top: 1px solid #eee;\n        flex-shrink: 0;\n    }\n\n        .dialog-actions > div:first-child {\n            display: flex;\n            align-items: center;\n            gap: 24px;\n        }\n\n        .dialog-actions > div:last-child {\n            display: flex;\n            flex-direction: row;\n            gap: 18px;\n            align-items: center;\n        }\n\n        .dialog-actions .btn-blue {\n            padding: 10px 24px;\n            min-width: 120px;\n            font-size: 22px;\n        }\n\n    .btn-disabled {\n        background: #f2f2f2;\n        color: #999;\n        border: none;\n        padding: 10px 24px;\n        border-radius: 4px;\n        font-weight: 500;\n        cursor: not-allowed;\n        box-shadow: none;\n        min-width: 120px;\n    }\n\n    .table-section {\n        display: flex;\n        justify-content: center;\n        margin: 1vh 0;\n        overflow-x: auto;\n        width: 100%; /* 确保表格容器占满宽度 */\n    }\n\n    table.styled-table {\n        max-width: 1800px; /* 从1600px增加到1800px */\n        width: 98vw; /* 从95vw增加到98vw */\n        margin: 0 auto;\n        border-collapse: separate;\n        border-spacing: 0;\n        border: 2px solid #bfbfbf;\n        background: #fff;\n        border-radius: 12px;\n        overflow: hidden;\n        box-shadow: 0 2px 12px rgba(0,0,0,0.06);\n    }\n\n        table.styled-table thead th {\n            background: #fafafa;\n            border-bottom: 2px solid #bfbfbf;\n            padding: 16px 10px;\n            font-weight: bold;\n            text-align: center;\n            font-size: 22px;\n        }\n\n        table.styled-table tbody td {\n            border-bottom: 1px solid #e8e8e8;\n            padding: 14px 10px;\n            vertical-align: middle;\n            text-align: center;\n            font-size: 22px;\n        }\n\n    .table-section table th:first-child, .table-section table td:first-child {\n        border-left: 2px solid #bfbfbf;\n    }\n\n    .table-section table th:last-child, .table-section table td:last-child {\n        border-right: 2px solid #bfbfbf;\n    }\n\n    .row-odd {\n        background: #fff;\n    }\n\n        .row-odd + tr {\n            background: #fafafa;\n        }\n\n    .num {\n        text-align: center;\n        padding-right: 0;\n        font-variant-numeric: tabular-nums;\n    }\n\n    .left {\n        text-align: left;\n        padding-left: 8px;\n    }\n\n    .warn-cell {\n        color: #d93025;\n        font-weight: bold;\n    }\n\n    .ok-cell {\n        color: #333;\n    }\n\n    .warn-badge {\n        display: inline-block;\n        background: #ff4d4f;\n        color: #fff;\n        padding: 2px 6px;\n        border-radius: 3px;\n        font-weight: bold;\n    }\n\n    /* 响应式调整 */\n    @media (max-width: 1200px) {\n        .form-cell {\n            margin: 0 4px;\n        }\n\n        .form-label {\n            width: 90px;\n        }\n\n        .input {\n            padding: 10px 14px;\n        }\n\n        .btn-blue {\n            padding: 10px 18px;\n        }\n    }\n\n    .input-life-warn {\n        width: 48px !important; /* 稍微放宽，避免字体溢出 */\n        min-width: 0 !important;\n        margin-right: 4px;\n        padding-left: 2px;\n        padding-right: 2px;\n        font-size: 22px !important;\n        text-align: center;\n        box-sizing: border-box;\n    }\n\n    .input,\n    .input.small-font,\n    .input-use-limit,\n    .input-tool-model,\n    .input-tool-name,\n    .input-life-warn {\n        font-size: 22px !important;\n    }\n\n    .input-tool-model {\n        width: 320px !important; /* 原为200px，现加长 */\n        min-width: 0 !important;\n        margin-right: 16px;\n    }\n\n    .input-tool-name {\n        width: 120px !important;\n        min-width: 0 !important;\n        margin-right: 16px;\n    }\n\n    .highlight-label {\n        color: #1890ff !important;\n    }\n\n    .tool-dir-cell {\n        flex: 0 0 auto !important;\n        justify-content: flex-start !important;\n        display: flex !important;\n        align-items: center;\n        margin-left: 16px; /* 与规格型号输入框拉开距离 */\n    }\n\n    .form-cell-flex {\n        display: flex;\n        align-items: center;\n        flex: 0 0 60%;\n        min-width: 320px;\n    }\n\n        .form-cell-flex .form-label {\n            margin-right: 4px;\n            width: auto;\n        }\n\n        .form-cell-flex .input-use-limit {\n            margin-right: 12px;\n        }\n\n    .input-use-limit {\n        width: 450px !important;\n        min-width: 0 !important;\n        margin-right: 16px;\n        flex: none !important; /* 关键：彻底禁止flex拉伸 */\n    }\n\n    /* 新增：调机区域样式 */\n    .tiaoji-section {\n        width: 100%;\n        margin: 2vh 0;\n        padding: 20px;\n        background: #f8f9fa;\n        border-radius: 8px;\n        border: 1px solid #e9ecef;\n    }\n\n    .tiaoji-row {\n        display: flex;\n        flex-wrap: wrap;\n        align-items: center;\n        gap: 20px;\n    }\n\n    /* 当前调机师傅区域 - 与报工界面保持一致 */\n    .current-user-section {\n        display: flex;\n        align-items: center;\n        font-size: 22px;\n        border: 1.5px solid #f00;\n        border-radius: 10px;\n        padding: 14px 22px;\n        background: #fff;\n        gap: 14px;\n        flex: 0 0 auto;\n    }\n\n    .current-user-name {\n        font-weight: bold;\n        font-size: 22px;\n    }\n\n    /* 选人按钮 - 蓝色主题，与报工界面保持一致 */\n    .select-user-btn {\n        background: #00a2e9;\n        color: #fff;\n        border: none;\n        padding: 12px 22px;\n        border-radius: 12px;\n        font-size: 22px;\n        cursor: pointer;\n        transition: background 0.15s;\n        height: 66px;\n        box-sizing: border-box;\n        display: flex;\n        align-items: center;\n        justify-content: center;\n    }\n\n        .select-user-btn:hover {\n            background: #008ac2;\n        }\n\n    /* 调机数量输入区域 */\n    .tiaoji-input-section {\n        display: flex;\n        align-items: center;\n        gap: 14px;\n        font-size: 22px;\n    }\n\n    .tiaoji-input {\n        width: 200px;\n        max-width: 100%;\n        height: 66px;\n        border: 2px solid #808080;\n        font-size: 28px;\n        text-align: center;\n        border-radius: 8px;\n        box-sizing: border-box;\n    }\n\n    /* 送检呼叫按钮 - 与报工界面的确认提交按钮保持一致 */\n    .details-btn {\n        padding: 12px 34px;\n        background: #00a2e9;\n        color: #fff;\n        font-size: 32px;\n        border: none;\n        cursor: pointer;\n        border-radius: 12px;\n        height: 66px;\n        min-width: 180px;\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: center;\n        line-height: 1.1;\n        box-sizing: border-box;\n        transition: background 0.15s;\n    }\n\n        .details-btn:hover {\n            background: #008ac2;\n        }\n\n        .details-btn:disabled {\n            opacity: 0.6;\n            cursor: not-allowed;\n            background: #bae7ff;\n        }\n\n    .tiaoji-submit-section {\n        display: flex;\n        align-items: center;\n    }\n\n    /* 选人弹窗样式 - 与报工界面保持一致 */\n    .overlay {\n        position: fixed;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 100%;\n        background: rgba(0,0,0,.45);\n        display: flex;\n        justify-content: center;\n        align-items: center;\n        z-index: 1000;\n    }\n\n    .user-select-popup {\n        background: #fff;\n        width: 1600px;\n        max-width: 99vw;\n        min-width: 1000px;\n        height: auto;\n        min-height: 520px;\n        padding: 0;\n        display: flex;\n        flex-direction: column;\n        font-size: 32px;\n        border-radius: 12px;\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\n        z-index: 1001;\n    }\n\n    .user-search-bar {\n        display: flex;\n        align-items: center;\n        gap: 18px;\n        padding: 24px 64px 0 64px;\n        background: #fff;\n        flex-wrap: wrap;\n    }\n\n    .user-search-input {\n        flex: 1 1 260px;\n        padding: 16px 20px;\n        font-size: 28px;\n        border: 1px solid #bbb;\n        border-radius: 8px;\n        outline: none;\n        height: 54px;\n    }\n\n        .user-search-input:focus {\n            border-color: #007aff;\n            box-shadow: 0 0 0 2px rgba(0,122,255,.15);\n        }\n\n    .user-search-clear {\n        padding: 12px 28px;\n        background: #ff9f43;\n        color: #fff;\n        border: none;\n        border-radius: 8px;\n        font-size: 24px;\n        cursor: pointer;\n    }\n\n        .user-search-clear:hover {\n            background: #ff8920;\n        }\n\n    .user-search-info {\n        font-size: 22px;\n        color: #555;\n    }\n\n    .user-list-scroll {\n        flex: 1 1 auto;\n        overflow-y: auto;\n        padding: 32px 64px 0 64px;\n    }\n\n    .user-list-grid {\n        display: grid;\n        grid-template-columns: repeat(auto-fill,minmax(200px,1fr));\n        gap: 22px 22px;\n    }\n\n    .user-list-btn {\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: center;\n        gap: 2px;\n        padding: 10px 10px;\n        height: 100px;\n        font-size: 30px;\n        background: #00a2e9;\n        color: #fff;\n        border: none;\n        border-radius: 8px;\n        cursor: pointer;\n        box-sizing: border-box;\n        word-break: break-word;\n    }\n\n        .user-list-btn .user-code {\n            font-weight: 700;\n            font-size: 36px;\n            line-height: 1.1;\n        }\n\n        .user-list-btn .user-name {\n            font-size: 32px;\n            line-height: 1.1;\n        }\n\n        .user-list-btn.selected {\n            background: #0072c9;\n            box-shadow: 0 0 0 3px rgba(255,255,255,.6) inset;\n        }\n\n        .user-list-btn:hover {\n            background: #008ed0;\n        }\n\n    .no-user-result {\n        padding: 40px 0;\n        text-align: center;\n        font-size: 28px;\n        color: #666;\n    }\n\n    .user-popup-footer {\n        flex-shrink: 0;\n        padding: 24px 64px 32px 64px;\n        background: #fff;\n        text-align: center;\n    }\n\n    .clean-btn {\n        width: 24%;\n        padding: 10px 0;\n        color: #fff;\n        font-size: 20px;\n        border: none;\n        text-align: center;\n        cursor: pointer;\n        border-radius: 0.6vw;\n        background: #007aff;\n    }\n\n        .clean-btn.wide-btn {\n            width: 30%;\n            font-size: 22px;\n            padding: 12px 0;\n        }\n\n        .clean-btn:hover {\n            background: #0062c9;\n        }\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///62\n");
/***/ }),
/* 63 */
@@ -9724,7 +9689,11 @@
),
_c(
"view",
- { staticClass: _vm._$s(3, "sc", "table-section"), attrs: { _i: 3 } },
+ {
+ staticClass: _vm._$s(3, "sc", "table-section"),
+ class: _vm._$s(3, "c", { expanded: _vm.toolExpanded }),
+ attrs: { _i: 3 },
+ },
[
_c(
"view",
@@ -9756,11 +9725,7 @@
),
_c(
"table",
- {
- staticClass: _vm._$s(7, "sc", "styled-table"),
- class: _vm._$s(7, "c", { expanded: _vm.toolExpanded }),
- attrs: { _i: 7 },
- },
+ { staticClass: _vm._$s(7, "sc", "styled-table"), attrs: { _i: 7 } },
[
_c("thead", [
_c("tr", [
@@ -10142,6 +10107,20 @@
)
),
]),
+ _c("button", {
+ staticClass: _vm._$s(
+ 55,
+ "sc",
+ "inline-expand-btn"
+ ),
+ attrs: { _i: 55 },
+ on: {
+ click: function ($event) {
+ return _vm.toggleExpand("tool")
+ },
+ },
+ }),
+ _c("span"),
]
),
])
@@ -10155,21 +10134,25 @@
),
_c(
"view",
- { staticClass: _vm._$s(55, "sc", "table-section"), attrs: { _i: 55 } },
+ {
+ staticClass: _vm._$s(57, "sc", "table-section"),
+ class: _vm._$s(57, "c", { expanded: _vm.inspectionExpanded }),
+ attrs: { _i: 57 },
+ },
[
_c(
"view",
{
- staticClass: _vm._$s(56, "sc", "table-header"),
- attrs: { _i: 56 },
+ staticClass: _vm._$s(58, "sc", "table-header"),
+ attrs: { _i: 58 },
},
[
_c("h3"),
_c(
"button",
{
- staticClass: _vm._$s(58, "sc", "expand-btn"),
- attrs: { _i: 58 },
+ staticClass: _vm._$s(60, "sc", "expand-btn"),
+ attrs: { _i: 60 },
on: {
click: function ($event) {
return _vm.toggleExpand("inspection")
@@ -10179,7 +10162,7 @@
[
_vm._v(
_vm._$s(
- 58,
+ 60,
"t0-0",
_vm._s(_vm.inspectionExpanded ? "鏀惰捣" : "灞曞紑")
)
@@ -10191,9 +10174,8 @@
_c(
"table",
{
- staticClass: _vm._$s(59, "sc", "styled-table"),
- class: _vm._$s(59, "c", { expanded: _vm.inspectionExpanded }),
- attrs: { _i: 59 },
+ staticClass: _vm._$s(61, "sc", "styled-table"),
+ attrs: { _i: 61 },
},
[
_c("thead", [
@@ -10212,27 +10194,27 @@
"tbody",
[
_vm._l(
- _vm._$s(71, "f", {
+ _vm._$s(73, "f", {
forItems: _vm.visibleInspectionRecords,
}),
function (item, idx, $21, $31) {
return _c(
"tr",
{
- key: _vm._$s(71, "f", {
+ key: _vm._$s(73, "f", {
forIndex: $21,
key: item.id || idx,
}),
- class: _vm._$s("71-" + $31, "c", {
+ class: _vm._$s("73-" + $31, "c", {
"row-odd": idx % 2 === 0,
}),
- attrs: { _i: "71-" + $31 },
+ attrs: { _i: "73-" + $31 },
},
[
_c("td", [
_vm._v(
_vm._$s(
- "72-" + $31,
+ "74-" + $31,
"t0-0",
_vm._s(item.releaseNo || "")
)
@@ -10241,7 +10223,7 @@
_c("td", [
_vm._v(
_vm._$s(
- "73-" + $31,
+ "75-" + $31,
"t0-0",
_vm._s(item.fcheckBy || "")
)
@@ -10250,7 +10232,7 @@
_c("td", [
_vm._v(
_vm._$s(
- "74-" + $31,
+ "76-" + $31,
"t0-0",
_vm._s(_vm.formatDate(item.fcheckDate))
)
@@ -10259,7 +10241,7 @@
_c("td", [
_vm._v(
_vm._$s(
- "75-" + $31,
+ "77-" + $31,
"t0-0",
_vm._s(item.lineNo || "")
)
@@ -10268,7 +10250,7 @@
_c("td", [
_vm._v(
_vm._$s(
- "76-" + $31,
+ "78-" + $31,
"t0-0",
_vm._s(item.fsubmit == 1 ? "宸叉彁浜�" : "鏈彁浜�")
)
@@ -10277,7 +10259,7 @@
_c("td", [
_vm._v(
_vm._$s(
- "77-" + $31,
+ "79-" + $31,
"t0-0",
_vm._s(item.fcancel == "Y" ? "浣滃簾" : "鏈綔搴�")
)
@@ -10286,7 +10268,7 @@
_c("td", [
_vm._v(
_vm._$s(
- "78-" + $31,
+ "80-" + $31,
"t0-0",
_vm._s(item.fsecondResu || "")
)
@@ -10295,13 +10277,13 @@
_c(
"td",
{
- staticClass: _vm._$s("79-" + $31, "sc", "left"),
- attrs: { _i: "79-" + $31 },
+ staticClass: _vm._$s("81-" + $31, "sc", "left"),
+ attrs: { _i: "81-" + $31 },
},
[
_vm._v(
_vm._$s(
- "79-" + $31,
+ "81-" + $31,
"t0-0",
_vm._s(item.remeke || "")
)
@@ -10312,31 +10294,45 @@
)
}
),
- _vm._$s(80, "i", !_vm.inspectionRecords.length)
- ? _c("tr", { attrs: { _i: 80 } }, [_c("td", {})])
+ _vm._$s(82, "i", !_vm.inspectionRecords.length)
+ ? _c("tr", { attrs: { _i: 82 } }, [_c("td", {})])
: _vm._e(),
_vm._$s(
- 82,
+ 84,
"i",
_vm.hasMoreInspectionRecords && !_vm.inspectionExpanded
)
- ? _c("tr", { attrs: { _i: 82 } }, [
+ ? _c("tr", { attrs: { _i: 84 } }, [
_c(
"td",
{
- staticClass: _vm._$s(83, "sc", "more-records-tip"),
- attrs: { _i: 83 },
+ staticClass: _vm._$s(85, "sc", "more-records-tip"),
+ attrs: { _i: 85 },
},
[
_c("span", [
_vm._v(
_vm._$s(
- 84,
+ 86,
"t0-0",
_vm._s(_vm.remainingInspectionRecords)
)
),
]),
+ _c("button", {
+ staticClass: _vm._$s(
+ 87,
+ "sc",
+ "inline-expand-btn"
+ ),
+ attrs: { _i: 87 },
+ on: {
+ click: function ($event) {
+ return _vm.toggleExpand("inspection")
+ },
+ },
+ }),
+ _c("span"),
]
),
])
@@ -10377,7 +10373,7 @@
/***/ (function(module, exports, __webpack_require__) {
"use strict";
-eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 3));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 9));\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n data: function data() {\n return {\n machineNo: '',\n workOrderNo: '',\n selectedToolNo: '',\n toolName: '',\n useLimitInput: '',\n lifeWarnInput: '',\n toolRecords: [],\n inspectionRecords: [],\n // 棣栨璁板綍\n loadingForm: false,\n loadingInspection: false,\n // 棣栨璁板綍鍔犺浇鐘舵�乗n submitting: false,\n workOrderCurrentCjNum: null,\n toolExpanded: false,\n // 鍒�鍏疯〃鏍煎睍寮�鐘舵�乗n inspectionExpanded: false,\n // 棣栨琛ㄦ牸灞曞紑鐘舵�乗n defaultVisibleRows: 3 // 榛樿鏄剧ず鐨勮鏁癨n };\n },\n\n computed: {\n // 鍒�鍏疯〃鏍肩浉鍏宠绠梊n defaultToolRows: function defaultToolRows() {\n var total = this.toolRecords.length;\n if (total <= 3) return total;\n return Math.max(3, Math.floor(total / 2));\n },\n visibleToolRecords: function visibleToolRecords() {\n if (this.toolExpanded) {\n return this.toolRecords;\n } else {\n return this.toolRecords.slice(0, this.defaultToolRows);\n }\n },\n hasMoreToolRecords: function hasMoreToolRecords() {\n return this.toolRecords.length > this.defaultToolRows;\n },\n remainingToolRecords: function remainingToolRecords() {\n return this.toolRecords.length - this.defaultToolRows;\n },\n // 棣栨琛ㄦ牸鐩稿叧璁$畻\n defaultInspectionRows: function defaultInspectionRows() {\n var total = this.inspectionRecords.length;\n if (total <= 2) return total; // 棣栨琛ㄦ牸榛樿鏄剧ず2琛孿n return Math.max(2, Math.floor(total / 2));\n },\n visibleInspectionRecords: function visibleInspectionRecords() {\n if (this.inspectionExpanded) {\n return this.inspectionRecords;\n } else {\n return this.inspectionRecords.slice(0, this.defaultInspectionRows);\n }\n },\n hasMoreInspectionRecords: function hasMoreInspectionRecords() {\n return this.inspectionRecords.length > this.defaultInspectionRows;\n },\n remainingInspectionRecords: function remainingInspectionRecords() {\n return this.inspectionRecords.length - this.defaultInspectionRows;\n }\n },\n methods: {\n // 鍒囨崲琛ㄦ牸灞曞紑鐘舵�乗n toggleExpand: function toggleExpand(tableType) {\n if (tableType === 'tool') {\n this.toolExpanded = !this.toolExpanded;\n } else if (tableType === 'inspection') {\n this.inspectionExpanded = !this.inspectionExpanded;\n }\n },\n // 鍒锋柊鎸夐挳澶勭悊鏂规硶\n handleRefresh: function handleRefresh() {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!(_this.machineNo && _this.workOrderNo)) {\n _context.next = 4;\n break;\n }\n _context.next = 3;\n return Promise.all([_this.fetchFormData(), _this.fetchDefaultToolFromWorkOrder(), _this.fetchInspectionRecords()]);\n case 3:\n // 鍒锋柊鍚庤祴鍊肩涓�琛� currentCjNum\n if (_this.toolRecords.length > 0) {\n _this.$set(_this.toolRecords[0], 'currentCjNum', _this.workOrderCurrentCjNum);\n }\n case 4:\n _this.$showMessage('鍒锋柊瀹屾垚');\n case 5:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }))();\n },\n // 鑾峰彇宸ュ崟棣栨璁板綍\n fetchInspectionRecords: function fetchInspectionRecords() {\n var _this2 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {\n var res, list;\n return _regenerator.default.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n if (_this2.workOrderNo) {\n _context2.next = 3;\n break;\n }\n __f__(\"warn\", '宸ュ崟鍙蜂负绌猴紝璺宠繃鑾峰彇棣栨璁板綍', \" at pages/moldRecord.vue:239\");\n return _context2.abrupt(\"return\");\n case 3:\n _this2.loadingInspection = true;\n _context2.prev = 4;\n _context2.next = 7;\n return _this2.$post({\n url: '/MesCutterLedger/GetInspectionRecords',\n data: JSON.stringify({\n aufnr: _this2.workOrderNo,\n ftype: '棣栨'\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 7:\n res = _context2.sent;\n if (res.status === 0) {\n // 鏍规嵁瀹為檯鎺ュ彛杩斿洖缁撴瀯璋冩暣\n list = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : [];\n _this2.inspectionRecords = list || [];\n } else {\n _this2.$showMessage(res.message || '鑾峰彇棣栨璁板綍澶辫触');\n _this2.inspectionRecords = [];\n }\n _context2.next = 16;\n break;\n case 11:\n _context2.prev = 11;\n _context2.t0 = _context2[\"catch\"](4);\n __f__(\"error\", '鑾峰彇棣栨璁板綍閿欒:', _context2.t0, \" at pages/moldRecord.vue:265\");\n _this2.$showMessage('鑾峰彇棣栨璁板綍澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');\n _this2.inspectionRecords = [];\n case 16:\n _context2.prev = 16;\n _this2.loadingInspection = false;\n return _context2.finish(16);\n case 19:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, null, [[4, 11, 16, 19]]);\n }))();\n },\n // 鏍煎紡鍖栨棩鏈焅n formatDate: function formatDate(dateStr) {\n if (!dateStr) return '';\n try {\n var date = new Date(dateStr);\n if (isNaN(date.getTime())) return String(dateStr);\n return \"\".concat(date.getMonth() + 1, \"-\").concat(date.getDate(), \" \").concat(date.getHours(), \":\").concat(String(date.getMinutes()).padStart(2, '0'));\n } catch (_unused) {\n return String(dateStr);\n }\n },\n // 鍏朵粬宸叉湁鏂规硶淇濇寔涓嶅彉...\n fetchDefaultToolFromWorkOrder: function fetchDefaultToolFromWorkOrder() {\n var _this3 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {\n var _res$data, res, _ref, _order$CurrentCjNum, order, warn;\n return _regenerator.default.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n if (_this3.machineNo) {\n _context3.next = 2;\n break;\n }\n return _context3.abrupt(\"return\");\n case 2:\n _context3.prev = 2;\n _context3.next = 5;\n return _this3.$post({\n url: '/Womdaa/GetWomdaasByShow',\n data: JSON.stringify({\n machineNo: _this3.machineNo\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 5:\n res = _context3.sent;\n if (res.status === 0 && Array.isArray((_res$data = res.data) === null || _res$data === void 0 ? void 0 : _res$data.tbBillList) && res.data.tbBillList.length > 0) {\n order = res.data.tbBillList[0];\n _this3.selectedToolNo = order.cutterId || order.cutteR_ID || '';\n _this3.toolName = order.cutterName || order.cutteR_NAME || '';\n _this3.workOrderCurrentCjNum = (_ref = (_order$CurrentCjNum = order.CurrentCjNum) !== null && _order$CurrentCjNum !== void 0 ? _order$CurrentCjNum : order.currentCjNum) !== null && _ref !== void 0 ? _ref : null;\n if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\n warn = Number(order.modlLifeWorning);\n _this3.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n } else {\n _this3.lifeWarnInput = '';\n }\n } else {\n _this3.workOrderCurrentCjNum = null;\n }\n _context3.next = 13;\n break;\n case 9:\n _context3.prev = 9;\n _context3.t0 = _context3[\"catch\"](2);\n __f__(\"warn\", '鑷姩甯﹀嚭宸ュ崟鍒�鍏峰け璐�', _context3.t0, \" at pages/moldRecord.vue:309\");\n _this3.workOrderCurrentCjNum = null;\n case 13:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, null, [[2, 9]]);\n }))();\n },\n fetchFormData: function fetchFormData() {\n var _this4 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4() {\n var payload, res, list, getField, mapped;\n return _regenerator.default.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n if (!(!_this4.workOrderNo || !_this4.machineNo)) {\n _context4.next = 3;\n break;\n }\n __f__(\"warn\", '宸ュ崟鍙锋垨鏈哄彴鍙蜂负绌猴紝璺宠繃鑾峰彇琛ㄥ崟鏁版嵁', \" at pages/moldRecord.vue:316\");\n return _context4.abrupt(\"return\");\n case 3:\n _this4.loadingForm = true;\n payload = {\n workOrderNo: _this4.workOrderNo.trim(),\n machineNo: _this4.machineNo.trim()\n };\n _context4.prev = 5;\n _context4.next = 8;\n return _this4.$post({\n url: '/MesCutterLedger/GetFormData',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 8:\n res = _context4.sent;\n if (!(res.status !== 0)) {\n _context4.next = 13;\n break;\n }\n _this4.$showMessage(res.message || '鑾峰彇琛ㄥ崟鏁版嵁澶辫触');\n _this4.toolRecords = [];\n return _context4.abrupt(\"return\");\n case 13:\n list = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : []; // 鏁版嵁澶勭悊閫昏緫淇濇寔涓嶅彉...\n getField = function getField(obj) {\n for (var _len = arguments.length, keys = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n keys[_key - 1] = arguments[_key];\n }\n for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {\n var k = _keys[_i];\n if ((obj === null || obj === void 0 ? void 0 : obj[k]) !== undefined && (obj === null || obj === void 0 ? void 0 : obj[k]) !== null) return obj[k];\n }\n return null;\n };\n mapped = (list || []).map(function (t) {\n var _getField, _getField2;\n var upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\n var downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\n var lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\n var currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\n var useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\n var useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\n var percent = '';\n if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n percent = (Number(useCount) / Number(useLimit) * 100).toFixed(0) + '%';\n }\n var parseNumber = function parseNumber(v) {\n if (v === null || v === undefined || v === '') return null;\n var s = String(v).replace(/[,锛�%]/g, '').trim();\n var n = parseFloat(s);\n return Number.isFinite(n) ? n : null;\n };\n var formatPercent = function formatPercent(n) {\n if (n === null || n === undefined || isNaN(n)) return '';\n if (n <= 1) return \"\".concat((n * 100).toFixed(0), \"%\");\n return \"\".concat(Number(n).toFixed(0), \"%\");\n };\n var lifeWarnNum = parseNumber(lifeWarnRaw);\n var warnStatus = getField(t, 'status', 'STATUS') || '';\n if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n var percentNum = Number(useCount) / Number(useLimit);\n warnStatus = percentNum >= lifeWarnNum ? '棰勮' : '姝e父';\n } else {\n warnStatus = warnStatus || '鏈煡';\n }\n return {\n id: getField(t, 'id', 'ID') || \"\".concat(getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || '', \"-\").concat(upTimeRaw || ''),\n no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\n name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\n upTime: _this4.formatDateTime(upTimeRaw),\n upCount: (_getField = getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount')) !== null && _getField !== void 0 ? _getField : '',\n downTime: _this4.formatDateTime(downTimeRaw),\n downCount: (_getField2 = getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount')) !== null && _getField2 !== void 0 ? _getField2 : '',\n useCount: useCount !== null && useCount !== void 0 ? useCount : '',\n useLimit: useLimit !== null && useLimit !== void 0 ? useLimit : '',\n lifePercent: percent,\n lifeWarn: formatPercent(lifeWarnNum),\n warnStatus: warnStatus,\n currentCjNum: currentCjNum\n };\n });\n mapped.sort(function (a, b) {\n var parse = function parse(s) {\n if (!s) return 0;\n var year = new Date().getFullYear();\n return new Date(\"\".concat(year, \"-\").concat(s.replace(/-/g, '-'), \":00\")).getTime();\n };\n return parse(b.upTime) - parse(a.upTime);\n });\n _this4.toolRecords = mapped;\n _context4.next = 25;\n break;\n case 20:\n _context4.prev = 20;\n _context4.t0 = _context4[\"catch\"](5);\n __f__(\"error\", '鑾峰彇琛ㄥ崟鏁版嵁閿欒:', _context4.t0, \" at pages/moldRecord.vue:409\");\n _this4.$showMessage('鑾峰彇鏁版嵁澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');\n _this4.toolRecords = [];\n case 25:\n _context4.prev = 25;\n _this4.loadingForm = false;\n return _context4.finish(25);\n case 28:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, null, [[5, 20, 25, 28]]);\n }))();\n },\n formatDateTime: function formatDateTime(dateTimeStr) {\n if (!dateTimeStr) return '';\n try {\n var s = String(dateTimeStr).trim();\n if (/^\\d{10}$/.test(s)) {\n var d = new Date(Number(s) * 1000);\n return \"\".concat(d.getMonth() + 1, \"-\").concat(d.getDate(), \" \").concat(d.getHours(), \":\").concat(String(d.getMinutes()).padStart(2, '0'));\n }\n if (/^\\d{13}$/.test(s)) {\n var _d = new Date(Number(s));\n return \"\".concat(_d.getMonth() + 1, \"-\").concat(_d.getDate(), \" \").concat(_d.getHours(), \":\").concat(String(_d.getMinutes()).padStart(2, '0'));\n }\n var date = new Date(dateTimeStr);\n if (!isNaN(date.getTime())) {\n return \"\".concat(date.getMonth() + 1, \"-\").concat(date.getDate(), \" \").concat(date.getHours(), \":\").concat(String(date.getMinutes()).padStart(2, '0'));\n }\n var match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\n if (match) return \"\".concat(match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, function (m) {\n return m;\n }), \" \").concat(match[2]);\n return String(dateTimeStr);\n } catch (_unused2) {\n return String(dateTimeStr);\n }\n }\n },\n mounted: function mounted() {\n var _this5 = this;\n this.machineNo = uni.getStorageSync('machineNo') || '';\n this.workOrderNo = uni.getStorageSync('daa001') || '';\n if (this.machineNo && this.workOrderNo) {\n this.fetchFormData().then( /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5() {\n return _regenerator.default.wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n _context5.next = 2;\n return _this5.fetchDefaultToolFromWorkOrder();\n case 2:\n _context5.next = 4;\n return _this5.fetchInspectionRecords();\n case 4:\n if (_this5.toolRecords.length > 0) {\n _this5.$set(_this5.toolRecords[0], 'currentCjNum', _this5.workOrderCurrentCjNum);\n }\n case 5:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5);\n })));\n } else {\n __f__(\"warn\", '鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇鏁版嵁', \" at pages/moldRecord.vue:454\");\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 1)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/moldRecord.vue"],"names":["data","machineNo","workOrderNo","selectedToolNo","toolName","useLimitInput","lifeWarnInput","toolRecords","inspectionRecords","loadingForm","loadingInspection","submitting","workOrderCurrentCjNum","toolExpanded","inspectionExpanded","defaultVisibleRows","computed","defaultToolRows","visibleToolRecords","hasMoreToolRecords","remainingToolRecords","defaultInspectionRows","visibleInspectionRecords","hasMoreInspectionRecords","remainingInspectionRecords","methods","toggleExpand","handleRefresh","Promise","fetchInspectionRecords","url","aufnr","ftype","headers","res","list","formatDate","fetchDefaultToolFromWorkOrder","order","warn","fetchFormData","payload","getField","keys","mapped","percent","warnStatus","id","no","name","upTime","upCount","downTime","downCount","useCount","useLimit","lifePercent","lifeWarn","currentCjNum","formatDateTime","mounted"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAoJA;EACAA;IACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MACAC;MAAA;MACAC;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;IACA;EACA;;EACAC;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;QACA;MACA;QACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MACA;IACA;IAEA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;QACA;MACA;QACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MACA;IACA;EACA;EACAC;IACA;IACAC;MACA;QACA;MACA;QACA;MACA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACAC,aACA,uBACA,uCACA,+BACA;cAAA;gBACA;gBACA;kBACA;gBACA;cAAA;gBAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;gBAAA;gBAAA;gBAAA,OAEA;kBACAC;kBACA9B;oBACA+B;oBACAC;kBACA;kBACAC;oBAAA;kBAAA;gBACA;cAAA;gBAPAC;gBASA;kBACA;kBACAC,4CACAD,wDACAA,4CACA;kBACA;gBACA;kBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAE;MACA;MACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAP;kBACA9B;oBAAAC;kBAAA;kBACAgC;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAKA;kBACAI;kBACA;kBACA;kBACA;kBACA;oBACAC;oBACA;kBACA;oBACA;kBACA;gBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;gBACAC;kBACAvC;kBACAD;gBACA;gBAAA;gBAAA;gBAAA,OAEA;kBACA6B;kBACA9B;kBACAiC;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACA;gBACA;gBAAA;cAAA;gBAGAC,4CACAD,wDACAA,4CACA,IAEA;gBACAQ;kBAAA;oBAAAC;kBAAA;kBACA;oBAAA;oBAAA;kBAAA;kBACA;gBACA;gBAEAC;kBAAA;kBACA;kBACA;kBACA;kBACA;kBAEA;kBACA;kBAEA;kBACA;oBACAC;kBACA;kBAEA;oBACA;oBACA;oBACA;oBACA;kBACA;kBACA;oBACA;oBACA;oBACA;kBACA;kBACA;kBAEA;kBACA;oBACA;oBACAC;kBACA;oBACAA;kBACA;kBAEA;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAX;oBACAY;kBACA;gBACA;gBAEAd;kBACA;oBACA;oBACA;oBACA;kBACA;kBACA;gBACA;gBAEA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEAe;MACA;MACA;QACA;QACA;UACA;UACA;QACA;QACA;UACA;UACA;QACA;QACA;QACA;UACA;QACA;QACA;QACA;UAAA;QAAA;QACA;MACA;QACA;MACA;IACA;EACA;EACAC;IAAA;IACA;IACA;IAEA;MACA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBACA;kBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CACA;IACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"119.js","sourcesContent":["<template>\r\n    <view class=\"page\">\r\n        <!-- 操作按钮 -->\r\n        <view class=\"button-row\">\r\n            <button class=\"save-btn\" @click=\"handleRefresh\" :disabled=\"loadingForm || submitting || loadingInspection\">刷新</button>\r\n        </view>\r\n\r\n        <!-- 刀具使用记录表格 -->\r\n        <view class=\"table-section\">\r\n            <view class=\"table-header\">\r\n                <h3>上下刀记录</h3>\r\n                <button class=\"expand-btn\" @click=\"toggleExpand('tool')\">\r\n                    {{ toolExpanded ? '收起' : '展开' }}\r\n                </button>\r\n            </view>\r\n            <table class=\"styled-table\" :class=\"{'expanded': toolExpanded}\">\r\n                <thead>\r\n                    <tr>\r\n                        <th style=\"width:7%\">刀具编号</th>\r\n                        <th style=\"width:12%\">刀具名称</th>\r\n                        <th style=\"width:10%\">上刀时间</th>\r\n                        <th class=\"num\" style=\"width:7%\">上刀计数</th>\r\n                        <th style=\"width:10%\">下刀时间</th>\r\n                        <th class=\"num\" style=\"width:7%\">下刀计数</th>\r\n                        <th class=\"num\" style=\"width:7%\">使用次数</th>\r\n                        <th class=\"num\" style=\"width:7%\">使用上限</th>\r\n                        <th class=\"num\" style=\"width:7%\">寿命比%</th>\r\n                        <th class=\"num\" style=\"width:7%\">寿命比预警值</th>\r\n                        <th style=\"width:7%\">预警状态</th>\r\n                        <th style=\"width:7%\">刀具在机状态</th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr v-for=\"(item, idx) in visibleToolRecords\" :key=\"item.id\" :class=\"{'row-odd': idx % 2 === 0}\">\r\n                        <td>{{ item.no }}</td>\r\n                        <td class=\"left\">{{ item.name }}</td>\r\n                        <td>{{ item.upTime }}</td>\r\n                        <td class=\"num\">{{ item.upCount != null ? item.upCount : '' }}</td>\r\n                        <td>{{ item.downTime }}</td>\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <template v-if=\"!item.downTime\">\r\n                                    {{ item.currentCjNum != null ? item.currentCjNum : '' }}\r\n                                </template>\r\n                                <template v-else>\r\n                                    {{ item.downCount != null ? item.downCount : '' }}\r\n                                </template>\r\n                            </template>\r\n                            <template v-else>\r\n                                {{ item.downCount != null ? item.downCount : '' }}\r\n                            </template>\r\n                        </td>\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <template v-if=\"!item.downTime\">\r\n                                    {{item.currentCjNum != null && item.upCount != null ? (Number(item.currentCjNum) - Number(item.upCount)) : (item.useCount != null ? item.useCount : '') }}\r\n                                </template>\r\n                                <template v-else>\r\n                                    {{ item.useCount != null ? item.useCount : '' }}\r\n                                </template>\r\n                            </template>\r\n                            <template v-else>\r\n                                {{ item.useCount != null ? item.useCount : '' }}\r\n                            </template>\r\n                        </td>\r\n                        <td class=\"num\">{{ item.useLimit != null ? item.useLimit : '' }}</td>\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <template v-if=\"!item.downTime\">\r\n                                    {{item.currentCjNum != null && item.upCount != null && item.useLimit != null && Number(item.useLimit) > 0 ? Math.round((Number(item.currentCjNum) - Number(item.upCount)) / Number(item.useLimit) * 100) + '%' : (item.lifePercent != null ? item.lifePercent : '') }}\r\n                                </template>\r\n                                <template v-else>\r\n                                    {{ item.lifePercent != null ? item.lifePercent : '' }}\r\n                                </template>\r\n                            </template>\r\n                            <template v-else>\r\n                                {{ item.lifePercent }}\r\n                            </template>\r\n                        </td>\r\n                        <td class=\"num\">{{ item.lifeWarn }}</td>\r\n                        <td :class=\"item.warnStatus === '预警' ? 'warn-cell' : (item.warnStatus === '正常' ? 'ok-cell' : '')\">\r\n                            <span v-if=\"item.warnStatus === '预警'\" class=\"warn-badge\">警告</span>\r\n                            <span v-else>{{ item.warnStatus }}</span>\r\n                        </td>\r\n                        <td>\r\n                            {{ item.downTime ? '下机' : '在机' }}\r\n                        </td>\r\n                    </tr>\r\n                    <tr v-if=\"!toolRecords.length\">\r\n                        <td colspan=\"12\">暂无数据</td>\r\n                    </tr>\r\n                    <tr v-if=\"hasMoreToolRecords && !toolExpanded\">\r\n                        <td colspan=\"12\" class=\"more-records-tip\">\r\n                            <span>还有 {{ remainingToolRecords }} 条记录，点击\"展开\"按钮查看全部</span>\r\n                        </td>\r\n                    </tr>\r\n                </tbody>\r\n            </table>\r\n        </view>\r\n\r\n        <!-- 工单首检记录表格 -->\r\n        <view class=\"table-section\">\r\n            <view class=\"table-header\">\r\n                <h3>工单首检记录</h3>\r\n                <button class=\"expand-btn\" @click=\"toggleExpand('inspection')\">\r\n                    {{ inspectionExpanded ? '收起' : '展开' }}\r\n                </button>\r\n            </view>\r\n            <table class=\"styled-table\" :class=\"{'expanded': inspectionExpanded}\">\r\n                <thead>\r\n                    <tr>\r\n                        <th style=\"width:10%\">检验单号</th>\r\n                        <th style=\"width:10%\">检验人员</th>\r\n                        <th style=\"width:10%\">检验日期</th>\r\n                        <th style=\"width:10%\">机台编号</th>\r\n                        <th style=\"width:10%\">提交标识</th>\r\n                        <th style=\"width:10%\">检验结果</th>\r\n                        <th style=\"width:10%\">作废标识</th>\r\n                        <th style=\"width:10%\">备注</th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr v-for=\"(item, idx) in visibleInspectionRecords\" :key=\"item.id || idx\" :class=\"{'row-odd': idx % 2 === 0}\">\r\n                        <!-- 修改为小驼峰格式 -->\r\n                        <td>{{ item.releaseNo || '' }}</td>\r\n                        <td>{{ item.fcheckBy || '' }}</td>\r\n                        <td>{{ formatDate(item.fcheckDate) }}</td>\r\n                        <td>{{ item.lineNo || '' }}</td>\r\n                        <td>{{ item.fsubmit == 1 ? '已提交' : '未提交' }}</td>\r\n                        <td>{{ item.fcancel == 'Y' ? '作废' : '未作废' }}</td>\r\n                        <td>{{ item.fsecondResu || '' }}</td>\r\n                        <td class=\"left\">{{ item.remeke || '' }}</td>\r\n                    </tr>\r\n                    <tr v-if=\"!inspectionRecords.length\">\r\n                        <td colspan=\"10\">暂无首检记录</td>\r\n                    </tr>\r\n                    <tr v-if=\"hasMoreInspectionRecords && !inspectionExpanded\">\r\n                        <td colspan=\"10\" class=\"more-records-tip\">\r\n                            <span>还有 {{ remainingInspectionRecords }} 条记录，点击\"展开\"按钮查看全部</span>\r\n                        </td>\r\n                    </tr>\r\n                </tbody>\r\n            </table>\r\n        </view>\r\n    </view>\r\n</template>\r\n\r\n<script>\r\n    export default {\r\n        data() {\r\n            return {\r\n                machineNo: '',\r\n                workOrderNo: '',\r\n                selectedToolNo: '',\r\n                toolName: '',\r\n                useLimitInput: '',\r\n                lifeWarnInput: '',\r\n                toolRecords: [],\r\n                inspectionRecords: [], // 首检记录\r\n                loadingForm: false,\r\n                loadingInspection: false, // 首检记录加载状态\r\n                submitting: false,\r\n                workOrderCurrentCjNum: null,\r\n                toolExpanded: false, // 刀具表格展开状态\r\n                inspectionExpanded: false, // 首检表格展开状态\r\n                defaultVisibleRows: 3, // 默认显示的行数\r\n            };\r\n        },\r\n        computed: {\r\n            // 刀具表格相关计算\r\n            defaultToolRows() {\r\n                const total = this.toolRecords.length;\r\n                if (total <= 3) return total;\r\n                return Math.max(3, Math.floor(total / 2));\r\n            },\r\n            visibleToolRecords() {\r\n                if (this.toolExpanded) {\r\n                    return this.toolRecords;\r\n                } else {\r\n                    return this.toolRecords.slice(0, this.defaultToolRows);\r\n                }\r\n            },\r\n            hasMoreToolRecords() {\r\n                return this.toolRecords.length > this.defaultToolRows;\r\n            },\r\n            remainingToolRecords() {\r\n                return this.toolRecords.length - this.defaultToolRows;\r\n            },\r\n\r\n            // 首检表格相关计算\r\n            defaultInspectionRows() {\r\n                const total = this.inspectionRecords.length;\r\n                if (total <= 2) return total; // 首检表格默认显示2行\r\n                return Math.max(2, Math.floor(total / 2));\r\n            },\r\n            visibleInspectionRecords() {\r\n                if (this.inspectionExpanded) {\r\n                    return this.inspectionRecords;\r\n                } else {\r\n                    return this.inspectionRecords.slice(0, this.defaultInspectionRows);\r\n                }\r\n            },\r\n            hasMoreInspectionRecords() {\r\n                return this.inspectionRecords.length > this.defaultInspectionRows;\r\n            },\r\n            remainingInspectionRecords() {\r\n                return this.inspectionRecords.length - this.defaultInspectionRows;\r\n            }\r\n        },\r\n        methods: {\r\n            // 切换表格展开状态\r\n            toggleExpand(tableType) {\r\n                if (tableType === 'tool') {\r\n                    this.toolExpanded = !this.toolExpanded;\r\n                } else if (tableType === 'inspection') {\r\n                    this.inspectionExpanded = !this.inspectionExpanded;\r\n                }\r\n            },\r\n\r\n            // 刷新按钮处理方法\r\n            async handleRefresh() {\r\n                if (this.machineNo && this.workOrderNo) {\r\n                    await Promise.all([\r\n                        this.fetchFormData(),\r\n                        this.fetchDefaultToolFromWorkOrder(),\r\n                        this.fetchInspectionRecords()\r\n                    ]);\r\n                    // 刷新后赋值第一行 currentCjNum\r\n                    if (this.toolRecords.length > 0) {\r\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\r\n                    }\r\n                }\r\n                this.$showMessage('刷新完成');\r\n            },\r\n\r\n            // 获取工单首检记录\r\n            async fetchInspectionRecords() {\r\n                if (!this.workOrderNo) {\r\n                    console.warn('工单号为空，跳过获取首检记录');\r\n                    return;\r\n                }\r\n                this.loadingInspection = true;\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/GetInspectionRecords',\r\n                        data: JSON.stringify({\r\n                            aufnr: this.workOrderNo,\r\n                            ftype: '首检'\r\n                        }),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n\r\n                    if (res.status === 0) {\r\n                        // 根据实际接口返回结构调整\r\n                        const list = Array.isArray(res.data) ? res.data\r\n                            : (res.data && res.data.tbBillList) ? res.data.tbBillList\r\n                                : (res.data && res.data.data) ? res.data.data\r\n                                    : [];\r\n                        this.inspectionRecords = list || [];\r\n                    } else {\r\n                        this.$showMessage(res.message || '获取首检记录失败');\r\n                        this.inspectionRecords = [];\r\n                    }\r\n                } catch (error) {\r\n                    console.error('获取首检记录错误:', error);\r\n                    this.$showMessage('获取首检记录失败，请检查网络连接');\r\n                    this.inspectionRecords = [];\r\n                } finally {\r\n                    this.loadingInspection = false;\r\n                }\r\n            },\r\n\r\n            // 格式化日期\r\n            formatDate(dateStr) {\r\n                if (!dateStr) return '';\r\n                try {\r\n                    const date = new Date(dateStr);\r\n                    if (isNaN(date.getTime())) return String(dateStr);\r\n                    return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${String(date.getMinutes()).padStart(2, '0')}`;\r\n                } catch {\r\n                    return String(dateStr);\r\n                }\r\n            },\r\n\r\n            // 其他已有方法保持不变...\r\n            async fetchDefaultToolFromWorkOrder() {\r\n                if (!this.machineNo) return;\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/Womdaa/GetWomdaasByShow',\r\n                        data: JSON.stringify({ machineNo: this.machineNo }),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.status === 0 && Array.isArray(res.data?.tbBillList) && res.data.tbBillList.length > 0) {\r\n                        const order = res.data.tbBillList[0];\r\n                        this.selectedToolNo = order.cutterId || order.cutteR_ID || '';\r\n                        this.toolName = order.cutterName || order.cutteR_NAME || '';\r\n                        this.workOrderCurrentCjNum = order.CurrentCjNum ?? order.currentCjNum ?? null;\r\n                        if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\r\n                            const warn = Number(order.modlLifeWorning);\r\n                            this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\r\n                        } else {\r\n                            this.lifeWarnInput = '';\r\n                        }\r\n                    } else {\r\n                        this.workOrderCurrentCjNum = null;\r\n                    }\r\n                } catch (e) {\r\n                    console.warn('自动带出工单刀具失败', e);\r\n                    this.workOrderCurrentCjNum = null;\r\n                }\r\n            },\r\n\r\n            async fetchFormData() {\r\n                if (!this.workOrderNo || !this.machineNo) {\r\n                    console.warn('工单号或机台号为空，跳过获取表单数据');\r\n                    return;\r\n                }\r\n                this.loadingForm = true;\r\n                const payload = {\r\n                    workOrderNo: this.workOrderNo.trim(),\r\n                    machineNo: this.machineNo.trim()\r\n                };\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/GetFormData',\r\n                        data: JSON.stringify(payload),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.status !== 0) {\r\n                        this.$showMessage(res.message || '获取表单数据失败');\r\n                        this.toolRecords = [];\r\n                        return;\r\n                    }\r\n                    const list = Array.isArray(res.data) ? res.data\r\n                        : (res.data && res.data.tbBillList) ? res.data.tbBillList\r\n                            : (res.data && res.data.data) ? res.data.data\r\n                                : [];\r\n\r\n                    // 数据处理逻辑保持不变...\r\n                    const getField = (obj, ...keys) => {\r\n                        for (const k of keys) if (obj?.[k] !== undefined && obj?.[k] !== null) return obj[k];\r\n                        return null;\r\n                    };\r\n\r\n                    const mapped = (list || []).map(t => {\r\n                        const upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\r\n                        const downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\r\n                        const lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\r\n                        const currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\r\n\r\n                        const useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\r\n                        const useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\r\n\r\n                        let percent = '';\r\n                        if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\r\n                            percent = ((Number(useCount) / Number(useLimit)) * 100).toFixed(0) + '%';\r\n                        }\r\n\r\n                        const parseNumber = v => {\r\n                            if (v === null || v === undefined || v === '') return null;\r\n                            const s = String(v).replace(/[,％%]/g, '').trim();\r\n                            const n = parseFloat(s);\r\n                            return Number.isFinite(n) ? n : null;\r\n                        };\r\n                        const formatPercent = n => {\r\n                            if (n === null || n === undefined || isNaN(n)) return '';\r\n                            if (n <= 1) return `${(n * 100).toFixed(0)}%`;\r\n                            return `${Number(n).toFixed(0)}%`;\r\n                        };\r\n                        const lifeWarnNum = parseNumber(lifeWarnRaw);\r\n\r\n                        let warnStatus = getField(t, 'status', 'STATUS') || '';\r\n                        if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\r\n                            const percentNum = Number(useCount) / Number(useLimit);\r\n                            warnStatus = (percentNum >= lifeWarnNum) ? '预警' : '正常';\r\n                        } else {\r\n                            warnStatus = warnStatus || '未知';\r\n                        }\r\n\r\n                        return {\r\n                            id: getField(t, 'id', 'ID') || `${getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || ''}-${upTimeRaw || ''}`,\r\n                            no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\r\n                            name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\r\n                            upTime: this.formatDateTime(upTimeRaw),\r\n                            upCount: getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount') ?? '',\r\n                            downTime: this.formatDateTime(downTimeRaw),\r\n                            downCount: getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount') ?? '',\r\n                            useCount: useCount ?? '',\r\n                            useLimit: useLimit ?? '',\r\n                            lifePercent: percent,\r\n                            lifeWarn: formatPercent(lifeWarnNum),\r\n                            warnStatus,\r\n                            currentCjNum\r\n                        };\r\n                    });\r\n\r\n                    mapped.sort((a, b) => {\r\n                        const parse = s => {\r\n                            if (!s) return 0;\r\n                            const year = new Date().getFullYear();\r\n                            return new Date(`${year}-${s.replace(/-/g, '-')}:00`).getTime();\r\n                        };\r\n                        return parse(b.upTime) - parse(a.upTime);\r\n                    });\r\n\r\n                    this.toolRecords = mapped;\r\n                } catch (error) {\r\n                    console.error('获取表单数据错误:', error);\r\n                    this.$showMessage('获取数据失败，请检查网络连接');\r\n                    this.toolRecords = [];\r\n                } finally {\r\n                    this.loadingForm = false;\r\n                }\r\n            },\r\n\r\n            formatDateTime(dateTimeStr) {\r\n                if (!dateTimeStr) return '';\r\n                try {\r\n                    const s = String(dateTimeStr).trim();\r\n                    if (/^\\d{10}$/.test(s)) {\r\n                        const d = new Date(Number(s) * 1000);\r\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\r\n                    }\r\n                    if (/^\\d{13}$/.test(s)) {\r\n                        const d = new Date(Number(s));\r\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\r\n                    }\r\n                    const date = new Date(dateTimeStr);\r\n                    if (!isNaN(date.getTime())) {\r\n                        return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${String(date.getMinutes()).padStart(2, '0')}`;\r\n                    }\r\n                    const match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\r\n                    if (match) return `${match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, (m) => m)} ${match[2]}`;\r\n                    return String(dateTimeStr);\r\n                } catch {\r\n                    return String(dateTimeStr);\r\n                }\r\n            }\r\n        },\r\n        mounted() {\r\n            this.machineNo = uni.getStorageSync('machineNo') || '';\r\n            this.workOrderNo = uni.getStorageSync('daa001') || '';\r\n\r\n            if (this.machineNo && this.workOrderNo) {\r\n                this.fetchFormData().then(async () => {\r\n                    await this.fetchDefaultToolFromWorkOrder();\r\n                    await this.fetchInspectionRecords();\r\n                    if (this.toolRecords.length > 0) {\r\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\r\n                    }\r\n                });\r\n            } else {\r\n                console.warn('机台号或工单号为空，无法获取数据');\r\n            }\r\n        }\r\n    };\r\n</script>\r\n\r\n<style scoped>\r\n    .page {\r\n        padding: 20px;\r\n        display: flex;\r\n        flex-direction: column;\r\n        gap: 16px; /* 两个表格之间的间距 */\r\n    }\r\n\r\n    .button-row {\r\n        display: flex;\r\n        justify-content: center;\r\n        margin: 2vh 0;\r\n    }\r\n\r\n    .save-btn {\r\n        width: 20%;\r\n        padding: 1.5vh;\r\n        background-color: #00A2E9;\r\n        color: white;\r\n        border: none;\r\n        text-align: center;\r\n        border-radius: 4px;\r\n        transition: all 0.3s;\r\n        font-size: 22px;\r\n        font-weight: 500;\r\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\r\n    }\r\n\r\n        .save-btn:hover {\r\n            background-color: #40a9ff;\r\n        }\r\n\r\n        .save-btn:active {\r\n            background-color: #096dd9;\r\n        }\r\n\r\n        .save-btn:disabled {\r\n            opacity: 0.6;\r\n            cursor: not-allowed;\r\n        }\r\n\r\n    /* 表格容器样式 */\r\n    .table-section {\r\n        display: flex;\r\n        flex-direction: column;\r\n        margin: 0;\r\n        overflow-x: auto;\r\n        width: 100%;\r\n        border: 1px solid #f0f0f0;\r\n        border-radius: 8px;\r\n        background: #fff;\r\n    }\r\n\r\n    .table-header {\r\n        display: flex;\r\n        justify-content: space-between;\r\n        align-items: center;\r\n        padding: 12px 16px;\r\n        background: #fafafa;\r\n        border-bottom: 1px solid #e8e8e8;\r\n    }\r\n\r\n        .table-header h3 {\r\n            margin: 0;\r\n            font-size: 24px;\r\n            color: #333;\r\n            font-weight: 600;\r\n        }\r\n\r\n    .expand-btn {\r\n        padding: 8px 20px;\r\n        background-color: #52c41a;\r\n        color: white;\r\n        border: none;\r\n        border-radius: 4px;\r\n        font-size: 20px;\r\n        cursor: pointer;\r\n        transition: all 0.3s;\r\n    }\r\n\r\n        .expand-btn:hover {\r\n            background-color: #73d13d;\r\n        }\r\n\r\n        .expand-btn:active {\r\n            background-color: #389e0d;\r\n        }\r\n\r\n    /* 表格样式 */\r\n    table.styled-table {\r\n        max-width: 1800px;\r\n        width: 98vw;\r\n        margin: 0 auto;\r\n        border-collapse: separate;\r\n        border-spacing: 0;\r\n        border: 2px solid #bfbfbf;\r\n        background: #fff;\r\n        overflow: hidden;\r\n        box-shadow: 0 2px 12px rgba(0,0,0,0.06);\r\n        max-height: 180px; /* 调整高度使页面饱满 */\r\n        display: block;\r\n        overflow-y: hidden;\r\n        transition: max-height 0.3s ease;\r\n    }\r\n\r\n        table.styled-table.expanded {\r\n            max-height: 400px; /* 展开时的高度 */\r\n            overflow-y: auto;\r\n        }\r\n\r\n        table.styled-table thead {\r\n            display: table;\r\n            width: 100%;\r\n            table-layout: fixed;\r\n        }\r\n\r\n            table.styled-table thead th {\r\n                background: #fafafa;\r\n                border-bottom: 2px solid #bfbfbf;\r\n                padding: 16px 10px;\r\n                font-weight: bold;\r\n                text-align: center;\r\n                font-size: 22px;\r\n                position: sticky;\r\n                top: 0;\r\n                z-index: 10;\r\n            }\r\n\r\n        table.styled-table tbody {\r\n            display: block;\r\n            max-height: calc(180px - 50px); /* 减去表头高度 */\r\n            overflow-y: hidden;\r\n        }\r\n\r\n        table.styled-table.expanded tbody {\r\n            max-height: calc(400px - 50px);\r\n            overflow-y: auto;\r\n        }\r\n\r\n        table.styled-table tbody tr {\r\n            display: table;\r\n            width: 100%;\r\n            table-layout: fixed;\r\n        }\r\n\r\n        table.styled-table tbody td {\r\n            border-bottom: 1px solid #e8e8e8;\r\n            padding: 14px 10px;\r\n            vertical-align: middle;\r\n            text-align: center;\r\n            font-size: 22px;\r\n        }\r\n\r\n        table.styled-table tbody .left {\r\n            text-align: left;\r\n            padding-left: 8px;\r\n        }\r\n\r\n    .row-odd {\r\n        background: #fff;\r\n    }\r\n\r\n        .row-odd + tr {\r\n            background: #fafafa;\r\n        }\r\n\r\n    .num {\r\n        text-align: center;\r\n        padding-right: 0;\r\n        font-variant-numeric: tabular-nums;\r\n    }\r\n\r\n    .warn-cell {\r\n        color: #d93025;\r\n        font-weight: bold;\r\n    }\r\n\r\n    .ok-cell {\r\n        color: #333;\r\n    }\r\n\r\n    .warn-badge {\r\n        display: inline-block;\r\n        background: #ff4d4f;\r\n        color: #fff;\r\n        padding: 2px 6px;\r\n        border-radius: 3px;\r\n        font-weight: bold;\r\n    }\r\n\r\n    .more-records-tip {\r\n        text-align: center;\r\n        color: #666;\r\n        font-size: 18px;\r\n        padding: 20px !important;\r\n        background-color: #f9f9f9;\r\n    }\r\n\r\n        .more-records-tip span {\r\n            display: inline-block;\r\n            padding: 5px 15px;\r\n            background-color: #f0f0f0;\r\n            border-radius: 4px;\r\n            border: 1px dashed #ccc;\r\n        }\r\n\r\n    /* 响应式调整 */\r\n    @media (max-width: 1200px) {\r\n        .save-btn {\r\n            width: 30%;\r\n        }\r\n\r\n        .table-header {\r\n            flex-direction: column;\r\n            gap: 8px;\r\n            align-items: flex-start;\r\n        }\r\n\r\n        .expand-btn {\r\n            align-self: flex-end;\r\n        }\r\n    }\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///119\n");
+eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 3));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 9));\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n data: function data() {\n return {\n machineNo: '',\n workOrderNo: '',\n selectedToolNo: '',\n toolName: '',\n useLimitInput: '',\n lifeWarnInput: '',\n toolRecords: [],\n inspectionRecords: [],\n // 棣栨璁板綍\n loadingForm: false,\n loadingInspection: false,\n // 棣栨璁板綍鍔犺浇鐘舵�乗n submitting: false,\n workOrderCurrentCjNum: null,\n toolExpanded: false,\n // 鍒�鍏疯〃鏍煎睍寮�鐘舵�乗n inspectionExpanded: false,\n // 棣栨琛ㄦ牸灞曞紑鐘舵�乗n defaultVisibleRows: 3 // 榛樿鏄剧ず鐨勮鏁癨n };\n },\n\n computed: {\n // 鍒�鍏疯〃鏍肩浉鍏宠绠梊n defaultToolRows: function defaultToolRows() {\n var total = this.toolRecords.length;\n if (total <= 3) return total;\n return Math.max(3, Math.floor(total / 2));\n },\n visibleToolRecords: function visibleToolRecords() {\n if (this.toolExpanded) {\n return this.toolRecords;\n } else {\n return this.toolRecords.slice(0, this.defaultToolRows);\n }\n },\n hasMoreToolRecords: function hasMoreToolRecords() {\n return this.toolRecords.length > this.defaultToolRows;\n },\n remainingToolRecords: function remainingToolRecords() {\n return this.toolRecords.length - this.defaultToolRows;\n },\n // 棣栨琛ㄦ牸鐩稿叧璁$畻\n defaultInspectionRows: function defaultInspectionRows() {\n var total = this.inspectionRecords.length;\n if (total <= 2) return total; // 棣栨琛ㄦ牸榛樿鏄剧ず2琛孿n return Math.max(2, Math.floor(total / 2));\n },\n visibleInspectionRecords: function visibleInspectionRecords() {\n if (this.inspectionExpanded) {\n return this.inspectionRecords;\n } else {\n return this.inspectionRecords.slice(0, this.defaultInspectionRows);\n }\n },\n hasMoreInspectionRecords: function hasMoreInspectionRecords() {\n return this.inspectionRecords.length > this.defaultInspectionRows;\n },\n remainingInspectionRecords: function remainingInspectionRecords() {\n return this.inspectionRecords.length - this.defaultInspectionRows;\n }\n },\n methods: {\n // 鍒囨崲琛ㄦ牸灞曞紑鐘舵�乗n toggleExpand: function toggleExpand(tableType) {\n if (tableType === 'tool') {\n this.toolExpanded = !this.toolExpanded;\n } else if (tableType === 'inspection') {\n this.inspectionExpanded = !this.inspectionExpanded;\n }\n },\n // 鍒锋柊鎸夐挳澶勭悊鏂规硶\n handleRefresh: function handleRefresh() {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!(_this.machineNo && _this.workOrderNo)) {\n _context.next = 4;\n break;\n }\n _context.next = 3;\n return Promise.all([_this.fetchFormData(), _this.fetchDefaultToolFromWorkOrder(), _this.fetchInspectionRecords()]);\n case 3:\n // 鍒锋柊鍚庤祴鍊肩涓�琛� currentCjNum\n if (_this.toolRecords.length > 0) {\n _this.$set(_this.toolRecords[0], 'currentCjNum', _this.workOrderCurrentCjNum);\n }\n case 4:\n _this.$showMessage('鍒锋柊瀹屾垚');\n case 5:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }))();\n },\n // 鑾峰彇宸ュ崟棣栨璁板綍\n fetchInspectionRecords: function fetchInspectionRecords() {\n var _this2 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {\n var res, list;\n return _regenerator.default.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n if (_this2.workOrderNo) {\n _context2.next = 3;\n break;\n }\n __f__(\"warn\", '宸ュ崟鍙蜂负绌猴紝璺宠繃鑾峰彇棣栨璁板綍', \" at pages/moldRecord.vue:243\");\n return _context2.abrupt(\"return\");\n case 3:\n _this2.loadingInspection = true;\n _context2.prev = 4;\n _context2.next = 7;\n return _this2.$post({\n url: '/MesCutterLedger/GetInspectionRecords',\n data: JSON.stringify({\n aufnr: _this2.workOrderNo,\n ftype: '棣栨'\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 7:\n res = _context2.sent;\n if (res.status === 0) {\n // 鏍规嵁瀹為檯鎺ュ彛杩斿洖缁撴瀯璋冩暣\n list = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : [];\n _this2.inspectionRecords = list || [];\n } else {\n _this2.$showMessage(res.message || '鑾峰彇棣栨璁板綍澶辫触');\n _this2.inspectionRecords = [];\n }\n _context2.next = 16;\n break;\n case 11:\n _context2.prev = 11;\n _context2.t0 = _context2[\"catch\"](4);\n __f__(\"error\", '鑾峰彇棣栨璁板綍閿欒:', _context2.t0, \" at pages/moldRecord.vue:269\");\n _this2.$showMessage('鑾峰彇棣栨璁板綍澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');\n _this2.inspectionRecords = [];\n case 16:\n _context2.prev = 16;\n _this2.loadingInspection = false;\n return _context2.finish(16);\n case 19:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, null, [[4, 11, 16, 19]]);\n }))();\n },\n // 鏍煎紡鍖栨棩鏈焅n formatDate: function formatDate(dateStr) {\n if (!dateStr) return '';\n try {\n var date = new Date(dateStr);\n if (isNaN(date.getTime())) return String(dateStr);\n return \"\".concat(date.getMonth() + 1, \"-\").concat(date.getDate(), \" \").concat(date.getHours(), \":\").concat(String(date.getMinutes()).padStart(2, '0'));\n } catch (_unused) {\n return String(dateStr);\n }\n },\n // 鍏朵粬宸叉湁鏂规硶淇濇寔涓嶅彉...\n fetchDefaultToolFromWorkOrder: function fetchDefaultToolFromWorkOrder() {\n var _this3 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {\n var _res$data, res, _ref, _order$CurrentCjNum, order, warn;\n return _regenerator.default.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n if (_this3.machineNo) {\n _context3.next = 2;\n break;\n }\n return _context3.abrupt(\"return\");\n case 2:\n _context3.prev = 2;\n _context3.next = 5;\n return _this3.$post({\n url: '/Womdaa/GetWomdaasByShow',\n data: JSON.stringify({\n machineNo: _this3.machineNo\n }),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 5:\n res = _context3.sent;\n if (res.status === 0 && Array.isArray((_res$data = res.data) === null || _res$data === void 0 ? void 0 : _res$data.tbBillList) && res.data.tbBillList.length > 0) {\n order = res.data.tbBillList[0];\n _this3.selectedToolNo = order.cutterId || order.cutteR_ID || '';\n _this3.toolName = order.cutterName || order.cutteR_NAME || '';\n _this3.workOrderCurrentCjNum = (_ref = (_order$CurrentCjNum = order.CurrentCjNum) !== null && _order$CurrentCjNum !== void 0 ? _order$CurrentCjNum : order.currentCjNum) !== null && _ref !== void 0 ? _ref : null;\n if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\n warn = Number(order.modlLifeWorning);\n _this3.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\n } else {\n _this3.lifeWarnInput = '';\n }\n } else {\n _this3.workOrderCurrentCjNum = null;\n }\n _context3.next = 13;\n break;\n case 9:\n _context3.prev = 9;\n _context3.t0 = _context3[\"catch\"](2);\n __f__(\"warn\", '鑷姩甯﹀嚭宸ュ崟鍒�鍏峰け璐�', _context3.t0, \" at pages/moldRecord.vue:313\");\n _this3.workOrderCurrentCjNum = null;\n case 13:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, null, [[2, 9]]);\n }))();\n },\n fetchFormData: function fetchFormData() {\n var _this4 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4() {\n var payload, res, list, getField, mapped;\n return _regenerator.default.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n if (!(!_this4.workOrderNo || !_this4.machineNo)) {\n _context4.next = 3;\n break;\n }\n __f__(\"warn\", '宸ュ崟鍙锋垨鏈哄彴鍙蜂负绌猴紝璺宠繃鑾峰彇琛ㄥ崟鏁版嵁', \" at pages/moldRecord.vue:320\");\n return _context4.abrupt(\"return\");\n case 3:\n _this4.loadingForm = true;\n payload = {\n workOrderNo: _this4.workOrderNo.trim(),\n machineNo: _this4.machineNo.trim()\n };\n _context4.prev = 5;\n _context4.next = 8;\n return _this4.$post({\n url: '/MesCutterLedger/GetFormData',\n data: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json'\n }\n });\n case 8:\n res = _context4.sent;\n if (!(res.status !== 0)) {\n _context4.next = 13;\n break;\n }\n _this4.$showMessage(res.message || '鑾峰彇琛ㄥ崟鏁版嵁澶辫触');\n _this4.toolRecords = [];\n return _context4.abrupt(\"return\");\n case 13:\n list = Array.isArray(res.data) ? res.data : res.data && res.data.tbBillList ? res.data.tbBillList : res.data && res.data.data ? res.data.data : []; // 鏁版嵁澶勭悊閫昏緫淇濇寔涓嶅彉...\n getField = function getField(obj) {\n for (var _len = arguments.length, keys = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n keys[_key - 1] = arguments[_key];\n }\n for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {\n var k = _keys[_i];\n if ((obj === null || obj === void 0 ? void 0 : obj[k]) !== undefined && (obj === null || obj === void 0 ? void 0 : obj[k]) !== null) return obj[k];\n }\n return null;\n };\n mapped = (list || []).map(function (t) {\n var _getField, _getField2;\n var upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\n var downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\n var lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\n var currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\n var useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\n var useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\n var percent = '';\n if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n percent = (Number(useCount) / Number(useLimit) * 100).toFixed(0) + '%';\n }\n var parseNumber = function parseNumber(v) {\n if (v === null || v === undefined || v === '') return null;\n var s = String(v).replace(/[,锛�%]/g, '').trim();\n var n = parseFloat(s);\n return Number.isFinite(n) ? n : null;\n };\n var formatPercent = function formatPercent(n) {\n if (n === null || n === undefined || isNaN(n)) return '';\n if (n <= 1) return \"\".concat((n * 100).toFixed(0), \"%\");\n return \"\".concat(Number(n).toFixed(0), \"%\");\n };\n var lifeWarnNum = parseNumber(lifeWarnRaw);\n var warnStatus = getField(t, 'status', 'STATUS') || '';\n if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\n var percentNum = Number(useCount) / Number(useLimit);\n warnStatus = percentNum >= lifeWarnNum ? '棰勮' : '姝e父';\n } else {\n warnStatus = warnStatus || '鏈煡';\n }\n return {\n id: getField(t, 'id', 'ID') || \"\".concat(getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || '', \"-\").concat(upTimeRaw || ''),\n no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\n name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\n upTime: _this4.formatDateTime(upTimeRaw),\n upCount: (_getField = getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount')) !== null && _getField !== void 0 ? _getField : '',\n downTime: _this4.formatDateTime(downTimeRaw),\n downCount: (_getField2 = getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount')) !== null && _getField2 !== void 0 ? _getField2 : '',\n useCount: useCount !== null && useCount !== void 0 ? useCount : '',\n useLimit: useLimit !== null && useLimit !== void 0 ? useLimit : '',\n lifePercent: percent,\n lifeWarn: formatPercent(lifeWarnNum),\n warnStatus: warnStatus,\n currentCjNum: currentCjNum\n };\n });\n mapped.sort(function (a, b) {\n var parse = function parse(s) {\n if (!s) return 0;\n var year = new Date().getFullYear();\n return new Date(\"\".concat(year, \"-\").concat(s.replace(/-/g, '-'), \":00\")).getTime();\n };\n return parse(b.upTime) - parse(a.upTime);\n });\n _this4.toolRecords = mapped;\n _context4.next = 25;\n break;\n case 20:\n _context4.prev = 20;\n _context4.t0 = _context4[\"catch\"](5);\n __f__(\"error\", '鑾峰彇琛ㄥ崟鏁版嵁閿欒:', _context4.t0, \" at pages/moldRecord.vue:413\");\n _this4.$showMessage('鑾峰彇鏁版嵁澶辫触锛岃妫�鏌ョ綉缁滆繛鎺�');\n _this4.toolRecords = [];\n case 25:\n _context4.prev = 25;\n _this4.loadingForm = false;\n return _context4.finish(25);\n case 28:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, null, [[5, 20, 25, 28]]);\n }))();\n },\n formatDateTime: function formatDateTime(dateTimeStr) {\n if (!dateTimeStr) return '';\n try {\n var s = String(dateTimeStr).trim();\n if (/^\\d{10}$/.test(s)) {\n var d = new Date(Number(s) * 1000);\n return \"\".concat(d.getMonth() + 1, \"-\").concat(d.getDate(), \" \").concat(d.getHours(), \":\").concat(String(d.getMinutes()).padStart(2, '0'));\n }\n if (/^\\d{13}$/.test(s)) {\n var _d = new Date(Number(s));\n return \"\".concat(_d.getMonth() + 1, \"-\").concat(_d.getDate(), \" \").concat(_d.getHours(), \":\").concat(String(_d.getMinutes()).padStart(2, '0'));\n }\n var date = new Date(dateTimeStr);\n if (!isNaN(date.getTime())) {\n return \"\".concat(date.getMonth() + 1, \"-\").concat(date.getDate(), \" \").concat(date.getHours(), \":\").concat(String(date.getMinutes()).padStart(2, '0'));\n }\n var match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\n if (match) return \"\".concat(match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, function (m) {\n return m;\n }), \" \").concat(match[2]);\n return String(dateTimeStr);\n } catch (_unused2) {\n return String(dateTimeStr);\n }\n }\n },\n mounted: function mounted() {\n var _this5 = this;\n this.machineNo = uni.getStorageSync('machineNo') || '';\n this.workOrderNo = uni.getStorageSync('daa001') || '';\n if (this.machineNo && this.workOrderNo) {\n this.fetchFormData().then( /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5() {\n return _regenerator.default.wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n _context5.next = 2;\n return _this5.fetchDefaultToolFromWorkOrder();\n case 2:\n _context5.next = 4;\n return _this5.fetchInspectionRecords();\n case 4:\n if (_this5.toolRecords.length > 0) {\n _this5.$set(_this5.toolRecords[0], 'currentCjNum', _this5.workOrderCurrentCjNum);\n }\n case 5:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5);\n })));\n } else {\n __f__(\"warn\", '鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇鏁版嵁', \" at pages/moldRecord.vue:458\");\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 1)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/moldRecord.vue"],"names":["data","machineNo","workOrderNo","selectedToolNo","toolName","useLimitInput","lifeWarnInput","toolRecords","inspectionRecords","loadingForm","loadingInspection","submitting","workOrderCurrentCjNum","toolExpanded","inspectionExpanded","defaultVisibleRows","computed","defaultToolRows","visibleToolRecords","hasMoreToolRecords","remainingToolRecords","defaultInspectionRows","visibleInspectionRecords","hasMoreInspectionRecords","remainingInspectionRecords","methods","toggleExpand","handleRefresh","Promise","fetchInspectionRecords","url","aufnr","ftype","headers","res","list","formatDate","fetchDefaultToolFromWorkOrder","order","warn","fetchFormData","payload","getField","keys","mapped","percent","warnStatus","id","no","name","upTime","upCount","downTime","downCount","useCount","useLimit","lifePercent","lifeWarn","currentCjNum","formatDateTime","mounted"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAwJA;EACAA;IACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MACAC;MAAA;MACAC;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;IACA;EACA;;EACAC;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;QACA;MACA;QACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MACA;IACA;IAEA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;QACA;MACA;QACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MACA;IACA;EACA;EACAC;IACA;IACAC;MACA;QACA;MACA;QACA;MACA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACAC,aACA,uBACA,uCACA,+BACA;cAAA;gBACA;gBACA;kBACA;gBACA;cAAA;gBAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;gBAAA;gBAAA;gBAAA,OAEA;kBACAC;kBACA9B;oBACA+B;oBACAC;kBACA;kBACAC;oBAAA;kBAAA;gBACA;cAAA;gBAPAC;gBASA;kBACA;kBACAC,4CACAD,wDACAA,4CACA;kBACA;gBACA;kBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAE;MACA;MACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAP;kBACA9B;oBAAAC;kBAAA;kBACAgC;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAKA;kBACAI;kBACA;kBACA;kBACA;kBACA;oBACAC;oBACA;kBACA;oBACA;kBACA;gBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;gBACAC;kBACAvC;kBACAD;gBACA;gBAAA;gBAAA;gBAAA,OAEA;kBACA6B;kBACA9B;kBACAiC;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACA;gBACA;gBAAA;cAAA;gBAGAC,4CACAD,wDACAA,4CACA,IAEA;gBACAQ;kBAAA;oBAAAC;kBAAA;kBACA;oBAAA;oBAAA;kBAAA;kBACA;gBACA;gBAEAC;kBAAA;kBACA;kBACA;kBACA;kBACA;kBAEA;kBACA;kBAEA;kBACA;oBACAC;kBACA;kBAEA;oBACA;oBACA;oBACA;oBACA;kBACA;kBACA;oBACA;oBACA;oBACA;kBACA;kBACA;kBAEA;kBACA;oBACA;oBACAC;kBACA;oBACAA;kBACA;kBAEA;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAC;oBACAX;oBACAY;kBACA;gBACA;gBAEAd;kBACA;oBACA;oBACA;oBACA;kBACA;kBACA;gBACA;gBAEA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEAe;MACA;MACA;QACA;QACA;UACA;UACA;QACA;QACA;UACA;UACA;QACA;QACA;QACA;UACA;QACA;QACA;QACA;UAAA;QAAA;QACA;MACA;QACA;MACA;IACA;EACA;EACAC;IAAA;IACA;IACA;IAEA;MACA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBACA;kBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,CACA;IACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"119.js","sourcesContent":["<template>\r\n    <view class=\"page\">\r\n        <!-- 操作按钮 -->\r\n        <view class=\"button-row\">\r\n            <button class=\"save-btn\" @click=\"handleRefresh\" :disabled=\"loadingForm || submitting || loadingInspection\">刷新</button>\r\n        </view>\r\n\r\n        <!-- 刀具使用记录表格 -->\r\n        <view class=\"table-section\" :class=\"{'expanded': toolExpanded}\">\r\n            <view class=\"table-header\">\r\n                <h3>上下刀记录</h3>\r\n                <button class=\"expand-btn\" @click=\"toggleExpand('tool')\">\r\n                    {{ toolExpanded ? '收起' : '展开' }}\r\n                </button>\r\n            </view>\r\n            <table class=\"styled-table\">\r\n                <thead>\r\n                    <tr>\r\n                        <th style=\"width:7%\">刀具编号</th>\r\n                        <th style=\"width:12%\">刀具名称</th>\r\n                        <th style=\"width:10%\">上刀时间</th>\r\n                        <th class=\"num\" style=\"width:7%\">上刀计数</th>\r\n                        <th style=\"width:10%\">下刀时间</th>\r\n                        <th class=\"num\" style=\"width:7%\">下刀计数</th>\r\n                        <th class=\"num\" style=\"width:7%\">使用次数</th>\r\n                        <th class=\"num\" style=\"width:7%\">使用上限</th>\r\n                        <th class=\"num\" style=\"width:7%\">寿命比%</th>\r\n                        <th class=\"num\" style=\"width:7%\">寿命比预警值</th>\r\n                        <th style=\"width:7%\">预警状态</th>\r\n                        <th style=\"width:7%\">刀具在机状态</th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr v-for=\"(item, idx) in visibleToolRecords\" :key=\"item.id\" :class=\"{'row-odd': idx % 2 === 0}\">\r\n                        <td>{{ item.no }}</td>\r\n                        <td class=\"left\">{{ item.name }}</td>\r\n                        <td>{{ item.upTime }}</td>\r\n                        <td class=\"num\">{{ item.upCount != null ? item.upCount : '' }}</td>\r\n                        <td>{{ item.downTime }}</td>\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <template v-if=\"!item.downTime\">\r\n                                    {{ item.currentCjNum != null ? item.currentCjNum : '' }}\r\n                                </template>\r\n                                <template v-else>\r\n                                    {{ item.downCount != null ? item.downCount : '' }}\r\n                                </template>\r\n                            </template>\r\n                            <template v-else>\r\n                                {{ item.downCount != null ? item.downCount : '' }}\r\n                            </template>\r\n                        </td>\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <template v-if=\"!item.downTime\">\r\n                                    {{item.currentCjNum != null && item.upCount != null ? (Number(item.currentCjNum) - Number(item.upCount)) : (item.useCount != null ? item.useCount : '') }}\r\n                                </template>\r\n                                <template v-else>\r\n                                    {{ item.useCount != null ? item.useCount : '' }}\r\n                                </template>\r\n                            </template>\r\n                            <template v-else>\r\n                                {{ item.useCount != null ? item.useCount : '' }}\r\n                            </template>\r\n                        </td>\r\n                        <td class=\"num\">{{ item.useLimit != null ? item.useLimit : '' }}</td>\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <template v-if=\"!item.downTime\">\r\n                                    {{item.currentCjNum != null && item.upCount != null && item.useLimit != null && Number(item.useLimit) > 0 ? Math.round((Number(item.currentCjNum) - Number(item.upCount)) / Number(item.useLimit) * 100) + '%' : (item.lifePercent != null ? item.lifePercent : '') }}\r\n                                </template>\r\n                                <template v-else>\r\n                                    {{ item.lifePercent != null ? item.lifePercent : '' }}\r\n                                </template>\r\n                            </template>\r\n                            <template v-else>\r\n                                {{ item.lifePercent }}\r\n                            </template>\r\n                        </td>\r\n                        <td class=\"num\">{{ item.lifeWarn }}</td>\r\n                        <td :class=\"item.warnStatus === '预警' ? 'warn-cell' : (item.warnStatus === '正常' ? 'ok-cell' : '')\">\r\n                            <span v-if=\"item.warnStatus === '预警'\" class=\"warn-badge\">警告</span>\r\n                            <span v-else>{{ item.warnStatus }}</span>\r\n                        </td>\r\n                        <td>\r\n                            {{ item.downTime ? '下机' : '在机' }}\r\n                        </td>\r\n                    </tr>\r\n                    <tr v-if=\"!toolRecords.length\">\r\n                        <td colspan=\"12\">暂无数据</td>\r\n                    </tr>\r\n                    <tr v-if=\"hasMoreToolRecords && !toolExpanded\">\r\n                        <td colspan=\"12\" class=\"more-records-tip\">\r\n                            <span>还有 {{ remainingToolRecords }} 条记录，点击</span>\r\n                            <button class=\"inline-expand-btn\" @click=\"toggleExpand('tool')\">展开</button>\r\n                            <span>按钮查看全部</span>\r\n                        </td>\r\n                    </tr>\r\n                </tbody>\r\n            </table>\r\n        </view>\r\n\r\n        <!-- 工单首检记录表格 -->\r\n        <view class=\"table-section\" :class=\"{'expanded': inspectionExpanded}\">\r\n            <view class=\"table-header\">\r\n                <h3>工单首检记录</h3>\r\n                <button class=\"expand-btn\" @click=\"toggleExpand('inspection')\">\r\n                    {{ inspectionExpanded ? '收起' : '展开' }}\r\n                </button>\r\n            </view>\r\n            <table class=\"styled-table\">\r\n                <thead>\r\n                    <tr>\r\n                        <th style=\"width:10%\">检验单号</th>\r\n                        <th style=\"width:10%\">检验人员</th>\r\n                        <th style=\"width:10%\">检验日期</th>\r\n                        <th style=\"width:10%\">机台编号</th>\r\n                        <th style=\"width:10%\">提交标识</th>\r\n                        <th style=\"width:10%\">检验结果</th>\r\n                        <th style=\"width:10%\">作废标识</th>\r\n                        <th style=\"width:10%\">备注</th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr v-for=\"(item, idx) in visibleInspectionRecords\" :key=\"item.id || idx\" :class=\"{'row-odd': idx % 2 === 0}\">\r\n                        <!-- 修改为小驼峰格式 -->\r\n                        <td>{{ item.releaseNo || '' }}</td>\r\n                        <td>{{ item.fcheckBy || '' }}</td>\r\n                        <td>{{ formatDate(item.fcheckDate) }}</td>\r\n                        <td>{{ item.lineNo || '' }}</td>\r\n                        <td>{{ item.fsubmit == 1 ? '已提交' : '未提交' }}</td>\r\n                        <td>{{ item.fcancel == 'Y' ? '作废' : '未作废' }}</td>\r\n                        <td>{{ item.fsecondResu || '' }}</td>\r\n                        <td class=\"left\">{{ item.remeke || '' }}</td>\r\n                    </tr>\r\n                    <tr v-if=\"!inspectionRecords.length\">\r\n                        <td colspan=\"10\">暂无首检记录</td>\r\n                    </tr>\r\n                    <tr v-if=\"hasMoreInspectionRecords && !inspectionExpanded\">\r\n                        <td colspan=\"10\" class=\"more-records-tip\">\r\n                            <span>还有 {{ remainingInspectionRecords }} 条记录，点击</span>\r\n                            <button class=\"inline-expand-btn\" @click=\"toggleExpand('inspection')\">展开</button>\r\n                            <span>按钮查看全部</span>\r\n                        </td>\r\n                    </tr>\r\n                </tbody>\r\n            </table>\r\n        </view>\r\n    </view>\r\n</template>\r\n\r\n<script>\r\n    export default {\r\n        data() {\r\n            return {\r\n                machineNo: '',\r\n                workOrderNo: '',\r\n                selectedToolNo: '',\r\n                toolName: '',\r\n                useLimitInput: '',\r\n                lifeWarnInput: '',\r\n                toolRecords: [],\r\n                inspectionRecords: [], // 首检记录\r\n                loadingForm: false,\r\n                loadingInspection: false, // 首检记录加载状态\r\n                submitting: false,\r\n                workOrderCurrentCjNum: null,\r\n                toolExpanded: false, // 刀具表格展开状态\r\n                inspectionExpanded: false, // 首检表格展开状态\r\n                defaultVisibleRows: 3, // 默认显示的行数\r\n            };\r\n        },\r\n        computed: {\r\n            // 刀具表格相关计算\r\n            defaultToolRows() {\r\n                const total = this.toolRecords.length;\r\n                if (total <= 3) return total;\r\n                return Math.max(3, Math.floor(total / 2));\r\n            },\r\n            visibleToolRecords() {\r\n                if (this.toolExpanded) {\r\n                    return this.toolRecords;\r\n                } else {\r\n                    return this.toolRecords.slice(0, this.defaultToolRows);\r\n                }\r\n            },\r\n            hasMoreToolRecords() {\r\n                return this.toolRecords.length > this.defaultToolRows;\r\n            },\r\n            remainingToolRecords() {\r\n                return this.toolRecords.length - this.defaultToolRows;\r\n            },\r\n\r\n            // 首检表格相关计算\r\n            defaultInspectionRows() {\r\n                const total = this.inspectionRecords.length;\r\n                if (total <= 2) return total; // 首检表格默认显示2行\r\n                return Math.max(2, Math.floor(total / 2));\r\n            },\r\n            visibleInspectionRecords() {\r\n                if (this.inspectionExpanded) {\r\n                    return this.inspectionRecords;\r\n                } else {\r\n                    return this.inspectionRecords.slice(0, this.defaultInspectionRows);\r\n                }\r\n            },\r\n            hasMoreInspectionRecords() {\r\n                return this.inspectionRecords.length > this.defaultInspectionRows;\r\n            },\r\n            remainingInspectionRecords() {\r\n                return this.inspectionRecords.length - this.defaultInspectionRows;\r\n            }\r\n        },\r\n        methods: {\r\n            // 切换表格展开状态\r\n            toggleExpand(tableType) {\r\n                if (tableType === 'tool') {\r\n                    this.toolExpanded = !this.toolExpanded;\r\n                } else if (tableType === 'inspection') {\r\n                    this.inspectionExpanded = !this.inspectionExpanded;\r\n                }\r\n            },\r\n\r\n            // 刷新按钮处理方法\r\n            async handleRefresh() {\r\n                if (this.machineNo && this.workOrderNo) {\r\n                    await Promise.all([\r\n                        this.fetchFormData(),\r\n                        this.fetchDefaultToolFromWorkOrder(),\r\n                        this.fetchInspectionRecords()\r\n                    ]);\r\n                    // 刷新后赋值第一行 currentCjNum\r\n                    if (this.toolRecords.length > 0) {\r\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\r\n                    }\r\n                }\r\n                this.$showMessage('刷新完成');\r\n            },\r\n\r\n            // 获取工单首检记录\r\n            async fetchInspectionRecords() {\r\n                if (!this.workOrderNo) {\r\n                    console.warn('工单号为空，跳过获取首检记录');\r\n                    return;\r\n                }\r\n                this.loadingInspection = true;\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/GetInspectionRecords',\r\n                        data: JSON.stringify({\r\n                            aufnr: this.workOrderNo,\r\n                            ftype: '首检'\r\n                        }),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n\r\n                    if (res.status === 0) {\r\n                        // 根据实际接口返回结构调整\r\n                        const list = Array.isArray(res.data) ? res.data\r\n                            : (res.data && res.data.tbBillList) ? res.data.tbBillList\r\n                                : (res.data && res.data.data) ? res.data.data\r\n                                    : [];\r\n                        this.inspectionRecords = list || [];\r\n                    } else {\r\n                        this.$showMessage(res.message || '获取首检记录失败');\r\n                        this.inspectionRecords = [];\r\n                    }\r\n                } catch (error) {\r\n                    console.error('获取首检记录错误:', error);\r\n                    this.$showMessage('获取首检记录失败，请检查网络连接');\r\n                    this.inspectionRecords = [];\r\n                } finally {\r\n                    this.loadingInspection = false;\r\n                }\r\n            },\r\n\r\n            // 格式化日期\r\n            formatDate(dateStr) {\r\n                if (!dateStr) return '';\r\n                try {\r\n                    const date = new Date(dateStr);\r\n                    if (isNaN(date.getTime())) return String(dateStr);\r\n                    return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${String(date.getMinutes()).padStart(2, '0')}`;\r\n                } catch {\r\n                    return String(dateStr);\r\n                }\r\n            },\r\n\r\n            // 其他已有方法保持不变...\r\n            async fetchDefaultToolFromWorkOrder() {\r\n                if (!this.machineNo) return;\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/Womdaa/GetWomdaasByShow',\r\n                        data: JSON.stringify({ machineNo: this.machineNo }),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.status === 0 && Array.isArray(res.data?.tbBillList) && res.data.tbBillList.length > 0) {\r\n                        const order = res.data.tbBillList[0];\r\n                        this.selectedToolNo = order.cutterId || order.cutteR_ID || '';\r\n                        this.toolName = order.cutterName || order.cutteR_NAME || '';\r\n                        this.workOrderCurrentCjNum = order.CurrentCjNum ?? order.currentCjNum ?? null;\r\n                        if (order.modlLifeWorning !== undefined && order.modlLifeWorning !== null) {\r\n                            const warn = Number(order.modlLifeWorning);\r\n                            this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\r\n                        } else {\r\n                            this.lifeWarnInput = '';\r\n                        }\r\n                    } else {\r\n                        this.workOrderCurrentCjNum = null;\r\n                    }\r\n                } catch (e) {\r\n                    console.warn('自动带出工单刀具失败', e);\r\n                    this.workOrderCurrentCjNum = null;\r\n                }\r\n            },\r\n\r\n            async fetchFormData() {\r\n                if (!this.workOrderNo || !this.machineNo) {\r\n                    console.warn('工单号或机台号为空，跳过获取表单数据');\r\n                    return;\r\n                }\r\n                this.loadingForm = true;\r\n                const payload = {\r\n                    workOrderNo: this.workOrderNo.trim(),\r\n                    machineNo: this.machineNo.trim()\r\n                };\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/GetFormData',\r\n                        data: JSON.stringify(payload),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.status !== 0) {\r\n                        this.$showMessage(res.message || '获取表单数据失败');\r\n                        this.toolRecords = [];\r\n                        return;\r\n                    }\r\n                    const list = Array.isArray(res.data) ? res.data\r\n                        : (res.data && res.data.tbBillList) ? res.data.tbBillList\r\n                            : (res.data && res.data.data) ? res.data.data\r\n                                : [];\r\n\r\n                    // 数据处理逻辑保持不变...\r\n                    const getField = (obj, ...keys) => {\r\n                        for (const k of keys) if (obj?.[k] !== undefined && obj?.[k] !== null) return obj[k];\r\n                        return null;\r\n                    };\r\n\r\n                    const mapped = (list || []).map(t => {\r\n                        const upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');\r\n                        const downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');\r\n                        const lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');\r\n                        const currentCjNum = getField(t, 'currentCjNum', 'CURRENTCJNUM', 'CurrentCjNum');\r\n\r\n                        const useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');\r\n                        const useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');\r\n\r\n                        let percent = '';\r\n                        if (useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\r\n                            percent = ((Number(useCount) / Number(useLimit)) * 100).toFixed(0) + '%';\r\n                        }\r\n\r\n                        const parseNumber = v => {\r\n                            if (v === null || v === undefined || v === '') return null;\r\n                            const s = String(v).replace(/[,％%]/g, '').trim();\r\n                            const n = parseFloat(s);\r\n                            return Number.isFinite(n) ? n : null;\r\n                        };\r\n                        const formatPercent = n => {\r\n                            if (n === null || n === undefined || isNaN(n)) return '';\r\n                            if (n <= 1) return `${(n * 100).toFixed(0)}%`;\r\n                            return `${Number(n).toFixed(0)}%`;\r\n                        };\r\n                        const lifeWarnNum = parseNumber(lifeWarnRaw);\r\n\r\n                        let warnStatus = getField(t, 'status', 'STATUS') || '';\r\n                        if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {\r\n                            const percentNum = Number(useCount) / Number(useLimit);\r\n                            warnStatus = (percentNum >= lifeWarnNum) ? '预警' : '正常';\r\n                        } else {\r\n                            warnStatus = warnStatus || '未知';\r\n                        }\r\n\r\n                        return {\r\n                            id: getField(t, 'id', 'ID') || `${getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || ''}-${upTimeRaw || ''}`,\r\n                            no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',\r\n                            name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',\r\n                            upTime: this.formatDateTime(upTimeRaw),\r\n                            upCount: getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount') ?? '',\r\n                            downTime: this.formatDateTime(downTimeRaw),\r\n                            downCount: getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount') ?? '',\r\n                            useCount: useCount ?? '',\r\n                            useLimit: useLimit ?? '',\r\n                            lifePercent: percent,\r\n                            lifeWarn: formatPercent(lifeWarnNum),\r\n                            warnStatus,\r\n                            currentCjNum\r\n                        };\r\n                    });\r\n\r\n                    mapped.sort((a, b) => {\r\n                        const parse = s => {\r\n                            if (!s) return 0;\r\n                            const year = new Date().getFullYear();\r\n                            return new Date(`${year}-${s.replace(/-/g, '-')}:00`).getTime();\r\n                        };\r\n                        return parse(b.upTime) - parse(a.upTime);\r\n                    });\r\n\r\n                    this.toolRecords = mapped;\r\n                } catch (error) {\r\n                    console.error('获取表单数据错误:', error);\r\n                    this.$showMessage('获取数据失败，请检查网络连接');\r\n                    this.toolRecords = [];\r\n                } finally {\r\n                    this.loadingForm = false;\r\n                }\r\n            },\r\n\r\n            formatDateTime(dateTimeStr) {\r\n                if (!dateTimeStr) return '';\r\n                try {\r\n                    const s = String(dateTimeStr).trim();\r\n                    if (/^\\d{10}$/.test(s)) {\r\n                        const d = new Date(Number(s) * 1000);\r\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\r\n                    }\r\n                    if (/^\\d{13}$/.test(s)) {\r\n                        const d = new Date(Number(s));\r\n                        return `${d.getMonth() + 1}-${d.getDate()} ${d.getHours()}:${String(d.getMinutes()).padStart(2, '0')}`;\r\n                    }\r\n                    const date = new Date(dateTimeStr);\r\n                    if (!isNaN(date.getTime())) {\r\n                        return `${date.getMonth() + 1}-${date.getDate()} ${date.getHours()}:${String(date.getMinutes()).padStart(2, '0')}`;\r\n                    }\r\n                    const match = String(dateTimeStr).match(/(\\d{1,4}[-\\/]\\d{1,2}[-\\/]\\d{1,2}).*?(\\d{1,2}:\\d{2})/);\r\n                    if (match) return `${match[1].replace(/-/g, '/').replace(/^\\d{4}\\//, (m) => m)} ${match[2]}`;\r\n                    return String(dateTimeStr);\r\n                } catch {\r\n                    return String(dateTimeStr);\r\n                }\r\n            }\r\n        },\r\n        mounted() {\r\n            this.machineNo = uni.getStorageSync('machineNo') || '';\r\n            this.workOrderNo = uni.getStorageSync('daa001') || '';\r\n\r\n            if (this.machineNo && this.workOrderNo) {\r\n                this.fetchFormData().then(async () => {\r\n                    await this.fetchDefaultToolFromWorkOrder();\r\n                    await this.fetchInspectionRecords();\r\n                    if (this.toolRecords.length > 0) {\r\n                        this.$set(this.toolRecords[0], 'currentCjNum', this.workOrderCurrentCjNum);\r\n                    }\r\n                });\r\n            } else {\r\n                console.warn('机台号或工单号为空，无法获取数据');\r\n            }\r\n        }\r\n    };\r\n</script>\r\n\r\n<style scoped>\r\n    .page {\r\n        padding: 8px 12px; /* 减少上下内边距 */\r\n        display: flex;\r\n        flex-direction: column;\r\n        gap: 8px; /* 减少两个表格之间的间距 */\r\n    }\r\n\r\n    .button-row {\r\n        display: flex;\r\n        justify-content: center;\r\n        margin: 0.5vh 0; /* 减少上下边距 */\r\n    }\r\n\r\n    .save-btn {\r\n        width: 20%;\r\n        padding: 1.5vh;\r\n        background-color: #00A2E9;\r\n        color: white;\r\n        border: none;\r\n        text-align: center;\r\n        border-radius: 4px;\r\n        transition: all 0.3s;\r\n        font-size: 22px;\r\n        font-weight: 500;\r\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\r\n    }\r\n\r\n        .save-btn:hover {\r\n            background-color: #40a9ff;\r\n        }\r\n\r\n        .save-btn:active {\r\n            background-color: #096dd9;\r\n        }\r\n\r\n        .save-btn:disabled {\r\n            opacity: 0.6;\r\n            cursor: not-allowed;\r\n        }\r\n\r\n    /* 表格容器样式 */\r\n    .table-section {\r\n        display: flex;\r\n        flex-direction: column;\r\n        margin: 0;\r\n        overflow: auto; /* 统一滚动条 */\r\n        width: 100%;\r\n        border: 1px solid #f0f0f0;\r\n        border-radius: 8px;\r\n        background: #fff;\r\n        max-height: 220px; /* 默认高度 */\r\n        transition: max-height 0.3s ease;\r\n    }\r\n\r\n    .table-header {\r\n        display: flex;\r\n        justify-content: space-between;\r\n        align-items: center;\r\n        padding: 12px 16px;\r\n        background: #fafafa;\r\n        border-bottom: 1px solid #e8e8e8;\r\n    }\r\n\r\n        .table-header h3 {\r\n            margin: 0;\r\n            font-size: 24px;\r\n            color: #333;\r\n            font-weight: 600;\r\n        }\r\n\r\n    .expand-btn {\r\n        padding: 8px 20px;\r\n        background-color: #52c41a;\r\n        color: white;\r\n        border: none;\r\n        border-radius: 4px;\r\n        font-size: 20px;\r\n        cursor: pointer;\r\n        transition: all 0.3s;\r\n    }\r\n\r\n        .expand-btn:hover {\r\n            background-color: #73d13d;\r\n        }\r\n\r\n        .expand-btn:active {\r\n            background-color: #389e0d;\r\n        }\r\n\r\n    /* 表格样式 */\r\n    table.styled-table {\r\n        max-width: 1800px;\r\n        width: 98vw;\r\n        margin: 0;\r\n        border-collapse: separate;\r\n        border-spacing: 0;\r\n        border: 2px solid #bfbfbf;\r\n        background: #fff;\r\n        box-shadow: 0 2px 12px rgba(0,0,0,0.06);\r\n    }\r\n\r\n        table.styled-table thead th {\r\n            background: #fafafa;\r\n            border-bottom: 2px solid #bfbfbf;\r\n            padding: 16px 10px;\r\n            font-weight: bold;\r\n            text-align: center;\r\n            font-size: 22px;\r\n            position: sticky; /* 表头置顶 */\r\n            top: 0;\r\n            z-index: 10;\r\n        }\r\n\r\n        table.styled-table tbody td {\r\n            border-bottom: 1px solid #e8e8e8;\r\n            padding: 14px 10px;\r\n            vertical-align: middle;\r\n            text-align: center;\r\n            font-size: 22px;\r\n        }\r\n\r\n    /* 展开状态 - 只改变容器高度 */\r\n    .table-section.expanded {\r\n        max-height: 450px; /* 展开时的容器高度 */\r\n    }\r\n\r\n        table.styled-table tbody .left {\r\n            text-align: left;\r\n            padding-left: 8px;\r\n        }\r\n\r\n    .row-odd {\r\n        background: #fff;\r\n    }\r\n\r\n        .row-odd + tr {\r\n            background: #fafafa;\r\n        }\r\n\r\n    .num {\r\n        text-align: center;\r\n        padding-right: 0;\r\n        font-variant-numeric: tabular-nums;\r\n    }\r\n\r\n    .warn-cell {\r\n        color: #d93025;\r\n        font-weight: bold;\r\n    }\r\n\r\n    .ok-cell {\r\n        color: #333;\r\n    }\r\n\r\n    .warn-badge {\r\n        display: inline-block;\r\n        background: #ff4d4f;\r\n        color: #fff;\r\n        padding: 2px 6px;\r\n        border-radius: 3px;\r\n        font-weight: bold;\r\n    }\r\n\r\n    .more-records-tip {\r\n        text-align: center;\r\n        color: #666;\r\n        font-size: 18px;\r\n        padding: 20px !important;\r\n        background-color: #f9f9f9;\r\n    }\r\n\r\n        .more-records-tip span {\r\n            display: inline;\r\n            font-size: 20px;\r\n            color: #666;\r\n        }\r\n\r\n    /* 行内展开按钮样式 - 蓝色 */\r\n    .inline-expand-btn {\r\n        display: inline-block;\r\n        padding: 2px 12px; /* 减小内边距,与文字高度一致 */\r\n        margin: 0 6px;\r\n        background-color: #00A2E9; /* 蓝色 */\r\n        color: white;\r\n        border: none;\r\n        border-radius: 3px;\r\n        font-size: 20px; /* 与提示文字大小一致 */\r\n        font-weight: 500;\r\n        cursor: pointer;\r\n        transition: all 0.3s;\r\n        box-shadow: 0 2px 4px rgba(0, 162, 233, 0.2);\r\n        vertical-align: baseline; /* 与文字基线对齐 */\r\n        line-height: 1.2; /* 控制行高 */\r\n    }\r\n\r\n        .inline-expand-btn:hover {\r\n            background-color: #40a9ff; /* 悬停时变淡 */\r\n            box-shadow: 0 4px 8px rgba(0, 162, 233, 0.3);\r\n            transform: translateY(-1px);\r\n        }\r\n\r\n        .inline-expand-btn:active {\r\n            background-color: #096dd9; /* 点击时变深 */\r\n            transform: translateY(0);\r\n        }\r\n\r\n    /* 响应式调整 */\r\n    @media (max-width: 1200px) {\r\n        .save-btn {\r\n            width: 30%;\r\n        }\r\n\r\n        .table-header {\r\n            flex-direction: column;\r\n            gap: 8px;\r\n            align-items: flex-start;\r\n        }\r\n\r\n        .expand-btn {\r\n            align-self: flex-end;\r\n        }\r\n    }\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///119\n");
/***/ }),
/* 120 */
@@ -10452,7 +10448,7 @@
/***/ (function(module, exports, __webpack_require__) {
"use strict";
-eval("\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _vue = _interopRequireDefault(__webpack_require__(/*! vue */ 123));\nvar _vuex = _interopRequireDefault(__webpack_require__(/*! vuex */ 127));\n//寮曞叆vuex鎻掍欢 杩涜鐘舵�佺鐞哱n_vue.default.use(_vuex.default);\nvar store = new _vuex.default.Store({\n state: {\n id: 'id',\n serverInfo: {\n //鏈嶅姟淇℃伅\n networkFlag: '鍐呯綉',\n serverURLInt: 'http://192.168.11.251:10054',\n //鏈嶅姟鍣ㄤ綋妫� 10.0.1.104:10054\n serverURL: 'http://localhost:5106',\n //鏈湴璋冭瘯鍦板潃\n //serverAPI:'http://78566b00.r1.cpolar.top/api',//澶栫綉鍦板潃\n //serverAPI:'http://192.168.0.94:8008/api', //鍐呯綉鍦板潃\n serverAPI: 'http://localhost:5106/api' //鏈湴璋冭瘯鍦板潃\n }\n },\n\n mutations: {\n test: function test(state, id) {\n state.id = id;\n }\n },\n getters: {\n currentColor: function currentColor(state) {\n return state.colorList[state.colorIndex];\n }\n },\n actions: {\n // lazy loading openid\n }\n});\nvar _default = store;\nexports.default = _default;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaS1hcHA6Ly8vc3RvcmUvaW5kZXguanMiXSwibmFtZXMiOlsiVnVlIiwidXNlIiwiVnVleCIsInN0b3JlIiwiU3RvcmUiLCJzdGF0ZSIsImlkIiwic2VydmVySW5mbyIsIm5ldHdvcmtGbGFnIiwic2VydmVyVVJMSW50Iiwic2VydmVyVVJMIiwic2VydmVyQVBJIiwibXV0YXRpb25zIiwidGVzdCIsImdldHRlcnMiLCJjdXJyZW50Q29sb3IiLCJjb2xvckxpc3QiLCJjb2xvckluZGV4IiwiYWN0aW9ucyJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBO0FBQ0E7QUFFQTtBQUNBQSxZQUFHLENBQUNDLEdBQUcsQ0FBQ0MsYUFBSSxDQUFDO0FBQ2IsSUFBTUMsS0FBSyxHQUFHLElBQUlELGFBQUksQ0FBQ0UsS0FBSyxDQUFDO0VBQzVCQyxLQUFLLEVBQUU7SUFDTkMsRUFBRSxFQUFFLElBQUk7SUFDUkMsVUFBVSxFQUFDO01BQUM7TUFDWEMsV0FBVyxFQUFDLElBQUk7TUFDaEJDLFlBQVksRUFBQyw2QkFBNkI7TUFBQztNQUMzQ0MsU0FBUyxFQUFDLHVCQUF1QjtNQUFDO01BQ2xDO01BQ0E7TUFDQUMsU0FBUyxFQUFDLDJCQUEyQixDQUFDO0lBQ3ZDO0VBQ0QsQ0FBQzs7RUFDREMsU0FBUyxFQUFFO0lBQ1ZDLElBQUksZ0JBQUNSLEtBQUssRUFBQ0MsRUFBRSxFQUFDO01BQ2JELEtBQUssQ0FBQ0MsRUFBRSxHQUFHQSxFQUFFO0lBQ2Q7RUFDRCxDQUFDO0VBQ0VRLE9BQU8sRUFBQztJQUNKQyxZQUFZLHdCQUFDVixLQUFLLEVBQUM7TUFDZixPQUFPQSxLQUFLLENBQUNXLFNBQVMsQ0FBQ1gsS0FBSyxDQUFDWSxVQUFVLENBQUM7SUFDNUM7RUFDSixDQUFDO0VBQ0pDLE9BQU8sRUFBRTtJQUNSO0VBQUE7QUFFRixDQUFDLENBQUM7QUFBQSxlQUVhZixLQUFLO0FBQUEiLCJmaWxlIjoiMTI2LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFZ1ZSBmcm9tICd2dWUnXHJcbmltcG9ydCBWdWV4IGZyb20gJ3Z1ZXgnXHJcblxyXG4vL+W8leWFpXZ1ZXjmj5Lku7Yg6L+b6KGM54q25oCB566h55CGXHJcblZ1ZS51c2UoVnVleCkgXHJcbmNvbnN0IHN0b3JlID0gbmV3IFZ1ZXguU3RvcmUoe1xyXG5cdHN0YXRlOiB7IFxyXG5cdFx0aWQ6ICdpZCcsXHJcblx0XHRzZXJ2ZXJJbmZvOnsvL+acjeWKoeS/oeaBr1xyXG5cdFx0XHRuZXR3b3JrRmxhZzon5YaF572RJywgXHJcblx0XHRcdHNlcnZlclVSTEludDonaHR0cDovLzE5Mi4xNjguMTEuMjUxOjEwMDU0JywvL+acjeWKoeWZqOS9k+ajgCAxMC4wLjEuMTA0OjEwMDU0XHJcblx0XHRcdHNlcnZlclVSTDonaHR0cDovL2xvY2FsaG9zdDo1MTA2JywvL+acrOWcsOiwg+ivleWcsOWdgFxyXG5cdFx0XHQvL3NlcnZlckFQSTonaHR0cDovLzc4NTY2YjAwLnIxLmNwb2xhci50b3AvYXBpJywvL+Wklue9keWcsOWdgFxyXG5cdFx0XHQvL3NlcnZlckFQSTonaHR0cDovLzE5Mi4xNjguMC45NDo4MDA4L2FwaScsIC8v5YaF572R5Zyw5Z2AXHJcblx0XHRcdHNlcnZlckFQSTonaHR0cDovL2xvY2FsaG9zdDo1MTA2L2FwaScsLy/mnKzlnLDosIPor5XlnLDlnYBcclxuXHRcdH1cclxuXHR9LFxyXG5cdG11dGF0aW9uczoge1xyXG5cdFx0dGVzdChzdGF0ZSxpZCl7XHJcblx0XHRcdHN0YXRlLmlkID0gaWQ7XHJcblx0XHR9XHJcblx0fSxcclxuICAgIGdldHRlcnM6e1xyXG4gICAgICAgIGN1cnJlbnRDb2xvcihzdGF0ZSl7XHJcbiAgICAgICAgICAgIHJldHVybiBzdGF0ZS5jb2xvckxpc3Rbc3RhdGUuY29sb3JJbmRleF1cclxuICAgICAgICB9XHJcbiAgICB9LFxyXG5cdGFjdGlvbnM6IHtcclxuXHRcdC8vIGxhenkgbG9hZGluZyBvcGVuaWRcclxuXHR9XHJcbn0pXHJcblxyXG5leHBvcnQgZGVmYXVsdCBzdG9yZVxyXG4iXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///126\n");
+eval("\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 2);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _vue = _interopRequireDefault(__webpack_require__(/*! vue */ 123));\nvar _vuex = _interopRequireDefault(__webpack_require__(/*! vuex */ 127));\n//寮曞叆vuex鎻掍欢 杩涜鐘舵�佺鐞哱n_vue.default.use(_vuex.default);\nvar store = new _vuex.default.Store({\n state: {\n id: 'id',\n serverInfo: {\n //鏈嶅姟淇℃伅\n networkFlag: '鍐呯綉',\n serverURLInt: 'http://192.168.11.251:10054',\n //鏈嶅姟鍣ㄤ綋妫� 10.0.1.104:10054\n serverURL: 'http://localhost:10054',\n //鏈湴璋冭瘯鍦板潃\n //serverAPI:'http://78566b00.r1.cpolar.top/api',//澶栫綉鍦板潃\n serverAPI: 'http://192.168.0.94:8008/api' //鍐呯綉鍦板潃\n //serverAPI:'http://localhost:5106/api',//鏈湴璋冭瘯鍦板潃\n }\n },\n\n mutations: {\n test: function test(state, id) {\n state.id = id;\n }\n },\n getters: {\n currentColor: function currentColor(state) {\n return state.colorList[state.colorIndex];\n }\n },\n actions: {\n // lazy loading openid\n }\n});\nvar _default = store;\nexports.default = _default;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaS1hcHA6Ly8vc3RvcmUvaW5kZXguanMiXSwibmFtZXMiOlsiVnVlIiwidXNlIiwiVnVleCIsInN0b3JlIiwiU3RvcmUiLCJzdGF0ZSIsImlkIiwic2VydmVySW5mbyIsIm5ldHdvcmtGbGFnIiwic2VydmVyVVJMSW50Iiwic2VydmVyVVJMIiwic2VydmVyQVBJIiwibXV0YXRpb25zIiwidGVzdCIsImdldHRlcnMiLCJjdXJyZW50Q29sb3IiLCJjb2xvckxpc3QiLCJjb2xvckluZGV4IiwiYWN0aW9ucyJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBO0FBQ0E7QUFFQTtBQUNBQSxZQUFHLENBQUNDLEdBQUcsQ0FBQ0MsYUFBSSxDQUFDO0FBQ2IsSUFBTUMsS0FBSyxHQUFHLElBQUlELGFBQUksQ0FBQ0UsS0FBSyxDQUFDO0VBQzVCQyxLQUFLLEVBQUU7SUFDTkMsRUFBRSxFQUFFLElBQUk7SUFDUkMsVUFBVSxFQUFDO01BQUM7TUFDWEMsV0FBVyxFQUFDLElBQUk7TUFDaEJDLFlBQVksRUFBRSw2QkFBNkI7TUFBQztNQUM1Q0MsU0FBUyxFQUFFLHdCQUF3QjtNQUFDO01BQ3BDO01BQ0FDLFNBQVMsRUFBRSw4QkFBOEIsQ0FBRTtNQUMzQztJQUNEO0VBQ0QsQ0FBQzs7RUFDREMsU0FBUyxFQUFFO0lBQ1ZDLElBQUksZ0JBQUNSLEtBQUssRUFBQ0MsRUFBRSxFQUFDO01BQ2JELEtBQUssQ0FBQ0MsRUFBRSxHQUFHQSxFQUFFO0lBQ2Q7RUFDRCxDQUFDO0VBQ0VRLE9BQU8sRUFBQztJQUNKQyxZQUFZLHdCQUFDVixLQUFLLEVBQUM7TUFDZixPQUFPQSxLQUFLLENBQUNXLFNBQVMsQ0FBQ1gsS0FBSyxDQUFDWSxVQUFVLENBQUM7SUFDNUM7RUFDSixDQUFDO0VBQ0pDLE9BQU8sRUFBRTtJQUNSO0VBQUE7QUFFRixDQUFDLENBQUM7QUFBQSxlQUVhZixLQUFLO0FBQUEiLCJmaWxlIjoiMTI2LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFZ1ZSBmcm9tICd2dWUnXHJcbmltcG9ydCBWdWV4IGZyb20gJ3Z1ZXgnXHJcblxyXG4vL+W8leWFpXZ1ZXjmj5Lku7Yg6L+b6KGM54q25oCB566h55CGXHJcblZ1ZS51c2UoVnVleCkgXHJcbmNvbnN0IHN0b3JlID0gbmV3IFZ1ZXguU3RvcmUoe1xyXG5cdHN0YXRlOiB7IFxyXG5cdFx0aWQ6ICdpZCcsXHJcblx0XHRzZXJ2ZXJJbmZvOnsvL+acjeWKoeS/oeaBr1xyXG5cdFx0XHRuZXR3b3JrRmxhZzon5YaF572RJywgXHJcblx0XHRcdHNlcnZlclVSTEludDogJ2h0dHA6Ly8xOTIuMTY4LjExLjI1MToxMDA1NCcsLy/mnI3liqHlmajkvZPmo4AgMTAuMC4xLjEwNDoxMDA1NFxyXG5cdFx0XHRzZXJ2ZXJVUkw6ICdodHRwOi8vbG9jYWxob3N0OjEwMDU0JywvL+acrOWcsOiwg+ivleWcsOWdgFxyXG5cdFx0XHQvL3NlcnZlckFQSTonaHR0cDovLzc4NTY2YjAwLnIxLmNwb2xhci50b3AvYXBpJywvL+Wklue9keWcsOWdgFxyXG5cdFx0XHRzZXJ2ZXJBUEk6ICdodHRwOi8vMTkyLjE2OC4wLjk0OjgwMDgvYXBpJywgLy/lhoXnvZHlnLDlnYBcclxuXHRcdFx0Ly9zZXJ2ZXJBUEk6J2h0dHA6Ly9sb2NhbGhvc3Q6NTEwNi9hcGknLC8v5pys5Zyw6LCD6K+V5Zyw5Z2AXHJcblx0XHR9XHJcblx0fSxcclxuXHRtdXRhdGlvbnM6IHtcclxuXHRcdHRlc3Qoc3RhdGUsaWQpe1xyXG5cdFx0XHRzdGF0ZS5pZCA9IGlkO1xyXG5cdFx0fVxyXG5cdH0sXHJcbiAgICBnZXR0ZXJzOntcclxuICAgICAgICBjdXJyZW50Q29sb3Ioc3RhdGUpe1xyXG4gICAgICAgICAgICByZXR1cm4gc3RhdGUuY29sb3JMaXN0W3N0YXRlLmNvbG9ySW5kZXhdXHJcbiAgICAgICAgfVxyXG4gICAgfSxcclxuXHRhY3Rpb25zOiB7XHJcblx0XHQvLyBsYXp5IGxvYWRpbmcgb3BlbmlkXHJcblx0fVxyXG59KVxyXG5cclxuZXhwb3J0IGRlZmF1bHQgc3RvcmVcclxuIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///126\n");
/***/ }),
/* 127 */
diff --git a/unpackage/dist/dev/app-plus/app-view.js b/unpackage/dist/dev/app-plus/app-view.js
index 0c8afd2..9cc99ef 100644
--- a/unpackage/dist/dev/app-plus/app-view.js
+++ b/unpackage/dist/dev/app-plus/app-view.js
@@ -7233,7 +7233,7 @@
},
},
},
- [_vm._v("涓婂垁鎻愪氦(=璋冩満寮�濮�)")]
+ [_vm._v("涓婂垁鎻愪氦")]
),
_c(
"v-uni-button",
@@ -7264,24 +7264,298 @@
],
1
),
- _vm._$g(28, "i")
- ? _c(
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(28, "sc"), attrs: { _i: 28 } },
+ [
+ _c(
"uni-view",
- { staticClass: _vm._$g(28, "sc"), attrs: { _i: 28 } },
+ { staticClass: _vm._$g(29, "sc"), attrs: { _i: 29 } },
[
_c(
"uni-view",
- { staticClass: _vm._$g(29, "sc"), attrs: { _i: 29 } },
+ { staticClass: _vm._$g(30, "sc"), attrs: { _i: 30 } },
+ [
+ _c("v-uni-text", { attrs: { _i: 31 } }, [
+ _vm._v("褰撳墠璋冩満甯堝倕锛�"),
+ ]),
+ _c(
+ "v-uni-text",
+ { staticClass: _vm._$g(32, "sc"), attrs: { _i: 32 } },
+ [_vm._v(_vm._$g(32, "t0-0"))]
+ ),
+ _c(
+ "v-uni-button",
+ {
+ staticClass: _vm._$g(33, "sc"),
+ attrs: { _i: 33 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [_vm._v("閫変汉")]
+ ),
+ ],
+ 1
+ ),
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(34, "sc"), attrs: { _i: 34 } },
+ [
+ _c("v-uni-text", { attrs: { _i: 35 } }, [
+ _vm._v("璋冩満鑹搧鏁帮細"),
+ ]),
+ _c("v-uni-input", {
+ staticClass: _vm._$g(36, "sc"),
+ attrs: {
+ type: "number",
+ placeholder: "璇疯緭鍏ユ暟閲�",
+ _i: 36,
+ },
+ model: {
+ value: _vm._$g(36, "v-model"),
+ callback: function ($$v) {
+ _vm.$handleVModelEvent(36, $$v)
+ },
+ expression: "tiaojiOkQty",
+ },
+ }),
+ ],
+ 1
+ ),
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(37, "sc"), attrs: { _i: 37 } },
+ [
+ _c("v-uni-text", { attrs: { _i: 38 } }, [
+ _vm._v("璋冩満涓嶈壇鍝佹暟锛�"),
+ ]),
+ _c("v-uni-input", {
+ staticClass: _vm._$g(39, "sc"),
+ attrs: {
+ type: "number",
+ placeholder: "璇疯緭鍏ユ暟閲�",
+ _i: 39,
+ },
+ model: {
+ value: _vm._$g(39, "v-model"),
+ callback: function ($$v) {
+ _vm.$handleVModelEvent(39, $$v)
+ },
+ expression: "tiaojiBadQty",
+ },
+ }),
+ ],
+ 1
+ ),
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(40, "sc"), attrs: { _i: 40 } },
+ [
+ _c(
+ "v-uni-button",
+ {
+ staticClass: _vm._$g(41, "sc"),
+ attrs: { _i: 41 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [_vm._v("閫佹鍛煎彨")]
+ ),
+ ],
+ 1
+ ),
+ ],
+ 1
+ ),
+ ],
+ 1
+ ),
+ _vm._$g(42, "i")
+ ? _c(
+ "uni-view",
+ { staticClass: _vm._$g(42, "sc"), attrs: { _i: 42 } },
+ [
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(43, "sc"), attrs: { _i: 43 } },
[
_c(
"uni-view",
- { staticClass: _vm._$g(30, "sc"), attrs: { _i: 30 } },
+ { staticClass: _vm._$g(44, "sc"), attrs: { _i: 44 } },
[
_c("v-uni-input", {
- staticClass: _vm._$g(31, "sc"),
+ staticClass: _vm._$g(45, "sc"),
+ attrs: {
+ type: "text",
+ placeholder: "杈撳叆宸ュ彿鎴栧鍚嶆悳绱�",
+ _i: 45,
+ },
+ on: {
+ keydown: function ($event) {
+ return _vm.$handleViewEvent($event, {
+ enter: true,
+ prevent: true,
+ })
+ },
+ },
+ model: {
+ value: _vm._$g(45, "v-model"),
+ callback: function ($$v) {
+ _vm.$handleVModelEvent(45, $$v)
+ },
+ expression: "tiaojiUserSearch",
+ },
+ }),
+ _vm._$g(46, "i")
+ ? _c(
+ "v-uni-button",
+ {
+ staticClass: _vm._$g(46, "sc"),
+ attrs: { _i: 46 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [_vm._v("娓呯┖")]
+ )
+ : _vm._e(),
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(47, "sc"), attrs: { _i: 47 } },
+ [
+ _vm._v(
+ "鍖归厤锛�" +
+ _vm._$g(47, "t0-0") +
+ " / " +
+ _vm._$g(47, "t0-1")
+ ),
+ ]
+ ),
+ ],
+ 1
+ ),
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(48, "sc"), attrs: { _i: 48 } },
+ [
+ _vm._$g(49, "i")
+ ? [
+ _c(
+ "uni-view",
+ {
+ staticClass: _vm._$g(50, "sc"),
+ attrs: { _i: 50 },
+ },
+ _vm._l(
+ _vm._$g(51, "f"),
+ function (u, index, $20, $30) {
+ return _c(
+ "v-uni-button",
+ {
+ key: u,
+ class: _vm._$g("51-" + $30, "c"),
+ attrs: { _i: "51-" + $30 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [
+ _c(
+ "span",
+ {
+ staticClass: _vm._$g(
+ "52-" + $30,
+ "sc"
+ ),
+ attrs: { _i: "52-" + $30 },
+ },
+ [_vm._v(_vm._$g("52-" + $30, "t0-0"))]
+ ),
+ _c(
+ "span",
+ {
+ staticClass: _vm._$g(
+ "53-" + $30,
+ "sc"
+ ),
+ attrs: { _i: "53-" + $30 },
+ },
+ [_vm._v(_vm._$g("53-" + $30, "t0-0"))]
+ ),
+ ],
+ 1
+ )
+ }
+ ),
+ 1
+ ),
+ ]
+ : _c(
+ "uni-view",
+ {
+ staticClass: _vm._$g(54, "sc"),
+ attrs: { _i: 54 },
+ },
+ [_vm._v("鏈壘鍒板尮閰嶄汉鍛�")]
+ ),
+ ],
+ 2
+ ),
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(55, "sc"), attrs: { _i: 55 } },
+ [
+ _c(
+ "v-uni-button",
+ {
+ staticClass: _vm._$g(56, "sc"),
+ attrs: { _i: 56 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [_vm._v("鍏抽棴")]
+ ),
+ ],
+ 1
+ ),
+ ],
+ 1
+ ),
+ ],
+ 1
+ )
+ : _vm._e(),
+ _vm._$g(57, "i")
+ ? _c(
+ "uni-view",
+ { staticClass: _vm._$g(57, "sc"), attrs: { _i: 57 } },
+ [
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(58, "sc"), attrs: { _i: 58 } },
+ [
+ _c(
+ "uni-view",
+ { staticClass: _vm._$g(59, "sc"), attrs: { _i: 59 } },
+ [
+ _c("v-uni-input", {
+ staticClass: _vm._$g(60, "sc"),
attrs: {
placeholder: "杈撳叆鍒�鍏风紪鐮併�佸悕绉版ā绯婃悳绱�",
- _i: 31,
+ _i: 60,
},
on: {
input: function ($event) {
@@ -7289,7 +7563,7 @@
},
},
model: {
- value: _vm._$g(31, "v-model"),
+ value: _vm._$g(60, "v-model"),
callback: function () {},
expression: "searchKey",
},
@@ -7297,10 +7571,10 @@
_c(
"v-uni-button",
{
- staticClass: _vm._$g(32, "sc"),
+ staticClass: _vm._$g(61, "sc"),
attrs: {
- disabled: _vm._$g(32, "a-disabled"),
- _i: 32,
+ disabled: _vm._$g(61, "a-disabled"),
+ _i: 61,
},
on: {
click: function ($event) {
@@ -7315,15 +7589,15 @@
),
_c(
"uni-view",
- { staticClass: _vm._$g(33, "sc"), attrs: { _i: 33 } },
- _vm._l(_vm._$g(34, "f"), function (tool, $10, $20, $30) {
+ { staticClass: _vm._$g(62, "sc"), attrs: { _i: 62 } },
+ _vm._l(_vm._$g(63, "f"), function (tool, $11, $21, $31) {
return _c(
"v-uni-button",
{
key: tool,
- staticClass: _vm._$g("34-" + $30, "sc"),
- class: _vm._$g("34-" + $30, "c"),
- attrs: { _i: "34-" + $30 },
+ staticClass: _vm._$g("63-" + $31, "sc"),
+ class: _vm._$g("63-" + $31, "c"),
+ attrs: { _i: "63-" + $31 },
on: {
click: function ($event) {
return _vm.$handleViewEvent($event)
@@ -7332,9 +7606,9 @@
},
[
_vm._v(
- _vm._$g("34-" + $30, "t0-0") +
+ _vm._$g("63-" + $31, "t0-0") +
" | " +
- _vm._$g("34-" + $30, "t0-1")
+ _vm._$g("63-" + $31, "t0-1")
),
]
)
@@ -7343,7 +7617,7 @@
),
_c(
"uni-view",
- { staticClass: _vm._$g(35, "sc"), attrs: { _i: 35 } },
+ { staticClass: _vm._$g(64, "sc"), attrs: { _i: 64 } },
[
_c(
"div",
@@ -7352,16 +7626,16 @@
display: "flex",
"align-items": "center",
},
- attrs: { _i: 36 },
+ attrs: { _i: 65 },
},
[
_c(
"v-uni-button",
{
- staticClass: _vm._$g(37, "sc"),
+ staticClass: _vm._$g(66, "sc"),
attrs: {
- disabled: _vm._$g(37, "a-disabled"),
- _i: 37,
+ disabled: _vm._$g(66, "a-disabled"),
+ _i: 66,
},
on: {
click: function ($event) {
@@ -7375,14 +7649,14 @@
"span",
{
staticStyle: { margin: "0 12px" },
- attrs: { _i: 38 },
+ attrs: { _i: 67 },
},
[
_vm._v(
"绗�" +
- _vm._$g(38, "t0-0") +
+ _vm._$g(67, "t0-0") +
"椤� / 鍏�" +
- _vm._$g(38, "t0-1") +
+ _vm._$g(67, "t0-1") +
"椤�"
),
]
@@ -7390,10 +7664,10 @@
_c(
"v-uni-button",
{
- staticClass: _vm._$g(39, "sc"),
+ staticClass: _vm._$g(68, "sc"),
attrs: {
- disabled: _vm._$g(39, "a-disabled"),
- _i: 39,
+ disabled: _vm._$g(68, "a-disabled"),
+ _i: 68,
},
on: {
click: function ($event) {
@@ -7414,14 +7688,14 @@
gap: "18px",
"align-items": "center",
},
- attrs: { _i: 40 },
+ attrs: { _i: 69 },
},
[
_c(
"v-uni-button",
{
- staticClass: _vm._$g(41, "sc"),
- attrs: { _i: 41 },
+ staticClass: _vm._$g(70, "sc"),
+ attrs: { _i: 70 },
on: {
click: function ($event) {
return _vm.$handleViewEvent($event)
@@ -7433,8 +7707,8 @@
_c(
"v-uni-button",
{
- staticClass: _vm._$g(42, "sc"),
- attrs: { _i: 42 },
+ staticClass: _vm._$g(71, "sc"),
+ attrs: { _i: 71 },
on: {
click: function ($event) {
return _vm.$handleViewEvent($event)
@@ -7456,267 +7730,9 @@
1
)
: _vm._e(),
- _c(
- "uni-view",
- { staticClass: _vm._$g(43, "sc"), attrs: { _i: 43 } },
- [
- _c(
- "table",
- { staticClass: _vm._$g(44, "sc"), attrs: { _i: 44 } },
- [
- _c(
- "thead",
- { attrs: { _i: 45 } },
- [
- _c(
- "tr",
- { attrs: { _i: 46 } },
- [
- _c(
- "th",
- { staticStyle: { width: "7%" }, attrs: { _i: 47 } },
- [_vm._v("鍒�鍏风紪鍙�")]
- ),
- _c(
- "th",
- { staticStyle: { width: "12%" }, attrs: { _i: 48 } },
- [_vm._v("鍒�鍏峰悕绉�")]
- ),
- _c(
- "th",
- { staticStyle: { width: "10%" }, attrs: { _i: 49 } },
- [_vm._v("涓婂垁鏃堕棿")]
- ),
- _c(
- "th",
- {
- staticClass: _vm._$g(50, "sc"),
- staticStyle: { width: "7%" },
- attrs: { _i: 50 },
- },
- [_vm._v("涓婂垁璁℃暟")]
- ),
- _c(
- "th",
- { staticStyle: { width: "10%" }, attrs: { _i: 51 } },
- [_vm._v("涓嬪垁鏃堕棿")]
- ),
- _c(
- "th",
- {
- staticClass: _vm._$g(52, "sc"),
- staticStyle: { width: "7%" },
- attrs: { _i: 52 },
- },
- [_vm._v("涓嬪垁璁℃暟")]
- ),
- _c(
- "th",
- {
- staticClass: _vm._$g(53, "sc"),
- staticStyle: { width: "7%" },
- attrs: { _i: 53 },
- },
- [_vm._v("浣跨敤娆℃暟")]
- ),
- _c(
- "th",
- {
- staticClass: _vm._$g(54, "sc"),
- staticStyle: { width: "7%" },
- attrs: { _i: 54 },
- },
- [_vm._v("浣跨敤涓婇檺")]
- ),
- _c(
- "th",
- {
- staticClass: _vm._$g(55, "sc"),
- staticStyle: { width: "7%" },
- attrs: { _i: 55 },
- },
- [_vm._v("瀵垮懡姣�%")]
- ),
- _c(
- "th",
- {
- staticClass: _vm._$g(56, "sc"),
- staticStyle: { width: "7%" },
- attrs: { _i: 56 },
- },
- [_vm._v("瀵垮懡姣旈璀﹀��")]
- ),
- _c(
- "th",
- { staticStyle: { width: "7%" }, attrs: { _i: 57 } },
- [_vm._v("棰勮鐘舵��")]
- ),
- _c(
- "th",
- { staticStyle: { width: "7%" }, attrs: { _i: 58 } },
- [_vm._v("鍒�鍏峰湪鏈虹姸鎬�")]
- ),
- ],
- 1
- ),
- ],
- 1
- ),
- _c(
- "tbody",
- { attrs: { _i: 59 } },
- [
- _vm._l(_vm._$g(60, "f"), function (item, idx, $21, $31) {
- return _c(
- "tr",
- {
- key: item,
- class: _vm._$g("60-" + $31, "c"),
- attrs: { _i: "60-" + $31 },
- },
- [
- _c("td", { attrs: { _i: "61-" + $31 } }, [
- _vm._v(_vm._$g("61-" + $31, "t0-0")),
- ]),
- _c(
- "td",
- {
- staticClass: _vm._$g("62-" + $31, "sc"),
- attrs: { _i: "62-" + $31 },
- },
- [_vm._v(_vm._$g("62-" + $31, "t0-0"))]
- ),
- _c("td", { attrs: { _i: "63-" + $31 } }, [
- _vm._v(_vm._$g("63-" + $31, "t0-0")),
- ]),
- _c(
- "td",
- {
- staticClass: _vm._$g("64-" + $31, "sc"),
- attrs: { _i: "64-" + $31 },
- },
- [_vm._v(_vm._$g("64-" + $31, "t0-0"))]
- ),
- _c("td", { attrs: { _i: "65-" + $31 } }, [
- _vm._v(_vm._$g("65-" + $31, "t0-0")),
- ]),
- _c(
- "td",
- {
- staticClass: _vm._$g("66-" + $31, "sc"),
- attrs: { _i: "66-" + $31 },
- },
- [
- _vm._$g("67-" + $31, "i")
- ? [
- _vm._$g("68-" + $31, "i")
- ? [_vm._v(_vm._$g("68-" + $31, "t0-0"))]
- : [_vm._v(_vm._$g("69-" + $31, "t0-0"))],
- ]
- : [_vm._v(_vm._$g("70-" + $31, "t0-0"))],
- ],
- 2
- ),
- _c(
- "td",
- {
- staticClass: _vm._$g("71-" + $31, "sc"),
- attrs: { _i: "71-" + $31 },
- },
- [
- _vm._$g("72-" + $31, "i")
- ? [
- _vm._$g("73-" + $31, "i")
- ? [_vm._v(_vm._$g("73-" + $31, "t0-0"))]
- : [_vm._v(_vm._$g("74-" + $31, "t0-0"))],
- ]
- : [_vm._v(_vm._$g("75-" + $31, "t0-0"))],
- ],
- 2
- ),
- _c(
- "td",
- {
- staticClass: _vm._$g("76-" + $31, "sc"),
- attrs: { _i: "76-" + $31 },
- },
- [_vm._v(_vm._$g("76-" + $31, "t0-0"))]
- ),
- _c(
- "td",
- {
- staticClass: _vm._$g("77-" + $31, "sc"),
- attrs: { _i: "77-" + $31 },
- },
- [
- _vm._$g("78-" + $31, "i")
- ? [
- _vm._$g("79-" + $31, "i")
- ? [_vm._v(_vm._$g("79-" + $31, "t0-0"))]
- : [_vm._v(_vm._$g("80-" + $31, "t0-0"))],
- ]
- : [_vm._v(_vm._$g("81-" + $31, "t0-0"))],
- ],
- 2
- ),
- _c(
- "td",
- {
- staticClass: _vm._$g("82-" + $31, "sc"),
- attrs: { _i: "82-" + $31 },
- },
- [_vm._v(_vm._$g("82-" + $31, "t0-0"))]
- ),
- _c(
- "td",
- {
- class: _vm._$g("83-" + $31, "c"),
- attrs: { _i: "83-" + $31 },
- },
- [
- _vm._$g("84-" + $31, "i")
- ? _c(
- "span",
- {
- staticClass: _vm._$g("84-" + $31, "sc"),
- attrs: { _i: "84-" + $31 },
- },
- [_vm._v("璀﹀憡")]
- )
- : _c("span", { attrs: { _i: "85-" + $31 } }, [
- _vm._v(_vm._$g("85-" + $31, "t0-0")),
- ]),
- ],
- 1
- ),
- _c("td", { attrs: { _i: "86-" + $31 } }, [
- _vm._v(_vm._$g("86-" + $31, "t0-0")),
- ]),
- ],
- 1
- )
- }),
- _vm._$g(87, "i")
- ? _c(
- "tr",
- { attrs: { _i: 87 } },
- [
- _c("td", { attrs: { colspan: "12", _i: 88 } }, [
- _vm._v("鏆傛棤鏁版嵁"),
- ]),
- ],
- 1
- )
- : _vm._e(),
- ],
- 2
- ),
- ],
- 1
- ),
- ],
- 1
- ),
+ false
+ ? undefined
+ : _vm._e(),
],
1
)
@@ -7815,7 +7831,7 @@
var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 13);
exports = ___CSS_LOADER_API_IMPORT___(false);
// Module
-exports.push([module.i, "\n.top-section-grid[data-v-69099b55] {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n gap: 12px;\n margin-bottom: 2vh;\n width: 99vw;\n max-width: 1920px;\n margin-left: auto;\n margin-right: auto;\n padding: 12px;\n background: #f8f9fa;\n border-radius: 8px;\n border: 1px solid #e9ecef;\n}\n.form-row[data-v-69099b55] {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: center;\n width: 100%;\n margin-bottom: 12px;\n}\n.form-row[data-v-69099b55]:last-child {\n margin-bottom: 0;\n}\n.form-cell[data-v-69099b55] {\n display: flex;\n align-items: center;\n min-width: 0;\n margin-right: 0;\n}\n.form-cell[data-v-69099b55]:nth-child(1) {\n flex: 0 0 28%;\n min-width: 180px;\n}\n.form-cell[data-v-69099b55]:nth-child(2) {\n flex: 0 0 32%;\n min-width: 180px;\n justify-content: flex-start;\n}\n.form-cell[data-v-69099b55]:nth-child(3) {\n flex: 0 0 auto;\n min-width: 0;\n max-width: 220px; /* 闄愬埗鏈�澶у搴︼紝閬垮厤鎾戝紑 */\n justify-content: flex-end;\n}\n.form-label[data-v-69099b55] {\n width: auto;\n font-weight: 500;\n color: #333;\n white-space: nowrap;\n margin-right: 4px;\n flex-shrink: 0;\n font-size: 22px;\n}\n.input[data-v-69099b55] {\n padding: 14px 20px;\n border: 1px solid #dcdfe6;\n flex: 1;\n margin-right: 0;\n border-radius: 4px;\n background: #fff;\n min-width: 0;\n height: 56px !important;\n box-sizing: border-box;\n font-size: 22px;\n}\n.input.small-font[data-v-69099b55] {\n /* 涓嶈缃瓧浣撳ぇ灏� */\n}\n.input[data-v-69099b55]:disabled {\n background-color: #f5f7fa;\n color: #c0c4cc;\n cursor: not-allowed;\n}\n.input-with-unit[data-v-69099b55] {\n display: flex;\n align-items: center;\n gap: 0;\n}\n.input-with-unit .input[data-v-69099b55] {\n width: 60px !important;\n min-width: 0 !important;\n margin-right: 2px !important;\n text-align: center;\n padding-left: 2px;\n padding-right: 2px;\n}\n.input-with-unit .input[data-v-69099b55] {\n margin-right: 4px !important;\n width: 60px !important;\n min-width: 0 !important;\n text-align: center;\n}\n.unit-text[data-v-69099b55] {\n margin-left: 0 !important;\n padding-left: 0 !important;\n font-size: 22px !important;\n}\n.btn-blue[data-v-69099b55], .btn-blue.large-btn[data-v-69099b55] {\n background-color: #1890ff;\n color: white;\n border: none;\n padding: 14px 32px;\n border-radius: 4px;\n cursor: pointer;\n font-weight: 500;\n white-space: nowrap;\n height: 70px !important;\n box-sizing: border-box;\n transition: all 0.3s;\n flex-shrink: 0;\n min-width: 140px;\n margin-left: 24px;\n}\n.btn-blue.large-btn[data-v-69099b55] {\n padding: 0 60px;\n min-width: 180px;\n height: 72px !important;\n margin-left: 0 !important;\n font-size: 1.3em;\n box-shadow: 0 2px 8px rgba(24,144,255,0.08);\n line-height: 72px; /* 鍨傜洿灞呬腑 */\n display: inline-block; /* 淇濊瘉line-height鐢熸晥 */\n vertical-align: middle;\n}\n.btn-blue[data-v-69099b55]:hover {\n background-color: #40a9ff;\n}\n.btn-blue[data-v-69099b55]:active {\n background-color: #096dd9;\n}\n.btn-blue[data-v-69099b55]:disabled {\n background: #bae7ff;\n color: #91d5ff;\n cursor: not-allowed;\n}\n.button-row[data-v-69099b55] {\n display: flex;\n justify-content: center;\n gap: 32px;\n margin: 2vh 0;\n}\n.save-btn[data-v-69099b55], .cancel-btn[data-v-69099b55] {\n width: 28%;\n padding: 1.5vh;\n background-color: #00A2E9;\n color: white;\n border: none;\n text-align: center;\n border-radius: 4px;\n transition: all 0.3s;\n font-size: 22px;\n font-weight: 500;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n.cancel-btn[data-v-69099b55] {\n background-color: #f5f5f5;\n color: #333;\n}\n.save-btn[data-v-69099b55]:hover {\n background-color: #40a9ff;\n}\n.save-btn[data-v-69099b55]:active {\n background-color: #096dd9;\n}\n.save-btn[data-v-69099b55]:disabled, .cancel-btn[data-v-69099b55]:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n}\n\n/* 寮圭獥鏍峰紡 */\n.dialog-overlay[data-v-69099b55] {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0,0,0,0.18);\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 1000;\n}\n.dialog[data-v-69099b55] {\n background: #fff;\n padding: 3vh 3vw;\n border-radius: 18px;\n width: 90vw;\n max-width: 1600px;\n min-height: 70vh;\n max-height: 85vh;\n box-sizing: border-box;\n box-shadow: 0 8px 32px rgba(0,0,0,0.12);\n display: flex;\n flex-direction: column;\n}\n.form-group[data-v-69099b55] {\n display: flex;\n gap: 12px;\n align-items: center;\n margin-bottom: 2vh;\n flex-shrink: 0;\n}\n.form-group .input[data-v-69099b55] {\n flex: 1;\n min-width: 300px;\n border-radius: 6px;\n background: #f8f8f8;\n}\n.tool-list[data-v-69099b55] {\n display: flex;\n flex-wrap: wrap;\n margin: 1vh 0;\n flex: 1;\n overflow-y: auto;\n gap: 12px;\n align-content: flex-start;\n}\n.tool-btn[data-v-69099b55] {\n flex: 0 0 calc(20% - 10px);\n box-sizing: border-box;\n padding: 10px 12px;\n background: #f5f5f5;\n border: 1px solid #d0d0d0;\n border-radius: 8px;\n cursor: pointer;\n color: #333;\n text-align: left;\n min-height: 50px;\n transition: background 0.15s, color 0.15s;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n line-height: 1.4;\n}\n.tool-btn.active[data-v-69099b55] {\n background: #00A2E9;\n color: #fff;\n font-weight: bold;\n border: 1.5px solid #0086c2;\n}\n.dialog-actions[data-v-69099b55] {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-top: 2vh;\n padding-top: 2vh;\n border-top: 1px solid #eee;\n flex-shrink: 0;\n}\n.dialog-actions > div[data-v-69099b55]:first-child {\n display: flex;\n align-items: center;\n gap: 24px;\n}\n.dialog-actions > div[data-v-69099b55]:last-child {\n display: flex;\n flex-direction: row;\n gap: 18px;\n align-items: center;\n}\n.dialog-actions .btn-blue[data-v-69099b55] {\n padding: 10px 24px;\n min-width: 120px;\n font-size: 22px;\n}\n.btn-disabled[data-v-69099b55] {\n background: #f2f2f2;\n color: #999;\n border: none;\n padding: 10px 24px;\n border-radius: 4px;\n font-weight: 500;\n cursor: not-allowed;\n box-shadow: none;\n min-width: 120px;\n}\n.table-section[data-v-69099b55] {\n display: flex;\n justify-content: center;\n margin: 1vh 0;\n overflow-x: auto;\n width: 100%; /* 纭繚琛ㄦ牸瀹瑰櫒鍗犳弧瀹藉害 */\n}\ntable.styled-table[data-v-69099b55] {\n max-width: 1800px; /* 浠�1600px澧炲姞鍒�1800px */\n width: 98vw; /* 浠�95vw澧炲姞鍒�98vw */\n margin: 0 auto;\n border-collapse: separate;\n border-spacing: 0;\n border: 2px solid #bfbfbf;\n background: #fff;\n border-radius: 12px;\n overflow: hidden;\n box-shadow: 0 2px 12px rgba(0,0,0,0.06);\n}\ntable.styled-table thead th[data-v-69099b55] {\n background: #fafafa;\n border-bottom: 2px solid #bfbfbf;\n padding: 16px 10px;\n font-weight: bold;\n text-align: center;\n font-size: 22px;\n}\ntable.styled-table tbody td[data-v-69099b55] {\n border-bottom: 1px solid #e8e8e8;\n padding: 14px 10px;\n vertical-align: middle;\n text-align: center;\n font-size: 22px;\n}\n.table-section table th[data-v-69099b55]:first-child, .table-section table td[data-v-69099b55]:first-child {\n border-left: 2px solid #bfbfbf;\n}\n.table-section table th[data-v-69099b55]:last-child, .table-section table td[data-v-69099b55]:last-child {\n border-right: 2px solid #bfbfbf;\n}\n.row-odd[data-v-69099b55] {\n background: #fff;\n}\n.row-odd + tr[data-v-69099b55] {\n background: #fafafa;\n}\n.num[data-v-69099b55] {\n text-align: center;\n padding-right: 0;\n font-variant-numeric: tabular-nums;\n}\n.left[data-v-69099b55] {\n text-align: left;\n padding-left: 8px;\n}\n.warn-cell[data-v-69099b55] {\n color: #d93025;\n font-weight: bold;\n}\n.ok-cell[data-v-69099b55] {\n color: #333;\n}\n.warn-badge[data-v-69099b55] {\n display: inline-block;\n background: #ff4d4f;\n color: #fff;\n padding: 2px 6px;\n border-radius: 3px;\n font-weight: bold;\n}\n\n/* 鍝嶅簲寮忚皟鏁� */\n@media (max-width: 1200px) {\n.form-cell[data-v-69099b55] {\n margin: 0 4px;\n}\n.form-label[data-v-69099b55] {\n width: 90px;\n}\n.input[data-v-69099b55] {\n padding: 10px 14px;\n}\n.btn-blue[data-v-69099b55] {\n padding: 10px 18px;\n}\n}\n.input-life-warn[data-v-69099b55] {\n width: 48px !important; /* 绋嶅井鏀惧锛岄伩鍏嶅瓧浣撴孩鍑� */\n min-width: 0 !important;\n margin-right: 4px;\n padding-left: 2px;\n padding-right: 2px;\n font-size: 22px !important;\n text-align: center;\n box-sizing: border-box;\n}\n.input[data-v-69099b55],\n.input.small-font[data-v-69099b55],\n.input-use-limit[data-v-69099b55],\n.input-tool-model[data-v-69099b55],\n.input-tool-name[data-v-69099b55],\n.input-life-warn[data-v-69099b55] {\n font-size: 22px !important;\n}\n.input-tool-model[data-v-69099b55] {\n width: 320px !important; /* 鍘熶负200px锛岀幇鍔犻暱 */\n min-width: 0 !important;\n margin-right: 16px;\n}\n.input-tool-name[data-v-69099b55] {\n width: 120px !important;\n min-width: 0 !important;\n margin-right: 16px;\n}\n.highlight-label[data-v-69099b55] {\n color: #1890ff !important;\n}\n.tool-dir-cell[data-v-69099b55] {\n flex: 0 0 auto !important;\n justify-content: flex-start !important;\n display: flex !important;\n align-items: center;\n margin-left: 16px; /* 涓庤鏍煎瀷鍙疯緭鍏ユ鎷夊紑璺濈 */\n}\n.form-cell-flex[data-v-69099b55] {\n display: flex;\n align-items: center;\n flex: 0 0 60%;\n min-width: 320px;\n}\n.form-cell-flex .form-label[data-v-69099b55] {\n margin-right: 4px;\n width: auto;\n}\n.form-cell-flex .input-use-limit[data-v-69099b55] {\n margin-right: 12px;\n}\n.input-use-limit[data-v-69099b55] {\n width: 450px !important;\n min-width: 0 !important;\n margin-right: 16px;\n flex: none !important; /* 鍏抽敭锛氬交搴曠姝lex鎷変几 */\n}\n", ""]);
+exports.push([module.i, "\n.top-section-grid[data-v-69099b55] {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n gap: 12px;\n margin-bottom: 2vh;\n width: 99vw;\n max-width: 1920px;\n margin-left: auto;\n margin-right: auto;\n padding: 12px;\n background: #f8f9fa;\n border-radius: 8px;\n border: 1px solid #e9ecef;\n}\n.form-row[data-v-69099b55] {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n align-items: center;\n width: 100%;\n margin-bottom: 12px;\n}\n.form-row[data-v-69099b55]:last-child {\n margin-bottom: 0;\n}\n.form-cell[data-v-69099b55] {\n display: flex;\n align-items: center;\n min-width: 0;\n margin-right: 0;\n}\n.form-cell[data-v-69099b55]:nth-child(1) {\n flex: 0 0 28%;\n min-width: 180px;\n}\n.form-cell[data-v-69099b55]:nth-child(2) {\n flex: 0 0 32%;\n min-width: 180px;\n justify-content: flex-start;\n}\n.form-cell[data-v-69099b55]:nth-child(3) {\n flex: 0 0 auto;\n min-width: 0;\n max-width: 220px; /* 闄愬埗鏈�澶у搴︼紝閬垮厤鎾戝紑 */\n justify-content: flex-end;\n}\n.form-label[data-v-69099b55] {\n width: auto;\n font-weight: 500;\n color: #333;\n white-space: nowrap;\n margin-right: 4px;\n flex-shrink: 0;\n font-size: 22px;\n}\n.input[data-v-69099b55] {\n padding: 14px 20px;\n border: 1px solid #dcdfe6;\n flex: 1;\n margin-right: 0;\n border-radius: 4px;\n background: #fff;\n min-width: 0;\n height: 56px !important;\n box-sizing: border-box;\n font-size: 22px;\n}\n.input.small-font[data-v-69099b55] {\n /* 涓嶈缃瓧浣撳ぇ灏� */\n}\n.input[data-v-69099b55]:disabled {\n background-color: #f5f7fa;\n color: #c0c4cc;\n cursor: not-allowed;\n}\n.input-with-unit[data-v-69099b55] {\n display: flex;\n align-items: center;\n gap: 0;\n}\n.input-with-unit .input[data-v-69099b55] {\n width: 60px !important;\n min-width: 0 !important;\n margin-right: 2px !important;\n text-align: center;\n padding-left: 2px;\n padding-right: 2px;\n}\n.input-with-unit .input[data-v-69099b55] {\n margin-right: 4px !important;\n width: 60px !important;\n min-width: 0 !important;\n text-align: center;\n}\n.unit-text[data-v-69099b55] {\n margin-left: 0 !important;\n padding-left: 0 !important;\n font-size: 22px !important;\n}\n.btn-blue[data-v-69099b55], .btn-blue.large-btn[data-v-69099b55] {\n background-color: #1890ff;\n color: white;\n border: none;\n padding: 14px 32px;\n border-radius: 4px;\n cursor: pointer;\n font-weight: 500;\n white-space: nowrap;\n height: 70px !important;\n box-sizing: border-box;\n transition: all 0.3s;\n flex-shrink: 0;\n min-width: 140px;\n margin-left: 24px;\n}\n.btn-blue.large-btn[data-v-69099b55] {\n padding: 0 60px;\n min-width: 180px;\n height: 72px !important;\n margin-left: 0 !important;\n font-size: 1.3em;\n box-shadow: 0 2px 8px rgba(24,144,255,0.08);\n line-height: 72px; /* 鍨傜洿灞呬腑 */\n display: inline-block; /* 淇濊瘉line-height鐢熸晥 */\n vertical-align: middle;\n}\n.btn-blue[data-v-69099b55]:hover {\n background-color: #40a9ff;\n}\n.btn-blue[data-v-69099b55]:active {\n background-color: #096dd9;\n}\n.btn-blue[data-v-69099b55]:disabled {\n background: #bae7ff;\n color: #91d5ff;\n cursor: not-allowed;\n}\n.button-row[data-v-69099b55] {\n display: flex;\n justify-content: center;\n gap: 32px;\n margin: 2vh 0;\n}\n.save-btn[data-v-69099b55], .cancel-btn[data-v-69099b55] {\n width: 28%;\n padding: 1.5vh;\n background-color: #00A2E9;\n color: white;\n border: none;\n text-align: center;\n border-radius: 4px;\n transition: all 0.3s;\n font-size: 22px;\n font-weight: 500;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n.cancel-btn[data-v-69099b55] {\n background-color: #f5f5f5;\n color: #333;\n}\n.save-btn[data-v-69099b55]:hover {\n background-color: #40a9ff;\n}\n.save-btn[data-v-69099b55]:active {\n background-color: #096dd9;\n}\n.save-btn[data-v-69099b55]:disabled, .cancel-btn[data-v-69099b55]:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n}\n\n/* 寮圭獥鏍峰紡 */\n.dialog-overlay[data-v-69099b55] {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: rgba(0,0,0,0.18);\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 1000;\n}\n.dialog[data-v-69099b55] {\n background: #fff;\n padding: 3vh 3vw;\n border-radius: 18px;\n width: 90vw;\n max-width: 1600px;\n min-height: 70vh;\n max-height: 85vh;\n box-sizing: border-box;\n box-shadow: 0 8px 32px rgba(0,0,0,0.12);\n display: flex;\n flex-direction: column;\n}\n.form-group[data-v-69099b55] {\n display: flex;\n gap: 12px;\n align-items: center;\n margin-bottom: 2vh;\n flex-shrink: 0;\n}\n.form-group .input[data-v-69099b55] {\n flex: 1;\n min-width: 300px;\n border-radius: 6px;\n background: #f8f8f8;\n}\n.tool-list[data-v-69099b55] {\n display: flex;\n flex-wrap: wrap;\n margin: 1vh 0;\n flex: 1;\n overflow-y: auto;\n gap: 12px;\n align-content: flex-start;\n}\n.tool-btn[data-v-69099b55] {\n flex: 0 0 calc(20% - 10px);\n box-sizing: border-box;\n padding: 10px 12px;\n background: #f5f5f5;\n border: 1px solid #d0d0d0;\n border-radius: 8px;\n cursor: pointer;\n color: #333;\n text-align: left;\n min-height: 50px;\n transition: background 0.15s, color 0.15s;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n line-height: 1.4;\n}\n.tool-btn.active[data-v-69099b55] {\n background: #00A2E9;\n color: #fff;\n font-weight: bold;\n border: 1.5px solid #0086c2;\n}\n.dialog-actions[data-v-69099b55] {\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-top: 2vh;\n padding-top: 2vh;\n border-top: 1px solid #eee;\n flex-shrink: 0;\n}\n.dialog-actions > div[data-v-69099b55]:first-child {\n display: flex;\n align-items: center;\n gap: 24px;\n}\n.dialog-actions > div[data-v-69099b55]:last-child {\n display: flex;\n flex-direction: row;\n gap: 18px;\n align-items: center;\n}\n.dialog-actions .btn-blue[data-v-69099b55] {\n padding: 10px 24px;\n min-width: 120px;\n font-size: 22px;\n}\n.btn-disabled[data-v-69099b55] {\n background: #f2f2f2;\n color: #999;\n border: none;\n padding: 10px 24px;\n border-radius: 4px;\n font-weight: 500;\n cursor: not-allowed;\n box-shadow: none;\n min-width: 120px;\n}\n.table-section[data-v-69099b55] {\n display: flex;\n justify-content: center;\n margin: 1vh 0;\n overflow-x: auto;\n width: 100%; /* 纭繚琛ㄦ牸瀹瑰櫒鍗犳弧瀹藉害 */\n}\ntable.styled-table[data-v-69099b55] {\n max-width: 1800px; /* 浠�1600px澧炲姞鍒�1800px */\n width: 98vw; /* 浠�95vw澧炲姞鍒�98vw */\n margin: 0 auto;\n border-collapse: separate;\n border-spacing: 0;\n border: 2px solid #bfbfbf;\n background: #fff;\n border-radius: 12px;\n overflow: hidden;\n box-shadow: 0 2px 12px rgba(0,0,0,0.06);\n}\ntable.styled-table thead th[data-v-69099b55] {\n background: #fafafa;\n border-bottom: 2px solid #bfbfbf;\n padding: 16px 10px;\n font-weight: bold;\n text-align: center;\n font-size: 22px;\n}\ntable.styled-table tbody td[data-v-69099b55] {\n border-bottom: 1px solid #e8e8e8;\n padding: 14px 10px;\n vertical-align: middle;\n text-align: center;\n font-size: 22px;\n}\n.table-section table th[data-v-69099b55]:first-child, .table-section table td[data-v-69099b55]:first-child {\n border-left: 2px solid #bfbfbf;\n}\n.table-section table th[data-v-69099b55]:last-child, .table-section table td[data-v-69099b55]:last-child {\n border-right: 2px solid #bfbfbf;\n}\n.row-odd[data-v-69099b55] {\n background: #fff;\n}\n.row-odd + tr[data-v-69099b55] {\n background: #fafafa;\n}\n.num[data-v-69099b55] {\n text-align: center;\n padding-right: 0;\n font-variant-numeric: tabular-nums;\n}\n.left[data-v-69099b55] {\n text-align: left;\n padding-left: 8px;\n}\n.warn-cell[data-v-69099b55] {\n color: #d93025;\n font-weight: bold;\n}\n.ok-cell[data-v-69099b55] {\n color: #333;\n}\n.warn-badge[data-v-69099b55] {\n display: inline-block;\n background: #ff4d4f;\n color: #fff;\n padding: 2px 6px;\n border-radius: 3px;\n font-weight: bold;\n}\n\n/* 鍝嶅簲寮忚皟鏁� */\n@media (max-width: 1200px) {\n.form-cell[data-v-69099b55] {\n margin: 0 4px;\n}\n.form-label[data-v-69099b55] {\n width: 90px;\n}\n.input[data-v-69099b55] {\n padding: 10px 14px;\n}\n.btn-blue[data-v-69099b55] {\n padding: 10px 18px;\n}\n}\n.input-life-warn[data-v-69099b55] {\n width: 48px !important; /* 绋嶅井鏀惧锛岄伩鍏嶅瓧浣撴孩鍑� */\n min-width: 0 !important;\n margin-right: 4px;\n padding-left: 2px;\n padding-right: 2px;\n font-size: 22px !important;\n text-align: center;\n box-sizing: border-box;\n}\n.input[data-v-69099b55],\n.input.small-font[data-v-69099b55],\n.input-use-limit[data-v-69099b55],\n.input-tool-model[data-v-69099b55],\n.input-tool-name[data-v-69099b55],\n.input-life-warn[data-v-69099b55] {\n font-size: 22px !important;\n}\n.input-tool-model[data-v-69099b55] {\n width: 320px !important; /* 鍘熶负200px锛岀幇鍔犻暱 */\n min-width: 0 !important;\n margin-right: 16px;\n}\n.input-tool-name[data-v-69099b55] {\n width: 120px !important;\n min-width: 0 !important;\n margin-right: 16px;\n}\n.highlight-label[data-v-69099b55] {\n color: #1890ff !important;\n}\n.tool-dir-cell[data-v-69099b55] {\n flex: 0 0 auto !important;\n justify-content: flex-start !important;\n display: flex !important;\n align-items: center;\n margin-left: 16px; /* 涓庤鏍煎瀷鍙疯緭鍏ユ鎷夊紑璺濈 */\n}\n.form-cell-flex[data-v-69099b55] {\n display: flex;\n align-items: center;\n flex: 0 0 60%;\n min-width: 320px;\n}\n.form-cell-flex .form-label[data-v-69099b55] {\n margin-right: 4px;\n width: auto;\n}\n.form-cell-flex .input-use-limit[data-v-69099b55] {\n margin-right: 12px;\n}\n.input-use-limit[data-v-69099b55] {\n width: 450px !important;\n min-width: 0 !important;\n margin-right: 16px;\n flex: none !important; /* 鍏抽敭锛氬交搴曠姝lex鎷変几 */\n}\n\n/* 鏂板锛氳皟鏈哄尯鍩熸牱寮� */\n.tiaoji-section[data-v-69099b55] {\n width: 100%;\n margin: 2vh 0;\n padding: 20px;\n background: #f8f9fa;\n border-radius: 8px;\n border: 1px solid #e9ecef;\n}\n.tiaoji-row[data-v-69099b55] {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: 20px;\n}\n\n/* 褰撳墠璋冩満甯堝倕鍖哄煙 - 涓庢姤宸ョ晫闈繚鎸佷竴鑷� */\n.current-user-section[data-v-69099b55] {\n display: flex;\n align-items: center;\n font-size: 22px;\n border: 1.5px solid #f00;\n border-radius: 10px;\n padding: 14px 22px;\n background: #fff;\n gap: 14px;\n flex: 0 0 auto;\n}\n.current-user-name[data-v-69099b55] {\n font-weight: bold;\n font-size: 22px;\n}\n\n/* 閫変汉鎸夐挳 - 钃濊壊涓婚锛屼笌鎶ュ伐鐣岄潰淇濇寔涓�鑷� */\n.select-user-btn[data-v-69099b55] {\n background: #00a2e9;\n color: #fff;\n border: none;\n padding: 12px 22px;\n border-radius: 12px;\n font-size: 22px;\n cursor: pointer;\n transition: background 0.15s;\n height: 66px;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n.select-user-btn[data-v-69099b55]:hover {\n background: #008ac2;\n}\n\n/* 璋冩満鏁伴噺杈撳叆鍖哄煙 */\n.tiaoji-input-section[data-v-69099b55] {\n display: flex;\n align-items: center;\n gap: 14px;\n font-size: 22px;\n}\n.tiaoji-input[data-v-69099b55] {\n width: 200px;\n max-width: 100%;\n height: 66px;\n border: 2px solid #808080;\n font-size: 28px;\n text-align: center;\n border-radius: 8px;\n box-sizing: border-box;\n}\n\n/* 閫佹鍛煎彨鎸夐挳 - 涓庢姤宸ョ晫闈㈢殑纭鎻愪氦鎸夐挳淇濇寔涓�鑷� */\n.details-btn[data-v-69099b55] {\n padding: 12px 34px;\n background: #00a2e9;\n color: #fff;\n font-size: 32px;\n border: none;\n cursor: pointer;\n border-radius: 12px;\n height: 66px;\n min-width: 180px;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n line-height: 1.1;\n box-sizing: border-box;\n transition: background 0.15s;\n}\n.details-btn[data-v-69099b55]:hover {\n background: #008ac2;\n}\n.details-btn[data-v-69099b55]:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n background: #bae7ff;\n}\n.tiaoji-submit-section[data-v-69099b55] {\n display: flex;\n align-items: center;\n}\n\n/* 閫変汉寮圭獥鏍峰紡 - 涓庢姤宸ョ晫闈繚鎸佷竴鑷� */\n.overlay[data-v-69099b55] {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background: rgba(0,0,0,.45);\n display: flex;\n justify-content: center;\n align-items: center;\n z-index: 1000;\n}\n.user-select-popup[data-v-69099b55] {\n background: #fff;\n width: 1600px;\n max-width: 99vw;\n min-width: 1000px;\n height: auto;\n min-height: 520px;\n padding: 0;\n display: flex;\n flex-direction: column;\n font-size: 32px;\n border-radius: 12px;\n box-shadow: 0 8px 32px rgba(0,0,0,0.12);\n z-index: 1001;\n}\n.user-search-bar[data-v-69099b55] {\n display: flex;\n align-items: center;\n gap: 18px;\n padding: 24px 64px 0 64px;\n background: #fff;\n flex-wrap: wrap;\n}\n.user-search-input[data-v-69099b55] {\n flex: 1 1 260px;\n padding: 16px 20px;\n font-size: 28px;\n border: 1px solid #bbb;\n border-radius: 8px;\n outline: none;\n height: 54px;\n}\n.user-search-input[data-v-69099b55]:focus {\n border-color: #007aff;\n box-shadow: 0 0 0 2px rgba(0,122,255,.15);\n}\n.user-search-clear[data-v-69099b55] {\n padding: 12px 28px;\n background: #ff9f43;\n color: #fff;\n border: none;\n border-radius: 8px;\n font-size: 24px;\n cursor: pointer;\n}\n.user-search-clear[data-v-69099b55]:hover {\n background: #ff8920;\n}\n.user-search-info[data-v-69099b55] {\n font-size: 22px;\n color: #555;\n}\n.user-list-scroll[data-v-69099b55] {\n flex: 1 1 auto;\n overflow-y: auto;\n padding: 32px 64px 0 64px;\n}\n.user-list-grid[data-v-69099b55] {\n display: grid;\n grid-template-columns: repeat(auto-fill,minmax(200px,1fr));\n gap: 22px 22px;\n}\n.user-list-btn[data-v-69099b55] {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 2px;\n padding: 10px 10px;\n height: 100px;\n font-size: 30px;\n background: #00a2e9;\n color: #fff;\n border: none;\n border-radius: 8px;\n cursor: pointer;\n box-sizing: border-box;\n word-break: break-word;\n}\n.user-list-btn .user-code[data-v-69099b55] {\n font-weight: 700;\n font-size: 36px;\n line-height: 1.1;\n}\n.user-list-btn .user-name[data-v-69099b55] {\n font-size: 32px;\n line-height: 1.1;\n}\n.user-list-btn.selected[data-v-69099b55] {\n background: #0072c9;\n box-shadow: 0 0 0 3px rgba(255,255,255,.6) inset;\n}\n.user-list-btn[data-v-69099b55]:hover {\n background: #008ed0;\n}\n.no-user-result[data-v-69099b55] {\n padding: 40px 0;\n text-align: center;\n font-size: 28px;\n color: #666;\n}\n.user-popup-footer[data-v-69099b55] {\n flex-shrink: 0;\n padding: 24px 64px 32px 64px;\n background: #fff;\n text-align: center;\n}\n.clean-btn[data-v-69099b55] {\n width: 24%;\n padding: 10px 0;\n color: #fff;\n font-size: 20px;\n border: none;\n text-align: center;\n cursor: pointer;\n border-radius: 0.6vw;\n background: #007aff;\n}\n.clean-btn.wide-btn[data-v-69099b55] {\n width: 30%;\n font-size: 22px;\n padding: 12px 0;\n}\n.clean-btn[data-v-69099b55]:hover {\n background: #0062c9;\n}\n", ""]);
// Exports
module.exports = exports;
@@ -10177,7 +10193,11 @@
),
_c(
"uni-view",
- { staticClass: _vm._$g(3, "sc"), attrs: { _i: 3 } },
+ {
+ staticClass: _vm._$g(3, "sc"),
+ class: _vm._$g(3, "c"),
+ attrs: { _i: 3 },
+ },
[
_c(
"uni-view",
@@ -10202,11 +10222,7 @@
),
_c(
"table",
- {
- staticClass: _vm._$g(7, "sc"),
- class: _vm._$g(7, "c"),
- attrs: { _i: 7 },
- },
+ { staticClass: _vm._$g(7, "sc"), attrs: { _i: 7 } },
[
_c(
"thead",
@@ -10468,8 +10484,24 @@
_vm._v(
"杩樻湁 " +
_vm._$g(54, "t0-0") +
- ' 鏉¤褰曪紝鐐瑰嚮"灞曞紑"鎸夐挳鏌ョ湅鍏ㄩ儴'
+ " 鏉¤褰曪紝鐐瑰嚮"
),
+ ]),
+ _c(
+ "v-uni-button",
+ {
+ staticClass: _vm._$g(55, "sc"),
+ attrs: { _i: 55 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [_vm._v("灞曞紑")]
+ ),
+ _c("span", { attrs: { _i: 56 } }, [
+ _vm._v("鎸夐挳鏌ョ湅鍏ㄩ儴"),
]),
],
1
@@ -10489,83 +10521,83 @@
),
_c(
"uni-view",
- { staticClass: _vm._$g(55, "sc"), attrs: { _i: 55 } },
+ {
+ staticClass: _vm._$g(57, "sc"),
+ class: _vm._$g(57, "c"),
+ attrs: { _i: 57 },
+ },
[
_c(
"uni-view",
- { staticClass: _vm._$g(56, "sc"), attrs: { _i: 56 } },
+ { staticClass: _vm._$g(58, "sc"), attrs: { _i: 58 } },
[
- _c("h3", { attrs: { _i: 57 } }, [_vm._v("宸ュ崟棣栨璁板綍")]),
+ _c("h3", { attrs: { _i: 59 } }, [_vm._v("宸ュ崟棣栨璁板綍")]),
_c(
"v-uni-button",
{
- staticClass: _vm._$g(58, "sc"),
- attrs: { _i: 58 },
+ staticClass: _vm._$g(60, "sc"),
+ attrs: { _i: 60 },
on: {
click: function ($event) {
return _vm.$handleViewEvent($event)
},
},
},
- [_vm._v(_vm._$g(58, "t0-0"))]
+ [_vm._v(_vm._$g(60, "t0-0"))]
),
],
1
),
_c(
"table",
- {
- staticClass: _vm._$g(59, "sc"),
- class: _vm._$g(59, "c"),
- attrs: { _i: 59 },
- },
+ { staticClass: _vm._$g(61, "sc"), attrs: { _i: 61 } },
[
_c(
"thead",
- { attrs: { _i: 60 } },
+ { attrs: { _i: 62 } },
[
_c(
"tr",
- { attrs: { _i: 61 } },
+ { attrs: { _i: 63 } },
[
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 62 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 64 } },
[_vm._v("妫�楠屽崟鍙�")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 63 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 65 } },
[_vm._v("妫�楠屼汉鍛�")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 64 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 66 } },
[_vm._v("妫�楠屾棩鏈�")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 65 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 67 } },
[_vm._v("鏈哄彴缂栧彿")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 66 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 68 } },
[_vm._v("鎻愪氦鏍囪瘑")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 67 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 69 } },
[_vm._v("妫�楠岀粨鏋�")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 68 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 70 } },
[_vm._v("浣滃簾鏍囪瘑")]
),
_c(
"th",
- { staticStyle: { width: "10%" }, attrs: { _i: 69 } },
+ { staticStyle: { width: "10%" }, attrs: { _i: 71 } },
[_vm._v("澶囨敞")]
),
],
@@ -10576,23 +10608,17 @@
),
_c(
"tbody",
- { attrs: { _i: 70 } },
+ { attrs: { _i: 72 } },
[
- _vm._l(_vm._$g(71, "f"), function (item, idx, $21, $31) {
+ _vm._l(_vm._$g(73, "f"), function (item, idx, $21, $31) {
return _c(
"tr",
{
key: item,
- class: _vm._$g("71-" + $31, "c"),
- attrs: { _i: "71-" + $31 },
+ class: _vm._$g("73-" + $31, "c"),
+ attrs: { _i: "73-" + $31 },
},
[
- _c("td", { attrs: { _i: "72-" + $31 } }, [
- _vm._v(_vm._$g("72-" + $31, "t0-0")),
- ]),
- _c("td", { attrs: { _i: "73-" + $31 } }, [
- _vm._v(_vm._$g("73-" + $31, "t0-0")),
- ]),
_c("td", { attrs: { _i: "74-" + $31 } }, [
_vm._v(_vm._$g("74-" + $31, "t0-0")),
]),
@@ -10608,48 +10634,70 @@
_c("td", { attrs: { _i: "78-" + $31 } }, [
_vm._v(_vm._$g("78-" + $31, "t0-0")),
]),
+ _c("td", { attrs: { _i: "79-" + $31 } }, [
+ _vm._v(_vm._$g("79-" + $31, "t0-0")),
+ ]),
+ _c("td", { attrs: { _i: "80-" + $31 } }, [
+ _vm._v(_vm._$g("80-" + $31, "t0-0")),
+ ]),
_c(
"td",
{
- staticClass: _vm._$g("79-" + $31, "sc"),
- attrs: { _i: "79-" + $31 },
+ staticClass: _vm._$g("81-" + $31, "sc"),
+ attrs: { _i: "81-" + $31 },
},
- [_vm._v(_vm._$g("79-" + $31, "t0-0"))]
+ [_vm._v(_vm._$g("81-" + $31, "t0-0"))]
),
],
1
)
}),
- _vm._$g(80, "i")
+ _vm._$g(82, "i")
? _c(
"tr",
- { attrs: { _i: 80 } },
+ { attrs: { _i: 82 } },
[
- _c("td", { attrs: { colspan: "10", _i: 81 } }, [
+ _c("td", { attrs: { colspan: "10", _i: 83 } }, [
_vm._v("鏆傛棤棣栨璁板綍"),
]),
],
1
)
: _vm._e(),
- _vm._$g(82, "i")
+ _vm._$g(84, "i")
? _c(
"tr",
- { attrs: { _i: 82 } },
+ { attrs: { _i: 84 } },
[
_c(
"td",
{
- staticClass: _vm._$g(83, "sc"),
- attrs: { colspan: "10", _i: 83 },
+ staticClass: _vm._$g(85, "sc"),
+ attrs: { colspan: "10", _i: 85 },
},
[
- _c("span", { attrs: { _i: 84 } }, [
+ _c("span", { attrs: { _i: 86 } }, [
_vm._v(
"杩樻湁 " +
- _vm._$g(84, "t0-0") +
- ' 鏉¤褰曪紝鐐瑰嚮"灞曞紑"鎸夐挳鏌ョ湅鍏ㄩ儴'
+ _vm._$g(86, "t0-0") +
+ " 鏉¤褰曪紝鐐瑰嚮"
),
+ ]),
+ _c(
+ "v-uni-button",
+ {
+ staticClass: _vm._$g(87, "sc"),
+ attrs: { _i: 87 },
+ on: {
+ click: function ($event) {
+ return _vm.$handleViewEvent($event)
+ },
+ },
+ },
+ [_vm._v("灞曞紑")]
+ ),
+ _c("span", { attrs: { _i: 88 } }, [
+ _vm._v("鎸夐挳鏌ョ湅鍏ㄩ儴"),
]),
],
1
@@ -10765,7 +10813,7 @@
var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 13);
exports = ___CSS_LOADER_API_IMPORT___(false);
// Module
-exports.push([module.i, "\n.page[data-v-37e63344] {\n padding: 8px 12px; /* 鍑忓皯涓婁笅鍐呰竟璺� */\n display: flex;\n flex-direction: column;\n gap: 8px; /* 鍑忓皯涓や釜琛ㄦ牸涔嬮棿鐨勯棿璺� */\n}\n.button-row[data-v-37e63344] {\n display: flex;\n justify-content: center;\n margin: 0.5vh 0; /* 鍑忓皯涓婁笅杈硅窛 */\n}\n.save-btn[data-v-37e63344] {\n width: 20%;\n padding: 1.5vh;\n background-color: #00A2E9;\n color: white;\n border: none;\n text-align: center;\n border-radius: 4px;\n transition: all 0.3s;\n font-size: 22px;\n font-weight: 500;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n.save-btn[data-v-37e63344]:hover {\n background-color: #40a9ff;\n}\n.save-btn[data-v-37e63344]:active {\n background-color: #096dd9;\n}\n.save-btn[data-v-37e63344]:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n}\n\n/* 琛ㄦ牸瀹瑰櫒鏍峰紡 */\n.table-section[data-v-37e63344] {\n display: flex;\n flex-direction: column;\n margin: 0;\n overflow-x: auto;\n width: 100%;\n border: 1px solid #f0f0f0;\n border-radius: 8px;\n background: #fff;\n}\n.table-header[data-v-37e63344] {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 12px 16px;\n background: #fafafa;\n border-bottom: 1px solid #e8e8e8;\n}\n.table-header h3[data-v-37e63344] {\n margin: 0;\n font-size: 24px;\n color: #333;\n font-weight: 600;\n}\n.expand-btn[data-v-37e63344] {\n padding: 8px 20px;\n background-color: #52c41a;\n color: white;\n border: none;\n border-radius: 4px;\n font-size: 20px;\n cursor: pointer;\n transition: all 0.3s;\n}\n.expand-btn[data-v-37e63344]:hover {\n background-color: #73d13d;\n}\n.expand-btn[data-v-37e63344]:active {\n background-color: #389e0d;\n}\n\n/* 琛ㄦ牸鏍峰紡 */\ntable.styled-table[data-v-37e63344] {\n max-width: 1800px;\n width: 98vw;\n margin: 0 auto;\n border-collapse: separate;\n border-spacing: 0;\n border: 2px solid #bfbfbf;\n background: #fff;\n overflow: hidden;\n box-shadow: 0 2px 12px rgba(0,0,0,0.06);\n max-height: 180px; /* 璋冩暣楂樺害浣块〉闈㈤ケ婊� */\n display: block;\n overflow-y: hidden;\n transition: max-height 0.3s ease;\n}\ntable.styled-table.expanded[data-v-37e63344] {\n max-height: 400px; /* 灞曞紑鏃剁殑楂樺害 */\n overflow-y: auto;\n}\ntable.styled-table thead[data-v-37e63344] {\n display: table;\n width: 100%;\n table-layout: fixed;\n}\ntable.styled-table thead th[data-v-37e63344] {\n background: #fafafa;\n border-bottom: 2px solid #bfbfbf;\n padding: 16px 10px;\n font-weight: bold;\n text-align: center;\n font-size: 22px;\n position: -webkit-sticky;\n position: sticky;\n top: 0;\n z-index: 10;\n}\ntable.styled-table tbody[data-v-37e63344] {\n display: block;\n max-height: calc(180px - 50px); /* 鍑忓幓琛ㄥご楂樺害 */\n overflow-y: hidden;\n}\ntable.styled-table.expanded tbody[data-v-37e63344] {\n max-height: calc(400px - 50px);\n overflow-y: auto;\n}\ntable.styled-table tbody tr[data-v-37e63344] {\n display: table;\n width: 100%;\n table-layout: fixed;\n}\ntable.styled-table tbody td[data-v-37e63344] {\n border-bottom: 1px solid #e8e8e8;\n padding: 14px 10px;\n vertical-align: middle;\n text-align: center;\n font-size: 22px;\n}\ntable.styled-table tbody .left[data-v-37e63344] {\n text-align: left;\n padding-left: 8px;\n}\n.row-odd[data-v-37e63344] {\n background: #fff;\n}\n.row-odd + tr[data-v-37e63344] {\n background: #fafafa;\n}\n.num[data-v-37e63344] {\n text-align: center;\n padding-right: 0;\n font-variant-numeric: tabular-nums;\n}\n.warn-cell[data-v-37e63344] {\n color: #d93025;\n font-weight: bold;\n}\n.ok-cell[data-v-37e63344] {\n color: #333;\n}\n.warn-badge[data-v-37e63344] {\n display: inline-block;\n background: #ff4d4f;\n color: #fff;\n padding: 2px 6px;\n border-radius: 3px;\n font-weight: bold;\n}\n.more-records-tip[data-v-37e63344] {\n text-align: center;\n color: #666;\n font-size: 18px;\n padding: 20px !important;\n background-color: #f9f9f9;\n}\n.more-records-tip span[data-v-37e63344] {\n display: inline-block;\n padding: 5px 15px;\n background-color: #f0f0f0;\n border-radius: 4px;\n border: 1px dashed #ccc;\n}\n\n/* 鍝嶅簲寮忚皟鏁� */\n@media (max-width: 1200px) {\n.save-btn[data-v-37e63344] {\n width: 30%;\n}\n.table-header[data-v-37e63344] {\n flex-direction: column;\n gap: 8px;\n align-items: flex-start;\n}\n.expand-btn[data-v-37e63344] {\n align-self: flex-end;\n}\n}\n", ""]);
+exports.push([module.i, "\n.page[data-v-37e63344] {\n padding: 8px 12px; /* 鍑忓皯涓婁笅鍐呰竟璺� */\n display: flex;\n flex-direction: column;\n gap: 8px; /* 鍑忓皯涓や釜琛ㄦ牸涔嬮棿鐨勯棿璺� */\n}\n.button-row[data-v-37e63344] {\n display: flex;\n justify-content: center;\n margin: 0.5vh 0; /* 鍑忓皯涓婁笅杈硅窛 */\n}\n.save-btn[data-v-37e63344] {\n width: 20%;\n padding: 1.5vh;\n background-color: #00A2E9;\n color: white;\n border: none;\n text-align: center;\n border-radius: 4px;\n transition: all 0.3s;\n font-size: 22px;\n font-weight: 500;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n.save-btn[data-v-37e63344]:hover {\n background-color: #40a9ff;\n}\n.save-btn[data-v-37e63344]:active {\n background-color: #096dd9;\n}\n.save-btn[data-v-37e63344]:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n}\n\n/* 琛ㄦ牸瀹瑰櫒鏍峰紡 */\n.table-section[data-v-37e63344] {\n display: flex;\n flex-direction: column;\n margin: 0;\n overflow: auto; /* 缁熶竴婊氬姩鏉� */\n width: 100%;\n border: 1px solid #f0f0f0;\n border-radius: 8px;\n background: #fff;\n max-height: 220px; /* 榛樿楂樺害 */\n transition: max-height 0.3s ease;\n}\n.table-header[data-v-37e63344] {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 12px 16px;\n background: #fafafa;\n border-bottom: 1px solid #e8e8e8;\n}\n.table-header h3[data-v-37e63344] {\n margin: 0;\n font-size: 24px;\n color: #333;\n font-weight: 600;\n}\n.expand-btn[data-v-37e63344] {\n padding: 8px 20px;\n background-color: #52c41a;\n color: white;\n border: none;\n border-radius: 4px;\n font-size: 20px;\n cursor: pointer;\n transition: all 0.3s;\n}\n.expand-btn[data-v-37e63344]:hover {\n background-color: #73d13d;\n}\n.expand-btn[data-v-37e63344]:active {\n background-color: #389e0d;\n}\n\n/* 琛ㄦ牸鏍峰紡 */\ntable.styled-table[data-v-37e63344] {\n max-width: 1800px;\n width: 98vw;\n margin: 0;\n border-collapse: separate;\n border-spacing: 0;\n border: 2px solid #bfbfbf;\n background: #fff;\n box-shadow: 0 2px 12px rgba(0,0,0,0.06);\n}\ntable.styled-table thead th[data-v-37e63344] {\n background: #fafafa;\n border-bottom: 2px solid #bfbfbf;\n padding: 16px 10px;\n font-weight: bold;\n text-align: center;\n font-size: 22px;\n position: -webkit-sticky;\n position: sticky; /* 琛ㄥご缃《 */\n top: 0;\n z-index: 10;\n}\ntable.styled-table tbody td[data-v-37e63344] {\n border-bottom: 1px solid #e8e8e8;\n padding: 14px 10px;\n vertical-align: middle;\n text-align: center;\n font-size: 22px;\n}\n\n/* 灞曞紑鐘舵�� - 鍙敼鍙樺鍣ㄩ珮搴� */\n.table-section.expanded[data-v-37e63344] {\n max-height: 450px; /* 灞曞紑鏃剁殑瀹瑰櫒楂樺害 */\n}\ntable.styled-table tbody .left[data-v-37e63344] {\n text-align: left;\n padding-left: 8px;\n}\n.row-odd[data-v-37e63344] {\n background: #fff;\n}\n.row-odd + tr[data-v-37e63344] {\n background: #fafafa;\n}\n.num[data-v-37e63344] {\n text-align: center;\n padding-right: 0;\n font-variant-numeric: tabular-nums;\n}\n.warn-cell[data-v-37e63344] {\n color: #d93025;\n font-weight: bold;\n}\n.ok-cell[data-v-37e63344] {\n color: #333;\n}\n.warn-badge[data-v-37e63344] {\n display: inline-block;\n background: #ff4d4f;\n color: #fff;\n padding: 2px 6px;\n border-radius: 3px;\n font-weight: bold;\n}\n.more-records-tip[data-v-37e63344] {\n text-align: center;\n color: #666;\n font-size: 18px;\n padding: 20px !important;\n background-color: #f9f9f9;\n}\n.more-records-tip span[data-v-37e63344] {\n display: inline;\n font-size: 20px;\n color: #666;\n}\n\n/* 琛屽唴灞曞紑鎸夐挳鏍峰紡 - 钃濊壊 */\n.inline-expand-btn[data-v-37e63344] {\n display: inline-block;\n padding: 2px 12px; /* 鍑忓皬鍐呰竟璺�,涓庢枃瀛楅珮搴︿竴鑷� */\n margin: 0 6px;\n background-color: #00A2E9; /* 钃濊壊 */\n color: white;\n border: none;\n border-radius: 3px;\n font-size: 20px; /* 涓庢彁绀烘枃瀛楀ぇ灏忎竴鑷� */\n font-weight: 500;\n cursor: pointer;\n transition: all 0.3s;\n box-shadow: 0 2px 4px rgba(0, 162, 233, 0.2);\n vertical-align: baseline; /* 涓庢枃瀛楀熀绾垮榻� */\n line-height: 1.2; /* 鎺у埗琛岄珮 */\n}\n.inline-expand-btn[data-v-37e63344]:hover {\n background-color: #40a9ff; /* 鎮仠鏃跺彉娣� */\n box-shadow: 0 4px 8px rgba(0, 162, 233, 0.3);\n -webkit-transform: translateY(-1px);\n transform: translateY(-1px);\n}\n.inline-expand-btn[data-v-37e63344]:active {\n background-color: #096dd9; /* 鐐瑰嚮鏃跺彉娣� */\n -webkit-transform: translateY(0);\n transform: translateY(0);\n}\n\n/* 鍝嶅簲寮忚皟鏁� */\n@media (max-width: 1200px) {\n.save-btn[data-v-37e63344] {\n width: 30%;\n}\n.table-header[data-v-37e63344] {\n flex-direction: column;\n gap: 8px;\n align-items: flex-start;\n}\n.expand-btn[data-v-37e63344] {\n align-self: flex-end;\n}\n}\n", ""]);
// Exports
module.exports = exports;
--
Gitblit v1.9.3