| | |
| | | import DateTypeSwitch from './DateTypeSwitch.vue' |
| | | import Echarts from '@/components/Echarts/echarts.vue' |
| | | |
| | | const dateType = ref(1) // 1=周 2=月 3=季度 |
| | | const dateType = ref(1) |
| | | |
| | | const chartStyle = { |
| | | width: '100%', |
| | | height: '140%', |
| | | } |
| | | |
| | | const grid = { left: '10%', right: '4%', bottom: '3%', top: '10%', containLabel: true } |
| | | const grid = { left: '3%', right: '4%', bottom: '3%', top: '10%', containLabel: true } |
| | | |
| | | const barLegend = { |
| | | show: true, |
| | | textStyle: { color: '#B8C8E0' }, |
| | | data: ['产量', '工资', '合格率'], |
| | | data: ['完成数量', '工资金额', '合格率'], |
| | | } |
| | | |
| | | // 柱状图:产量、工资;折线图:合格率(绿色) |
| | | const chartSeries = ref([ |
| | | { |
| | | name: '产量', |
| | | name: '完成数量', |
| | | type: 'bar', |
| | | barWidth: 20, |
| | | barGap: '40%', |
| | | yAxisIndex: 0, |
| | | emphasis: { focus: 'series' }, |
| | | itemStyle: { |
| | | color: { |
| | |
| | | data: [], |
| | | }, |
| | | { |
| | | name: '工资', |
| | | name: '工资金额', |
| | | type: 'bar', |
| | | barGap: '40%', |
| | | barWidth: 20, |
| | | yAxisIndex: 1, |
| | | emphasis: { focus: 'series' }, |
| | | itemStyle: { |
| | | color: { |
| | |
| | | { |
| | | name: '合格率', |
| | | type: 'line', |
| | | yAxisIndex: 2, |
| | | yAxisIndex: 1, |
| | | showSymbol: true, |
| | | symbol: 'circle', |
| | | symbolSize: 8, |
| | |
| | | }, |
| | | ]) |
| | | |
| | | const tooltip = { |
| | | trigger: 'axis', |
| | | axisPointer: { type: 'cross' }, |
| | | formatter(params) { |
| | | let result = params[0].axisValueLabel + '<br/>' |
| | | params.forEach((item) => { |
| | | let unit = '件' |
| | | if (item.seriesName === '合格率') unit = '%' |
| | | else if (item.seriesName === '工资') unit = '元' |
| | | result += `<div>${item.marker} ${item.seriesName}: ${item.value}${unit}</div>` |
| | | }) |
| | | return result |
| | | }, |
| | | } |
| | | |
| | | const xAxis1 = ref([ |
| | | { type: 'category', axisTick: { show: false }, axisLabel: { color: '#B8C8E0' }, data: [] }, |
| | | ]) |
| | | |
| | | const yAxis1 = [ |
| | | { type: 'value', name: '产量(件)', position: 'left', axisLabel: { color: '#B8C8E0' }, nameTextStyle: { color: '#B8C8E0' } }, |
| | | { type: 'value', name: '工资(元)', position: 'left', offset: 50, axisLabel: { color: '#B8C8E0' }, nameTextStyle: { color: '#B8C8E0' } }, |
| | | { |
| | | type: 'value', |
| | | name: '数量/金额', |
| | | axisLabel: { color: '#B8C8E0' }, |
| | | nameTextStyle: { color: '#B8C8E0' }, |
| | | // splitLine: { lineStyle: { color: 'rgba(184, 200, 224, 0.2)' } }, |
| | | }, |
| | | { |
| | | type: 'value', |
| | | name: '合格率(%)', |
| | | position: 'right', |
| | | min: 0, |
| | | max: 100, |
| | | axisLabel: { color: '#B8C8E0', formatter: '{value}%' }, |
| | |
| | | }, |
| | | ] |
| | | |
| | | const tooltip = { |
| | | trigger: 'axis', |
| | | axisPointer: { type: 'cross' }, |
| | | formatter(params) { |
| | | let result = params[0].axisValueLabel + '<br/>' |
| | | params.forEach((item) => { |
| | | const unit = item.seriesName === '合格率' ? '%' : (item.seriesName === '工资金额' ? ' 元' : ' 个') |
| | | result += `<div>${item.marker} ${item.seriesName}: ${item.value}${unit}</div>` |
| | | }) |
| | | return result |
| | | }, |
| | | } |
| | | |
| | | const handleDateTypeChange = () => { |
| | | fetchData() |
| | | } |
| | |
| | | const fetchData = () => { |
| | | productionAccountingAnalysis({ type: dateType.value }) |
| | | .then((res) => { |
| | | console.log('res ======> ', res) |
| | | if (res.code === 200 && Array.isArray(res.data)) { |
| | | const items = res.data |
| | | |
| | | if (!Array.isArray(res?.data)) return |
| | | |
| | | const items = res.data |
| | | |
| | | xAxis1.value[0].data = items.map(d => d.dateStr) |
| | | |
| | | // 产量 |
| | | chartSeries.value[0].data = items.map(d => Number(d.numberOfCompleted) || 0) |
| | | |
| | | // 工资 |
| | | chartSeries.value[1].data = items.map(d => Number(d.amount) || 0) |
| | | |
| | | // 合格率 |
| | | chartSeries.value[2].data = items.map(d => Number(d.passRate) || 0) |
| | | xAxis1.value[0].data = items.map(item => item.dateStr) |
| | | chartSeries.value[0].data = items.map(item => Number(item.numberOfCompleted) || 0) |
| | | chartSeries.value[1].data = items.map(item => Number(item.amount) || 0) |
| | | chartSeries.value[2].data = items.map(item => Number(item.passRate) || 0) |
| | | } |
| | | }) |
| | | .catch((err) => { |
| | | console.error('获取产量、工资与合格率数据失败:', err) |
| | | console.error('数据加载失败', err) |
| | | }) |
| | | } |
| | | |
| | | |
| | | onMounted(() => { |
| | | fetchData() |
| | |
| | | padding: 18px; |
| | | width: 100%; |
| | | height: 449px; |
| | | box-sizing: border-box; |
| | | } |
| | | </style> |
| | | </style> |