快乐的昕的电脑
2025-10-18 38032dc27d6449f030e41794f2676f01684db39a
界面优化
已修改1个文件
200 ■■■■■ 文件已修改
components/mold.vue 200 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
components/mold.vue
@@ -113,7 +113,7 @@
            return {
                machineNo: '',//机台编码
                workOrderNo: '',//工单号
                activeToolNo: '', // 当前选中的刀具编号
                activeToolNo: '', // 当前选中的刀具编号
                pageIndex: 1,
                pageSize: 18,
                total: 0,
@@ -365,70 +365,70 @@
                        return Number.isFinite(n) ? n : null;
                    };
                    const formatPercent = n => {
                        if (n === null || n === undefined || isNaN(n)) return '';
                    const formatPercent = n => {
                        if (n === null || n === undefined || isNaN(n)) return '';
                        // 如果是小于等于1的小数,按比例放大
                        if (n <= 1) return `${(n * 100).toFixed(0)}%`;
                        return `${Number(n).toFixed(0)}%`;
                        if (n <= 1) return `${(n * 100).toFixed(0)}%`;
                        return `${Number(n).toFixed(0)}%`;
                    };
                    const mapped = (list || []).map(t => {
                        const upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');
                        const downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');
                        const lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');
                    const mapped = (list || []).map(t => {
                        const upTimeRaw = getField(t, 'uP_TIME', 'UP_TIME', 'uPTime', 'UPTIME', 'UpTime');
                        const downTimeRaw = getField(t, 'dowN_TIME', 'DOWN_TIME', 'downTime', 'DOWNTIME');
                        const lifeWarnRaw = getField(t, 'lifE_WARN', 'LIFE_WARN', 'lifeWarn', 'LIFEWARN');
                        // 使用次数和上限
                        const useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');
                        const useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');
                        const useCount = getField(t, 'usE_COUNT', 'USE_COUNT', 'useCount');
                        const useLimit = getField(t, 'usE_LIMIT', 'USE_LIMIT', 'useLimit');
                        // 计算寿命比(使用次数/使用上限)
                        let percent = '';
                        if (
                            useCount != null && useLimit != null &&
                            !isNaN(useCount) && !isNaN(useLimit) &&
                            Number(useLimit) > 0
                        ) {
                            percent = ((Number(useCount) / Number(useLimit)) * 100).toFixed(0) + '%';
                        }
                        let percent = '';
                        if (
                            useCount != null && useLimit != null &&
                            !isNaN(useCount) && !isNaN(useLimit) &&
                            Number(useLimit) > 0
                        ) {
                            percent = ((Number(useCount) / Number(useLimit)) * 100).toFixed(0) + '%';
                        }
                        // 预警值格式化
                        const parseNumber = v => {
                            if (v === null || v === undefined || v === '') return null;
                            const s = String(v).replace(/[,%%]/g, '').trim();
                            const n = parseFloat(s);
                            return Number.isFinite(n) ? n : null;
                        };
                        const formatPercent = n => {
                            if (n === null || n === undefined || isNaN(n)) return '';
                            if (n <= 1) return `${(n * 100).toFixed(0)}%`;
                            return `${Number(n).toFixed(0)}%`;
                        };
                        const lifeWarnNum = parseNumber(lifeWarnRaw);
                        const parseNumber = v => {
                            if (v === null || v === undefined || v === '') return null;
                            const s = String(v).replace(/[,%%]/g, '').trim();
                            const n = parseFloat(s);
                            return Number.isFinite(n) ? n : null;
                        };
                        const formatPercent = n => {
                            if (n === null || n === undefined || isNaN(n)) return '';
                            if (n <= 1) return `${(n * 100).toFixed(0)}%`;
                            return `${Number(n).toFixed(0)}%`;
                        };
                        const lifeWarnNum = parseNumber(lifeWarnRaw);
                        // 预警规则:当寿命比 >= 预警值时标记 预警
                        let warnStatus = getField(t, 'status', 'STATUS') || '';
                        if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {
                            const percentNum = Number(useCount) / Number(useLimit);
                            warnStatus = (percentNum >= lifeWarnNum) ? '预警' : '正常';
                        } else {
                            warnStatus = warnStatus || '未知';
                        }
                        let warnStatus = getField(t, 'status', 'STATUS') || '';
                        if (lifeWarnNum !== null && useCount != null && useLimit != null && !isNaN(useCount) && !isNaN(useLimit) && Number(useLimit) > 0) {
                            const percentNum = Number(useCount) / Number(useLimit);
                            warnStatus = (percentNum >= lifeWarnNum) ? '预警' : '正常';
                        } else {
                            warnStatus = warnStatus || '未知';
                        }
                        return {
                            id: getField(t, 'id', 'ID') || `${getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || ''}-${upTimeRaw || ''}`,
                            no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',
                            name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',
                            upTime: this.formatDateTime(upTimeRaw),
                            upCount: getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount') ?? '',
                            downTime: this.formatDateTime(downTimeRaw),
                            downCount: getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount') ?? '',
                            useCount: useCount ?? '',
                            useLimit: useLimit ?? '',
                            lifePercent: percent,
                            lifeWarn: formatPercent(lifeWarnNum),
                            warnStatus
                        };
                    });
                        return {
                            id: getField(t, 'id', 'ID') || `${getField(t, 'cutteR_ID') || getField(t, 'CUTTER_ID') || ''}-${upTimeRaw || ''}`,
                            no: getField(t, 'cutteR_ID', 'CUTTER_ID', 'cutterId', 'no') || '',
                            name: getField(t, 'cutteR_NAME', 'CUTTER_NAME', 'cutterName', 'name') || '',
                            upTime: this.formatDateTime(upTimeRaw),
                            upCount: getField(t, 'uP_COUNT', 'UP_COUNT', 'upCount') ?? '',
                            downTime: this.formatDateTime(downTimeRaw),
                            downCount: getField(t, 'dowN_COUNT', 'DOWN_COUNT', 'downCount') ?? '',
                            useCount: useCount ?? '',
                            useLimit: useLimit ?? '',
                            lifePercent: percent,
                            lifeWarn: formatPercent(lifeWarnNum),
                            warnStatus
                        };
                    });
                    this.toolRecords = mapped;
                    const totalFromRes = Number(
@@ -441,6 +441,25 @@
                    this.toolRecords = [];
                } finally {
                    this.loadingForm = false;
                }
            },
            // 自动带出工单刀具信息
            async fetchDefaultToolFromWorkOrder() {
                if (!this.workOrderNo) return;
                try {
                    const res = await this.$post({
                        url: '/Womdaa/GetWomdaasByShow',
                        data: JSON.stringify({ daa001: this.workOrderNo }),
                        headers: { 'Content-Type': 'application/json' }
                    });
                    if (res.status === 0 && Array.isArray(res.data?.tbBillList) && res.data.tbBillList.length > 0) {
                        const tool = res.data.tbBillList[0];
                        this.selectedToolNo = tool.cutterId || tool.cutteR_ID || '';
                        this.toolName = tool.cutterName || tool.cutteR_NAME || '';
                        this.toolModel = tool.cutterModel || tool.cutteR_MODEL || '';
                    }
                } catch (e) {
                    console.warn('自动带出工单刀具失败', e);
                }
            },
            formatDateTime(dateTimeStr) {
@@ -477,6 +496,7 @@
            if (this.machineNo && this.workOrderNo) {
                this.fetchFormData();
                this.fetchDefaultToolFromWorkOrder(); // 自动带出工单刀具
            } else {
                console.warn('机台号或工单号为空,无法获取表单数据');
            }
@@ -564,47 +584,47 @@
        z-index: 1000;
    }
    .dialog {
        background: #fff;
        padding: 3vh 3vw; /* 增大内边距 */
        border-radius: 12px; /* 稍微圆润一点 */
        width: 100vw; /* 原60vw,改为100vw更宽 */
        max-width: 1200px; /* 限制最大宽度,防止超屏 */
        min-height: 60vh; /* 增加最小高度 */
        box-sizing: border-box;
    }
    .dialog {
        background: #fff;
        padding: 3vh 3vw; /* 增大内边距 */
        border-radius: 12px; /* 稍微圆润一点 */
        width: 100vw; /* 原60vw,改为100vw更宽 */
        max-width: 1200px; /* 限制最大宽度,防止超屏 */
        min-height: 60vh; /* 增加最小高度 */
        box-sizing: border-box;
    }
    .form-group .input {
        width: 24vw; /* 输入框更宽 */
    }
    .form-group .input {
        width: 24vw; /* 输入框更宽 */
    }
    .tool-list {
        display: flex;
        flex-wrap: wrap;
        margin: 1vh 0;
        max-height: 40vh;
        overflow-y: auto;
    }
    .tool-list {
        display: flex;
        flex-wrap: wrap;
        margin: 1vh 0;
        max-height: 40vh;
        overflow-y: auto;
    }
    .tool-btn {
        flex: 0 0 32%;
        box-sizing: border-box;
        margin: 5px 1% 5px 0;
        padding: 8px 16px;
        background: #e0e0e0;
        border: 1px solid #ccc;
        border-radius: 4px;
        cursor: pointer;
        color: #333;
        text-align: left;
        transition: background 0.15s, color 0.15s;
    }
    .tool-btn {
        flex: 0 0 32%;
        box-sizing: border-box;
        margin: 5px 1% 5px 0;
        padding: 8px 16px;
        background: #e0e0e0;
        border: 1px solid #ccc;
        border-radius: 4px;
        cursor: pointer;
        color: #333;
        text-align: left;
        transition: background 0.15s, color 0.15s;
    }
        .tool-btn.active {
            background: #00A2E9;
            color: #fff;
            font-weight: bold;
        }
        .tool-btn.active {
            background: #00A2E9;
            color: #fff;
            font-weight: bold;
        }
    .dialog-actions {
        display: flex;