From 1c23dc22cc3350d4989522282e6b3e1c5e64436f Mon Sep 17 00:00:00 2001
From: 快乐的昕的电脑 <快乐的昕的电脑@DESKTOP-C2BQPQU>
Date: 星期四, 25 十二月 2025 10:48:46 +0800
Subject: [PATCH] 调试

---
 unpackage/dist/dev/app-plus/app-service.js |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/unpackage/dist/dev/app-plus/app-service.js b/unpackage/dist/dev/app-plus/app-service.js
index 6d95f4b..108e72c 100644
--- a/unpackage/dist/dev/app-plus/app-service.js
+++ b/unpackage/dist/dev/app-plus/app-service.js
@@ -4827,7 +4827,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//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\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;\n        var okQty, badQty, staffNo, currentCjNum, 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                currentCjNum = ((_this15$order = _this15.order) === null || _this15$order === void 0 ? void 0 : _this15$order.currentCjNum) || 0; // 璋冪敤鎶ヨ瘯浜ф暟鎺ュ彛(浣跨敤鎶ュ伐鐣岄潰鐨勬帴鍙�)\n                payload = {\n                  orderNo: _this15.workOrderNo,\n                  orderId: _this15.orderId,\n                  // 闇�瑕佷粠宸ュ崟鏁版嵁涓幏鍙朶n                  bf: badQty,\n                  // bf浼犻�掍笉鑹搧鏁癨n                  staffNo: staffNo,\n                  initCjNum: currentCjNum - badQty - okQty,\n                  // initCjNum = currentCjNum - bf - 鑹搧鏁癨n                  currentCjNum: currentCjNum,\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 = 31;\n                return _this15.autoHandleMachineInspection();\n              case 31:\n                _context13.next = 37;\n                break;\n              case 33:\n                _context13.prev = 33;\n                _context13.t0 = _context13[\"catch\"](14);\n                __f__(\"error\", '璋冩満鎶ュ伐閿欒:', _context13.t0, \" at components/mold.vue:874\");\n                _this15.$showMessage('璋冩満鎶ュ伐澶辫触锛岃妫�鏌ョ綉缁�');\n              case 37:\n                _context13.prev = 37;\n                _this15.submitting = false;\n                return _context13.finish(37);\n              case 40:\n              case \"end\":\n                return _context13.stop();\n            }\n          }\n        }, _callee13, null, [[14, 33, 37, 40]]);\n      }))();\n    },\n    // 鏂板锛氳嚜鍔ㄥ鐞嗚皟鏈洪�佹鐣岄潰鐨勬寜閽�昏緫\n    autoHandleMachineInspection: function autoHandleMachineInspection() {\n      var _this16 = this;\n      return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee14() {\n        var statusRes, statusForm, maStartTime, maShoutTime, maEndTime, needSave, updateData, saveRes;\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: '/MesOrderSta/FindByOrderNo',\n                  data: {\n                    orderId: _this16.orderId,\n                    orderNo: _this16.workOrderNo\n                  }\n                });\n              case 3:\n                statusRes = _context14.sent;\n                if (!(!statusRes || !statusRes.data || !statusRes.data.tbBillList)) {\n                  _context14.next = 7;\n                  break;\n                }\n                __f__(\"error\", '鑾峰彇宸ュ崟鐘舵�佸け璐�', \" at components/mold.vue:894\");\n                return _context14.abrupt(\"return\");\n              case 7:\n                statusForm = statusRes.data.tbBillList;\n                maStartTime = statusForm.maStartTime;\n                maShoutTime = statusForm.maShoutTime;\n                maEndTime = statusForm.maEndTime; // 2. 鍑嗗闇�瑕佹洿鏂扮殑鏃堕棿鏁版嵁\n                needSave = false;\n                updateData = {\n                  id: statusForm.id,\n                  orderId: _this16.orderId,\n                  machineNo: _this16.machineNo,\n                  flag: -1\n                }; // 3. 浠庝笂鍒颁笅鏍规嵁鏄剧ず妗嗛噷鏄惁鏈夋椂闂翠緷娆¤缃甛n                // 濡傛灉璋冩満寮�濮嬫椂闂翠负绌猴紝璁剧疆璋冩満寮�濮嬫椂闂碶n                if (!maStartTime) {\n                  updateData.maStartTime = _this16.$getDate('yyyy-mm-dd hh24:mi:ss');\n                  updateData.flag = -1; // 璋冩満寮�濮嬬殑flag=-1\n                  needSave = true;\n                } else {\n                  updateData.maStartTime = maStartTime;\n                }\n\n                // 濡傛灉閫佹鍛煎彨鏃堕棿涓虹┖锛岃缃�佹鍛煎彨鏃堕棿\n                if (!maShoutTime) {\n                  updateData.maShoutTime = _this16.$getDate('yyyy-mm-dd hh24:mi:ss');\n                  updateData.flag = 1; // 棣栨閫佹鍛煎彨鐨刦lag=1\n                  needSave = true;\n                } else {\n                  updateData.maShoutTime = maShoutTime;\n                }\n\n                // 璋冩満瀹屾垚鏃堕棿淇濇寔涓嶅彉\n                updateData.maEndTime = maEndTime || '';\n\n                // 4. 濡傛灉鏈夐渶瑕佹洿鏂扮殑鏃堕棿锛岃皟鐢ㄤ繚瀛樻帴鍙n                if (!needSave) {\n                  _context14.next = 21;\n                  break;\n                }\n                _context14.next = 19;\n                return _this16.$post({\n                  url: '/MesOrderSta/ChangeMachineTime',\n                  data: updateData\n                });\n              case 19:\n                saveRes = _context14.sent;\n                if (saveRes && saveRes.data && saveRes.data.tbBillList) {\n                  __f__(\"log\", '璋冩満閫佹鐣岄潰鏃堕棿鑷姩鏇存柊鎴愬姛', \" at components/mold.vue:942\");\n                } else {\n                  __f__(\"error\", '璋冩満閫佹鐣岄潰鏃堕棿鑷姩鏇存柊澶辫触', \" at components/mold.vue:944\");\n                }\n              case 21:\n                _context14.next = 26;\n                break;\n              case 23:\n                _context14.prev = 23;\n                _context14.t0 = _context14[\"catch\"](0);\n                __f__(\"error\", '鑷姩澶勭悊璋冩満閫佹鐣岄潰澶辫触:', _context14.t0, \" at components/mold.vue:948\");\n                // 涓嶄腑鏂富娴佺▼锛屽彧璁板綍閿欒\n              case 26:\n              case \"end\":\n                return _context14.stop();\n            }\n          }\n        }, _callee14, null, [[0, 23]]);\n      }))();\n    },\n    // 鏂板锛氳幏鍙栬皟鏈哄笀鍌呭垪琛╘n    fetchTiaojiStaff: function fetchTiaojiStaff() {\n      var _this17 = this;\n      return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee15() {\n        var res, staff;\n        return _regenerator.default.wrap(function _callee15$(_context15) {\n          while (1) {\n            switch (_context15.prev = _context15.next) {\n              case 0:\n                _context15.prev = 0;\n                _context15.next = 3;\n                return _this17.$post({\n                  url: '/MesStaff/GetAllXS0101BYtj' // 涓庢姤宸ョ晫闈娇鐢ㄧ浉鍚屾帴鍙n                });\n              case 3:\n                res = _context15.sent;\n                if (res.status === 0 && res.data && res.data.tbBillList) {\n                  staff = res.data.tbBillList;\n                  _this17.tiaojiUsers = staff.map(function (s) {\n                    return s.staffNo + ':' + s.staffName;\n                  });\n                }\n                _context15.next = 10;\n                break;\n              case 7:\n                _context15.prev = 7;\n                _context15.t0 = _context15[\"catch\"](0);\n                __f__(\"error\", '鑾峰彇璋冩満甯堝倕鍒楄〃澶辫触:', _context15.t0, \" at components/mold.vue:964\");\n              case 10:\n              case \"end\":\n                return _context15.stop();\n            }\n          }\n        }, _callee15, null, [[0, 7]]);\n      }))();\n    }\n  },\n  mounted: function mounted() {\n    var _this18 = 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 _callee16() {\n        return _regenerator.default.wrap(function _callee16$(_context16) {\n          while (1) {\n            switch (_context16.prev = _context16.next) {\n              case 0:\n                _context16.next = 2;\n                return _this18.fetchDefaultToolFromWorkOrder();\n              case 2:\n                // 杩涘叆椤甸潰鏃惰祴鍊肩涓�琛� currentCjNum\n                if (_this18.toolRecords.length > 0) {\n                  _this18.$set(_this18.toolRecords[0], 'currentCjNum', _this18.workOrderCurrentCjNum);\n                }\n              case 3:\n              case \"end\":\n                return _context16.stop();\n            }\n          }\n        }, _callee16);\n      })));\n    } else {\n      __f__(\"warn\", '鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇琛ㄥ崟鏁版嵁', \" at components/mold.vue:985\");\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","orderNo","bf","initCjNum","autoHandleMachineInspection","statusRes","statusForm","maStartTime","maShoutTime","maEndTime","needSave","updateData","flag","saveRes","fetchTiaojiStaff","staff","mounted","beforeDestroy"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAsPA;EACAA;IACA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;;MAEA;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MAAA;;MAEA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;;MAEA;MACAC;MAAA;MACAC;IACA;EACA;;EACAC;IACAC;MACA;IACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACA;IACAC;MACA;MACA;MACA;QAAA;MAAA;IACA;EACA;EACAC;IACA;IACA/B;MAAA;IAAA;IACAM;MAAA;IAAA;IACAC;MAAA;IAAA;IACAN;MAAA;IAAA;IACAC;MAAA;IAAA;EACA;EACA8B;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAC;kBACA1C;oBAAAC;kBAAA;kBACA0C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACAC;kBAAA,OACAC;gBAAA,EACA;gBAAA,iCACAD;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;cAAA;gBAAA,iCAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IAEA;IACAE;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBACA;gBACA;kBACA;gBACA;cAAA;gBAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACA;IACAC;MAAA;MACA;MACA;MACA;QACA;MACA;IACA;IACA;IACAC;MACA;QACAC;QACA;MACA;IACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAEAC,4FACA,oCACA;gBAAA,IACAA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAAA;gBAKA;gBAAA;gBAAA,OACAA;cAAA;gBAAA;gBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBAAA;gBAAA;gBAAA,OAEA;kBACAd;kBACA1C;oBACAY;oBACAR;oBACAC;kBACA;kBACAsC;oBAAA;kBAAA;gBACA;cAAA;gBARAC;gBAUA;kBACAa,+CACAb,wDACAA,4CACA;kBAEAc;oBAAA;sBAAAC;oBAAA;oBACA;sBAAA;sBAAA;oBAAA;oBACA;kBACA,GAEA;kBACAC;oBAAA;sBACAC;sBACAC;sBACAC;sBACAC;oBACA;kBAAA;kBAEA;kBACA;kBAEAC,kFACArB,8XACA;kBACA;kBACA;oBACA;kBACA;gBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAsB;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;gBAAA,OACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAC;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;gBAAA,OACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAC;MAAA;MACAC;MACA;QACA;MACA;IACA;IACAC;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBAAA;gBAAA,OACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGAC;gBAAA,MACAC;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;kBACA;oBACA;sBAAAC;oBAAA;kBACA;kBACA;gBACA;gBACA;kBAAA;oBAAAA;kBAAA;gBAAA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IAEA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBACAD;gBAAA,MACAD;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAEA;gBACAG;gBACAC;gBACAtB;kBACAvD;kBACAD;kBACA+E;kBACAC;kBACAL;kBACAE;kBAAA;kBACAI;gBACA;gBAAA;gBAEA;gBAAA;gBAAA,OACA;kBACAxC;kBACA1C;kBACA2C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACAuC;kBACAC;kBACAC;gBACA;gBAAA;cAAA;gBAEA;kBACAF;oBACAC;oBACAC;kBACA;gBACA;cAAA;gBAAA,MAEAzC;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;gBACA;gBAAA;cAAA;gBAAA;gBAGA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACA;IACA0C;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBACA;gBACA;gBACAV,0CACA;gBAEA;gBACAW;gBACAR;gBACAtB;kBACAvD;kBACAD;kBACA+E;kBACAC;kBACAL;kBACAW;kBAAA;kBACAL;gBACA;gBAAA;gBAEA;gBAAA;gBAAA,OACA;kBACAxC;kBACA1C;kBACA2C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACAuC;kBACAC;kBACAC;gBACA;gBAAA;cAAA;gBAEA;kBACAF;oBACAC;oBACAC;kBACA;gBACA;cAAA;gBAAA,MAEAzC;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;gBACA;gBAAA;cAAA;gBAAA;gBAGA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACA4C;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;gBACAhC;kBACAvD;kBACAD;gBACA;gBAAA;gBAAA;gBAAA,OAEA;kBACAyC;kBACA1C;kBACA2C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACA;gBACA;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;gBACAR,kIAEA;gBACA3C;kBACAoD;kBACA5E;kBAAA;kBACA6E;kBAAA;kBACAF;kBACAG;kBAAA;kBACAX;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,OAGA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAoE;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA;gBAAA,OAGA;kBACAtE;kBACA1C;oBACAiC;oBACA4E;kBACA;gBACA;cAAA;gBANAI;gBAAA,MAQA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAIAC;gBACAC;gBACAC;gBACAC,kCAEA;gBACAC;gBACAC;kBACA1B;kBACA5D;kBACAhC;kBACAuH;gBACA,GAEA;gBACA;gBACA;kBACAD;kBACAA;kBACAD;gBACA;kBACAC;gBACA;;gBAEA;gBACA;kBACAA;kBACAA;kBACAD;gBACA;kBACAC;gBACA;;gBAEA;gBACAA;;gBAEA;gBAAA,KACAD;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;kBACA5E;kBACA1C;gBACA;cAAA;gBAHAyH;gBAKA;kBACA;gBACA;kBACA;gBACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAhF;gBACA;cAAA;gBAFAE;gBAGA;kBACA+E;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>\r\n    <view class=\"page\">\r\n        <!-- 刀具选择区 -->\r\n        <view class=\"top-section-grid\">\r\n            <!-- 第一行：移除刀具目录按钮 -->\r\n            <view class=\"form-row\">\r\n                <view class=\"form-cell\">\r\n                    <label class=\"form-label\">刀具编号：</label>\r\n                    <input class=\"input small-font\" v-model=\"selectedToolNo\" placeholder=\"请通过刀具目录选择\" disabled />\r\n                </view>\r\n                <view class=\"form-cell form-cell-flex\">\r\n                    <label class=\"form-label highlight-label\">使用上限：</label>\r\n                    <input class=\"input small-font input-use-limit\" type=\"number\" v-model=\"useLimitInput\" placeholder=\"每次上刀时手填上限\" :disabled=\"!selectedToolNo || loadingForm\" />\r\n                    <label class=\"form-label\" style=\"margin-left:16px;\">寿命比预警值：</label>\r\n                    <view class=\"input-with-unit\">\r\n                        <input class=\"input small-font input-life-warn\"\r\n                               v-model=\"lifeWarnInput\"\r\n                               placeholder=\"如90\"\r\n                               :disabled=\"!selectedToolNo || loadingForm\" />\r\n                        <span class=\"unit-text\">%</span>\r\n                    </view>\r\n                </view>\r\n            </view>\r\n\r\n            <!-- 第二行：在最后添加刀具目录按钮 -->\r\n            <view class=\"form-row\">\r\n                <!-- 刀具名称 -->\r\n                <view class=\"form-cell\">\r\n                    <label class=\"form-label\">刀具名称：</label>\r\n                    <input class=\"input small-font input-tool-name\" v-model=\"toolName\" placeholder=\"刀具带出\" disabled />\r\n                </view>\r\n                <!-- 规格型号 -->\r\n                <view class=\"form-cell\">\r\n                    <label class=\"form-label\">规格型号：</label>\r\n                    <input class=\"input small-font input-tool-model\" v-model=\"toolModel\" placeholder=\"刀具带出\" disabled />\r\n                </view>\r\n                <!-- 刀具目录按钮右移 -->\r\n                <view class=\"form-cell tool-dir-cell\">\r\n                    <button class=\"btn-blue large-btn\" @click=\"openToolDialog\" :disabled=\"loadingTools\">刀具目录</button>\r\n                </view>\r\n                <!-- 新增：刷新按钮 -->\r\n                <view class=\"form-cell\" style=\"flex:0 0 auto; margin-left:16px;\">\r\n                    <button class=\"btn-blue large-btn\" @click=\"handleRefresh\" :disabled=\"loadingForm || submitting\">刷新</button>\r\n                </view>\r\n            </view>\r\n        </view>  <!-- 这里闭合 top-section-grid -->\r\n        <!-- 操作按钮 - 移出 top-section-grid -->\r\n        <view class=\"button-row\">\r\n            <button class=\"save-btn\" @click=\"handleUpTool\" :disabled=\"submitting || loadingForm\">上刀提交</button>\r\n            <button class=\"save-btn\" @click=\"handleDownTool\" :disabled=\"submitting || loadingForm\">下刀提交</button>\r\n            <button class=\"cancel-btn\" @click=\"cancel\" :disabled=\"submitting || loadingForm\">清空刀具选择</button>\r\n        </view>\r\n\r\n        <!-- 新增：调机数据输入区域 -->\r\n        <view class=\"tiaoji-section\">\r\n            <view class=\"tiaoji-row\">\r\n                <!-- 当前调机师傅 -->\r\n                <view class=\"current-user-section\">\r\n                    <text>当前调机师傅：</text>\r\n                    <text class=\"current-user-name\">{{ tiaojiStaffDisplay || '未选择' }}</text>\r\n                    <button class=\"select-user-btn\" @click=\"isTiaojiUserSelectShow = true\">选人</button>\r\n                </view>\r\n\r\n                <!-- 调机良品数 -->\r\n                <view class=\"tiaoji-input-section\">\r\n                    <text>调机良品数：</text>\r\n                    <input v-model=\"tiaojiOkQty\" class=\"inp tiaoji-input\" type=\"number\" placeholder=\"请输入数量\" />\r\n                </view>\r\n\r\n                <!-- 调机不良品数 -->\r\n                <view class=\"tiaoji-input-section\">\r\n                    <text>调机不良品数：</text>\r\n                    <input v-model=\"tiaojiBadQty\" class=\"inp tiaoji-input\" type=\"number\" placeholder=\"请输入数量\" />\r\n                </view>\r\n\r\n                <!-- 送检呼叫按钮 -->\r\n                <view class=\"tiaoji-submit-section\">\r\n                    <button class=\"details-btn\" @click=\"handleInspectionCall\">送检呼叫</button>\r\n                </view>\r\n            </view>\r\n        </view>\r\n\r\n        <!-- 选择调机师傅弹窗 -->\r\n        <view v-if=\"isTiaojiUserSelectShow\" class=\"overlay\">\r\n            <view class=\"popup user-select-popup\">\r\n                <!-- 搜索栏 -->\r\n                <view class=\"user-search-bar\">\r\n                    <input v-model.trim=\"tiaojiUserSearch\"\r\n                           type=\"text\"\r\n                           class=\"user-search-input\"\r\n                           placeholder=\"输入工号或姓名搜索\"\r\n                           @keydown.enter.prevent />\r\n                    <button v-if=\"tiaojiUserSearch\" class=\"user-search-clear\" @click=\"tiaojiUserSearch=''\">清空</button>\r\n                    <view class=\"user-search-info\">\r\n                        匹配：{{ filteredTiaojiUsers.length }} / {{ tiaojiUsers.length }}\r\n                    </view>\r\n                </view>\r\n                <view class=\"user-list-scroll\">\r\n                    <template v-if=\"filteredTiaojiUsers.length\">\r\n                        <view class=\"user-list-grid\">\r\n                            <button v-for=\"(u, index) in filteredTiaojiUsers\"\r\n                                    :key=\"index\"\r\n                                    :class=\"['user-list-btn', {'selected': u===tiaojiStaffNo}]\"\r\n                                    @click=\"selectTiaojiUser(u)\">\r\n                                <span class=\"user-code\">{{ u.split(':')[0] }}</span>\r\n                                <span class=\"user-name\">{{ u.split(':')[1] }}</span>\r\n                            </button>\r\n                        </view>\r\n                    </template>\r\n                    <view v-else class=\"no-user-result\">\r\n                        未找到匹配人员\r\n                    </view>\r\n                </view>\r\n                <view class=\"user-popup-footer\">\r\n                    <button class=\"clean-btn wide-btn\" @click=\"isTiaojiUserSelectShow = false\">关闭</button>\r\n                </view>\r\n            </view>\r\n        </view>\r\n\r\n        <!-- 刀具目录弹窗 -->\r\n        <view v-if=\"showToolDialog\" class=\"dialog-overlay\">\r\n            <view class=\"dialog\">\r\n                <view class=\"form-group\">\r\n                    <input v-model=\"searchKey\" placeholder=\"输入刀具编码、名称模糊搜索\" class=\"input\" @input=\"onSearchKeyInput\" />\r\n                    <button class=\"btn-blue\" @click=\"searchTool\" :disabled=\"loadingTools\">搜索</button>\r\n                </view>\r\n                <view class=\"tool-list\">\r\n                    <button v-for=\"tool in filteredTools\"\r\n                            :key=\"tool.no\"\r\n                            class=\"tool-btn\"\r\n                            :class=\"{ active: activeToolNo === tool.no }\"\r\n                            @click=\"selectTool(tool)\">\r\n                        {{ tool.no }} | {{ tool.name }}\r\n                    </button>\r\n                </view>\r\n                <view class=\"dialog-actions\">\r\n                    <div style=\"display: flex; align-items: center;\">\r\n                        <button class=\"btn-blue\" @click=\"prevPage\" :disabled=\"pageIndex === 1 || loadingTools\">上一页</button>\r\n                        <span style=\"margin: 0 12px;\">第{{ pageIndex }}页 / 共{{ totalPages }}页</span>\r\n                        <button class=\"btn-blue\" @click=\"nextPage\" :disabled=\"pageIndex === totalPages || loadingTools\">下一页</button>\r\n                    </div>\r\n                    <div style=\"display: flex; gap: 18px; align-items: center;\">\r\n                        <button class=\"btn-blue\" @click=\"confirmTool\">确定</button>\r\n                        <button class=\"btn-disabled\" @click=\"closeToolDialog\">取消</button>\r\n                    </div>\r\n                </view>\r\n            </view>\r\n        </view>\r\n\r\n        <!-- 隐藏刀具使用记录表格 -->\r\n        <view v-if=\"false\" class=\"table-section\">\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 toolRecords\" :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                        <!-- 只有第一行显示 currentCjNum，其它行显示 downCount -->\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <!-- 第一行：下机时不实时显示 currentCjNum，显示 downCount -->\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                        <!--使用次数-->\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <!-- 第一行实时计算使用次数，若为下机则不实时显示 -->\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                        <!--寿命比%-->\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <!-- 第一行实时计算寿命比%，若为下机则不实时显示 -->\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                </tbody>\r\n            </table>\r\n        </view>\r\n\r\n        <!-- 说明 -->\r\n        <!--<view class=\"tool-desc\">\r\n            <p style=\"color:red;\">'使用上限'以下刀时的'使用上限'为计算标准</p>\r\n            <p style=\"color:red;\">寿命比预警值默认为90%</p>\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                activeToolNo: '', // 当前选中的刀具编号\r\n                pageIndex: 1,\r\n                pageSize: 20, //单页显示的刀具数量\r\n                total: 0,\r\n                toolList: [],\r\n                selectedToolNo: '',\r\n                toolName: '',\r\n                toolModel: '',\r\n                showToolDialog: false,\r\n                searchKey: '',\r\n                filteredTools: [],\r\n                useLimitInput: '',\r\n                lifeWarnInput: '', // 新增：寿命比预警值原始输入\r\n                toolRecords: [],\r\n                loadingTools: false,\r\n                loadingForm: false,\r\n                submitting: false,\r\n                _searchTimer: null,\r\n                workOrderCurrentCjNum: null, // 工单当前数采\r\n\r\n                // 自动保存相关\r\n                autoSaveTimer: null,\r\n                isDirty: false, // 表单是否有未保存变更\r\n                autoSaveIntervalMs: 5 * 60 * 1000, // 默认 5 分钟\r\n                autoSaveEnabled: true,\r\n                autoSaveActionName: 'handleUpTool', // 自动触发的方法名，可改为自定义保存方法\r\n\r\n                // 新增：调机相关字段\r\n                isTiaojiUserSelectShow: false, // 调机师傅选择弹窗\r\n                tiaojiStaffNo: '', // 当前选中的调机师傅(格式: 工号:姓名)\r\n                tiaojiOkQty: '', // 调机良品数\r\n                tiaojiBadQty: '', // 调机不良品数\r\n                tiaojiUsers: [], // 调机师傅列表\r\n                tiaojiUserSearch: '', // 搜索关键词\r\n                                \r\n                // 新增：报试产数所需字段\r\n                orderId: null, // 工单ID\r\n                order: {} // 工单数据\r\n            };\r\n        },\r\n        computed: {\r\n            totalPages() {\r\n                return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);\r\n            },\r\n            // 新增：调机师傅显示名称\r\n            tiaojiStaffDisplay() {\r\n                if (!this.tiaojiStaffNo) return '';\r\n                const segs = this.tiaojiStaffNo.split(':');\r\n                return segs.length > 1 ? `${segs[0]} ${segs[1]}` : this.tiaojiStaffNo;\r\n            },\r\n            // 新增：过滤后的调机师傅列表\r\n            filteredTiaojiUsers() {\r\n                if (!this.tiaojiUserSearch) return this.tiaojiUsers;\r\n                const kw = this.tiaojiUserSearch.trim().toLowerCase();\r\n                return this.tiaojiUsers.filter(u => u.toLowerCase().includes(kw));\r\n            }\r\n        },\r\n        watch: {\r\n            // 标记脏数据：按需监听字段变化\r\n            selectedToolNo() { this.isDirty = true; },\r\n            useLimitInput() { this.isDirty = true; },\r\n            lifeWarnInput() { this.isDirty = true; },\r\n            toolName() { this.isDirty = true; },\r\n            toolModel() { this.isDirty = true; }\r\n        },\r\n        methods: {\r\n            //查询当前数采数，作为下刀计数实时显示\r\n            async fetchCurrentCjNum(toolNo) {\r\n                if (!this.machineNo) return null;\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)) {\r\n                        const found = res.data.tbBillList.find(x =>\r\n                            x.cutterId === toolNo || x.cutteR_ID === toolNo\r\n                        );\r\n                        return found ? (found.CurrentCjNum ?? found.currentCjNum ?? null) : null;\r\n                    }\r\n                } catch (e) {\r\n                    console.warn('获取currentCjNum失败', e);\r\n                }\r\n                return null;\r\n            },\r\n\r\n            // 新增：刷新按钮处理方法\r\n            async handleRefresh() {\r\n                this.fetchTools('');\r\n                if (this.machineNo && this.workOrderNo) {\r\n                    await this.fetchFormData();\r\n                    await this.fetchDefaultToolFromWorkOrder();\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            startAutoSave() {\r\n                if (!this.autoSaveEnabled) return;\r\n                this.stopAutoSave();\r\n                this.autoSaveTimer = setInterval(() => {\r\n                    this.autoSaveTick();\r\n                }, this.autoSaveIntervalMs);\r\n            },\r\n            // 自动保存：停止\r\n            stopAutoSave() {\r\n                if (this.autoSaveTimer) {\r\n                    clearInterval(this.autoSaveTimer);\r\n                    this.autoSaveTimer = null;\r\n                }\r\n            },\r\n            // 自动保存：每次定时执行时的逻辑\r\n            async autoSaveTick() {\r\n                if (!this.autoSaveEnabled) return;\r\n                if (!this.isDirty) return;\r\n                if (this.submitting || this.loadingForm) return;\r\n\r\n                const fn = this.autoSaveActionName && typeof this[this.autoSaveActionName] === 'function'\r\n                    ? this[this.autoSaveActionName]\r\n                    : null;\r\n                if (!fn) {\r\n                    console.warn('自动保存：未找到方法', this.autoSaveActionName);\r\n                    return;\r\n                }\r\n\r\n                try {\r\n                    this.submitting = true;\r\n                    await fn.call(this); // 调用保存方法（例如 handleUpTool）\r\n                    // 如果保存成功，清脏标记（保存方法内部若失败没有抛出可保持此方式）\r\n                    this.isDirty = false;\r\n                } catch (e) {\r\n                    console.error('自动保存失败：', e);\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n\r\n            // 新增：寿命比预警值归一化 (返回 0~1 或 null)\r\n            normalizeLifeWarn(v) {\r\n                if (v == null) return null;\r\n                const raw = String(v).trim().replace(/[%％]/g, '');\r\n                if (raw === '') return null;\r\n                const num = Number(raw);\r\n                if (!isFinite(num) || num <= 0) return null;\r\n                return num > 1 ? (num / 100) : num;\r\n            },\r\n            openToolDialog() {\r\n                this.showToolDialog = true;\r\n                this.pageIndex = 1;\r\n                this.fetchTools(this.searchKey);\r\n            },\r\n            closeToolDialog() {\r\n                this.showToolDialog = false;\r\n            },\r\n            async fetchTools(searchKey) {\r\n                this.loadingTools = true;\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/QueryTools',\r\n                        data: JSON.stringify({\r\n                            searchKey,\r\n                            pageIndex: this.pageIndex,\r\n                            pageSize: this.pageSize\r\n                        }),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n\r\n                    if (res.status === 0) {\r\n                        const payload = 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                        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                        // 这里需要把 lifeWarn 字段也带出来\r\n                        const mapped = (payload || []).map(t => ({\r\n                            no: getField(t, 'cutterId', 'CUTTER_ID', 'cutteR_ID', 'daA001', 'no'),\r\n                            name: getField(t, 'cutterName', 'CUTTER_NAME', 'cutteR_NAME', 'name'),\r\n                            model: getField(t, 'cutterModel', 'CUTTER_MODEL', 'cutteR_MODEL', 'model'),\r\n                            lifeWarn: getField(t, 'modlLifeWorning', 'lifeWarn', 'LIFE_WARN', 'lifE_WARN')\r\n                        }));\r\n\r\n                        this.filteredTools = mapped;\r\n                        this.toolList = mapped.slice();\r\n\r\n                        const totalFromRes = Number(\r\n                            res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\r\n                        );\r\n                        this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\r\n                        if (this.pageIndex > this.totalPages) {\r\n                            this.pageIndex = this.totalPages;\r\n                        }\r\n                    } else {\r\n                        this.$showMessage(res.message || '查询失败');\r\n                    }\r\n                } catch (err) {\r\n                    console.error('fetchTools 错误：', err);\r\n                    this.$showMessage('查询刀具失败，请检查网络或接口');\r\n                } finally {\r\n                    this.loadingTools = false;\r\n                }\r\n            },\r\n            async prevPage() {\r\n                if (this.pageIndex > 1) {\r\n                    this.pageIndex--;\r\n                    await this.fetchTools(this.searchKey);\r\n                }\r\n            },\r\n            async nextPage() {\r\n                if (this.pageIndex < this.totalPages) {\r\n                    this.pageIndex++;\r\n                    await this.fetchTools(this.searchKey);\r\n                }\r\n            },\r\n            onSearchKeyInput() {\r\n                clearTimeout(this._searchTimer);\r\n                this._searchTimer = setTimeout(() => {\r\n                    this.searchTool();\r\n                }, 300);\r\n            },\r\n            async searchTool() {\r\n                this.pageIndex = 1;\r\n                await this.fetchTools(this.searchKey);\r\n            },\r\n            selectTool(tool) {\r\n                this.selectedToolNo = tool.no;\r\n                this.toolName = tool.name;\r\n                this.toolModel = tool.model;\r\n                this.activeToolNo = tool.no;\r\n                // 新增：带出寿命比预警值\r\n                if (tool.lifeWarn !== undefined && tool.lifeWarn !== null) {\r\n                    // 格式化为百分比字符串\r\n                    const warn = Number(tool.lifeWarn);\r\n                    this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\r\n                } else {\r\n                    this.lifeWarnInput = '';\r\n                }\r\n            },\r\n            confirmTool() {\r\n                this.showToolDialog = false;\r\n            },\r\n            async setUseLimit() {\r\n                if (!this.selectedToolNo) {\r\n                    this.$showMessage('请选择刀具后再设置上限');\r\n                    return;\r\n                }\r\n                const v = Number(this.useLimitInput);\r\n                if (isNaN(v) || v <= 0) {\r\n                    this.$showMessage('请输入有效的使用上限');\r\n                    return;\r\n                }\r\n                this.toolRecords = this.toolRecords.map(r => {\r\n                    if (r.no === this.selectedToolNo) {\r\n                        return { ...r, useLimit: v };\r\n                    }\r\n                    return r;\r\n                });\r\n                this.toolList = this.toolList.map(t => t.no === this.selectedToolNo ? { ...t, useLimit: v } : t);\r\n                this.$showMessage('使用上限已设置（仅前端显示）');\r\n            },\r\n            // 上刀时传递 sdjs = 工单 currentCjNum\r\n            async handleUpTool() {\r\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\r\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\r\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\r\n                //上刀强制录入使用上限\r\n                if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\r\n                const useLimit = Number(this.useLimitInput);\r\n                if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\r\n\r\n                // sdjs 使用工单 currentCjNum\r\n                const sdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\r\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\r\n                const payload = {\r\n                    workOrderNo: this.workOrderNo,\r\n                    machineNo: this.machineNo,\r\n                    toolNo: this.selectedToolNo,\r\n                    type: '上机',\r\n                    useLimit,\r\n                    sdjs,// 上刀计数（工单当前数采）\r\n                    modlLifeWorning: lifeWarnRatio // 新增\r\n                };\r\n                try {\r\n                    this.submitting = true;\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/SubmitToolAction',\r\n                        data: JSON.stringify(payload),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.data && res.data.outSum === \"0\") {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg || '',\r\n                            icon: 'error'\r\n                        });\r\n                        return;\r\n                    } else if (res.data && res.data.outMsg) {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg,\r\n                            icon: 'none'\r\n                        });\r\n                    }\r\n                    // 后续逻辑继续执行\r\n                    if (res.status === 0) {\r\n                        await this.fetchFormData();\r\n                    }\r\n                } catch (err) {\r\n                    console.error(err);\r\n                    this.$showMessage('上刀提交失败，请检查网络');\r\n                    throw err; // 抛出以便自动保存逻辑捕获并保留 isDirty\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n            // 下刀时传递 xdjs = 工单 currentCjNum\r\n            async handleDownTool() {\r\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\r\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\r\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\r\n                //下刀不强制录入使用上限\r\n                //if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\r\n                const useLimit = Number(this.useLimitInput);\r\n                //if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\r\n\r\n                // 下刀计数同样取工单最新采集数\r\n                const xdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\r\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\r\n                const payload = {\r\n                    workOrderNo: this.workOrderNo,\r\n                    machineNo: this.machineNo,\r\n                    toolNo: this.selectedToolNo,\r\n                    type: '下机',\r\n                    useLimit,\r\n                    xdjs,// 下刀计数\r\n                    modlLifeWorning: lifeWarnRatio // 新增\r\n                };\r\n                try {\r\n                    this.submitting = true;\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/SubmitToolAction',\r\n                        data: JSON.stringify(payload),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.data && res.data.outSum === \"0\") {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg || '',\r\n                            icon: 'error'\r\n                        });\r\n                        return;\r\n                    } else if (res.data && res.data.outMsg) {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg,\r\n                            icon: 'none'\r\n                        });\r\n                    }\r\n                    // 后续逻辑继续执行\r\n                    if (res.status === 0) {\r\n                        await this.fetchFormData();\r\n                    }\r\n                } catch (err) {\r\n                    console.error(err);\r\n                    this.$showMessage('下刀提交失败，请检查网络');\r\n                    throw err;\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n            cancel() {\r\n                this.selectedToolNo = '';\r\n                this.toolName = '';\r\n                this.toolModel = '';\r\n                this.useLimitInput = '';\r\n                this.lifeWarnInput = ''; // 新增：清空\r\n                this.isDirty = false;\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                    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                    // 新增：按上刀时间降序排序（越晚的越上面）\r\n                    mapped.sort((a, b) => {\r\n                        // 时间格式如 \"10-24 16:03\"，转为 Date 对象比较\r\n                        const parse = s => {\r\n                            if (!s) return 0;\r\n                            // 补年份，假设都是今年\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                    const totalFromRes = Number(\r\n                        res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\r\n                    );\r\n                    this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\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            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                        \r\n                        // 新增：保存工单数据，用于报试产数\r\n                        this.order = order;\r\n                        this.orderId = order.id || order.ID || order.orderId || null;\r\n                        \r\n                        this.selectedToolNo = order.cutterId || order.cutteR_ID || '';\r\n                        this.toolName = order.cutterName || order.cutteR_NAME || '';\r\n                        this.toolModel = order.cutterModel || order.cutteR_MODEL || '';\r\n                        // 关键：获取工单最新采集数\r\n                        this.workOrderCurrentCjNum = order.CurrentCjNum ?? order.currentCjNum ?? null;\r\n                        // 新增：自动填充寿命比预警值\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                        this.order = {};\r\n                        this.orderId = null;\r\n                    }\r\n                } catch (e) {\r\n                    console.warn('自动带出工单刀具失败', e);\r\n                    this.workOrderCurrentCjNum = null;\r\n                    this.order = {};\r\n                    this.orderId = null;\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            // 新增：选择调机师傅\r\n            selectTiaojiUser(u) {\r\n                this.tiaojiStaffNo = u;\r\n                this.isTiaojiUserSelectShow = false;\r\n                this.tiaojiUserSearch = '';\r\n            },\r\n            \r\n            // 新增：送检呼叫 + 报试产数\r\n            async handleInspectionCall() {\r\n                // 验证必填项\r\n                if (!this.tiaojiStaffNo) {\r\n                    this.$showMessage('请选择调机师傅');\r\n                    return;\r\n                }\r\n                \r\n                const okQty = Number(this.tiaojiOkQty);\r\n                const badQty = Number(this.tiaojiBadQty);\r\n                \r\n                if (isNaN(okQty) || okQty < 0) {\r\n                    this.$showMessage('请输入有效的调机良品数');\r\n                    return;\r\n                }\r\n                \r\n                if (isNaN(badQty) || badQty < 0) {\r\n                    this.$showMessage('请输入有效的调机不良品数');\r\n                    return;\r\n                }\r\n                \r\n                const staffNo = this.tiaojiStaffNo.split(':')[0];\r\n                const currentCjNum = this.order?.currentCjNum || 0;\r\n                \r\n                // 调用报试产数接口(使用报工界面的接口)\r\n                const payload = {\r\n                    orderNo: this.workOrderNo,\r\n                    orderId: this.orderId, // 需要从工单数据中获取\r\n                    bf: badQty, // bf传递不良品数\r\n                    staffNo: staffNo,\r\n                    initCjNum: currentCjNum - badQty - okQty, // initCjNum = currentCjNum - bf - 良品数\r\n                    currentCjNum: currentCjNum,\r\n                    type: 'tiaoji', // 标识为调机报工\r\n                    tiaojiOkQty: okQty, // 新增:良品数\r\n                    tiaojiBadQty: badQty // 新增:不良品数\r\n                };\r\n                \r\n                try {\r\n                    this.submitting = true;\r\n                    // 调用报工界面的报试产数接口\r\n                    const res = await this.$post({\r\n                        url: '/MesInvItemBarcodes/AddBFToBarcodes',\r\n                        data: payload\r\n                    });\r\n                    \r\n                    if (res.status == 1) {\r\n                        this.$showMessage(res.message);\r\n                        return;\r\n                    }\r\n                    \r\n                    this.$showMessage('调机报工成功');\r\n                    // 清空输入\r\n                    this.tiaojiOkQty = '';\r\n                    this.tiaojiBadQty = '';\r\n                    // 刷新数据\r\n                    await this.fetchFormData();\r\n                    await this.fetchDefaultToolFromWorkOrder();\r\n                    \r\n                    // 新增：自动处理调机送检界面的按钮逻辑\r\n                    await this.autoHandleMachineInspection();\r\n                } catch (err) {\r\n                    console.error('调机报工错误:', err);\r\n                    this.$showMessage('调机报工失败，请检查网络');\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n            \r\n            // 新增：自动处理调机送检界面的按钮逻辑\r\n            async autoHandleMachineInspection() {\r\n                try {\r\n                    // 1. 使用 FindByOrderNo 获取调机送检界面的三个时间\r\n                    const statusRes = await this.$post({\r\n                        url: '/MesOrderSta/FindByOrderNo',\r\n                        data: {\r\n                            orderId: this.orderId,\r\n                            orderNo: this.workOrderNo\r\n                        }\r\n                    });\r\n                    \r\n                    if (!statusRes || !statusRes.data || !statusRes.data.tbBillList) {\r\n                        console.error('获取工单状态失败');\r\n                        return;\r\n                    }\r\n                    \r\n                    const statusForm = statusRes.data.tbBillList;\r\n                    const maStartTime = statusForm.maStartTime;\r\n                    const maShoutTime = statusForm.maShoutTime;\r\n                    const maEndTime = statusForm.maEndTime;\r\n                    \r\n                    // 2. 准备需要更新的时间数据\r\n                    let needSave = false;\r\n                    let updateData = {\r\n                        id: statusForm.id,\r\n                        orderId: this.orderId,\r\n                        machineNo: this.machineNo,\r\n                        flag: -1\r\n                    };\r\n                    \r\n                    // 3. 从上到下根据显示框里是否有时间依次设置\r\n                    // 如果调机开始时间为空，设置调机开始时间\r\n                    if (!maStartTime) {\r\n                        updateData.maStartTime = this.$getDate('yyyy-mm-dd hh24:mi:ss');\r\n                        updateData.flag = -1; // 调机开始的flag=-1\r\n                        needSave = true;\r\n                    } else {\r\n                        updateData.maStartTime = maStartTime;\r\n                    }\r\n                    \r\n                    // 如果送检呼叫时间为空，设置送检呼叫时间\r\n                    if (!maShoutTime) {\r\n                        updateData.maShoutTime = this.$getDate('yyyy-mm-dd hh24:mi:ss');\r\n                        updateData.flag = 1; // 首次送检呼叫的flag=1\r\n                        needSave = true;\r\n                    } else {\r\n                        updateData.maShoutTime = maShoutTime;\r\n                    }\r\n                    \r\n                    // 调机完成时间保持不变\r\n                    updateData.maEndTime = maEndTime || '';\r\n                    \r\n                    // 4. 如果有需要更新的时间，调用保存接口\r\n                    if (needSave) {\r\n                        const saveRes = await this.$post({\r\n                            url: '/MesOrderSta/ChangeMachineTime',\r\n                            data: updateData\r\n                        });\r\n                        \r\n                        if (saveRes && saveRes.data && saveRes.data.tbBillList) {\r\n                            console.log('调机送检界面时间自动更新成功');\r\n                        } else {\r\n                            console.error('调机送检界面时间自动更新失败');\r\n                        }\r\n                    }\r\n                } catch (err) {\r\n                    console.error('自动处理调机送检界面失败:', err);\r\n                    // 不中断主流程，只记录错误\r\n                }\r\n            },\r\n            \r\n            // 新增：获取调机师傅列表\r\n            async fetchTiaojiStaff() {\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesStaff/GetAllXS0101BYtj' // 与报工界面使用相同接口\r\n                    });\r\n                    if (res.status === 0 && res.data && res.data.tbBillList) {\r\n                        const staff = res.data.tbBillList;\r\n                        this.tiaojiUsers = staff.map(s => s.staffNo + ':' + s.staffName);\r\n                    }\r\n                } catch (err) {\r\n                    console.error('获取调机师傅列表失败:', err);\r\n                }\r\n            }\r\n        },\r\n        mounted() {\r\n            this.fetchTools('');\r\n            this.machineNo = uni.getStorageSync('machineNo') || '';\r\n            this.workOrderNo = uni.getStorageSync('daa001') || '';\r\n            \r\n            // 新增：获取调机师傅列表\r\n            this.fetchTiaojiStaff();\r\n\r\n            if (this.machineNo && this.workOrderNo) {\r\n                this.fetchFormData().then(async () => {\r\n                    await this.fetchDefaultToolFromWorkOrder();\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            } else {\r\n                console.warn('机台号或工单号为空，无法获取表单数据');\r\n            }\r\n\r\n            // 启动自动保存定时器\r\n            //this.startAutoSave();\r\n        },\r\n        beforeDestroy() {\r\n            // 清理定时器，防止内存泄漏\r\n            this.stopAutoSave();\r\n        }\r\n    };\r\n</script>\r\n\r\n<style scoped>\r\n    .top-section-grid {\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: center;\r\n        align-items: flex-start;\r\n        gap: 12px;\r\n        margin-bottom: 2vh;\r\n        width: 99vw;\r\n        max-width: 1920px;\r\n        margin-left: auto;\r\n        margin-right: auto;\r\n        padding: 12px;\r\n        background: #f8f9fa;\r\n        border-radius: 8px;\r\n        border: 1px solid #e9ecef;\r\n    }\r\n\r\n    .form-row {\r\n        display: flex;\r\n        flex-direction: row;\r\n        justify-content: flex-start;\r\n        align-items: center;\r\n        width: 100%;\r\n        margin-bottom: 12px;\r\n    }\r\n\r\n        .form-row:last-child {\r\n            margin-bottom: 0;\r\n        }\r\n\r\n    .form-cell {\r\n        display: flex;\r\n        align-items: center;\r\n        min-width: 0;\r\n        margin-right: 0;\r\n    }\r\n\r\n        .form-cell:nth-child(1) {\r\n            flex: 0 0 28%;\r\n            min-width: 180px;\r\n        }\r\n\r\n        .form-cell:nth-child(2) {\r\n            flex: 0 0 32%;\r\n            min-width: 180px;\r\n            justify-content: flex-start;\r\n        }\r\n\r\n        .form-cell:nth-child(3) {\r\n            flex: 0 0 auto;\r\n            min-width: 0;\r\n            max-width: 220px; /* 限制最大宽度，避免撑开 */\r\n            justify-content: flex-end;\r\n        }\r\n\r\n    .form-label {\r\n        width: auto;\r\n        font-weight: 500;\r\n        color: #333;\r\n        white-space: nowrap;\r\n        margin-right: 4px;\r\n        flex-shrink: 0;\r\n        font-size: 22px;\r\n    }\r\n\r\n    .input {\r\n        padding: 14px 20px;\r\n        border: 1px solid #dcdfe6;\r\n        flex: 1;\r\n        margin-right: 0;\r\n        border-radius: 4px;\r\n        background: #fff;\r\n        min-width: 0;\r\n        height: 56px !important;\r\n        box-sizing: border-box;\r\n        font-size: 22px;\r\n    }\r\n\r\n        .input.small-font {\r\n            /* 不设置字体大小 */\r\n        }\r\n\r\n        .input:disabled {\r\n            background-color: #f5f7fa;\r\n            color: #c0c4cc;\r\n            cursor: not-allowed;\r\n        }\r\n\r\n    .input-with-unit {\r\n        display: flex;\r\n        align-items: center;\r\n        gap: 0;\r\n    }\r\n\r\n        .input-with-unit .input {\r\n            width: 60px !important;\r\n            min-width: 0 !important;\r\n            margin-right: 2px !important;\r\n            text-align: center;\r\n            padding-left: 2px;\r\n            padding-right: 2px;\r\n        }\r\n\r\n        .input-with-unit .input {\r\n            margin-right: 4px !important;\r\n            width: 60px !important;\r\n            min-width: 0 !important;\r\n            text-align: center;\r\n        }\r\n\r\n    .unit-text {\r\n        margin-left: 0 !important;\r\n        padding-left: 0 !important;\r\n        font-size: 22px !important;\r\n    }\r\n\r\n    .btn-blue, .btn-blue.large-btn {\r\n        background-color: #1890ff;\r\n        color: white;\r\n        border: none;\r\n        padding: 14px 32px;\r\n        border-radius: 4px;\r\n        cursor: pointer;\r\n        font-weight: 500;\r\n        white-space: nowrap;\r\n        height: 70px !important;\r\n        box-sizing: border-box;\r\n        transition: all 0.3s;\r\n        flex-shrink: 0;\r\n        min-width: 140px;\r\n        margin-left: 24px;\r\n    }\r\n\r\n        .btn-blue.large-btn {\r\n            padding: 0 60px;\r\n            min-width: 180px;\r\n            height: 72px !important;\r\n            margin-left: 0 !important;\r\n            font-size: 1.3em;\r\n            box-shadow: 0 2px 8px rgba(24,144,255,0.08);\r\n            line-height: 72px; /* 垂直居中 */\r\n            display: inline-block; /* 保证line-height生效 */\r\n            vertical-align: middle;\r\n        }\r\n\r\n        .btn-blue:hover {\r\n            background-color: #40a9ff;\r\n        }\r\n\r\n        .btn-blue:active {\r\n            background-color: #096dd9;\r\n        }\r\n\r\n        .btn-blue:disabled {\r\n            background: #bae7ff;\r\n            color: #91d5ff;\r\n            cursor: not-allowed;\r\n        }\r\n\r\n    .button-row {\r\n        display: flex;\r\n        justify-content: center;\r\n        gap: 32px;\r\n        margin: 2vh 0;\r\n    }\r\n\r\n    .save-btn, .cancel-btn {\r\n        width: 28%;\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    .cancel-btn {\r\n        background-color: #f5f5f5;\r\n        color: #333;\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, .cancel-btn:disabled {\r\n        opacity: 0.6;\r\n        cursor: not-allowed;\r\n    }\r\n\r\n    /* 弹窗样式 */\r\n    .dialog-overlay {\r\n        position: fixed;\r\n        top: 0;\r\n        left: 0;\r\n        right: 0;\r\n        bottom: 0;\r\n        background: rgba(0,0,0,0.18);\r\n        display: flex;\r\n        justify-content: center;\r\n        align-items: center;\r\n        z-index: 1000;\r\n    }\r\n\r\n    .dialog {\r\n        background: #fff;\r\n        padding: 3vh 3vw;\r\n        border-radius: 18px;\r\n        width: 90vw;\r\n        max-width: 1600px;\r\n        min-height: 70vh;\r\n        max-height: 85vh;\r\n        box-sizing: border-box;\r\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\r\n        display: flex;\r\n        flex-direction: column;\r\n    }\r\n\r\n    .form-group {\r\n        display: flex;\r\n        gap: 12px;\r\n        align-items: center;\r\n        margin-bottom: 2vh;\r\n        flex-shrink: 0;\r\n    }\r\n\r\n        .form-group .input {\r\n            flex: 1;\r\n            min-width: 300px;\r\n            border-radius: 6px;\r\n            background: #f8f8f8;\r\n        }\r\n\r\n    .tool-list {\r\n        display: flex;\r\n        flex-wrap: wrap;\r\n        margin: 1vh 0;\r\n        flex: 1;\r\n        overflow-y: auto;\r\n        gap: 12px;\r\n        align-content: flex-start;\r\n    }\r\n\r\n    .tool-btn {\r\n        flex: 0 0 calc(20% - 10px);\r\n        box-sizing: border-box;\r\n        padding: 10px 12px;\r\n        background: #f5f5f5;\r\n        border: 1px solid #d0d0d0;\r\n        border-radius: 8px;\r\n        cursor: pointer;\r\n        color: #333;\r\n        text-align: left;\r\n        min-height: 50px;\r\n        transition: background 0.15s, color 0.15s;\r\n        overflow: hidden;\r\n        text-overflow: ellipsis;\r\n        white-space: nowrap;\r\n        line-height: 1.4;\r\n    }\r\n\r\n        .tool-btn.active {\r\n            background: #00A2E9;\r\n            color: #fff;\r\n            font-weight: bold;\r\n            border: 1.5px solid #0086c2;\r\n        }\r\n\r\n    .dialog-actions {\r\n        display: flex;\r\n        justify-content: space-between;\r\n        align-items: center;\r\n        margin-top: 2vh;\r\n        padding-top: 2vh;\r\n        border-top: 1px solid #eee;\r\n        flex-shrink: 0;\r\n    }\r\n\r\n        .dialog-actions > div:first-child {\r\n            display: flex;\r\n            align-items: center;\r\n            gap: 24px;\r\n        }\r\n\r\n        .dialog-actions > div:last-child {\r\n            display: flex;\r\n            flex-direction: row;\r\n            gap: 18px;\r\n            align-items: center;\r\n        }\r\n\r\n        .dialog-actions .btn-blue {\r\n            padding: 10px 24px;\r\n            min-width: 120px;\r\n            font-size: 22px;\r\n        }\r\n\r\n    .btn-disabled {\r\n        background: #f2f2f2;\r\n        color: #999;\r\n        border: none;\r\n        padding: 10px 24px;\r\n        border-radius: 4px;\r\n        font-weight: 500;\r\n        cursor: not-allowed;\r\n        box-shadow: none;\r\n        min-width: 120px;\r\n    }\r\n\r\n    .table-section {\r\n        display: flex;\r\n        justify-content: center;\r\n        margin: 1vh 0;\r\n        overflow-x: auto;\r\n        width: 100%; /* 确保表格容器占满宽度 */\r\n    }\r\n\r\n    table.styled-table {\r\n        max-width: 1800px; /* 从1600px增加到1800px */\r\n        width: 98vw; /* 从95vw增加到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        border-radius: 12px;\r\n        overflow: hidden;\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        }\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-section table th:first-child, .table-section table td:first-child {\r\n        border-left: 2px solid #bfbfbf;\r\n    }\r\n\r\n    .table-section table th:last-child, .table-section table td:last-child {\r\n        border-right: 2px solid #bfbfbf;\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    .left {\r\n        text-align: left;\r\n        padding-left: 8px;\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    /* 响应式调整 */\r\n    @media (max-width: 1200px) {\r\n        .form-cell {\r\n            margin: 0 4px;\r\n        }\r\n\r\n        .form-label {\r\n            width: 90px;\r\n        }\r\n\r\n        .input {\r\n            padding: 10px 14px;\r\n        }\r\n\r\n        .btn-blue {\r\n            padding: 10px 18px;\r\n        }\r\n    }\r\n\r\n    .input-life-warn {\r\n        width: 48px !important; /* 稍微放宽，避免字体溢出 */\r\n        min-width: 0 !important;\r\n        margin-right: 4px;\r\n        padding-left: 2px;\r\n        padding-right: 2px;\r\n        font-size: 22px !important;\r\n        text-align: center;\r\n        box-sizing: border-box;\r\n    }\r\n\r\n    .input,\r\n    .input.small-font,\r\n    .input-use-limit,\r\n    .input-tool-model,\r\n    .input-tool-name,\r\n    .input-life-warn {\r\n        font-size: 22px !important;\r\n    }\r\n\r\n    .input-tool-model {\r\n        width: 320px !important; /* 原为200px，现加长 */\r\n        min-width: 0 !important;\r\n        margin-right: 16px;\r\n    }\r\n\r\n    .input-tool-name {\r\n        width: 120px !important;\r\n        min-width: 0 !important;\r\n        margin-right: 16px;\r\n    }\r\n\r\n    .highlight-label {\r\n        color: #1890ff !important;\r\n    }\r\n\r\n    .tool-dir-cell {\r\n        flex: 0 0 auto !important;\r\n        justify-content: flex-start !important;\r\n        display: flex !important;\r\n        align-items: center;\r\n        margin-left: 16px; /* 与规格型号输入框拉开距离 */\r\n    }\r\n\r\n    .form-cell-flex {\r\n        display: flex;\r\n        align-items: center;\r\n        flex: 0 0 60%;\r\n        min-width: 320px;\r\n    }\r\n\r\n        .form-cell-flex .form-label {\r\n            margin-right: 4px;\r\n            width: auto;\r\n        }\r\n\r\n        .form-cell-flex .input-use-limit {\r\n            margin-right: 12px;\r\n        }\r\n\r\n    .input-use-limit {\r\n        width: 450px !important;\r\n        min-width: 0 !important;\r\n        margin-right: 16px;\r\n        flex: none !important; /* 关键：彻底禁止flex拉伸 */\r\n    }\r\n\r\n    /* 新增：调机区域样式 */\r\n    .tiaoji-section {\r\n        width: 100%;\r\n        margin: 2vh 0;\r\n        padding: 20px;\r\n        background: #f8f9fa;\r\n        border-radius: 8px;\r\n        border: 1px solid #e9ecef;\r\n    }\r\n\r\n    .tiaoji-row {\r\n        display: flex;\r\n        flex-wrap: wrap;\r\n        align-items: center;\r\n        gap: 20px;\r\n    }\r\n\r\n    /* 当前调机师傅区域 - 与报工界面保持一致 */\r\n    .current-user-section {\r\n        display: flex;\r\n        align-items: center;\r\n        font-size: 22px;\r\n        border: 1.5px solid #f00;\r\n        border-radius: 10px;\r\n        padding: 14px 22px;\r\n        background: #fff;\r\n        gap: 14px;\r\n        flex: 0 0 auto;\r\n    }\r\n\r\n    .current-user-name {\r\n        font-weight: bold;\r\n        font-size: 22px;\r\n    }\r\n\r\n    /* 选人按钮 - 蓝色主题，与报工界面保持一致 */\r\n    .select-user-btn {\r\n        background: #00a2e9;\r\n        color: #fff;\r\n        border: none;\r\n        padding: 12px 22px;\r\n        border-radius: 12px;\r\n        font-size: 22px;\r\n        cursor: pointer;\r\n        transition: background 0.15s;\r\n        height: 66px;\r\n        box-sizing: border-box;\r\n        display: flex;\r\n        align-items: center;\r\n        justify-content: center;\r\n    }\r\n\r\n        .select-user-btn:hover {\r\n            background: #008ac2;\r\n        }\r\n\r\n    /* 调机数量输入区域 */\r\n    .tiaoji-input-section {\r\n        display: flex;\r\n        align-items: center;\r\n        gap: 14px;\r\n        font-size: 22px;\r\n    }\r\n\r\n    .tiaoji-input {\r\n        width: 200px;\r\n        max-width: 100%;\r\n        height: 66px;\r\n        border: 2px solid #808080;\r\n        font-size: 28px;\r\n        text-align: center;\r\n        border-radius: 8px;\r\n        box-sizing: border-box;\r\n    }\r\n\r\n    /* 送检呼叫按钮 - 与报工界面的确认提交按钮保持一致 */\r\n    .details-btn {\r\n        padding: 12px 34px;\r\n        background: #00a2e9;\r\n        color: #fff;\r\n        font-size: 32px;\r\n        border: none;\r\n        cursor: pointer;\r\n        border-radius: 12px;\r\n        height: 66px;\r\n        min-width: 180px;\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: center;\r\n        align-items: center;\r\n        line-height: 1.1;\r\n        box-sizing: border-box;\r\n        transition: background 0.15s;\r\n    }\r\n\r\n        .details-btn:hover {\r\n            background: #008ac2;\r\n        }\r\n\r\n        .details-btn:disabled {\r\n            opacity: 0.6;\r\n            cursor: not-allowed;\r\n            background: #bae7ff;\r\n        }\r\n\r\n    .tiaoji-submit-section {\r\n        display: flex;\r\n        align-items: center;\r\n    }\r\n\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: rgba(0,0,0,.45);\r\n        display: flex;\r\n        justify-content: center;\r\n        align-items: center;\r\n        z-index: 1000;\r\n    }\r\n\r\n    .user-select-popup {\r\n        background: #fff;\r\n        width: 1600px;\r\n        max-width: 99vw;\r\n        min-width: 1000px;\r\n        height: auto;\r\n        min-height: 520px;\r\n        padding: 0;\r\n        display: flex;\r\n        flex-direction: column;\r\n        font-size: 32px;\r\n        border-radius: 12px;\r\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\r\n        z-index: 1001;\r\n    }\r\n\r\n    .user-search-bar {\r\n        display: flex;\r\n        align-items: center;\r\n        gap: 18px;\r\n        padding: 24px 64px 0 64px;\r\n        background: #fff;\r\n        flex-wrap: wrap;\r\n    }\r\n\r\n    .user-search-input {\r\n        flex: 1 1 260px;\r\n        padding: 16px 20px;\r\n        font-size: 28px;\r\n        border: 1px solid #bbb;\r\n        border-radius: 8px;\r\n        outline: none;\r\n        height: 54px;\r\n    }\r\n\r\n        .user-search-input:focus {\r\n            border-color: #007aff;\r\n            box-shadow: 0 0 0 2px rgba(0,122,255,.15);\r\n        }\r\n\r\n    .user-search-clear {\r\n        padding: 12px 28px;\r\n        background: #ff9f43;\r\n        color: #fff;\r\n        border: none;\r\n        border-radius: 8px;\r\n        font-size: 24px;\r\n        cursor: pointer;\r\n    }\r\n\r\n        .user-search-clear:hover {\r\n            background: #ff8920;\r\n        }\r\n\r\n    .user-search-info {\r\n        font-size: 22px;\r\n        color: #555;\r\n    }\r\n\r\n    .user-list-scroll {\r\n        flex: 1 1 auto;\r\n        overflow-y: auto;\r\n        padding: 32px 64px 0 64px;\r\n    }\r\n\r\n    .user-list-grid {\r\n        display: grid;\r\n        grid-template-columns: repeat(auto-fill,minmax(200px,1fr));\r\n        gap: 22px 22px;\r\n    }\r\n\r\n    .user-list-btn {\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: center;\r\n        align-items: center;\r\n        gap: 2px;\r\n        padding: 10px 10px;\r\n        height: 100px;\r\n        font-size: 30px;\r\n        background: #00a2e9;\r\n        color: #fff;\r\n        border: none;\r\n        border-radius: 8px;\r\n        cursor: pointer;\r\n        box-sizing: border-box;\r\n        word-break: break-word;\r\n    }\r\n\r\n        .user-list-btn .user-code {\r\n            font-weight: 700;\r\n            font-size: 36px;\r\n            line-height: 1.1;\r\n        }\r\n\r\n        .user-list-btn .user-name {\r\n            font-size: 32px;\r\n            line-height: 1.1;\r\n        }\r\n\r\n        .user-list-btn.selected {\r\n            background: #0072c9;\r\n            box-shadow: 0 0 0 3px rgba(255,255,255,.6) inset;\r\n        }\r\n\r\n        .user-list-btn:hover {\r\n            background: #008ed0;\r\n        }\r\n\r\n    .no-user-result {\r\n        padding: 40px 0;\r\n        text-align: center;\r\n        font-size: 28px;\r\n        color: #666;\r\n    }\r\n\r\n    .user-popup-footer {\r\n        flex-shrink: 0;\r\n        padding: 24px 64px 32px 64px;\r\n        background: #fff;\r\n        text-align: center;\r\n    }\r\n\r\n    .clean-btn {\r\n        width: 24%;\r\n        padding: 10px 0;\r\n        color: #fff;\r\n        font-size: 20px;\r\n        border: none;\r\n        text-align: center;\r\n        cursor: pointer;\r\n        border-radius: 0.6vw;\r\n        background: #007aff;\r\n    }\r\n\r\n        .clean-btn.wide-btn {\r\n            width: 30%;\r\n            font-size: 22px;\r\n            padding: 12px 0;\r\n        }\r\n\r\n        .clean-btn:hover {\r\n            background: #0062c9;\r\n        }\r\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;\n        var okQty, badQty, staffNo, currentCjNum, 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                currentCjNum = ((_this15$order = _this15.order) === null || _this15$order === void 0 ? void 0 : _this15$order.currentCjNum) || 0; // 璋冪敤鎶ヨ瘯浜ф暟鎺ュ彛(浣跨敤鎶ュ伐鐣岄潰鐨勬帴鍙�)\n                payload = {\n                  orderNo: _this15.workOrderNo,\n                  orderId: _this15.orderId,\n                  // 闇�瑕佷粠宸ュ崟鏁版嵁涓幏鍙朶n                  bf: badQty,\n                  // bf浼犻�掍笉鑹搧鏁癨n                  staffNo: staffNo,\n                  initCjNum: currentCjNum - badQty - okQty,\n                  // initCjNum = currentCjNum - bf - 鑹搧鏁癨n                  currentCjNum: currentCjNum,\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 = 31;\n                return _this15.autoHandleMachineInspection();\n              case 31:\n                _context13.next = 37;\n                break;\n              case 33:\n                _context13.prev = 33;\n                _context13.t0 = _context13[\"catch\"](14);\n                __f__(\"error\", '璋冩満鎶ュ伐閿欒:', _context13.t0, \" at components/mold.vue:874\");\n                _this15.$showMessage('璋冩満鎶ュ伐澶辫触锛岃妫�鏌ョ綉缁�');\n              case 37:\n                _context13.prev = 37;\n                _this15.submitting = false;\n                return _context13.finish(37);\n              case 40:\n              case \"end\":\n                return _context13.stop();\n            }\n          }\n        }, _callee13, null, [[14, 33, 37, 40]]);\n      }))();\n    },\n    // 鏂板锛氳嚜鍔ㄥ鐞嗚皟鏈洪�佹鐣岄潰鐨勬寜閽�昏緫\n    autoHandleMachineInspection: function autoHandleMachineInspection() {\n      var _this16 = this;\n      return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee14() {\n        var statusRes, statusForm, maStartTime, maShoutTime, maEndTime, needSave, updateData, actions, saveRes, successMsg, failMsg;\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: '/MesOrderSta/FindByOrderNo',\n                  data: {\n                    orderId: _this16.orderId,\n                    orderNo: _this16.workOrderNo\n                  }\n                });\n              case 3:\n                statusRes = _context14.sent;\n                if (!(!statusRes || !statusRes.data || !statusRes.data.tbBillList)) {\n                  _context14.next = 8;\n                  break;\n                }\n                __f__(\"error\", '鑾峰彇宸ュ崟鐘舵�佸け璐�', \" at components/mold.vue:894\");\n                _this16.$showMessage('鑾峰彇宸ュ崟鐘舵�佸け璐�');\n                return _context14.abrupt(\"return\");\n              case 8:\n                statusForm = statusRes.data.tbBillList;\n                maStartTime = statusForm.maStartTime;\n                maShoutTime = statusForm.maShoutTime;\n                maEndTime = statusForm.maEndTime; // 2. 鍑嗗闇�瑕佹洿鏂扮殑鏃堕棿鏁版嵁\n                needSave = false;\n                updateData = {\n                  id: statusForm.id,\n                  orderId: _this16.orderId,\n                  machineNo: _this16.machineNo,\n                  flag: -1\n                }; // 璁板綍鍝簺鎿嶄綔琚墽琛屼簡\n                actions = []; // 3. 浠庝笂鍒颁笅鏍规嵁鏄剧ず妗嗛噷鏄惁鏈夋椂闂翠緷娆¤缃甛n                // 濡傛灉璋冩満寮�濮嬫椂闂翠负绌猴紝璁剧疆璋冩満寮�濮嬫椂闂碶n                if (!maStartTime) {\n                  updateData.maStartTime = _this16.$getDate('yyyy-mm-dd hh24:mi:ss');\n                  updateData.flag = -1; // 璋冩満寮�濮嬬殑flag=-1\n                  needSave = true;\n                  actions.push('璋冩満寮�濮�');\n                } else {\n                  updateData.maStartTime = maStartTime;\n                }\n\n                // 濡傛灉閫佹鍛煎彨鏃堕棿涓虹┖锛岃缃�佹鍛煎彨鏃堕棿\n                if (!maShoutTime) {\n                  updateData.maShoutTime = _this16.$getDate('yyyy-mm-dd hh24:mi:ss');\n                  updateData.flag = 1; // 棣栨閫佹鍛煎彨鐨刦lag=1\n                  needSave = true;\n                  actions.push('閫佹鍛煎彨');\n                } else {\n                  updateData.maShoutTime = maShoutTime;\n                }\n\n                // 璋冩満瀹屾垚鏃堕棿淇濇寔涓嶅彉\n                updateData.maEndTime = maEndTime || '';\n\n                // 4. 濡傛灉鏈夐渶瑕佹洿鏂扮殑鏃堕棿锛岃皟鐢ㄤ繚瀛樻帴鍙n                if (!needSave) {\n                  _context14.next = 25;\n                  break;\n                }\n                _context14.next = 21;\n                return _this16.$post({\n                  url: '/MesOrderSta/ChangeMachineTime',\n                  data: updateData\n                });\n              case 21:\n                saveRes = _context14.sent;\n                if (saveRes && saveRes.data && saveRes.data.tbBillList) {\n                  successMsg = actions.join('銆�') + '鎴愬姛';\n                  _this16.$showMessage(successMsg);\n                  __f__(\"log\", '璋冩満閫佹鐣岄潰鏃堕棿鑷姩鏇存柊鎴愬姛:', actions, \" at components/mold.vue:950\");\n                } else {\n                  failMsg = actions.join('銆�') + '澶辫触';\n                  _this16.$showMessage(failMsg);\n                  __f__(\"error\", '璋冩満閫佹鐣岄潰鏃堕棿鑷姩鏇存柊澶辫触', \" at components/mold.vue:954\");\n                }\n                _context14.next = 27;\n                break;\n              case 25:\n                // 鎵�鏈夋椂闂撮兘宸插瓨鍦紝鏃犻渶鏇存柊\n                _this16.$showMessage('璋冩満寮�濮嬪拰閫佹鍛煎彨宸插畬鎴�');\n                __f__(\"log\", '璋冩満寮�濮嬪拰閫佹鍛煎彨鏃堕棿宸插瓨鍦紝鏃犻渶鏇存柊', \" at components/mold.vue:959\");\n              case 27:\n                _context14.next = 33;\n                break;\n              case 29:\n                _context14.prev = 29;\n                _context14.t0 = _context14[\"catch\"](0);\n                __f__(\"error\", '鑷姩澶勭悊璋冩満閫佹鐣岄潰澶辫触:', _context14.t0, \" at components/mold.vue:962\");\n                _this16.$showMessage('鑷姩澶勭悊璋冩満閫佹澶辫触');\n                // 涓嶄腑鏂富娴佺▼锛屽彧璁板綍閿欒\n              case 33:\n              case \"end\":\n                return _context14.stop();\n            }\n          }\n        }, _callee14, null, [[0, 29]]);\n      }))();\n    },\n    // 鏂板锛氳幏鍙栬皟鏈哄笀鍌呭垪琛╘n    fetchTiaojiStaff: function fetchTiaojiStaff() {\n      var _this17 = this;\n      return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee15() {\n        var res, staff;\n        return _regenerator.default.wrap(function _callee15$(_context15) {\n          while (1) {\n            switch (_context15.prev = _context15.next) {\n              case 0:\n                _context15.prev = 0;\n                _context15.next = 3;\n                return _this17.$post({\n                  url: '/MesStaff/GetAllXS0101BYtj' // 涓庢姤宸ョ晫闈娇鐢ㄧ浉鍚屾帴鍙n                });\n              case 3:\n                res = _context15.sent;\n                if (res.status === 0 && res.data && res.data.tbBillList) {\n                  staff = res.data.tbBillList;\n                  _this17.tiaojiUsers = staff.map(function (s) {\n                    return s.staffNo + ':' + s.staffName;\n                  });\n                }\n                _context15.next = 10;\n                break;\n              case 7:\n                _context15.prev = 7;\n                _context15.t0 = _context15[\"catch\"](0);\n                __f__(\"error\", '鑾峰彇璋冩満甯堝倕鍒楄〃澶辫触:', _context15.t0, \" at components/mold.vue:979\");\n              case 10:\n              case \"end\":\n                return _context15.stop();\n            }\n          }\n        }, _callee15, null, [[0, 7]]);\n      }))();\n    }\n  },\n  mounted: function mounted() {\n    var _this18 = 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 _callee16() {\n        return _regenerator.default.wrap(function _callee16$(_context16) {\n          while (1) {\n            switch (_context16.prev = _context16.next) {\n              case 0:\n                _context16.next = 2;\n                return _this18.fetchDefaultToolFromWorkOrder();\n              case 2:\n                // 杩涘叆椤甸潰鏃惰祴鍊肩涓�琛� currentCjNum\n                if (_this18.toolRecords.length > 0) {\n                  _this18.$set(_this18.toolRecords[0], 'currentCjNum', _this18.workOrderCurrentCjNum);\n                }\n              case 3:\n              case \"end\":\n                return _context16.stop();\n            }\n          }\n        }, _callee16);\n      })));\n    } else {\n      __f__(\"warn\", '鏈哄彴鍙锋垨宸ュ崟鍙蜂负绌猴紝鏃犳硶鑾峰彇琛ㄥ崟鏁版嵁', \" at components/mold.vue:1000\");\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","orderNo","bf","initCjNum","autoHandleMachineInspection","statusRes","statusForm","maStartTime","maShoutTime","maEndTime","needSave","updateData","flag","actions","saveRes","successMsg","failMsg","fetchTiaojiStaff","staff","mounted","beforeDestroy"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAsPA;EACAA;IACA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;;MAEA;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MAAA;;MAEA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;;MAEA;MACAC;MAAA;MACAC;IACA;EACA;;EACAC;IACAC;MACA;IACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACA;IACAC;MACA;MACA;MACA;QAAA;MAAA;IACA;EACA;EACAC;IACA;IACA/B;MAAA;IAAA;IACAM;MAAA;IAAA;IACAC;MAAA;IAAA;IACAN;MAAA;IAAA;IACAC;MAAA;IAAA;EACA;EACA8B;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAC;kBACA1C;oBAAAC;kBAAA;kBACA0C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACAC;kBAAA,OACAC;gBAAA,EACA;gBAAA,iCACAD;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;cAAA;gBAAA,iCAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IAEA;IACAE;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBACA;gBACA;kBACA;gBACA;cAAA;gBAEA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACA;IACAC;MAAA;MACA;MACA;MACA;QACA;MACA;IACA;IACA;IACAC;MACA;QACAC;QACA;MACA;IACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBAAA;cAAA;gBAEAC,4FACA,oCACA;gBAAA,IACAA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAAA;gBAKA;gBAAA;gBAAA,OACAA;cAAA;gBAAA;gBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBAAA;gBAAA;gBAAA,OAEA;kBACAd;kBACA1C;oBACAY;oBACAR;oBACAC;kBACA;kBACAsC;oBAAA;kBAAA;gBACA;cAAA;gBARAC;gBAUA;kBACAa,+CACAb,wDACAA,4CACA;kBAEAc;oBAAA;sBAAAC;oBAAA;oBACA;sBAAA;sBAAA;oBAAA;oBACA;kBACA,GAEA;kBACAC;oBAAA;sBACAC;sBACAC;sBACAC;sBACAC;oBACA;kBAAA;kBAEA;kBACA;kBAEAC,kFACArB,8XACA;kBACA;kBACA;oBACA;kBACA;gBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAsB;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;gBAAA,OACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAC;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;gBAAA,OACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACAC;MAAA;MACAC;MACA;QACA;MACA;IACA;IACAC;MAAA;MAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBAAA;gBAAA,OACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGAC;gBAAA,MACAC;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;kBACA;oBACA;sBAAAC;oBAAA;kBACA;kBACA;gBACA;gBACA;kBAAA;oBAAAA;kBAAA;gBAAA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IAEA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBACAD;gBAAA,MACAD;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAEA;gBACAG;gBACAC;gBACAtB;kBACAvD;kBACAD;kBACA+E;kBACAC;kBACAL;kBACAE;kBAAA;kBACAI;gBACA;gBAAA;gBAEA;gBAAA;gBAAA,OACA;kBACAxC;kBACA1C;kBACA2C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACAuC;kBACAC;kBACAC;gBACA;gBAAA;cAAA;gBAEA;kBACAF;oBACAC;oBACAC;kBACA;gBACA;cAAA;gBAAA,MAEAzC;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;gBACA;gBAAA;cAAA;gBAAA;gBAGA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACA;IACA0C;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBAAA,IACA;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA;cAAA;gBACA;gBACA;gBACAV,0CACA;gBAEA;gBACAW;gBACAR;gBACAtB;kBACAvD;kBACAD;kBACA+E;kBACAC;kBACAL;kBACAW;kBAAA;kBACAL;gBACA;gBAAA;gBAEA;gBAAA;gBAAA,OACA;kBACAxC;kBACA1C;kBACA2C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACAuC;kBACAC;kBACAC;gBACA;gBAAA;cAAA;gBAEA;kBACAF;oBACAC;oBACAC;kBACA;gBACA;cAAA;gBAAA,MAEAzC;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;gBACA;gBAAA;cAAA;gBAAA;gBAGA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IACA4C;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA,MACA;kBAAA;kBAAA;gBAAA;gBACA;gBAAA;cAAA;gBAGA;gBACAhC;kBACAvD;kBACAD;gBACA;gBAAA;gBAAA;gBAAA,OAEA;kBACAyC;kBACA1C;kBACA2C;oBAAA;kBAAA;gBACA;cAAA;gBAJAC;gBAAA,MAKAA;kBAAA;kBAAA;gBAAA;gBACA;gBACA;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;gBACAR,kIAEA;gBACA3C;kBACAoD;kBACA5E;kBAAA;kBACA6E;kBAAA;kBACAF;kBACAG;kBAAA;kBACAX;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,OAGA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAEA;gBACA;cAAA;gBAAA;gBAEA;gBAAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAoE;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA;gBAAA,OAGA;kBACAtE;kBACA1C;oBACAiC;oBACA4E;kBACA;gBACA;cAAA;gBANAI;gBAAA,MAQA;kBAAA;kBAAA;gBAAA;gBACA;gBACA;gBAAA;cAAA;gBAIAC;gBACAC;gBACAC;gBACAC,kCAEA;gBACAC;gBACAC;kBACA1B;kBACA5D;kBACAhC;kBACAuH;gBACA,GAEA;gBACAC,cAEA;gBACA;gBACA;kBACAF;kBACAA;kBACAD;kBACAG;gBACA;kBACAF;gBACA;;gBAEA;gBACA;kBACAA;kBACAA;kBACAD;kBACAG;gBACA;kBACAF;gBACA;;gBAEA;gBACAA;;gBAEA;gBAAA,KACAD;kBAAA;kBAAA;gBAAA;gBAAA;gBAAA,OACA;kBACA5E;kBACA1C;gBACA;cAAA;gBAHA0H;gBAKA;kBACAC;kBACA;kBACA;gBACA;kBACAC;kBACA;kBACA;gBACA;gBAAA;gBAAA;cAAA;gBAEA;gBACA;gBACA;cAAA;gBAAA;gBAAA;cAAA;gBAAA;gBAAA;gBAGA;gBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAEA;IAEA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA;gBAAA,OAEA;kBACAnF;gBACA;cAAA;gBAFAE;gBAGA;kBACAkF;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>\r\n    <view class=\"page\">\r\n        <!-- 刀具选择区 -->\r\n        <view class=\"top-section-grid\">\r\n            <!-- 第一行：移除刀具目录按钮 -->\r\n            <view class=\"form-row\">\r\n                <view class=\"form-cell\">\r\n                    <label class=\"form-label\">刀具编号：</label>\r\n                    <input class=\"input small-font\" v-model=\"selectedToolNo\" placeholder=\"请通过刀具目录选择\" disabled />\r\n                </view>\r\n                <view class=\"form-cell form-cell-flex\">\r\n                    <label class=\"form-label highlight-label\">使用上限：</label>\r\n                    <input class=\"input small-font input-use-limit\" type=\"number\" v-model=\"useLimitInput\" placeholder=\"每次上刀时手填上限\" :disabled=\"!selectedToolNo || loadingForm\" />\r\n                    <label class=\"form-label\" style=\"margin-left:16px;\">寿命比预警值：</label>\r\n                    <view class=\"input-with-unit\">\r\n                        <input class=\"input small-font input-life-warn\"\r\n                               v-model=\"lifeWarnInput\"\r\n                               placeholder=\"如90\"\r\n                               :disabled=\"!selectedToolNo || loadingForm\" />\r\n                        <span class=\"unit-text\">%</span>\r\n                    </view>\r\n                </view>\r\n            </view>\r\n\r\n            <!-- 第二行：在最后添加刀具目录按钮 -->\r\n            <view class=\"form-row\">\r\n                <!-- 刀具名称 -->\r\n                <view class=\"form-cell\">\r\n                    <label class=\"form-label\">刀具名称：</label>\r\n                    <input class=\"input small-font input-tool-name\" v-model=\"toolName\" placeholder=\"刀具带出\" disabled />\r\n                </view>\r\n                <!-- 规格型号 -->\r\n                <view class=\"form-cell\">\r\n                    <label class=\"form-label\">规格型号：</label>\r\n                    <input class=\"input small-font input-tool-model\" v-model=\"toolModel\" placeholder=\"刀具带出\" disabled />\r\n                </view>\r\n                <!-- 刀具目录按钮右移 -->\r\n                <view class=\"form-cell tool-dir-cell\">\r\n                    <button class=\"btn-blue large-btn\" @click=\"openToolDialog\" :disabled=\"loadingTools\">刀具目录</button>\r\n                </view>\r\n                <!-- 新增：刷新按钮 -->\r\n                <view class=\"form-cell\" style=\"flex:0 0 auto; margin-left:16px;\">\r\n                    <button class=\"btn-blue large-btn\" @click=\"handleRefresh\" :disabled=\"loadingForm || submitting\">刷新</button>\r\n                </view>\r\n            </view>\r\n        </view>  <!-- 这里闭合 top-section-grid -->\r\n        <!-- 操作按钮 - 移出 top-section-grid -->\r\n        <view class=\"button-row\">\r\n            <button class=\"save-btn\" @click=\"handleUpTool\" :disabled=\"submitting || loadingForm\">上刀提交</button>\r\n            <button class=\"save-btn\" @click=\"handleDownTool\" :disabled=\"submitting || loadingForm\">下刀提交</button>\r\n            <button class=\"cancel-btn\" @click=\"cancel\" :disabled=\"submitting || loadingForm\">清空刀具选择</button>\r\n        </view>\r\n\r\n        <!-- 新增：调机数据输入区域 -->\r\n        <view class=\"tiaoji-section\">\r\n            <view class=\"tiaoji-row\">\r\n                <!-- 当前调机师傅 -->\r\n                <view class=\"current-user-section\">\r\n                    <text>当前调机师傅：</text>\r\n                    <text class=\"current-user-name\">{{ tiaojiStaffDisplay || '未选择' }}</text>\r\n                    <button class=\"select-user-btn\" @click=\"isTiaojiUserSelectShow = true\">选人</button>\r\n                </view>\r\n\r\n                <!-- 调机良品数 -->\r\n                <view class=\"tiaoji-input-section\">\r\n                    <text>调机良品数：</text>\r\n                    <input v-model=\"tiaojiOkQty\" class=\"inp tiaoji-input\" type=\"number\" placeholder=\"请输入数量\" />\r\n                </view>\r\n\r\n                <!-- 调机不良品数 -->\r\n                <view class=\"tiaoji-input-section\">\r\n                    <text>调机不良品数：</text>\r\n                    <input v-model=\"tiaojiBadQty\" class=\"inp tiaoji-input\" type=\"number\" placeholder=\"请输入数量\" />\r\n                </view>\r\n\r\n                <!-- 送检呼叫按钮 -->\r\n                <view class=\"tiaoji-submit-section\">\r\n                    <button class=\"details-btn\" @click=\"handleInspectionCall\">送检呼叫</button>\r\n                </view>\r\n            </view>\r\n        </view>\r\n\r\n        <!-- 选择调机师傅弹窗 -->\r\n        <view v-if=\"isTiaojiUserSelectShow\" class=\"overlay\">\r\n            <view class=\"popup user-select-popup\">\r\n                <!-- 搜索栏 -->\r\n                <view class=\"user-search-bar\">\r\n                    <input v-model.trim=\"tiaojiUserSearch\"\r\n                           type=\"text\"\r\n                           class=\"user-search-input\"\r\n                           placeholder=\"输入工号或姓名搜索\"\r\n                           @keydown.enter.prevent />\r\n                    <button v-if=\"tiaojiUserSearch\" class=\"user-search-clear\" @click=\"tiaojiUserSearch=''\">清空</button>\r\n                    <view class=\"user-search-info\">\r\n                        匹配：{{ filteredTiaojiUsers.length }} / {{ tiaojiUsers.length }}\r\n                    </view>\r\n                </view>\r\n                <view class=\"user-list-scroll\">\r\n                    <template v-if=\"filteredTiaojiUsers.length\">\r\n                        <view class=\"user-list-grid\">\r\n                            <button v-for=\"(u, index) in filteredTiaojiUsers\"\r\n                                    :key=\"index\"\r\n                                    :class=\"['user-list-btn', {'selected': u===tiaojiStaffNo}]\"\r\n                                    @click=\"selectTiaojiUser(u)\">\r\n                                <span class=\"user-code\">{{ u.split(':')[0] }}</span>\r\n                                <span class=\"user-name\">{{ u.split(':')[1] }}</span>\r\n                            </button>\r\n                        </view>\r\n                    </template>\r\n                    <view v-else class=\"no-user-result\">\r\n                        未找到匹配人员\r\n                    </view>\r\n                </view>\r\n                <view class=\"user-popup-footer\">\r\n                    <button class=\"clean-btn wide-btn\" @click=\"isTiaojiUserSelectShow = false\">关闭</button>\r\n                </view>\r\n            </view>\r\n        </view>\r\n\r\n        <!-- 刀具目录弹窗 -->\r\n        <view v-if=\"showToolDialog\" class=\"dialog-overlay\">\r\n            <view class=\"dialog\">\r\n                <view class=\"form-group\">\r\n                    <input v-model=\"searchKey\" placeholder=\"输入刀具编码、名称模糊搜索\" class=\"input\" @input=\"onSearchKeyInput\" />\r\n                    <button class=\"btn-blue\" @click=\"searchTool\" :disabled=\"loadingTools\">搜索</button>\r\n                </view>\r\n                <view class=\"tool-list\">\r\n                    <button v-for=\"tool in filteredTools\"\r\n                            :key=\"tool.no\"\r\n                            class=\"tool-btn\"\r\n                            :class=\"{ active: activeToolNo === tool.no }\"\r\n                            @click=\"selectTool(tool)\">\r\n                        {{ tool.no }} | {{ tool.name }}\r\n                    </button>\r\n                </view>\r\n                <view class=\"dialog-actions\">\r\n                    <div style=\"display: flex; align-items: center;\">\r\n                        <button class=\"btn-blue\" @click=\"prevPage\" :disabled=\"pageIndex === 1 || loadingTools\">上一页</button>\r\n                        <span style=\"margin: 0 12px;\">第{{ pageIndex }}页 / 共{{ totalPages }}页</span>\r\n                        <button class=\"btn-blue\" @click=\"nextPage\" :disabled=\"pageIndex === totalPages || loadingTools\">下一页</button>\r\n                    </div>\r\n                    <div style=\"display: flex; gap: 18px; align-items: center;\">\r\n                        <button class=\"btn-blue\" @click=\"confirmTool\">确定</button>\r\n                        <button class=\"btn-disabled\" @click=\"closeToolDialog\">取消</button>\r\n                    </div>\r\n                </view>\r\n            </view>\r\n        </view>\r\n\r\n        <!-- 隐藏刀具使用记录表格 -->\r\n        <view v-if=\"false\" class=\"table-section\">\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 toolRecords\" :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                        <!-- 只有第一行显示 currentCjNum，其它行显示 downCount -->\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <!-- 第一行：下机时不实时显示 currentCjNum，显示 downCount -->\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                        <!--使用次数-->\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <!-- 第一行实时计算使用次数，若为下机则不实时显示 -->\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                        <!--寿命比%-->\r\n                        <td class=\"num\">\r\n                            <template v-if=\"idx === 0\">\r\n                                <!-- 第一行实时计算寿命比%，若为下机则不实时显示 -->\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                </tbody>\r\n            </table>\r\n        </view>\r\n\r\n        <!-- 说明 -->\r\n        <!--<view class=\"tool-desc\">\r\n            <p style=\"color:red;\">'使用上限'以下刀时的'使用上限'为计算标准</p>\r\n            <p style=\"color:red;\">寿命比预警值默认为90%</p>\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                activeToolNo: '', // 当前选中的刀具编号\r\n                pageIndex: 1,\r\n                pageSize: 20, //单页显示的刀具数量\r\n                total: 0,\r\n                toolList: [],\r\n                selectedToolNo: '',\r\n                toolName: '',\r\n                toolModel: '',\r\n                showToolDialog: false,\r\n                searchKey: '',\r\n                filteredTools: [],\r\n                useLimitInput: '',\r\n                lifeWarnInput: '', // 新增：寿命比预警值原始输入\r\n                toolRecords: [],\r\n                loadingTools: false,\r\n                loadingForm: false,\r\n                submitting: false,\r\n                _searchTimer: null,\r\n                workOrderCurrentCjNum: null, // 工单当前数采\r\n\r\n                // 自动保存相关\r\n                autoSaveTimer: null,\r\n                isDirty: false, // 表单是否有未保存变更\r\n                autoSaveIntervalMs: 5 * 60 * 1000, // 默认 5 分钟\r\n                autoSaveEnabled: true,\r\n                autoSaveActionName: 'handleUpTool', // 自动触发的方法名，可改为自定义保存方法\r\n\r\n                // 新增：调机相关字段\r\n                isTiaojiUserSelectShow: false, // 调机师傅选择弹窗\r\n                tiaojiStaffNo: '', // 当前选中的调机师傅(格式: 工号:姓名)\r\n                tiaojiOkQty: '', // 调机良品数\r\n                tiaojiBadQty: '', // 调机不良品数\r\n                tiaojiUsers: [], // 调机师傅列表\r\n                tiaojiUserSearch: '', // 搜索关键词\r\n                                \r\n                // 新增：报试产数所需字段\r\n                orderId: null, // 工单ID\r\n                order: {} // 工单数据\r\n            };\r\n        },\r\n        computed: {\r\n            totalPages() {\r\n                return Math.max(1, Math.ceil(this.total / this.pageSize) || 1);\r\n            },\r\n            // 新增：调机师傅显示名称\r\n            tiaojiStaffDisplay() {\r\n                if (!this.tiaojiStaffNo) return '';\r\n                const segs = this.tiaojiStaffNo.split(':');\r\n                return segs.length > 1 ? `${segs[0]} ${segs[1]}` : this.tiaojiStaffNo;\r\n            },\r\n            // 新增：过滤后的调机师傅列表\r\n            filteredTiaojiUsers() {\r\n                if (!this.tiaojiUserSearch) return this.tiaojiUsers;\r\n                const kw = this.tiaojiUserSearch.trim().toLowerCase();\r\n                return this.tiaojiUsers.filter(u => u.toLowerCase().includes(kw));\r\n            }\r\n        },\r\n        watch: {\r\n            // 标记脏数据：按需监听字段变化\r\n            selectedToolNo() { this.isDirty = true; },\r\n            useLimitInput() { this.isDirty = true; },\r\n            lifeWarnInput() { this.isDirty = true; },\r\n            toolName() { this.isDirty = true; },\r\n            toolModel() { this.isDirty = true; }\r\n        },\r\n        methods: {\r\n            //查询当前数采数，作为下刀计数实时显示\r\n            async fetchCurrentCjNum(toolNo) {\r\n                if (!this.machineNo) return null;\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)) {\r\n                        const found = res.data.tbBillList.find(x =>\r\n                            x.cutterId === toolNo || x.cutteR_ID === toolNo\r\n                        );\r\n                        return found ? (found.CurrentCjNum ?? found.currentCjNum ?? null) : null;\r\n                    }\r\n                } catch (e) {\r\n                    console.warn('获取currentCjNum失败', e);\r\n                }\r\n                return null;\r\n            },\r\n\r\n            // 新增：刷新按钮处理方法\r\n            async handleRefresh() {\r\n                this.fetchTools('');\r\n                if (this.machineNo && this.workOrderNo) {\r\n                    await this.fetchFormData();\r\n                    await this.fetchDefaultToolFromWorkOrder();\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            startAutoSave() {\r\n                if (!this.autoSaveEnabled) return;\r\n                this.stopAutoSave();\r\n                this.autoSaveTimer = setInterval(() => {\r\n                    this.autoSaveTick();\r\n                }, this.autoSaveIntervalMs);\r\n            },\r\n            // 自动保存：停止\r\n            stopAutoSave() {\r\n                if (this.autoSaveTimer) {\r\n                    clearInterval(this.autoSaveTimer);\r\n                    this.autoSaveTimer = null;\r\n                }\r\n            },\r\n            // 自动保存：每次定时执行时的逻辑\r\n            async autoSaveTick() {\r\n                if (!this.autoSaveEnabled) return;\r\n                if (!this.isDirty) return;\r\n                if (this.submitting || this.loadingForm) return;\r\n\r\n                const fn = this.autoSaveActionName && typeof this[this.autoSaveActionName] === 'function'\r\n                    ? this[this.autoSaveActionName]\r\n                    : null;\r\n                if (!fn) {\r\n                    console.warn('自动保存：未找到方法', this.autoSaveActionName);\r\n                    return;\r\n                }\r\n\r\n                try {\r\n                    this.submitting = true;\r\n                    await fn.call(this); // 调用保存方法（例如 handleUpTool）\r\n                    // 如果保存成功，清脏标记（保存方法内部若失败没有抛出可保持此方式）\r\n                    this.isDirty = false;\r\n                } catch (e) {\r\n                    console.error('自动保存失败：', e);\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n\r\n            // 新增：寿命比预警值归一化 (返回 0~1 或 null)\r\n            normalizeLifeWarn(v) {\r\n                if (v == null) return null;\r\n                const raw = String(v).trim().replace(/[%％]/g, '');\r\n                if (raw === '') return null;\r\n                const num = Number(raw);\r\n                if (!isFinite(num) || num <= 0) return null;\r\n                return num > 1 ? (num / 100) : num;\r\n            },\r\n            openToolDialog() {\r\n                this.showToolDialog = true;\r\n                this.pageIndex = 1;\r\n                this.fetchTools(this.searchKey);\r\n            },\r\n            closeToolDialog() {\r\n                this.showToolDialog = false;\r\n            },\r\n            async fetchTools(searchKey) {\r\n                this.loadingTools = true;\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/QueryTools',\r\n                        data: JSON.stringify({\r\n                            searchKey,\r\n                            pageIndex: this.pageIndex,\r\n                            pageSize: this.pageSize\r\n                        }),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n\r\n                    if (res.status === 0) {\r\n                        const payload = 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                        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                        // 这里需要把 lifeWarn 字段也带出来\r\n                        const mapped = (payload || []).map(t => ({\r\n                            no: getField(t, 'cutterId', 'CUTTER_ID', 'cutteR_ID', 'daA001', 'no'),\r\n                            name: getField(t, 'cutterName', 'CUTTER_NAME', 'cutteR_NAME', 'name'),\r\n                            model: getField(t, 'cutterModel', 'CUTTER_MODEL', 'cutteR_MODEL', 'model'),\r\n                            lifeWarn: getField(t, 'modlLifeWorning', 'lifeWarn', 'LIFE_WARN', 'lifE_WARN')\r\n                        }));\r\n\r\n                        this.filteredTools = mapped;\r\n                        this.toolList = mapped.slice();\r\n\r\n                        const totalFromRes = Number(\r\n                            res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\r\n                        );\r\n                        this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\r\n                        if (this.pageIndex > this.totalPages) {\r\n                            this.pageIndex = this.totalPages;\r\n                        }\r\n                    } else {\r\n                        this.$showMessage(res.message || '查询失败');\r\n                    }\r\n                } catch (err) {\r\n                    console.error('fetchTools 错误：', err);\r\n                    this.$showMessage('查询刀具失败，请检查网络或接口');\r\n                } finally {\r\n                    this.loadingTools = false;\r\n                }\r\n            },\r\n            async prevPage() {\r\n                if (this.pageIndex > 1) {\r\n                    this.pageIndex--;\r\n                    await this.fetchTools(this.searchKey);\r\n                }\r\n            },\r\n            async nextPage() {\r\n                if (this.pageIndex < this.totalPages) {\r\n                    this.pageIndex++;\r\n                    await this.fetchTools(this.searchKey);\r\n                }\r\n            },\r\n            onSearchKeyInput() {\r\n                clearTimeout(this._searchTimer);\r\n                this._searchTimer = setTimeout(() => {\r\n                    this.searchTool();\r\n                }, 300);\r\n            },\r\n            async searchTool() {\r\n                this.pageIndex = 1;\r\n                await this.fetchTools(this.searchKey);\r\n            },\r\n            selectTool(tool) {\r\n                this.selectedToolNo = tool.no;\r\n                this.toolName = tool.name;\r\n                this.toolModel = tool.model;\r\n                this.activeToolNo = tool.no;\r\n                // 新增：带出寿命比预警值\r\n                if (tool.lifeWarn !== undefined && tool.lifeWarn !== null) {\r\n                    // 格式化为百分比字符串\r\n                    const warn = Number(tool.lifeWarn);\r\n                    this.lifeWarnInput = warn <= 1 ? (warn * 100).toFixed(0) : warn.toFixed(0);\r\n                } else {\r\n                    this.lifeWarnInput = '';\r\n                }\r\n            },\r\n            confirmTool() {\r\n                this.showToolDialog = false;\r\n            },\r\n            async setUseLimit() {\r\n                if (!this.selectedToolNo) {\r\n                    this.$showMessage('请选择刀具后再设置上限');\r\n                    return;\r\n                }\r\n                const v = Number(this.useLimitInput);\r\n                if (isNaN(v) || v <= 0) {\r\n                    this.$showMessage('请输入有效的使用上限');\r\n                    return;\r\n                }\r\n                this.toolRecords = this.toolRecords.map(r => {\r\n                    if (r.no === this.selectedToolNo) {\r\n                        return { ...r, useLimit: v };\r\n                    }\r\n                    return r;\r\n                });\r\n                this.toolList = this.toolList.map(t => t.no === this.selectedToolNo ? { ...t, useLimit: v } : t);\r\n                this.$showMessage('使用上限已设置（仅前端显示）');\r\n            },\r\n            // 上刀时传递 sdjs = 工单 currentCjNum\r\n            async handleUpTool() {\r\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\r\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\r\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\r\n                //上刀强制录入使用上限\r\n                if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\r\n                const useLimit = Number(this.useLimitInput);\r\n                if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\r\n\r\n                // sdjs 使用工单 currentCjNum\r\n                const sdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\r\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\r\n                const payload = {\r\n                    workOrderNo: this.workOrderNo,\r\n                    machineNo: this.machineNo,\r\n                    toolNo: this.selectedToolNo,\r\n                    type: '上机',\r\n                    useLimit,\r\n                    sdjs,// 上刀计数（工单当前数采）\r\n                    modlLifeWorning: lifeWarnRatio // 新增\r\n                };\r\n                try {\r\n                    this.submitting = true;\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/SubmitToolAction',\r\n                        data: JSON.stringify(payload),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.data && res.data.outSum === \"0\") {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg || '',\r\n                            icon: 'error'\r\n                        });\r\n                        return;\r\n                    } else if (res.data && res.data.outMsg) {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg,\r\n                            icon: 'none'\r\n                        });\r\n                    }\r\n                    // 后续逻辑继续执行\r\n                    if (res.status === 0) {\r\n                        await this.fetchFormData();\r\n                    }\r\n                } catch (err) {\r\n                    console.error(err);\r\n                    this.$showMessage('上刀提交失败，请检查网络');\r\n                    throw err; // 抛出以便自动保存逻辑捕获并保留 isDirty\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n            // 下刀时传递 xdjs = 工单 currentCjNum\r\n            async handleDownTool() {\r\n                if (!this.workOrderNo) { this.$showMessage('工单号不能为空'); return; }\r\n                if (!this.machineNo) { this.$showMessage('机台号不能为空'); return; }\r\n                if (!this.selectedToolNo) { this.$showMessage('刀具编号不能为空'); return; }\r\n                //下刀不强制录入使用上限\r\n                //if (!this.useLimitInput) { this.$showMessage('使用上限不能为空'); return; }\r\n                const useLimit = Number(this.useLimitInput);\r\n                //if (isNaN(useLimit) || useLimit <= 0) { this.$showMessage('请输入有效的使用上限'); return; }\r\n\r\n                // 下刀计数同样取工单最新采集数\r\n                const xdjs = this.workOrderCurrentCjNum != null ? Number(this.workOrderCurrentCjNum) : null;\r\n                const lifeWarnRatio = this.normalizeLifeWarn(this.lifeWarnInput);\r\n                const payload = {\r\n                    workOrderNo: this.workOrderNo,\r\n                    machineNo: this.machineNo,\r\n                    toolNo: this.selectedToolNo,\r\n                    type: '下机',\r\n                    useLimit,\r\n                    xdjs,// 下刀计数\r\n                    modlLifeWorning: lifeWarnRatio // 新增\r\n                };\r\n                try {\r\n                    this.submitting = true;\r\n                    const res = await this.$post({\r\n                        url: '/MesCutterLedger/SubmitToolAction',\r\n                        data: JSON.stringify(payload),\r\n                        headers: { 'Content-Type': 'application/json' }\r\n                    });\r\n                    if (res.data && res.data.outSum === \"0\") {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg || '',\r\n                            icon: 'error'\r\n                        });\r\n                        return;\r\n                    } else if (res.data && res.data.outMsg) {\r\n                        uni.showToast({\r\n                            title: res.data.outMsg,\r\n                            icon: 'none'\r\n                        });\r\n                    }\r\n                    // 后续逻辑继续执行\r\n                    if (res.status === 0) {\r\n                        await this.fetchFormData();\r\n                    }\r\n                } catch (err) {\r\n                    console.error(err);\r\n                    this.$showMessage('下刀提交失败，请检查网络');\r\n                    throw err;\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n            cancel() {\r\n                this.selectedToolNo = '';\r\n                this.toolName = '';\r\n                this.toolModel = '';\r\n                this.useLimitInput = '';\r\n                this.lifeWarnInput = ''; // 新增：清空\r\n                this.isDirty = false;\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                    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                    // 新增：按上刀时间降序排序（越晚的越上面）\r\n                    mapped.sort((a, b) => {\r\n                        // 时间格式如 \"10-24 16:03\"，转为 Date 对象比较\r\n                        const parse = s => {\r\n                            if (!s) return 0;\r\n                            // 补年份，假设都是今年\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                    const totalFromRes = Number(\r\n                        res.data?.total ?? res.data?.totalCount ?? res.total ?? res.totalCount ?? mapped.length\r\n                    );\r\n                    this.total = Number.isFinite(totalFromRes) ? totalFromRes : mapped.length;\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            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                        \r\n                        // 新增：保存工单数据，用于报试产数\r\n                        this.order = order;\r\n                        this.orderId = order.id || order.ID || order.orderId || null;\r\n                        \r\n                        this.selectedToolNo = order.cutterId || order.cutteR_ID || '';\r\n                        this.toolName = order.cutterName || order.cutteR_NAME || '';\r\n                        this.toolModel = order.cutterModel || order.cutteR_MODEL || '';\r\n                        // 关键：获取工单最新采集数\r\n                        this.workOrderCurrentCjNum = order.CurrentCjNum ?? order.currentCjNum ?? null;\r\n                        // 新增：自动填充寿命比预警值\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                        this.order = {};\r\n                        this.orderId = null;\r\n                    }\r\n                } catch (e) {\r\n                    console.warn('自动带出工单刀具失败', e);\r\n                    this.workOrderCurrentCjNum = null;\r\n                    this.order = {};\r\n                    this.orderId = null;\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            // 新增：选择调机师傅\r\n            selectTiaojiUser(u) {\r\n                this.tiaojiStaffNo = u;\r\n                this.isTiaojiUserSelectShow = false;\r\n                this.tiaojiUserSearch = '';\r\n            },\r\n            \r\n            // 新增：送检呼叫 + 报试产数\r\n            async handleInspectionCall() {\r\n                // 验证必填项\r\n                if (!this.tiaojiStaffNo) {\r\n                    this.$showMessage('请选择调机师傅');\r\n                    return;\r\n                }\r\n                \r\n                const okQty = Number(this.tiaojiOkQty);\r\n                const badQty = Number(this.tiaojiBadQty);\r\n                \r\n                if (isNaN(okQty) || okQty < 0) {\r\n                    this.$showMessage('请输入有效的调机良品数');\r\n                    return;\r\n                }\r\n                \r\n                if (isNaN(badQty) || badQty < 0) {\r\n                    this.$showMessage('请输入有效的调机不良品数');\r\n                    return;\r\n                }\r\n                \r\n                const staffNo = this.tiaojiStaffNo.split(':')[0];\r\n                const currentCjNum = this.order?.currentCjNum || 0;\r\n                \r\n                // 调用报试产数接口(使用报工界面的接口)\r\n                const payload = {\r\n                    orderNo: this.workOrderNo,\r\n                    orderId: this.orderId, // 需要从工单数据中获取\r\n                    bf: badQty, // bf传递不良品数\r\n                    staffNo: staffNo,\r\n                    initCjNum: currentCjNum - badQty - okQty, // initCjNum = currentCjNum - bf - 良品数\r\n                    currentCjNum: currentCjNum,\r\n                    type: 'tiaoji', // 标识为调机报工\r\n                    tiaojiOkQty: okQty, // 新增:良品数\r\n                    tiaojiBadQty: badQty // 新增:不良品数\r\n                };\r\n                \r\n                try {\r\n                    this.submitting = true;\r\n                    // 调用报工界面的报试产数接口\r\n                    const res = await this.$post({\r\n                        url: '/MesInvItemBarcodes/AddBFToBarcodes',\r\n                        data: payload\r\n                    });\r\n                    \r\n                    if (res.status == 1) {\r\n                        this.$showMessage(res.message);\r\n                        return;\r\n                    }\r\n                    \r\n                    this.$showMessage('调机报工成功');\r\n                    // 清空输入\r\n                    this.tiaojiOkQty = '';\r\n                    this.tiaojiBadQty = '';\r\n                    // 刷新数据\r\n                    await this.fetchFormData();\r\n                    await this.fetchDefaultToolFromWorkOrder();\r\n                    \r\n                    // 新增：自动处理调机送检界面的按钮逻辑\r\n                    await this.autoHandleMachineInspection();\r\n                } catch (err) {\r\n                    console.error('调机报工错误:', err);\r\n                    this.$showMessage('调机报工失败，请检查网络');\r\n                } finally {\r\n                    this.submitting = false;\r\n                }\r\n            },\r\n            \r\n            // 新增：自动处理调机送检界面的按钮逻辑\r\n            async autoHandleMachineInspection() {\r\n                try {\r\n                    // 1. 使用 FindByOrderNo 获取调机送检界面的三个时间\r\n                    const statusRes = await this.$post({\r\n                        url: '/MesOrderSta/FindByOrderNo',\r\n                        data: {\r\n                            orderId: this.orderId,\r\n                            orderNo: this.workOrderNo\r\n                        }\r\n                    });\r\n                    \r\n                    if (!statusRes || !statusRes.data || !statusRes.data.tbBillList) {\r\n                        console.error('获取工单状态失败');\r\n                        this.$showMessage('获取工单状态失败');\r\n                        return;\r\n                    }\r\n                    \r\n                    const statusForm = statusRes.data.tbBillList;\r\n                    const maStartTime = statusForm.maStartTime;\r\n                    const maShoutTime = statusForm.maShoutTime;\r\n                    const maEndTime = statusForm.maEndTime;\r\n                    \r\n                    // 2. 准备需要更新的时间数据\r\n                    let needSave = false;\r\n                    let updateData = {\r\n                        id: statusForm.id,\r\n                        orderId: this.orderId,\r\n                        machineNo: this.machineNo,\r\n                        flag: -1\r\n                    };\r\n                    \r\n                    // 记录哪些操作被执行了\r\n                    let actions = [];\r\n                    \r\n                    // 3. 从上到下根据显示框里是否有时间依次设置\r\n                    // 如果调机开始时间为空，设置调机开始时间\r\n                    if (!maStartTime) {\r\n                        updateData.maStartTime = this.$getDate('yyyy-mm-dd hh24:mi:ss');\r\n                        updateData.flag = -1; // 调机开始的flag=-1\r\n                        needSave = true;\r\n                        actions.push('调机开始');\r\n                    } else {\r\n                        updateData.maStartTime = maStartTime;\r\n                    }\r\n                    \r\n                    // 如果送检呼叫时间为空，设置送检呼叫时间\r\n                    if (!maShoutTime) {\r\n                        updateData.maShoutTime = this.$getDate('yyyy-mm-dd hh24:mi:ss');\r\n                        updateData.flag = 1; // 首次送检呼叫的flag=1\r\n                        needSave = true;\r\n                        actions.push('送检呼叫');\r\n                    } else {\r\n                        updateData.maShoutTime = maShoutTime;\r\n                    }\r\n                    \r\n                    // 调机完成时间保持不变\r\n                    updateData.maEndTime = maEndTime || '';\r\n                    \r\n                    // 4. 如果有需要更新的时间，调用保存接口\r\n                    if (needSave) {\r\n                        const saveRes = await this.$post({\r\n                            url: '/MesOrderSta/ChangeMachineTime',\r\n                            data: updateData\r\n                        });\r\n                        \r\n                        if (saveRes && saveRes.data && saveRes.data.tbBillList) {\r\n                            const successMsg = actions.join('、') + '成功';\r\n                            this.$showMessage(successMsg);\r\n                            console.log('调机送检界面时间自动更新成功:', actions);\r\n                        } else {\r\n                            const failMsg = actions.join('、') + '失败';\r\n                            this.$showMessage(failMsg);\r\n                            console.error('调机送检界面时间自动更新失败');\r\n                        }\r\n                    } else {\r\n                        // 所有时间都已存在，无需更新\r\n                        this.$showMessage('调机开始和送检呼叫已完成');\r\n                        console.log('调机开始和送检呼叫时间已存在，无需更新');\r\n                    }\r\n                } catch (err) {\r\n                    console.error('自动处理调机送检界面失败:', err);\r\n                    this.$showMessage('自动处理调机送检失败');\r\n                    // 不中断主流程，只记录错误\r\n                }\r\n            },\r\n            \r\n            // 新增：获取调机师傅列表\r\n            async fetchTiaojiStaff() {\r\n                try {\r\n                    const res = await this.$post({\r\n                        url: '/MesStaff/GetAllXS0101BYtj' // 与报工界面使用相同接口\r\n                    });\r\n                    if (res.status === 0 && res.data && res.data.tbBillList) {\r\n                        const staff = res.data.tbBillList;\r\n                        this.tiaojiUsers = staff.map(s => s.staffNo + ':' + s.staffName);\r\n                    }\r\n                } catch (err) {\r\n                    console.error('获取调机师傅列表失败:', err);\r\n                }\r\n            }\r\n        },\r\n        mounted() {\r\n            this.fetchTools('');\r\n            this.machineNo = uni.getStorageSync('machineNo') || '';\r\n            this.workOrderNo = uni.getStorageSync('daa001') || '';\r\n            \r\n            // 新增：获取调机师傅列表\r\n            this.fetchTiaojiStaff();\r\n\r\n            if (this.machineNo && this.workOrderNo) {\r\n                this.fetchFormData().then(async () => {\r\n                    await this.fetchDefaultToolFromWorkOrder();\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            } else {\r\n                console.warn('机台号或工单号为空，无法获取表单数据');\r\n            }\r\n\r\n            // 启动自动保存定时器\r\n            //this.startAutoSave();\r\n        },\r\n        beforeDestroy() {\r\n            // 清理定时器，防止内存泄漏\r\n            this.stopAutoSave();\r\n        }\r\n    };\r\n</script>\r\n\r\n<style scoped>\r\n    .top-section-grid {\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: center;\r\n        align-items: flex-start;\r\n        gap: 12px;\r\n        margin-bottom: 2vh;\r\n        width: 99vw;\r\n        max-width: 1920px;\r\n        margin-left: auto;\r\n        margin-right: auto;\r\n        padding: 12px;\r\n        background: #f8f9fa;\r\n        border-radius: 8px;\r\n        border: 1px solid #e9ecef;\r\n    }\r\n\r\n    .form-row {\r\n        display: flex;\r\n        flex-direction: row;\r\n        justify-content: flex-start;\r\n        align-items: center;\r\n        width: 100%;\r\n        margin-bottom: 12px;\r\n    }\r\n\r\n        .form-row:last-child {\r\n            margin-bottom: 0;\r\n        }\r\n\r\n    .form-cell {\r\n        display: flex;\r\n        align-items: center;\r\n        min-width: 0;\r\n        margin-right: 0;\r\n    }\r\n\r\n        .form-cell:nth-child(1) {\r\n            flex: 0 0 28%;\r\n            min-width: 180px;\r\n        }\r\n\r\n        .form-cell:nth-child(2) {\r\n            flex: 0 0 32%;\r\n            min-width: 180px;\r\n            justify-content: flex-start;\r\n        }\r\n\r\n        .form-cell:nth-child(3) {\r\n            flex: 0 0 auto;\r\n            min-width: 0;\r\n            max-width: 220px; /* 限制最大宽度，避免撑开 */\r\n            justify-content: flex-end;\r\n        }\r\n\r\n    .form-label {\r\n        width: auto;\r\n        font-weight: 500;\r\n        color: #333;\r\n        white-space: nowrap;\r\n        margin-right: 4px;\r\n        flex-shrink: 0;\r\n        font-size: 22px;\r\n    }\r\n\r\n    .input {\r\n        padding: 14px 20px;\r\n        border: 1px solid #dcdfe6;\r\n        flex: 1;\r\n        margin-right: 0;\r\n        border-radius: 4px;\r\n        background: #fff;\r\n        min-width: 0;\r\n        height: 56px !important;\r\n        box-sizing: border-box;\r\n        font-size: 22px;\r\n    }\r\n\r\n        .input.small-font {\r\n            /* 不设置字体大小 */\r\n        }\r\n\r\n        .input:disabled {\r\n            background-color: #f5f7fa;\r\n            color: #c0c4cc;\r\n            cursor: not-allowed;\r\n        }\r\n\r\n    .input-with-unit {\r\n        display: flex;\r\n        align-items: center;\r\n        gap: 0;\r\n    }\r\n\r\n        .input-with-unit .input {\r\n            width: 60px !important;\r\n            min-width: 0 !important;\r\n            margin-right: 2px !important;\r\n            text-align: center;\r\n            padding-left: 2px;\r\n            padding-right: 2px;\r\n        }\r\n\r\n        .input-with-unit .input {\r\n            margin-right: 4px !important;\r\n            width: 60px !important;\r\n            min-width: 0 !important;\r\n            text-align: center;\r\n        }\r\n\r\n    .unit-text {\r\n        margin-left: 0 !important;\r\n        padding-left: 0 !important;\r\n        font-size: 22px !important;\r\n    }\r\n\r\n    .btn-blue, .btn-blue.large-btn {\r\n        background-color: #1890ff;\r\n        color: white;\r\n        border: none;\r\n        padding: 14px 32px;\r\n        border-radius: 4px;\r\n        cursor: pointer;\r\n        font-weight: 500;\r\n        white-space: nowrap;\r\n        height: 70px !important;\r\n        box-sizing: border-box;\r\n        transition: all 0.3s;\r\n        flex-shrink: 0;\r\n        min-width: 140px;\r\n        margin-left: 24px;\r\n    }\r\n\r\n        .btn-blue.large-btn {\r\n            padding: 0 60px;\r\n            min-width: 180px;\r\n            height: 72px !important;\r\n            margin-left: 0 !important;\r\n            font-size: 1.3em;\r\n            box-shadow: 0 2px 8px rgba(24,144,255,0.08);\r\n            line-height: 72px; /* 垂直居中 */\r\n            display: inline-block; /* 保证line-height生效 */\r\n            vertical-align: middle;\r\n        }\r\n\r\n        .btn-blue:hover {\r\n            background-color: #40a9ff;\r\n        }\r\n\r\n        .btn-blue:active {\r\n            background-color: #096dd9;\r\n        }\r\n\r\n        .btn-blue:disabled {\r\n            background: #bae7ff;\r\n            color: #91d5ff;\r\n            cursor: not-allowed;\r\n        }\r\n\r\n    .button-row {\r\n        display: flex;\r\n        justify-content: center;\r\n        gap: 32px;\r\n        margin: 2vh 0;\r\n    }\r\n\r\n    .save-btn, .cancel-btn {\r\n        width: 28%;\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    .cancel-btn {\r\n        background-color: #f5f5f5;\r\n        color: #333;\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, .cancel-btn:disabled {\r\n        opacity: 0.6;\r\n        cursor: not-allowed;\r\n    }\r\n\r\n    /* 弹窗样式 */\r\n    .dialog-overlay {\r\n        position: fixed;\r\n        top: 0;\r\n        left: 0;\r\n        right: 0;\r\n        bottom: 0;\r\n        background: rgba(0,0,0,0.18);\r\n        display: flex;\r\n        justify-content: center;\r\n        align-items: center;\r\n        z-index: 1000;\r\n    }\r\n\r\n    .dialog {\r\n        background: #fff;\r\n        padding: 3vh 3vw;\r\n        border-radius: 18px;\r\n        width: 90vw;\r\n        max-width: 1600px;\r\n        min-height: 70vh;\r\n        max-height: 85vh;\r\n        box-sizing: border-box;\r\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\r\n        display: flex;\r\n        flex-direction: column;\r\n    }\r\n\r\n    .form-group {\r\n        display: flex;\r\n        gap: 12px;\r\n        align-items: center;\r\n        margin-bottom: 2vh;\r\n        flex-shrink: 0;\r\n    }\r\n\r\n        .form-group .input {\r\n            flex: 1;\r\n            min-width: 300px;\r\n            border-radius: 6px;\r\n            background: #f8f8f8;\r\n        }\r\n\r\n    .tool-list {\r\n        display: flex;\r\n        flex-wrap: wrap;\r\n        margin: 1vh 0;\r\n        flex: 1;\r\n        overflow-y: auto;\r\n        gap: 12px;\r\n        align-content: flex-start;\r\n    }\r\n\r\n    .tool-btn {\r\n        flex: 0 0 calc(20% - 10px);\r\n        box-sizing: border-box;\r\n        padding: 10px 12px;\r\n        background: #f5f5f5;\r\n        border: 1px solid #d0d0d0;\r\n        border-radius: 8px;\r\n        cursor: pointer;\r\n        color: #333;\r\n        text-align: left;\r\n        min-height: 50px;\r\n        transition: background 0.15s, color 0.15s;\r\n        overflow: hidden;\r\n        text-overflow: ellipsis;\r\n        white-space: nowrap;\r\n        line-height: 1.4;\r\n    }\r\n\r\n        .tool-btn.active {\r\n            background: #00A2E9;\r\n            color: #fff;\r\n            font-weight: bold;\r\n            border: 1.5px solid #0086c2;\r\n        }\r\n\r\n    .dialog-actions {\r\n        display: flex;\r\n        justify-content: space-between;\r\n        align-items: center;\r\n        margin-top: 2vh;\r\n        padding-top: 2vh;\r\n        border-top: 1px solid #eee;\r\n        flex-shrink: 0;\r\n    }\r\n\r\n        .dialog-actions > div:first-child {\r\n            display: flex;\r\n            align-items: center;\r\n            gap: 24px;\r\n        }\r\n\r\n        .dialog-actions > div:last-child {\r\n            display: flex;\r\n            flex-direction: row;\r\n            gap: 18px;\r\n            align-items: center;\r\n        }\r\n\r\n        .dialog-actions .btn-blue {\r\n            padding: 10px 24px;\r\n            min-width: 120px;\r\n            font-size: 22px;\r\n        }\r\n\r\n    .btn-disabled {\r\n        background: #f2f2f2;\r\n        color: #999;\r\n        border: none;\r\n        padding: 10px 24px;\r\n        border-radius: 4px;\r\n        font-weight: 500;\r\n        cursor: not-allowed;\r\n        box-shadow: none;\r\n        min-width: 120px;\r\n    }\r\n\r\n    .table-section {\r\n        display: flex;\r\n        justify-content: center;\r\n        margin: 1vh 0;\r\n        overflow-x: auto;\r\n        width: 100%; /* 确保表格容器占满宽度 */\r\n    }\r\n\r\n    table.styled-table {\r\n        max-width: 1800px; /* 从1600px增加到1800px */\r\n        width: 98vw; /* 从95vw增加到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        border-radius: 12px;\r\n        overflow: hidden;\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        }\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-section table th:first-child, .table-section table td:first-child {\r\n        border-left: 2px solid #bfbfbf;\r\n    }\r\n\r\n    .table-section table th:last-child, .table-section table td:last-child {\r\n        border-right: 2px solid #bfbfbf;\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    .left {\r\n        text-align: left;\r\n        padding-left: 8px;\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    /* 响应式调整 */\r\n    @media (max-width: 1200px) {\r\n        .form-cell {\r\n            margin: 0 4px;\r\n        }\r\n\r\n        .form-label {\r\n            width: 90px;\r\n        }\r\n\r\n        .input {\r\n            padding: 10px 14px;\r\n        }\r\n\r\n        .btn-blue {\r\n            padding: 10px 18px;\r\n        }\r\n    }\r\n\r\n    .input-life-warn {\r\n        width: 48px !important; /* 稍微放宽，避免字体溢出 */\r\n        min-width: 0 !important;\r\n        margin-right: 4px;\r\n        padding-left: 2px;\r\n        padding-right: 2px;\r\n        font-size: 22px !important;\r\n        text-align: center;\r\n        box-sizing: border-box;\r\n    }\r\n\r\n    .input,\r\n    .input.small-font,\r\n    .input-use-limit,\r\n    .input-tool-model,\r\n    .input-tool-name,\r\n    .input-life-warn {\r\n        font-size: 22px !important;\r\n    }\r\n\r\n    .input-tool-model {\r\n        width: 320px !important; /* 原为200px，现加长 */\r\n        min-width: 0 !important;\r\n        margin-right: 16px;\r\n    }\r\n\r\n    .input-tool-name {\r\n        width: 120px !important;\r\n        min-width: 0 !important;\r\n        margin-right: 16px;\r\n    }\r\n\r\n    .highlight-label {\r\n        color: #1890ff !important;\r\n    }\r\n\r\n    .tool-dir-cell {\r\n        flex: 0 0 auto !important;\r\n        justify-content: flex-start !important;\r\n        display: flex !important;\r\n        align-items: center;\r\n        margin-left: 16px; /* 与规格型号输入框拉开距离 */\r\n    }\r\n\r\n    .form-cell-flex {\r\n        display: flex;\r\n        align-items: center;\r\n        flex: 0 0 60%;\r\n        min-width: 320px;\r\n    }\r\n\r\n        .form-cell-flex .form-label {\r\n            margin-right: 4px;\r\n            width: auto;\r\n        }\r\n\r\n        .form-cell-flex .input-use-limit {\r\n            margin-right: 12px;\r\n        }\r\n\r\n    .input-use-limit {\r\n        width: 450px !important;\r\n        min-width: 0 !important;\r\n        margin-right: 16px;\r\n        flex: none !important; /* 关键：彻底禁止flex拉伸 */\r\n    }\r\n\r\n    /* 新增：调机区域样式 */\r\n    .tiaoji-section {\r\n        width: 100%;\r\n        margin: 2vh 0;\r\n        padding: 20px;\r\n        background: #f8f9fa;\r\n        border-radius: 8px;\r\n        border: 1px solid #e9ecef;\r\n    }\r\n\r\n    .tiaoji-row {\r\n        display: flex;\r\n        flex-wrap: wrap;\r\n        align-items: center;\r\n        gap: 20px;\r\n    }\r\n\r\n    /* 当前调机师傅区域 - 与报工界面保持一致 */\r\n    .current-user-section {\r\n        display: flex;\r\n        align-items: center;\r\n        font-size: 22px;\r\n        border: 1.5px solid #f00;\r\n        border-radius: 10px;\r\n        padding: 14px 22px;\r\n        background: #fff;\r\n        gap: 14px;\r\n        flex: 0 0 auto;\r\n    }\r\n\r\n    .current-user-name {\r\n        font-weight: bold;\r\n        font-size: 22px;\r\n    }\r\n\r\n    /* 选人按钮 - 蓝色主题，与报工界面保持一致 */\r\n    .select-user-btn {\r\n        background: #00a2e9;\r\n        color: #fff;\r\n        border: none;\r\n        padding: 12px 22px;\r\n        border-radius: 12px;\r\n        font-size: 22px;\r\n        cursor: pointer;\r\n        transition: background 0.15s;\r\n        height: 66px;\r\n        box-sizing: border-box;\r\n        display: flex;\r\n        align-items: center;\r\n        justify-content: center;\r\n    }\r\n\r\n        .select-user-btn:hover {\r\n            background: #008ac2;\r\n        }\r\n\r\n    /* 调机数量输入区域 */\r\n    .tiaoji-input-section {\r\n        display: flex;\r\n        align-items: center;\r\n        gap: 14px;\r\n        font-size: 22px;\r\n    }\r\n\r\n    .tiaoji-input {\r\n        width: 200px;\r\n        max-width: 100%;\r\n        height: 66px;\r\n        border: 2px solid #808080;\r\n        font-size: 28px;\r\n        text-align: center;\r\n        border-radius: 8px;\r\n        box-sizing: border-box;\r\n    }\r\n\r\n    /* 送检呼叫按钮 - 与报工界面的确认提交按钮保持一致 */\r\n    .details-btn {\r\n        padding: 12px 34px;\r\n        background: #00a2e9;\r\n        color: #fff;\r\n        font-size: 32px;\r\n        border: none;\r\n        cursor: pointer;\r\n        border-radius: 12px;\r\n        height: 66px;\r\n        min-width: 180px;\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: center;\r\n        align-items: center;\r\n        line-height: 1.1;\r\n        box-sizing: border-box;\r\n        transition: background 0.15s;\r\n    }\r\n\r\n        .details-btn:hover {\r\n            background: #008ac2;\r\n        }\r\n\r\n        .details-btn:disabled {\r\n            opacity: 0.6;\r\n            cursor: not-allowed;\r\n            background: #bae7ff;\r\n        }\r\n\r\n    .tiaoji-submit-section {\r\n        display: flex;\r\n        align-items: center;\r\n    }\r\n\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: rgba(0,0,0,.45);\r\n        display: flex;\r\n        justify-content: center;\r\n        align-items: center;\r\n        z-index: 1000;\r\n    }\r\n\r\n    .user-select-popup {\r\n        background: #fff;\r\n        width: 1600px;\r\n        max-width: 99vw;\r\n        min-width: 1000px;\r\n        height: auto;\r\n        min-height: 520px;\r\n        padding: 0;\r\n        display: flex;\r\n        flex-direction: column;\r\n        font-size: 32px;\r\n        border-radius: 12px;\r\n        box-shadow: 0 8px 32px rgba(0,0,0,0.12);\r\n        z-index: 1001;\r\n    }\r\n\r\n    .user-search-bar {\r\n        display: flex;\r\n        align-items: center;\r\n        gap: 18px;\r\n        padding: 24px 64px 0 64px;\r\n        background: #fff;\r\n        flex-wrap: wrap;\r\n    }\r\n\r\n    .user-search-input {\r\n        flex: 1 1 260px;\r\n        padding: 16px 20px;\r\n        font-size: 28px;\r\n        border: 1px solid #bbb;\r\n        border-radius: 8px;\r\n        outline: none;\r\n        height: 54px;\r\n    }\r\n\r\n        .user-search-input:focus {\r\n            border-color: #007aff;\r\n            box-shadow: 0 0 0 2px rgba(0,122,255,.15);\r\n        }\r\n\r\n    .user-search-clear {\r\n        padding: 12px 28px;\r\n        background: #ff9f43;\r\n        color: #fff;\r\n        border: none;\r\n        border-radius: 8px;\r\n        font-size: 24px;\r\n        cursor: pointer;\r\n    }\r\n\r\n        .user-search-clear:hover {\r\n            background: #ff8920;\r\n        }\r\n\r\n    .user-search-info {\r\n        font-size: 22px;\r\n        color: #555;\r\n    }\r\n\r\n    .user-list-scroll {\r\n        flex: 1 1 auto;\r\n        overflow-y: auto;\r\n        padding: 32px 64px 0 64px;\r\n    }\r\n\r\n    .user-list-grid {\r\n        display: grid;\r\n        grid-template-columns: repeat(auto-fill,minmax(200px,1fr));\r\n        gap: 22px 22px;\r\n    }\r\n\r\n    .user-list-btn {\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: center;\r\n        align-items: center;\r\n        gap: 2px;\r\n        padding: 10px 10px;\r\n        height: 100px;\r\n        font-size: 30px;\r\n        background: #00a2e9;\r\n        color: #fff;\r\n        border: none;\r\n        border-radius: 8px;\r\n        cursor: pointer;\r\n        box-sizing: border-box;\r\n        word-break: break-word;\r\n    }\r\n\r\n        .user-list-btn .user-code {\r\n            font-weight: 700;\r\n            font-size: 36px;\r\n            line-height: 1.1;\r\n        }\r\n\r\n        .user-list-btn .user-name {\r\n            font-size: 32px;\r\n            line-height: 1.1;\r\n        }\r\n\r\n        .user-list-btn.selected {\r\n            background: #0072c9;\r\n            box-shadow: 0 0 0 3px rgba(255,255,255,.6) inset;\r\n        }\r\n\r\n        .user-list-btn:hover {\r\n            background: #008ed0;\r\n        }\r\n\r\n    .no-user-result {\r\n        padding: 40px 0;\r\n        text-align: center;\r\n        font-size: 28px;\r\n        color: #666;\r\n    }\r\n\r\n    .user-popup-footer {\r\n        flex-shrink: 0;\r\n        padding: 24px 64px 32px 64px;\r\n        background: #fff;\r\n        text-align: center;\r\n    }\r\n\r\n    .clean-btn {\r\n        width: 24%;\r\n        padding: 10px 0;\r\n        color: #fff;\r\n        font-size: 20px;\r\n        border: none;\r\n        text-align: center;\r\n        cursor: pointer;\r\n        border-radius: 0.6vw;\r\n        background: #007aff;\r\n    }\r\n\r\n        .clean-btn.wide-btn {\r\n            width: 30%;\r\n            font-size: 22px;\r\n            padding: 12px 0;\r\n        }\r\n\r\n        .clean-btn:hover {\r\n            background: #0062c9;\r\n        }\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///62\n");
 
 /***/ }),
 /* 63 */

--
Gitblit v1.9.3