gtsoft-snail-job-server/frontend/src/views/dashboard/JobAnalysis.vue
zhengweilin 5b985a0231 fix: 2.5.0:
1、重复、定时任务批量统计批量新增或更新改为普通新增或更新
2023-12-11 22:20:32 +08:00

167 lines
4.9 KiB
Vue

<template>
<div class="antd-pro-pages-dashboard-analysis-twoColLayout" :class="!isMobile && 'desktop'">
<a-row>
<a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
<g2-job-line ref="jobViewChart" name="G2JobLine" />
</a-col>
<a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
<rank-list :title="$t('dashboard.analysis.sales-ranking')" :list="rankList" />
</a-col>
</a-row>
<a-row :gutter="24" type="flex" :style="{ marginTop: '24px' }">
<a-col :xl="12" :lg="24" :md="24" :sm="24" :xs="24">
<a-card :loading="loading" :bordered="false" :title="$t('dashboard.analysis.online-top-search')" :style="{ height: '100%' }">
<s-table
ref="table"
size="default"
:rowKey="(record,index) => index"
:columns="columns"
:data="loadData"
:scroll="{ x: 200 }"
>
</s-table>
</a-card>
</a-col>
<a-col :xl="12" :lg="24" :md="24" :sm="24" :xs="24">
<a-card class="antd-pro-pages-dashboard-analysis-salesCard" :loading="loading" :bordered="false" :title="$t('dashboard.analysis.the-proportion-of-sales')" :style="{ height: '100%' }">
<h4>{{ $t('dashboard.analysis.job.sales') }}</h4>
<div>
<div>
<v-chart :force-fit="true" :height="405" :data="pieData" :scale="pieScale" >
<v-tooltip :showTitle="false" dataKey="value*percent" />
<v-axis />
<v-legend dataKey="value" />
<v-pie position="percent" color="value" :vStyle="pieStyle" />
<v-coord type="theta" :radius="0.95" :innerRadius="0.7" />
</v-chart>
</div>
</div>
</a-card>
</a-col>
</a-row>
</div>
</template>
<script>
import {
RankList,
STable
} from '@/components'
import { getAllGroupNameList, getDashboardJobLine } from '@/api/manage'
import { baseMixin } from '@/store/app-mixin'
import G2JobLine from '@/components/Charts/JobLine.vue'
import moment from 'moment'
export default {
name: 'JobAnalysis',
mixins: [ baseMixin ],
components: {
G2JobLine,
RankList,
STable
},
data () {
return {
loading: true,
rankList: [],
taskList: [],
dashboardLineResponseDOList: [],
type: 'WEEK',
groupName: '',
startTime: '',
endTime: '',
successNum: 0,
failNum: 0,
stopNum: 0,
cancelNum: 0,
total: 0,
groupNameList: [],
pieScale: [{
dataKey: 'percent',
min: 0,
formatter: '.0%'
}],
pieData: [],
pieStyle: {
stroke: '#fff',
lineWidth: 1
},
columns: [
{
title: '组名称',
dataIndex: 'groupName'
},
{
title: '运行中任务数',
dataIndex: 'run'
},
{
title: '总任务数',
dataIndex: 'total'
}
],
loadData: (parameter) => {
return getDashboardJobLine(Object.assign(parameter)).then((res) => {
this.rankList = res.data.rankList
return res.data.taskList
})
}
}
},
mounted () {
this.$bus.$on('job', (res) => {
this.total = 0
this.successNum = 0
this.failNum = 0
this.stopNum = 0
this.cancelNum = 0
this.rankList = res.data.rankList
this.taskList = res.data.taskList
res.data.dashboardLineResponseDOList.forEach(res => {
this.successNum += res.success
this.failNum += res.failNum
this.stopNum += res.stopNum
this.cancelNum += res.cancelNum
})
this.total = this.successNum + this.failNum + this.stopNum + this.cancelNum
this.pieData = [
{ value: 'SUCCESS', name: this.successNum, percent: this.successNum / this.total },
{ value: 'FAIL', name: this.failNum, percent: this.failNum / this.total },
{ value: 'STOP', name: this.stopNum, percent: this.stopNum / this.total },
{ value: 'CANCEL', name: this.cancelNum, percent: this.cancelNum / this.total }
]
})
},
methods: {
moment,
dataHandler (type) {
this.type = type
this.$refs.jobViewChart.getDashboardJobLine(this.groupName, this.type, this.startTime, this.endTime)
},
handleChange (value) {
this.groupName = value
this.$refs.jobViewChart.getDashboardJobLine(this.groupName, this.type, this.startTime, this.endTime)
},
dateChange (date, dateString) {
this.startTime = dateString[0]
this.endTime = dateString[1]
this.type = this.startTime === '' ? 'WEEK' : 'OTHERS'
this.$refs.jobViewChart.getDashboardJobLine(this.groupName, this.type, this.startTime, this.endTime)
}
},
created () {
getAllGroupNameList().then(res => {
this.groupNameList = res.data
})
setTimeout(() => {
this.loading = !this.loading
}, 1000)
}
}
</script>
<style lang='less' scoped>
@import 'Analysis.less';
</style>