'init'
This commit is contained in:
@@ -0,0 +1,143 @@
|
||||
<!--
|
||||
* @Author: gtz
|
||||
* @Date: 2022-01-19 15:58:17
|
||||
* @LastEditors: zhp
|
||||
* @LastEditTime: 2022-01-24 09:18:01
|
||||
* @Description: file content
|
||||
* @FilePath: \mt-bus-fe\src\views\OperationalOverview\components\baseContainer\index.vue
|
||||
-->
|
||||
<template>
|
||||
<div class="base-container" :style="{height: height * beilv + 'px', fontSize: 12 * beilv + 'px'}">
|
||||
<div class="line" />
|
||||
<div class="line line-vertical" />
|
||||
<div class="line line-right" />
|
||||
<div class="line line-right-vertical" />
|
||||
<div class="line line-bottom" />
|
||||
<div class="line line-bottom-vertical" />
|
||||
<div class="line line-bottom-right" />
|
||||
<div class="line line-bottom-right-vertical" />
|
||||
<div class="bar-item">
|
||||
<div v-if="title" class="bar-title">
|
||||
<span>
|
||||
<svg-icon :icon-class="titleIcon" style="font-size: 1.5em; position: relative; top: .08em" />
|
||||
{{ title }}
|
||||
</span>
|
||||
</div>
|
||||
<div class="bar-content">
|
||||
<slot />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'BaseContainer',
|
||||
props: {
|
||||
title: {
|
||||
type: String,
|
||||
default: ''
|
||||
},
|
||||
titleIcon: {
|
||||
type: String,
|
||||
default: ''
|
||||
},
|
||||
height: {
|
||||
type: Number,
|
||||
default: 200
|
||||
},
|
||||
baseSize: {
|
||||
type: Number,
|
||||
default: 12
|
||||
},
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
curIndex: 0
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
},
|
||||
methods: {
|
||||
changeTab(num) {
|
||||
this.curIndex = num
|
||||
this.$emit('tabSelect', num)
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.base-container {
|
||||
color: #fff;
|
||||
width: 100%;
|
||||
background-color: rgba($color: #061027, $alpha: 0.15);
|
||||
position: relative;
|
||||
border: 2px solid;
|
||||
border-image: linear-gradient(90deg, rgba(82, 255, 241, 0.6), rgba(95, 190, 249, 0), rgba(82, 255, 241, 0.6)) 2 2;
|
||||
.line {
|
||||
position: absolute;
|
||||
border-top: 4px solid #52FFF1;
|
||||
width: 2em;
|
||||
top: -.25em;
|
||||
left: -.25em;
|
||||
&-vertical {
|
||||
top: calc(-5em / 12);
|
||||
left: calc(-1em / 12);
|
||||
transform: rotate(90deg);
|
||||
transform-origin: left;
|
||||
}
|
||||
&-right {
|
||||
top: -.25em;
|
||||
right: -.25em;
|
||||
left: inherit;
|
||||
}
|
||||
&-right-vertical {
|
||||
top: calc(-5em / 12);
|
||||
right: calc(-1em / 12);
|
||||
left: inherit;
|
||||
transform: rotate(-90deg);
|
||||
transform-origin: right;
|
||||
}
|
||||
&-bottom {
|
||||
top: inherit;
|
||||
left: -.25em;
|
||||
bottom: -.25em;
|
||||
}
|
||||
&-bottom-vertical {
|
||||
top: inherit;
|
||||
left: calc(-1em / 12);
|
||||
bottom: calc(-5em / 12);
|
||||
transform: rotate(-90deg);
|
||||
transform-origin: left;
|
||||
}
|
||||
&-bottom-right {
|
||||
top: inherit;
|
||||
left: inherit;
|
||||
right: -.25em;
|
||||
bottom: -.25em;
|
||||
}
|
||||
&-bottom-right-vertical {
|
||||
top: inherit;
|
||||
left: inherit;
|
||||
right: calc(-1em / 12);
|
||||
bottom: calc(-5em / 12);
|
||||
transform: rotate(90deg);
|
||||
transform-origin: right;
|
||||
}
|
||||
}
|
||||
.bar-title {
|
||||
width: 100%;
|
||||
color: #52FFF1;
|
||||
font-size: 1.5em;
|
||||
padding: .67em;
|
||||
}
|
||||
// .bar-content{
|
||||
// padding: 1em;
|
||||
// }
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,58 @@
|
||||
<template>
|
||||
<div class="dataShowBox" :style="{height: height * beilv + 'px'}">
|
||||
<el-row>
|
||||
<el-col :span="7" :style="{paddingTop: 24 * beilv + 'px'}">
|
||||
<div class="numStyle" :style="{marginBottom: 8 * beilv + 'px', fontSize: 32 * beilv + 'px'}">12131</div>
|
||||
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">品类1</div>
|
||||
</el-col>
|
||||
<el-col :span="1">
|
||||
<span class="aa" :style="{height: 80 * beilv + 'px', marginTop: 16 * beilv + 'px'}" />
|
||||
</el-col>
|
||||
<el-col :span="7" :style="{paddingTop: 24 * beilv + 'px'}">
|
||||
<div class="numStyle" :style="{marginBottom: 8 * beilv + 'px', fontSize: 32 * beilv + 'px'}">12131</div>
|
||||
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">品类2</div>
|
||||
</el-col>
|
||||
<el-col :span="1">
|
||||
<span class="aa" :style="{height: 80 * beilv + 'px', marginTop: 16 * beilv + 'px'}" />
|
||||
</el-col>
|
||||
<el-col :span="7" :style="{paddingTop: 24 * beilv + 'px'}">
|
||||
<div class="numStyle" :style="{marginBottom: 8 * beilv + 'px', fontSize: 32 * beilv + 'px'}">12131</div>
|
||||
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">品类3</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
props: {
|
||||
height: {
|
||||
type: Number,
|
||||
default: 200
|
||||
},
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style lang="scss" scoped>
|
||||
.dataShowBox {
|
||||
text-align: center;
|
||||
width: 100%;
|
||||
background: rgba(0, 255, 241, 0.03);
|
||||
box-shadow: inset 0px 0px 20px 0px rgba(255, 255, 255, 0.22);
|
||||
}
|
||||
.numStyle {
|
||||
color: #52fff1;
|
||||
}
|
||||
.fontStyle {
|
||||
color: #ffffff;
|
||||
}
|
||||
.aa {
|
||||
display: block;
|
||||
width: 1px;
|
||||
background: linear-gradient(153deg, rgba(153, 255, 249, 0) 0%, #60fff1 46%, rgba(96, 255, 241, 0) 100%);
|
||||
margin: auto;
|
||||
}
|
||||
</style>
|
||||
@@ -0,0 +1,71 @@
|
||||
<template>
|
||||
<div class="dataShowMain" :style="{height: height * beilv + 'px'}">
|
||||
<el-row>
|
||||
<el-col :span="7" :style="{paddingTop: 64 * beilv + 'px'}">
|
||||
<div class="numStyle" :style="{marginBottom: 16 * beilv + 'px'}">
|
||||
<span :style="{fontSize: 24 * beilv + 'px'}">¥</span>
|
||||
<span :style="{fontSize: 36 * beilv + 'px'}">400,000.</span>
|
||||
<span :style="{fontSize: 24 * beilv + 'px'}">00</span>
|
||||
</div>
|
||||
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">— 年度销售目标 —</div>
|
||||
</el-col>
|
||||
<el-col :span="1">
|
||||
<span class="aa" :style="{height: 160 * beilv + 'px', marginTop: 28 * beilv + 'px'}" />
|
||||
</el-col>
|
||||
<el-col :span="7" :style="{paddingTop: 64 * beilv + 'px'}">
|
||||
<div class="numStyle" :style="{marginBottom: 16 * beilv + 'px'}">
|
||||
<span :style="{fontSize: 24 * beilv + 'px'}">¥</span>
|
||||
<span :style="{fontSize: 36 * beilv + 'px'}">417,997.</span>
|
||||
<span :style="{fontSize: 24 * beilv + 'px'}">00</span>
|
||||
</div>
|
||||
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">— 年度完成值 —</div>
|
||||
</el-col>
|
||||
<el-col :span="1">
|
||||
<span class="aa" :style="{height: 160 * beilv + 'px', marginTop: 28 * beilv + 'px'}" />
|
||||
</el-col>
|
||||
<el-col :span="7" :style="{paddingTop: 64 * beilv + 'px'}">
|
||||
<div class="numStyle" :style="{marginBottom: 16 * beilv + 'px'}">
|
||||
<span :style="{fontSize: 36 * beilv + 'px'}">104.</span>
|
||||
<span :style="{fontSize: 24 * beilv + 'px'}">5</span>
|
||||
<span :style="{fontSize: 36 * beilv + 'px'}">%</span>
|
||||
</div>
|
||||
<div class="fontStyle" :style="{fontSize: 18 * beilv + 'px'}">— 目标完成率 —</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
props: {
|
||||
height: {
|
||||
type: Number,
|
||||
default: 200
|
||||
},
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped>
|
||||
.dataShowMain {
|
||||
text-align: center;
|
||||
height: 90px;
|
||||
background: rgba(0, 255, 241, 0.03);
|
||||
box-shadow: inset 0px 0px 20px 0px rgba(255, 255, 255, 0.22);
|
||||
}
|
||||
.numStyle {
|
||||
color: #fff;
|
||||
font-weight: 600;
|
||||
}
|
||||
.fontStyle {
|
||||
color: #52fff1;
|
||||
}
|
||||
.aa {
|
||||
display: block;
|
||||
width: 1px;
|
||||
background: linear-gradient(153deg, rgba(153, 255, 249, 0) 0%, #60fff1 46%, rgba(96, 255, 241, 0) 100%);
|
||||
margin: auto;
|
||||
}
|
||||
</style>
|
||||
191
src/views/orderManage/orderMonitoring/components/lineChart.vue
Normal file
191
src/views/orderManage/orderMonitoring/components/lineChart.vue
Normal file
@@ -0,0 +1,191 @@
|
||||
<template>
|
||||
<div id="monthChart" :style="{ height: height * beilv + 'px', width:width}" />
|
||||
</template>
|
||||
<script>
|
||||
import echarts from 'echarts'
|
||||
import resize from './mixins/resize'
|
||||
export default {
|
||||
mixins: [resize],
|
||||
props: {
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
},
|
||||
height: {
|
||||
type: String,
|
||||
default: '300px'
|
||||
},
|
||||
width: {
|
||||
type: String,
|
||||
default: '100%'
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
chart: null
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.$nextTick(() => {
|
||||
this.initChart()
|
||||
})
|
||||
},
|
||||
methods: {
|
||||
initChart() {
|
||||
this.chart = echarts.init(document.getElementById('monthChart'))
|
||||
this.chart.setOption({
|
||||
legend: {
|
||||
itemWidth: 15, // 设置legend图标的宽度
|
||||
itemHeight: 15, // 设置legend图标的高度
|
||||
right: '10%',
|
||||
data: ['求和项:金额', '求和项:数量'],
|
||||
textStyle: {
|
||||
color: '#ffffff80'
|
||||
}
|
||||
},
|
||||
xAxis: {
|
||||
type: 'category',
|
||||
data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
|
||||
axisLine: {
|
||||
lineStyle: {
|
||||
color: '#ffffff80'
|
||||
},
|
||||
show: false
|
||||
},
|
||||
axisTick: {
|
||||
show: false
|
||||
}
|
||||
},
|
||||
yAxis: [
|
||||
{
|
||||
type: 'value',
|
||||
name: '金额',
|
||||
position: 'left',
|
||||
alignTicks: true,
|
||||
axisLine: {
|
||||
lineStyle: {
|
||||
type: 'solid',
|
||||
color: '#21325980'
|
||||
},
|
||||
show: true
|
||||
},
|
||||
splitLine: {
|
||||
lineStyle: {
|
||||
type: 'solid',
|
||||
color: '#21325980'
|
||||
}
|
||||
},
|
||||
axisTick: {
|
||||
show: false
|
||||
},
|
||||
axisLabel: {
|
||||
// y轴文字的配置
|
||||
textStyle: {
|
||||
color: '#ffffff80' // Y轴内容文字颜色
|
||||
},
|
||||
formatter: '{value} W'
|
||||
},
|
||||
nameTextStyle: {
|
||||
color: '#FFFFFF80',
|
||||
fontSize: 12
|
||||
}
|
||||
},
|
||||
{
|
||||
type: 'value',
|
||||
name: '数量',
|
||||
position: 'right',
|
||||
alignTicks: true,
|
||||
splitLine: {
|
||||
lineStyle: {
|
||||
type: 'dashed',
|
||||
color: '#21325980'
|
||||
}
|
||||
},
|
||||
axisLine: {
|
||||
lineStyle: {
|
||||
type: 'dashed',
|
||||
color: '#21325980'
|
||||
}
|
||||
},
|
||||
axisTick: {
|
||||
show: false
|
||||
},
|
||||
axisLabel: {
|
||||
// y轴文字的配置
|
||||
textStyle: {
|
||||
color: '#ffffff80' // Y轴内容文字颜色
|
||||
}
|
||||
},
|
||||
nameTextStyle: {
|
||||
color: '#FFFFFF80',
|
||||
fontSize: 12
|
||||
}
|
||||
}
|
||||
],
|
||||
series: [
|
||||
{
|
||||
name: '求和项:金额',
|
||||
data: [12, 20, 15, 8, 7, 11, 13, 11, 9, 10.5, 13, 15],
|
||||
type: 'bar',
|
||||
barMaxWidth: 'auto',
|
||||
barWidth: 12,
|
||||
itemStyle: {
|
||||
color: {
|
||||
x: 0,
|
||||
y: 0,
|
||||
x2: 1,
|
||||
y2: 0,
|
||||
type: 'linear',
|
||||
colorStops: [
|
||||
{
|
||||
offset: 0,
|
||||
color: '#1EBEAC' // 0% 处的颜色
|
||||
},
|
||||
{
|
||||
offset: 1,
|
||||
color: '#52FDEA' // 100% 处的颜色
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
data: [12, 20, 15, 8, 7, 11, 13, 11, 9, 10.5, 13, 15],
|
||||
type: 'pictorialBar',
|
||||
barMaxWidth: '20',
|
||||
symbolPosition: 'end',
|
||||
symbol: 'diamond',
|
||||
itemStyle: {
|
||||
// 设置symbol的颜色
|
||||
normal: {
|
||||
color: '#A4FFF5'
|
||||
}
|
||||
},
|
||||
symbolOffset: [0, '-50%'],
|
||||
symbolSize: [12, 10],
|
||||
zlevel: 2
|
||||
},
|
||||
{
|
||||
name: '求和项:数量',
|
||||
type: 'line',
|
||||
yAxisIndex: 1,
|
||||
data: [90, 210, 180, 120, 60, 90, 150, 120, 40, 130, 145, 90],
|
||||
showSymbol: true,
|
||||
symbol: 'circle',
|
||||
symbolSize: 5,
|
||||
color: '#DE9134',
|
||||
areaStyle: {
|
||||
normal: {
|
||||
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
|
||||
{ offset: 0, color: 'rgba(255, 145, 52, 1)' }, // 顶端颜色
|
||||
{ offset: 1, color: 'rgba(255, 145, 52, 0.1)' } // 底部颜色
|
||||
])
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
@@ -0,0 +1,55 @@
|
||||
import { debounce } from '@/utils'
|
||||
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
$_sidebarElm: null,
|
||||
$_resizeHandler: null
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.$_resizeHandler = debounce(() => {
|
||||
if (this.chart) {
|
||||
this.chart.resize()
|
||||
}
|
||||
}, 100)
|
||||
this.$_initResizeEvent()
|
||||
this.$_initSidebarResizeEvent()
|
||||
},
|
||||
beforeDestroy() {
|
||||
this.$_destroyResizeEvent()
|
||||
this.$_destroySidebarResizeEvent()
|
||||
},
|
||||
// to fixed bug when cached by keep-alive
|
||||
// https://github.com/PanJiaChen/vue-element-admin/issues/2116
|
||||
activated() {
|
||||
this.$_initResizeEvent()
|
||||
this.$_initSidebarResizeEvent()
|
||||
},
|
||||
deactivated() {
|
||||
this.$_destroyResizeEvent()
|
||||
this.$_destroySidebarResizeEvent()
|
||||
},
|
||||
methods: {
|
||||
// use $_ for mixins properties
|
||||
// https://vuejs.org/v2/style-guide/index.html#Private-property-names-essential
|
||||
$_initResizeEvent() {
|
||||
window.addEventListener('resize', this.$_resizeHandler)
|
||||
},
|
||||
$_destroyResizeEvent() {
|
||||
window.removeEventListener('resize', this.$_resizeHandler)
|
||||
},
|
||||
$_sidebarResizeHandler(e) {
|
||||
if (e.propertyName === 'width') {
|
||||
this.$_resizeHandler()
|
||||
}
|
||||
},
|
||||
$_initSidebarResizeEvent() {
|
||||
this.$_sidebarElm = document.getElementsByClassName('sidebar-container')[0]
|
||||
this.$_sidebarElm && this.$_sidebarElm.addEventListener('transitionend', this.$_sidebarResizeHandler)
|
||||
},
|
||||
$_destroySidebarResizeEvent() {
|
||||
this.$_sidebarElm && this.$_sidebarElm.removeEventListener('transitionend', this.$_sidebarResizeHandler)
|
||||
}
|
||||
}
|
||||
}
|
||||
160
src/views/orderManage/orderMonitoring/components/pieChart.vue
Normal file
160
src/views/orderManage/orderMonitoring/components/pieChart.vue
Normal file
@@ -0,0 +1,160 @@
|
||||
<template>
|
||||
<div>
|
||||
<div :id="id" :style="{ height: height * beilv + 'px', width:width}" />
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import echarts from 'echarts'
|
||||
import resize from './mixins/resize'
|
||||
const color1 = new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
1,
|
||||
0,
|
||||
0,
|
||||
[
|
||||
{ offset: 0, color: '#E77657' },
|
||||
{ offset: 1, color: '#53222A' }
|
||||
],
|
||||
false
|
||||
)
|
||||
const color2 = new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
0,
|
||||
1,
|
||||
0,
|
||||
[
|
||||
{ offset: 0, color: '#31AFF0' },
|
||||
{ offset: 1, color: '#0B3A52' }
|
||||
],
|
||||
false
|
||||
)
|
||||
const color3 = new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
1,
|
||||
[
|
||||
{ offset: 0, color: '#F9A237' },
|
||||
{ offset: 1, color: '#6E4A27' }
|
||||
],
|
||||
false
|
||||
)
|
||||
const color4 = new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
0,
|
||||
0,
|
||||
1,
|
||||
[
|
||||
{ offset: 0, color: '#7AEAE0' },
|
||||
{ offset: 1, color: '#18433F' }
|
||||
],
|
||||
false
|
||||
)
|
||||
export default {
|
||||
mixins: [resize],
|
||||
props: {
|
||||
id: {
|
||||
type: String,
|
||||
default: 'OverviewLine'
|
||||
},
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
},
|
||||
height: {
|
||||
type: String,
|
||||
default: '300px'
|
||||
},
|
||||
width: {
|
||||
type: String,
|
||||
default: '100%'
|
||||
},
|
||||
pieData: {
|
||||
type: Array,
|
||||
default: () => []
|
||||
},
|
||||
formatter: {
|
||||
type: String,
|
||||
default: '{firstLine|{b}} \n {secondLine|{c}}'
|
||||
},
|
||||
pieStyle: {
|
||||
type: Object,
|
||||
default: () => {}
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
chart: null
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.$nextTick(() => {
|
||||
this.initChart()
|
||||
})
|
||||
},
|
||||
beforeDestroy() {
|
||||
if (!this.chart) {
|
||||
return
|
||||
}
|
||||
this.chart.dispose()
|
||||
this.chart = null
|
||||
},
|
||||
methods: {
|
||||
initChart() {
|
||||
this.chart = echarts.init(document.getElementById(this.id))
|
||||
this.chart.setOption({
|
||||
tooltip: {
|
||||
trigger: 'item'
|
||||
},
|
||||
color: [color1, color2, color3, color4],
|
||||
series: [
|
||||
{
|
||||
name: 'Access From',
|
||||
type: 'pie',
|
||||
radius: ['60%', '90%'],
|
||||
hoverAnimation: false,
|
||||
itemStyle: {
|
||||
borderRadius: 0,
|
||||
borderWidth: 3,
|
||||
borderColor: '#060F20'
|
||||
},
|
||||
labelLine: {
|
||||
show: true,
|
||||
length: 0,
|
||||
length2: this.beilv * this.pieStyle.line_s,
|
||||
smooth: true,
|
||||
lineStyle: {
|
||||
width: 1,
|
||||
cap: 'butt'
|
||||
}
|
||||
},
|
||||
label: {
|
||||
formatter: this.pieStyle.formatter,
|
||||
minMargin: 5,
|
||||
rich: {
|
||||
firstLine: {
|
||||
fontSize: this.beilv * 14,
|
||||
lineHeight: this.beilv * 30,
|
||||
color: '#ffffff80'
|
||||
},
|
||||
secondLine: {
|
||||
fontSize: this.beilv * this.pieStyle.num_fs,
|
||||
color: '#fff'
|
||||
}
|
||||
}
|
||||
},
|
||||
data: this.pieStyle.pieData,
|
||||
emphasis: {
|
||||
itemStyle: {
|
||||
shadowBlur: 10,
|
||||
shadowOffsetX: 0,
|
||||
shadowColor: 'rgba(0, 0, 0, 0.5)'
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
@@ -0,0 +1,55 @@
|
||||
<template>
|
||||
<el-row class="progress-main-box">
|
||||
<el-col :span="24">
|
||||
<template v-for="(item,index) in productData">
|
||||
<el-row :key="index" :style="{marginBottom: 18 * beilv + 'px'}">
|
||||
<el-col :span="4" style="text-align: right;padding-right:5px">{{ item.name }}</el-col>
|
||||
<el-col :span="20">
|
||||
<div
|
||||
class="progress"
|
||||
:class="index%2===0?'progress1':'progress2'"
|
||||
:style="{height: 18 * beilv + 'px', width: item.percentage}"
|
||||
>
|
||||
{{ item.number }}
|
||||
</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</template>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
naem: 'progressBox',
|
||||
props: {
|
||||
productData: {
|
||||
type: Array,
|
||||
default: () => []
|
||||
},
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped>
|
||||
.progress-main-box {
|
||||
padding: 0 10px;
|
||||
}
|
||||
.progress {
|
||||
text-align: right;
|
||||
line-height: 18px;
|
||||
border-radius: 5px;
|
||||
padding-right: 5px;
|
||||
}
|
||||
.progress1 {
|
||||
background: linear-gradient(270deg, #83f7ec 0%, rgba(76, 236, 213, 0.05) 100%);
|
||||
}
|
||||
.progress2 {
|
||||
background: linear-gradient(270deg, #3ac6fc 0%, rgba(56, 195, 255, 0.05) 100%);
|
||||
}
|
||||
</style>
|
||||
204
src/views/orderManage/orderMonitoring/components/ringChart.vue
Normal file
204
src/views/orderManage/orderMonitoring/components/ringChart.vue
Normal file
@@ -0,0 +1,204 @@
|
||||
<template>
|
||||
<div class="ringChartContainer">
|
||||
<ul v-if="orderList.length > 0" class="pieBox">
|
||||
<li v-for="(item,index) in orderList" :key="index">
|
||||
<div>
|
||||
<span class="title">{{ item.name }}</span>
|
||||
</div>
|
||||
<div :id="item.id" style="height:250px;width:250px" />
|
||||
</li>
|
||||
</ul>
|
||||
<div v-else class="imgBox">
|
||||
<img src="./../../../../assets/img/empty.png" alt="">
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import echarts from 'echarts'
|
||||
import i18n from '@/lang'
|
||||
export default {
|
||||
props: {
|
||||
orderList: {
|
||||
type: Array,
|
||||
default: () => {
|
||||
return []
|
||||
}
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
dataS: []
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
},
|
||||
methods: {
|
||||
initChart() {
|
||||
for (const item of this.orderList) {
|
||||
var chartDom = document.getElementById(item.id)
|
||||
var myChart = echarts.init(chartDom)
|
||||
var outQuantity = item.outQuantity ? item.outQuantity : 0 // 加工数量
|
||||
var scrapQuantity = item.scrapQuantity ? item.scrapQuantity : 0 // 损坏数量
|
||||
var planQuantity = item.planQuantity ? item.planQuantity : 0 // 计划加工量
|
||||
var syQuantity = (planQuantity - outQuantity - scrapQuantity) > 0 ? (planQuantity - outQuantity - scrapQuantity) : 0// 剩余数量
|
||||
var option = {
|
||||
color: ['#2C3AAE', '#C5E951', '#DCE4F1'],
|
||||
tooltip: {
|
||||
trigger: 'item'
|
||||
},
|
||||
legend: {
|
||||
icon: 'circle',
|
||||
bottom: '5%',
|
||||
left: 'center',
|
||||
itemWidth: 8,
|
||||
itemHeight: 8
|
||||
},
|
||||
series: [
|
||||
// 内圆1
|
||||
{
|
||||
type: 'pie',
|
||||
zlevel: 2, // 层级
|
||||
radius: ['46%', '50%'],
|
||||
center: ['50%', '45%'],
|
||||
itemStyle: {
|
||||
normal: {
|
||||
shadowBlur: 10,
|
||||
shadowColor: 'rgba(209, 204, 214, 0.64)',
|
||||
color: '#fff',
|
||||
label: {
|
||||
show: false
|
||||
},
|
||||
labelLine: {
|
||||
show: false
|
||||
}
|
||||
}
|
||||
},
|
||||
tooltip: {
|
||||
show: false
|
||||
},
|
||||
hoverAnimation: false,
|
||||
data: [100]
|
||||
},
|
||||
// 外环1
|
||||
{
|
||||
type: 'pie',
|
||||
radius: ['70%', '71%'],
|
||||
center: ['50%', '45%'],
|
||||
zlevel: 1, // 层级
|
||||
itemStyle: {
|
||||
normal: {
|
||||
shadowBlur: 10,
|
||||
shadowColor: 'rgba(0,0,0,.5)',
|
||||
color: '#fff',
|
||||
label: {
|
||||
show: false
|
||||
},
|
||||
labelLine: {
|
||||
show: false
|
||||
}
|
||||
}
|
||||
},
|
||||
tooltip: {
|
||||
show: false
|
||||
},
|
||||
hoverAnimation: false,
|
||||
data: [100]
|
||||
},
|
||||
// 占比环
|
||||
{
|
||||
name: 'Access From',
|
||||
type: 'pie',
|
||||
radius: ['50%', '70%'],
|
||||
center: ['50%', '45%'],
|
||||
clockWise: true,
|
||||
avoidLabelOverlap: false,
|
||||
hoverAnimation: false,
|
||||
silent: true,
|
||||
label: {
|
||||
normal: {
|
||||
show: true,
|
||||
position: 'center',
|
||||
color: '#9A9EBA',
|
||||
formatter: ['{a|' + planQuantity + '}', '{b|' + i18n.t('module.orderManage.orderMonitoring.orderQuantity') + '}'].join('\n\n'),
|
||||
rich: {
|
||||
a: {
|
||||
color: '#2F3AA7',
|
||||
fontSize: 24
|
||||
},
|
||||
b: {
|
||||
color: '#1E2AA8',
|
||||
fontSize: 12
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
labelLine: {
|
||||
show: false
|
||||
},
|
||||
data: [
|
||||
{
|
||||
value: outQuantity,
|
||||
name: i18n.t('module.orderManage.orderMonitoring.processingCapacity') + outQuantity,
|
||||
itemStyle: {
|
||||
normal: {
|
||||
color: '#2C3AAE'
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
value: scrapQuantity,
|
||||
name: i18n.t('module.orderManage.orderMonitoring.damageQuantity') + scrapQuantity,
|
||||
itemStyle: {
|
||||
normal: {
|
||||
color: '#C5E951'
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
value: syQuantity,
|
||||
itemStyle: {
|
||||
normal: {
|
||||
color: '#DCE4F1'
|
||||
}, // 默认颜色
|
||||
emphasis: {
|
||||
color: '#DCE4F1'
|
||||
} // hover 颜色
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
myChart.setOption(option, true)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
ul {
|
||||
list-style: none;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
.pieBox {
|
||||
display: flex;
|
||||
flex-flow: row wrap;
|
||||
}
|
||||
.pieBox > li {
|
||||
background-color: rgba(247, 248, 255, 0.7);
|
||||
margin: 0 16px 16px 0;
|
||||
padding: 16px;
|
||||
}
|
||||
.pieBox .title {
|
||||
font-size: 14px;
|
||||
font-family: PingFangSC-Semibold, PingFang SC;
|
||||
font-weight: 600;
|
||||
color: rgba(0, 0, 0, 0.85);
|
||||
}
|
||||
.imgBox {
|
||||
text-align: center;
|
||||
padding-top: 20px;
|
||||
}
|
||||
</style>
|
||||
200
src/views/orderManage/orderMonitoring/components/saleTop.vue
Normal file
200
src/views/orderManage/orderMonitoring/components/saleTop.vue
Normal file
@@ -0,0 +1,200 @@
|
||||
<template>
|
||||
<div id="saleTop" :style="{ height: height * beilv + 'px', width:width}" />
|
||||
</template>
|
||||
<script>
|
||||
import echarts from 'echarts'
|
||||
import resize from './mixins/resize'
|
||||
export default {
|
||||
mixins: [resize],
|
||||
props: {
|
||||
beilv: {
|
||||
type: Number,
|
||||
default: 1
|
||||
},
|
||||
height: {
|
||||
type: String,
|
||||
default: '300px'
|
||||
},
|
||||
width: {
|
||||
type: String,
|
||||
default: '100%'
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
chart: null
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.$nextTick(() => {
|
||||
this.initChart()
|
||||
})
|
||||
},
|
||||
beforeDestroy() {
|
||||
if (!this.chart) {
|
||||
return
|
||||
}
|
||||
this.chart.dispose()
|
||||
this.chart = null
|
||||
},
|
||||
methods: {
|
||||
initChart() {
|
||||
this.chart = echarts.init(document.getElementById('saleTop'))
|
||||
this.chart.setOption({
|
||||
tooltip: {
|
||||
trigger: 'axis',
|
||||
axisPointer: {
|
||||
type: 'shadow'
|
||||
}
|
||||
},
|
||||
grid: {
|
||||
left: '3%',
|
||||
right: '4%',
|
||||
bottom: '3%',
|
||||
containLabel: true
|
||||
},
|
||||
xAxis: [
|
||||
{
|
||||
type: 'category',
|
||||
data: ['员工2', '员工1', '员工3'],
|
||||
axisTick: {
|
||||
show: false
|
||||
},
|
||||
axisLine: {
|
||||
show: false,
|
||||
lineStyle: {
|
||||
color: '#fff'
|
||||
}
|
||||
}
|
||||
}
|
||||
],
|
||||
yAxis: [
|
||||
{
|
||||
type: 'value',
|
||||
show: false
|
||||
}
|
||||
],
|
||||
series: [
|
||||
{
|
||||
name: 'Direct',
|
||||
type: 'bar',
|
||||
barWidth: 32,
|
||||
itemStyle: {
|
||||
// 柱状颜色和圆角
|
||||
barBorderRadius: [16, 16, 16, 16] // (顺时针左上,右上,右下,左下)
|
||||
},
|
||||
label: {
|
||||
// 柱体上显示数值
|
||||
show: true, // 开启显示
|
||||
position: 'top', // 在上方显示
|
||||
textStyle: {
|
||||
// 数值样式
|
||||
fontSize: this.beilv * 22,
|
||||
color: '#FFF89F'
|
||||
},
|
||||
formatter: '{c}'
|
||||
},
|
||||
data: [
|
||||
{
|
||||
value: 100,
|
||||
itemStyle: {
|
||||
color: new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
1,
|
||||
0,
|
||||
0,
|
||||
[
|
||||
{ offset: 0, color: '#281B0E' },
|
||||
{ offset: 1, color: '#3AC6FC' }
|
||||
],
|
||||
false
|
||||
)
|
||||
}
|
||||
},
|
||||
{
|
||||
value: 205,
|
||||
itemStyle: {
|
||||
color: new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
1,
|
||||
0,
|
||||
0,
|
||||
[
|
||||
{ offset: 0, color: '#281B0E' },
|
||||
{ offset: 1, color: '#F9A237' }
|
||||
],
|
||||
false
|
||||
)
|
||||
}
|
||||
},
|
||||
{
|
||||
value: 152,
|
||||
itemStyle: {
|
||||
color: new echarts.graphic.LinearGradient(
|
||||
0,
|
||||
1,
|
||||
0,
|
||||
0,
|
||||
[
|
||||
{ offset: 0, color: '#281B0E' },
|
||||
{ offset: 1, color: '#83F7EC' }
|
||||
],
|
||||
false
|
||||
)
|
||||
}
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
type: 'pictorialBar',
|
||||
name: 'pictorial element',
|
||||
symbolSize: 50,
|
||||
z: 10,
|
||||
data: [
|
||||
{
|
||||
value: 100,
|
||||
symbol:
|
||||
'image://data:',
|
||||
xAxis: 0,
|
||||
symbolPosition: 'end',
|
||||
symbolOffset: [0, this.beilv * -200 + '%']
|
||||
},
|
||||
{
|
||||
value: 205,
|
||||
symbol:
|
||||
'image://',
|
||||
xAxis: 1,
|
||||
symbolPosition: 'end',
|
||||
symbolOffset: [0, this.beilv * -200 + '%']
|
||||
},
|
||||
{
|
||||
value: 152,
|
||||
symbol:
|
||||
'image://data:',
|
||||
xAxis: 2,
|
||||
symbolPosition: 'end',
|
||||
symbolOffset: [0, this.beilv * -200 + '%']
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped>
|
||||
.progress {
|
||||
width: 12px;
|
||||
border-radius: 5px;
|
||||
}
|
||||
.progress1 {
|
||||
background: linear-gradient(180deg, #3ac6fc 0%, rgba(56, 195, 255, 0.05) 100%);
|
||||
}
|
||||
.progress2 {
|
||||
background: linear-gradient(346deg, #281b0e 0%, #f9a237 100%);
|
||||
}
|
||||
.progress3 {
|
||||
background: linear-gradient(180deg, #83f7ec 0%, rgba(76, 236, 213, 0.05) 100%);
|
||||
}
|
||||
</style>
|
||||
239
src/views/orderManage/orderMonitoring/orderMonitoring.vue
Normal file
239
src/views/orderManage/orderMonitoring/orderMonitoring.vue
Normal file
@@ -0,0 +1,239 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<head-form :form-config="headFormConfig" @headBtnClick="btnClick" />
|
||||
<el-tabs v-model="activeName" @tab-click="toggleClick">
|
||||
<el-tab-pane :label="this.$t('module.orderManage.orderMonitoring.datasheets')" name="dataList" />
|
||||
<el-tab-pane :label="this.$t('module.orderManage.orderMonitoring.donutChart')" name="ringChart" />
|
||||
</el-tabs>
|
||||
<!-- 数据列表 -->
|
||||
<div v-if="showList">
|
||||
<base-table
|
||||
:page="listQuery.current"
|
||||
:limit="listQuery.size"
|
||||
:height="tableH"
|
||||
:table-config="tableProps"
|
||||
:table-data="list"
|
||||
:is-loading="listLoading"
|
||||
>
|
||||
<method-btn
|
||||
v-if="tableBtn.length"
|
||||
slot="handleBtn"
|
||||
:width="trueWidth"
|
||||
:method-list="tableBtn"
|
||||
@clickBtn="handleClick"
|
||||
/>
|
||||
</base-table>
|
||||
<pagination
|
||||
v-show="total > 0"
|
||||
:total="total"
|
||||
:page.sync="listQuery.current"
|
||||
:limit.sync="listQuery.size"
|
||||
@pagination="getList()"
|
||||
/>
|
||||
</div>
|
||||
<!-- 环状图 -->
|
||||
<ring-chart v-else ref="ringCharts" :order-list="list" />
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import HeadForm from '@/components/basicData/HeadForm'
|
||||
import i18n from '@/lang'
|
||||
import { timeFormatter, rateFormatter } from '@/filters'
|
||||
import BaseTable from '@/components/BaseTable'
|
||||
import Pagination from '@/components/Pagination' // Secondary package based on el-pagination
|
||||
import MethodBtn from '@/components/BaseTable/subcomponents/MethodBtn'
|
||||
import { orderMonitor } from '@/api/orderManage/order/order'
|
||||
import ringChart from './components/ringChart.vue'
|
||||
import newBasicData from '@/filters/newBasicData'
|
||||
import Vue from 'vue'
|
||||
import { tableHeight } from '@/utils/index'
|
||||
// detail是跳到监控详情的,详情是假数据,目前暂时不放详情按钮
|
||||
const tableBtn = [
|
||||
// {
|
||||
// type: 'detail',
|
||||
// btnName: 'btn.detail'
|
||||
// }
|
||||
]
|
||||
const tableProps = [
|
||||
{
|
||||
prop: 'name',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.orderName'),
|
||||
minWidth: 230,
|
||||
isFixed: true
|
||||
},
|
||||
{
|
||||
prop: 'startProduceTime',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.startProcessingTime'),
|
||||
minWidth: 160,
|
||||
filter: timeFormatter
|
||||
},
|
||||
{
|
||||
prop: 'finishProduceTime',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.completeTime'),
|
||||
minWidth: 160,
|
||||
filter: timeFormatter
|
||||
},
|
||||
{
|
||||
prop: 'pdl',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.processingLine')
|
||||
},
|
||||
{
|
||||
prop: 'outRate',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.processingCompletionRate'),
|
||||
minWidth: 160,
|
||||
filter: rateFormatter
|
||||
},
|
||||
{
|
||||
prop: 'inQuantity',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.originalFilmInput')
|
||||
},
|
||||
{
|
||||
prop: 'inRate',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.originalFilmusage'),
|
||||
filter: rateFormatter
|
||||
},
|
||||
{
|
||||
prop: 'scrapRate',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.scrapRate'),
|
||||
filter: rateFormatter
|
||||
},
|
||||
{
|
||||
prop: 'customerName',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.customer')
|
||||
},
|
||||
{
|
||||
prop: 'status',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.orderStatus'),
|
||||
filter: newBasicData('1526063541841727490')
|
||||
},
|
||||
{
|
||||
prop: 'unitCode',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.unit'),
|
||||
filter: newBasicData('1')
|
||||
},
|
||||
{
|
||||
prop: 'outQuantity',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.processingCapacity')
|
||||
},
|
||||
{
|
||||
prop: 'specifications',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.productSpecifications')
|
||||
},
|
||||
{
|
||||
prop: 'price',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.price')
|
||||
}
|
||||
]
|
||||
export default {
|
||||
name: 'OrderMonitoring',
|
||||
components: { HeadForm, BaseTable, Pagination, MethodBtn, ringChart },
|
||||
data() {
|
||||
return {
|
||||
showList: true,
|
||||
headFormConfig: [
|
||||
{
|
||||
type: 'input',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.orderName'),
|
||||
placeholder: i18n.t('module.orderManage.orderMonitoring.orderName'),
|
||||
param: 'name'
|
||||
},
|
||||
{
|
||||
type: 'datePicker',
|
||||
label: i18n.t('module.orderManage.orderMonitoring.period'),
|
||||
dateType: 'daterange',
|
||||
format: 'yyyy-MM-dd',
|
||||
valueFormat: 'yyyy-MM-dd',
|
||||
rangeSeparator: '-',
|
||||
startPlaceholder: this.$t('module.orderManage.orderMonitoring.startTime'),
|
||||
endPlaceholder: this.$t('module.orderManage.orderMonitoring.endTime'),
|
||||
param: 'searchTime'
|
||||
},
|
||||
{
|
||||
type: 'button',
|
||||
btnName: 'btn.search',
|
||||
name: 'search',
|
||||
color: 'primary'
|
||||
}
|
||||
],
|
||||
headFormValue: {},
|
||||
activeName: 'dataList',
|
||||
listQuery: {
|
||||
current: 1,
|
||||
size: 20,
|
||||
name: '',
|
||||
startTime: '',
|
||||
endTime: ''
|
||||
},
|
||||
tableProps,
|
||||
tableBtn,
|
||||
list: [],
|
||||
listLoading: false,
|
||||
trueWidth: 80,
|
||||
tableH: tableHeight(333),
|
||||
total: 0,
|
||||
unitList: JSON.parse(localStorage.getItem('dictObj'))['1'],
|
||||
unitObj: {},
|
||||
statusList: JSON.parse(localStorage.getItem('dictObj'))['1'],
|
||||
statusObj: {}
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
window.addEventListener('resize', () => {
|
||||
this.tableH = tableHeight(333)
|
||||
})
|
||||
this.unitList.map((item) => {
|
||||
this.unitObj[item.dataCode] = item.dataName
|
||||
})
|
||||
Vue.set(this.tableProps[12], 'unitObj', this.unitObj)
|
||||
this.statusList.map(item => {
|
||||
this.statusObj[item.dataCode] = item.dataName
|
||||
})
|
||||
Vue.set(this.tableProps[11], 'statusObj', this.statusObj)
|
||||
this.getList()
|
||||
},
|
||||
methods: {
|
||||
getList() {
|
||||
this.listQuery.name = this.headFormValue.name
|
||||
this.listQuery.startTime = this.headFormValue.searchTime ? this.headFormValue.searchTime[0] + 'T00:00:00' : ''
|
||||
this.listQuery.endTime = this.headFormValue.searchTime ? this.headFormValue.searchTime[1] + 'T23:59:59' : ''
|
||||
orderMonitor(this.listQuery).then(res => {
|
||||
if (res.data.records) {
|
||||
this.list = res.data.records
|
||||
} else {
|
||||
this.list = []
|
||||
}
|
||||
this.total = res.data.total
|
||||
if (!this.showList) {
|
||||
this.$nextTick(() => {
|
||||
this.$refs.ringCharts.initChart()
|
||||
})
|
||||
}
|
||||
})
|
||||
},
|
||||
btnClick(val) {
|
||||
this.headFormValue = val
|
||||
// 如果点击的是搜索栏的其他按钮在这里继续写判断
|
||||
if (this.headFormValue.btnName === 'search') {
|
||||
this.listQuery.current = 1
|
||||
this.getList()
|
||||
}
|
||||
},
|
||||
toggleClick() {
|
||||
if (this.activeName === 'ringChart') {
|
||||
this.showList = false
|
||||
this.$nextTick(() => {
|
||||
this.$refs.ringCharts.initChart()
|
||||
})
|
||||
} else if (this.activeName === 'dataList') {
|
||||
this.showList = true
|
||||
}
|
||||
this.getList()
|
||||
},
|
||||
handleClick() {
|
||||
this.$router.push({
|
||||
name: 'orderMonitoringDetail'
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
301
src/views/orderManage/orderMonitoring/orderMonitoringDetail.vue
Normal file
301
src/views/orderManage/orderMonitoring/orderMonitoringDetail.vue
Normal file
@@ -0,0 +1,301 @@
|
||||
<template>
|
||||
<div id="container" ref="container" class="visual-container">
|
||||
<el-row
|
||||
class="container-title"
|
||||
:style="{
|
||||
height: beilv * 88 + 'px',
|
||||
lineHeight: beilv * 88 + 'px',
|
||||
fontSize: beilv * 30 + 'px'
|
||||
}"
|
||||
>
|
||||
<img src="../../../assets/img/logo.png" style="width:1.1em;position:relative;top:.4em" alt="">
|
||||
合肥新能源数智工厂订单监控查询
|
||||
<el-button
|
||||
type="text"
|
||||
class="title-button"
|
||||
:style="{ right: 33 * beilv + 'px', top: 37 * beilv + 'px' }"
|
||||
@click="changeFullScreen"
|
||||
>
|
||||
<svg-icon v-if="isFullScreen" icon-class="unFullScreenView" />
|
||||
<svg-icon v-else icon-class="fullScreenView" />
|
||||
</el-button>
|
||||
</el-row>
|
||||
<el-row class="container-main">
|
||||
<el-row :style="{ padding: '0 ' + 9 * beilv + 'px' }" :gutter="9 * beilv">
|
||||
<el-col :span="6">
|
||||
<el-row>
|
||||
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24" style="position: relative;">
|
||||
<base-container :beilv="beilv" :height="463" :title="'三大品类'" :title-icon="'productType'">
|
||||
<pie-chart1 :id="'pie-chart1'" :beilv="beilv" :height="'256'" :pie-style="pieStyle1" />
|
||||
<dataShowBox :beilv="beilv" :height="112" style="position: absolute;bottom: 0;" />
|
||||
</base-container>
|
||||
</el-col>
|
||||
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
|
||||
<base-container :beilv="beilv" :height="463" :title="'销售额前十产品'" :title-icon="'5_4'">
|
||||
<progressBox :beilv="beilv" :product-data="progressData1" :style="{paddingTop: 20 * beilv + 'px'}" />
|
||||
</base-container>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-row>
|
||||
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
|
||||
<dataShowMain :beilv="beilv" :height="216" />
|
||||
</el-col>
|
||||
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
|
||||
<base-container :beilv="beilv" :height="711" :title="'各个季度完成情况'" :title-icon="'number'">
|
||||
<pie-chart2 :id="'pie-chart2'" :beilv="beilv" :height="'310'" :pie-style="pieStyle2" />
|
||||
<div>
|
||||
<div class="bar-title">
|
||||
<span>
|
||||
<svg-icon :icon-class="'5_2'" style="font-size: 1.5em; position: relative; top: .08em" />
|
||||
各月情况
|
||||
</span>
|
||||
</div>
|
||||
<lineChart :beilv="beilv" :height="'330'" />
|
||||
</div>
|
||||
</base-container>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-row>
|
||||
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
|
||||
<base-container :beilv="beilv" :height="463" :title="'销售三甲员工'" :title-icon="'1_1'">
|
||||
<saleTop :beilv="beilv" :height="'356'" />
|
||||
</base-container>
|
||||
</el-col>
|
||||
<el-col :style="{ margin: 8 * beilv + 'px' + ' 0' }" :span="24">
|
||||
<base-container :beilv="beilv" :height="463" :title="'大客户'" :title-icon="'1_4'">
|
||||
<progressBox :beilv="beilv" :product-data="progressData2" :style="{paddingTop: 20 * beilv + 'px'}" />
|
||||
</base-container>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-row>
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import baseContainer from './components/baseContainer'
|
||||
import pieChart1 from './components/pieChart'
|
||||
import pieChart2 from './components/pieChart'
|
||||
import screenfull from 'screenfull'
|
||||
import dataShowBox from './components/dataShowBox'
|
||||
import dataShowMain from './components/dataShowMain'
|
||||
import progressBox from './components/progressBox'
|
||||
import saleTop from './components/saleTop'
|
||||
import lineChart from './components/lineChart'
|
||||
const pieStyle1 = {
|
||||
num_fs: 18,
|
||||
line_s: 24,
|
||||
pieData: [
|
||||
{ value: 330, name: '品类1' },
|
||||
{ value: 120, name: '品类2' },
|
||||
{ value: 250, name: '品类3' }
|
||||
],
|
||||
formatter: '{firstLine|{b}} \n {secondLine|{d}%}'
|
||||
}
|
||||
const pieStyle2 = {
|
||||
num_fs: 24,
|
||||
line_s: 95,
|
||||
pieData: [
|
||||
{ value: 329, name: '第一季度' },
|
||||
{ value: 119, name: '第二季度' },
|
||||
{ value: 251, name: '第三季度' },
|
||||
{ value: 301, name: '第四季度' }
|
||||
],
|
||||
formatter: '{firstLine|{b} {d}%} \n {secondLine|{c}}'
|
||||
}
|
||||
export default {
|
||||
name: 'OrderMonitoringDetail',
|
||||
components: {
|
||||
baseContainer,
|
||||
pieChart1,
|
||||
pieChart2,
|
||||
dataShowBox,
|
||||
dataShowMain,
|
||||
progressBox,
|
||||
saleTop,
|
||||
lineChart
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
beilv: 1,
|
||||
isFullScreen: false,
|
||||
pieStyle1,
|
||||
pieStyle2,
|
||||
progressData1: [],
|
||||
progressData2: []
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
isFullScreen: function(val) {
|
||||
if (val) {
|
||||
this.beilv = document.body.offsetWidth / 1920
|
||||
} else {
|
||||
this.beilv = document.getElementById('container').offsetWidth / 1920
|
||||
}
|
||||
},
|
||||
'sidebar.opened': function(val) {
|
||||
console.log(val)
|
||||
if (!this.isFullScreen) {
|
||||
setTimeout(() => {
|
||||
this.beilv = document.getElementById('container').offsetWidth / 1920
|
||||
}, 300)
|
||||
}
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.beilv = document.getElementById('container').offsetWidth / 1920
|
||||
window.addEventListener('resize', () => {
|
||||
if (this.isFullScreen) {
|
||||
this.beilv = document.body.offsetWidth / 1920
|
||||
} else {
|
||||
this.beilv = document.getElementById('container').offsetWidth / 1920
|
||||
}
|
||||
})
|
||||
this.getMsg()
|
||||
},
|
||||
methods: {
|
||||
getMsg() {
|
||||
this.progressData1 = [
|
||||
{ name: '产品1', number: 1000, percentage: '100%' },
|
||||
{ name: '产品2', number: 900, percentage: '90%' },
|
||||
{ name: '产品3', number: 850, percentage: '85%' },
|
||||
{ name: '产品4', number: 700, percentage: '70%' },
|
||||
{ name: '产品5', number: 620, percentage: '62%' },
|
||||
{ name: '产品6', number: 550, percentage: '55%' },
|
||||
{ name: '产品7', number: 530, percentage: '53%' },
|
||||
{ name: '产品8', number: 500, percentage: '50%' },
|
||||
{ name: '产品9', number: 430, percentage: '43%' },
|
||||
{ name: '产品10', number: 300, percentage: '30%' }
|
||||
]
|
||||
this.progressData2 = [
|
||||
{ name: '客户1', number: 1000, percentage: '100%' },
|
||||
{ name: '客户2', number: 900, percentage: '90%' },
|
||||
{ name: '客户3', number: 850, percentage: '85%' },
|
||||
{ name: '客户4', number: 700, percentage: '70%' },
|
||||
{ name: '客户5', number: 620, percentage: '62%' },
|
||||
{ name: '客户6', number: 550, percentage: '55%' },
|
||||
{ name: '客户7', number: 530, percentage: '53%' },
|
||||
{ name: '客户8', number: 500, percentage: '50%' },
|
||||
{ name: '客户9', number: 430, percentage: '43%' },
|
||||
{ name: '客户10', number: 300, percentage: '30%' }
|
||||
]
|
||||
},
|
||||
change() {
|
||||
this.isFullScreen = screenfull.isFullscreen
|
||||
},
|
||||
init() {
|
||||
if (screenfull.enabled) {
|
||||
screenfull.on('change', this.change)
|
||||
}
|
||||
},
|
||||
destroy() {
|
||||
if (screenfull.enabled) {
|
||||
screenfull.off('change', this.change)
|
||||
}
|
||||
},
|
||||
changeFullScreen() {
|
||||
if (!screenfull.enabled) {
|
||||
this.$message({
|
||||
message: 'you browser can not work',
|
||||
type: 'warning'
|
||||
})
|
||||
return false
|
||||
}
|
||||
screenfull.toggle(this.$refs.container)
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style lang="scss" scoped>
|
||||
.visual-container {
|
||||
width: 100%;
|
||||
min-width: 960px;
|
||||
background: url('../../../assets/img/OperationalOverview/back.png') no-repeat;
|
||||
background-size: cover;
|
||||
.container-title {
|
||||
width: 100%;
|
||||
background: url('../../../assets/img/OperationalOverview/title.png') no-repeat;
|
||||
background-size: 100% 100%;
|
||||
color: #00fff0;
|
||||
text-align: center;
|
||||
.title-button {
|
||||
color: #00fff0;
|
||||
font-size: 20px;
|
||||
position: absolute;
|
||||
}
|
||||
}
|
||||
.container-main {
|
||||
padding: 16px;
|
||||
}
|
||||
}
|
||||
.now-team-title {
|
||||
margin: 0;
|
||||
margin-top: -1em;
|
||||
font-size: 1.2em;
|
||||
line-height: 2em;
|
||||
color: #fff;
|
||||
}
|
||||
.main-title {
|
||||
text-align: center;
|
||||
}
|
||||
.now-secondary-title {
|
||||
margin: 0;
|
||||
font-size: 1em;
|
||||
line-height: 2em;
|
||||
color: #fff;
|
||||
}
|
||||
.now-team-content {
|
||||
font-size: 3em;
|
||||
line-height: 1em;
|
||||
color: #52fff1;
|
||||
text-align: center;
|
||||
}
|
||||
// ::v-deep .el-progress-bar__inner {
|
||||
// background-color: unset;
|
||||
// background-image: linear-gradient(to right, #4573fe, #47f8dc);
|
||||
// }
|
||||
</style>
|
||||
<style lang="scss">
|
||||
.visual-container {
|
||||
::-webkit-scrollbar {
|
||||
width: 8px;
|
||||
height: 8px;
|
||||
background-color: transparent;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-track-piece {
|
||||
background: #1b2b3d;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-corner {
|
||||
background: #1b2b3d;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-track {
|
||||
width: 6px;
|
||||
background: #1b2b3d;
|
||||
-webkit-border-radius: 2em;
|
||||
-moz-border-radius: 2em;
|
||||
border-radius: 2em;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-thumb {
|
||||
background: rgba($color: #5bc4be, $alpha: 0.7);
|
||||
background-clip: padding-box;
|
||||
min-height: 28px;
|
||||
-webkit-border-radius: 2em;
|
||||
-moz-border-radius: 2em;
|
||||
border-radius: 2em;
|
||||
transition: background-color 0.3s;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-thumb:hover {
|
||||
background-color: rgba($color: #5bc4be, $alpha: 1);
|
||||
}
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user