diff --git a/frontend/mock/dashboard.ts b/frontend/mock/dashboard.ts index 752271e..b0c9532 100644 --- a/frontend/mock/dashboard.ts +++ b/frontend/mock/dashboard.ts @@ -1,4 +1,45 @@ -import type { MockMethod } from './types' +import type { MockMethod, MockRequest } from './types' + +// 日期工具 +function getToday(): string { return new Date().toISOString().slice(0, 10) } +function daysAgo(n: number): string { const d = new Date(); d.setDate(d.getDate() - n); return d.toISOString().slice(0, 10) } + +// 不同日期范围的数据倍率(模拟不同日期的数据差异) +function getMultiplier(startDate: string, endDate: string): number { + const today = getToday() + if (startDate === today && endDate === today) return 1.0 // 今日 + if (startDate === daysAgo(1) && endDate === daysAgo(1)) return 0.92 // 昨日 + if (startDate === daysAgo(2) && endDate === today) return 0.95 // 近3天 + if (startDate === daysAgo(6) && endDate === today) return 0.93 // 近7天 + return 0.88 // 自定义 +} + +const baseMachineRank = [ + { rank: 1, machineId: 1, machineName: '西-1.8', program: '1566.NC', quantity: 580, status: 1 }, + { rank: 2, machineId: 2, machineName: '西-1.10', program: 'O123.NC', quantity: 420, status: 1 }, + { rank: 3, machineId: 3, machineName: '东-2.0', program: 'A456.NC', quantity: 380, status: 1 }, + { rank: 4, machineId: 4, machineName: '东-2.5', program: 'B789.NC', quantity: 310, status: 0 }, + { rank: 5, machineId: 5, machineName: '南-3.1', program: 'C012.NC', quantity: 290, status: 1 }, + { rank: 6, machineId: 6, machineName: '南-3.2', program: 'D345.NC', quantity: 240, status: 1 }, + { rank: 7, machineId: 7, machineName: '北-4.0', program: 'E678.NC', quantity: 210, status: 1 }, + { rank: 8, machineId: 8, machineName: '北-4.1', program: 'F901.NC', quantity: 180, status: 0 }, + { rank: 9, machineId: 9, machineName: '西-1.5', program: 'G234.NC', quantity: 150, status: 1 }, + { rank: 10, machineId: 10, machineName: '东-2.8', program: 'H567.NC', quantity: 87, status: 1 }, +] + +const baseWorkerRank = [ + { rank: 1, workerId: 1, workerName: '张三', machineCount: 3, totalQuantity: 1240 }, + { rank: 2, workerId: 2, workerName: '李四', machineCount: 2, totalQuantity: 980 }, + { rank: 3, workerId: 3, workerName: '王五', machineCount: 4, totalQuantity: 870 }, + { rank: 4, workerId: 4, workerName: '赵六', machineCount: 2, totalQuantity: 650 }, + { rank: 5, workerId: 5, workerName: '孙七', machineCount: 3, totalQuantity: 520 }, +] + +const baseWorkshopProduction = [ + { workshopName: 'A栋', quantity: 1280, machineCount: 80, avgQuantity: 16.0 }, + { workshopName: 'B栋', quantity: 860, machineCount: 45, avgQuantity: 19.1 }, + { workshopName: 'C栋', quantity: 707, machineCount: 35, avgQuantity: 20.2 }, +] const mock: MockMethod[] = [ { @@ -35,38 +76,27 @@ const mock: MockMethod[] = [ { url: '/mock-api/admin/dashboard/machine-rank', method: 'get', - response: { - code: 0, - data: { - items: [ - { rank: 1, machineId: 1, machineName: '西-1.8', program: '1566.NC', quantity: 580, status: 1 }, - { rank: 2, machineId: 2, machineName: '西-1.10', program: 'O123.NC', quantity: 420, status: 1 }, - { rank: 3, machineId: 3, machineName: '东-2.0', program: 'A456.NC', quantity: 380, status: 1 }, - { rank: 4, machineId: 4, machineName: '东-2.5', program: 'B789.NC', quantity: 310, status: 0 }, - { rank: 5, machineId: 5, machineName: '南-3.1', program: 'C012.NC', quantity: 290, status: 1 }, - { rank: 6, machineId: 6, machineName: '南-3.2', program: 'D345.NC', quantity: 240, status: 1 }, - { rank: 7, machineId: 7, machineName: '北-4.0', program: 'E678.NC', quantity: 210, status: 1 }, - { rank: 8, machineId: 8, machineName: '北-4.1', program: 'F901.NC', quantity: 180, status: 0 }, - { rank: 9, machineId: 9, machineName: '西-1.5', program: 'G234.NC', quantity: 150, status: 1 }, - { rank: 10, machineId: 10, machineName: '东-2.8', program: 'H567.NC', quantity: 87, status: 1 }, - ], - }, + response: (req: MockRequest) => { + const m = getMultiplier(req.query.startDate, req.query.endDate) + return { + code: 0, + data: { + items: baseMachineRank.map(r => ({ ...r, quantity: Math.round(r.quantity * m) })), + }, + } }, }, { url: '/mock-api/admin/dashboard/worker-rank', method: 'get', - response: { - code: 0, - data: { - items: [ - { rank: 1, workerId: 1, workerName: '张三', machineCount: 3, totalQuantity: 1240 }, - { rank: 2, workerId: 2, workerName: '李四', machineCount: 2, totalQuantity: 980 }, - { rank: 3, workerId: 3, workerName: '王五', machineCount: 4, totalQuantity: 870 }, - { rank: 4, workerId: 4, workerName: '赵六', machineCount: 2, totalQuantity: 650 }, - { rank: 5, workerId: 5, workerName: '孙七', machineCount: 3, totalQuantity: 520 }, - ], - }, + response: (req: MockRequest) => { + const m = getMultiplier(req.query.startDate, req.query.endDate) + return { + code: 0, + data: { + items: baseWorkerRank.map(r => ({ ...r, totalQuantity: Math.round(r.totalQuantity * m) })), + }, + } }, }, // ===== 新增:产量趋势(近7天) ===== @@ -92,15 +122,18 @@ const mock: MockMethod[] = [ { url: '/mock-api/admin/dashboard/workshop-production', method: 'get', - response: { - code: 0, - data: { - items: [ - { workshopName: 'A栋', quantity: 1280, machineCount: 80, avgQuantity: 16.0 }, - { workshopName: 'B栋', quantity: 860, machineCount: 45, avgQuantity: 19.1 }, - { workshopName: 'C栋', quantity: 707, machineCount: 35, avgQuantity: 20.2 }, - ], - }, + response: (req: MockRequest) => { + const m = getMultiplier(req.query.startDate, req.query.endDate) + return { + code: 0, + data: { + items: baseWorkshopProduction.map(w => ({ + ...w, + quantity: Math.round(w.quantity * m), + avgQuantity: Math.round(w.avgQuantity * m * 10) / 10, + })), + }, + } }, }, // ===== 新增:机床状态分布 ===== diff --git a/frontend/src/views/dashboard/DashboardPage.vue b/frontend/src/views/dashboard/DashboardPage.vue index 17d4ec2..0fea062 100644 --- a/frontend/src/views/dashboard/DashboardPage.vue +++ b/frontend/src/views/dashboard/DashboardPage.vue @@ -134,7 +134,21 @@ - +
@@ -181,8 +195,17 @@ @@ -206,8 +229,17 @@ @@ -223,7 +255,7 @@