This commit is contained in:
gtz
2022-11-07 08:45:49 +08:00
commit 4d1231adc2
1222 changed files with 194552 additions and 0 deletions

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View 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>

View File

@@ -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)
}
}
}

View 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>

View File

@@ -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>

View 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>

View 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>

View 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>

View 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>