Browse Source

关闭顶部搜索,优化数据看板

dev
qb 4 months ago
parent
commit
64f08e6fb3
  1. 4
      src/css/common.css
  2. 8
      src/page/index/top/index.vue
  3. 2
      src/page/index/top/top-search.vue
  4. 37
      src/page/login/aiqa.vue
  5. 9
      src/styles/top.scss
  6. 338
      src/views/desk/DataBoard.vue

4
src/css/common.css

@ -208,8 +208,8 @@ a {
.top-search { .top-search {
line-height: 50px; line-height: 50px;
position: absolute !important; /* position: absolute !important; */
right: 200px; /* right: 200px; */
top: 0; top: 0;
width: 300px; width: 300px;
} }

8
src/page/index/top/index.vue

@ -11,9 +11,9 @@
</div> </div>
<div class="top-bar__title"> <div class="top-bar__title">
<top-menu ref="topMenu" v-if="setting.menu"></top-menu> <top-menu ref="topMenu" v-if="setting.menu"></top-menu>
<top-search class="top-bar__item" v-if="setting.search"></top-search>
</div> </div>
<div class="top-bar__right"> <div class="top-bar__right">
<!-- <top-search class="top-bar__item" v-if="setting.search"></top-search> -->
<div v-if="setting.lock" class="top-bar__item"> <div v-if="setting.lock" class="top-bar__item">
<top-lock></top-lock> <top-lock></top-lock>
</div> </div>
@ -137,23 +137,21 @@ export default {
filters: {}, filters: {},
created() { created() {
getMyCurrentWarehouse().then(res => { getMyCurrentWarehouse().then(res => {
if (res.data.data == null) { if (res.data.data == null) {
console.log('当前没有数据'); console.log('当前没有数据');
localStorage.setItem('WarehouseName', void 0); localStorage.setItem('WarehouseName', void 0);
localStorage.setItem('my_data', JSON.stringify('')) localStorage.setItem('my_data', JSON.stringify(''));
return; return;
} }
localStorage.setItem('WarehouseName', res.data.data.name); localStorage.setItem('WarehouseName', res.data.data.name);
localStorage.setItem('my_data', JSON.stringify(res.data.data)) localStorage.setItem('my_data', JSON.stringify(res.data.data));
if (!res.data.data.name) { if (!res.data.data.name) {
this.dataName = ''; this.dataName = '';
} else { } else {
this.dataName = res.data.data.name; // this.dataName = res.data.data.name; //
} }
}); });
}, },
computed: { computed: {
...mapGetters([ ...mapGetters([

2
src/page/index/top/top-search.vue

@ -119,7 +119,7 @@ export default {
} }
.el-autocomplete { .el-autocomplete {
width: 300px !important; width: 300px !important;
margin-right:7% !important; // margin-right:7% !important;
.el-input__wrapper { .el-input__wrapper {
border: 1px solid #d3d3d3 !important; border: 1px solid #d3d3d3 !important;
} }

37
src/page/login/aiqa.vue

@ -66,6 +66,8 @@
@keydown.enter="inputData(Data.input)" @keydown.enter="inputData(Data.input)"
v-model="Data.input" v-model="Data.input"
placeholder="请输入问题描述" placeholder="请输入问题描述"
type="textarea"
style="height: 100%; resize: none"
/> />
<el-button type="primary" @click="inputData(Data.input)">发送</el-button> <el-button type="primary" @click="inputData(Data.input)">发送</el-button>
</div> </div>
@ -146,8 +148,7 @@ const Data = ref({
}, },
{ {
content: '向日葵下载地址', content: '向日葵下载地址',
} },
], ],
ChathistoryList: [ ChathistoryList: [
// { // {
@ -316,11 +317,9 @@ const AiData = (value = '') => {
lowercaseValue.includes('东集pad安装初始密码') lowercaseValue.includes('东集pad安装初始密码')
) { ) {
aiResponse = '东集PDA安装初始密码是:4007770876'; aiResponse = '东集PDA安装初始密码是:4007770876';
} } else if (lowercaseValue.includes('东集pad-q7恢复出厂设置')) {
else if ( aiResponse =
lowercaseValue.includes('东集pad-q7恢复出厂设置') '东集pad-q7恢复出厂设置教程地址:1、关机状态下,按下【电源键】、【两侧扫描键】; 2、出现开机画面,松开【电源键】,出现工厂模式界面,按键全部松开;3、进入工厂模式后通过方向键选择【wipe data/factory reset】, 按电源键确认进入子菜单,选择【yes】,按【电源键】确认,恢复出厂完成后选择第一个【reboot system now】 ,按【电源键】确认重启设备。视频教程如下:https://mp.weixin.qq.com/s/0CG-jYooh9LJ-9aLauVGfA';
) {
aiResponse = '东集pad-q7恢复出厂设置教程地址:1、关机状态下,按下【电源键】、【两侧扫描键】; 2、出现开机画面,松开【电源键】,出现工厂模式界面,按键全部松开;3、进入工厂模式后通过方向键选择【wipe data/factory reset】, 按电源键确认进入子菜单,选择【yes】,按【电源键】确认,恢复出厂完成后选择第一个【reboot system now】 ,按【电源键】确认重启设备。视频教程如下:https://mp.weixin.qq.com/s/0CG-jYooh9LJ-9aLauVGfA';
} }
// else if ( // else if (
// lowercaseValue.includes('') // lowercaseValue.includes('')
@ -328,17 +327,15 @@ const AiData = (value = '') => {
// aiResponse = '627683'; // aiResponse = '627683';
// } // }
else if ( else if (
lowercaseValue.includes('蓝牙打印机芝柯tx453设备连接密码是多少') || lowercaseValue.includes('tx453') lowercaseValue.includes('蓝牙打印机芝柯tx453设备连接密码是多少') ||
lowercaseValue.includes('tx453')
) { ) {
aiResponse = '蓝牙打印机芝柯xt453设备连接密码是:0000'; aiResponse = '蓝牙打印机芝柯xt453设备连接密码是:0000';
} } else if (lowercaseValue.includes('向日葵') || lowercaseValue.includes('向日葵下载地址')) {
else if (
lowercaseValue.includes('向日葵') || lowercaseValue.includes('向日葵下载地址')
) {
aiResponse = '向日葵下载地址:https://sunlogin.oray.com/,使用教程点击下方立即下载'; aiResponse = '向日葵下载地址:https://sunlogin.oray.com/,使用教程点击下方立即下载';
data.link = 'http://files.huo5u.com/plugins/%E5%90%91%E6%97%A5%E8%91%B5%E8%BF%9C%E7%A8%8B%E8%BD%AF%E4%BB%B6%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B.docx'; data.link =
} 'http://files.huo5u.com/plugins/%E5%90%91%E6%97%A5%E8%91%B5%E8%BF%9C%E7%A8%8B%E8%BD%AF%E4%BB%B6%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B.docx';
else { } else {
aiResponse = '我不太理解您的问题,我正在努力学习中,请重新描述或输入其他问题,或联系管理员'; aiResponse = '我不太理解您的问题,我正在努力学习中,请重新描述或输入其他问题,或联系管理员';
} }
} }
@ -500,10 +497,11 @@ AiData(); //初始化AI机器人
flex: 1; flex: 1;
background-color: #fff; background-color: #fff;
border: 1px solid #9e9e9e; border: 1px solid #9e9e9e;
padding: 0 4px; padding: 0px 10px;
border-radius: 4px; border-radius: 4px;
p { p {
font-size: 13px; font-size: 13px;
margin: 10px 0;
// text-indent: 24px; // text-indent: 24px;
} }
} }
@ -537,6 +535,13 @@ AiData(); //初始化AI机器人
height: 100%; height: 100%;
font-size: 16px; font-size: 16px;
} }
.el-textarea__inner {
height: 100%;
box-shadow: none;
resize: none;
}
.is-focus { .is-focus {
box-shadow: none; box-shadow: none;
} }

9
src/styles/top.scss

@ -2,7 +2,7 @@
position: relative; position: relative;
background-color: #fff; background-color: #fff;
box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.15); box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.15);
color: rgba(0, 0, 0, .65); color: rgba(0, 0, 0, 0.65);
font-size: 28px; font-size: 28px;
height: $top_height; height: $top_height;
line-height: $top_height; line-height: $top_height;
@ -10,7 +10,8 @@
white-space: nowrap; white-space: nowrap;
.el-menu-item { .el-menu-item {
i, span { i,
span {
font-size: 13px; font-size: 13px;
// background-color: #d3832a; // background-color: #d3832a;
} }
@ -46,8 +47,8 @@
.top-search { .top-search {
line-height: $top_height; line-height: $top_height;
position: absolute !important; // position: absolute !important;
right: 200px; // right: 200px;
top: 0; top: 0;
width: 300px; width: 300px;

338
src/views/desk/DataBoard.vue

@ -520,7 +520,7 @@
<img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" /> <img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" />
<span>总数</span> <span>总数</span>
</div> </div>
<!-- <div <div
class="mt10" class="mt10"
@click=" @click="
() => () =>
@ -534,12 +534,12 @@
details.allocationDataInfo.totalNum || 0 details.allocationDataInfo.totalNum || 0
}}</span> }}</span>
<span class=""></span> <span class=""></span>
</div> --> </div>
<div class="mt10"> <!-- <div class="mt10">
<span class="data mr5px">{{ details.allocationDataInfo.totalNum || 0 }}</span> <span class="data mr5px">{{ details.allocationDataInfo.totalNum || 0 }}</span>
<span class=""></span> <span class=""></span>
</div> </div> -->
</div> </div>
<!-- 已上架 --> <!-- 已上架 -->
@ -839,10 +839,15 @@
class="data mr5px underline" class="data mr5px underline"
@click=" @click="
() => () =>
handleShowAbnormalData('异常数据-处理率-%', abnormal_status, { handleShowAbnormalData(
'异常数据-处理率-%',
abnormal_status,
{
tip: '处理率', tip: '处理率',
prop: 'processingRate', prop: 'processingRate',
},'bar') },
'bar'
)
" "
>{{ abnormal_Info.abnormalRate }}</span >{{ abnormal_Info.abnormalRate }}</span
> >
@ -1028,7 +1033,7 @@
</div> </div>
<div class="border pd10 flex-c-sb"> <div class="border pd10 flex-c-sb">
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box mb10" class="data_box mb10"
@click=" @click="
@ -1046,7 +1051,7 @@
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box orange mb10" class="data_box orange mb10"
@click=" @click="
@ -1064,14 +1069,19 @@
</div> </div>
</div> </div>
<div class="text_center" v-if="signforData_status !== 'daySignData'"> <div class="text_center flex1 mr10" v-if="signforData_status !== 'daySignData'">
<div <div
class="data_box blue mb10" class="data_box blue mb10"
@click=" @click="
handleShowSignDetail('签收数据 - 签收率 - %', signforData_status, { handleShowSignDetail(
'签收数据 - 签收率 - %',
signforData_status,
{
tip: '签收率', tip: '签收率',
prop: 'signScale', prop: 'signScale',
},'bar') },
'bar'
)
" "
> >
<div class="data mr5px underline"> <div class="data mr5px underline">
@ -1084,7 +1094,7 @@
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box purple mb10" class="data_box purple mb10"
@click=" @click="
@ -1102,27 +1112,32 @@
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10" v-if="signforData_status !== 'daySignData'">
<div <div
class="data_box purple mb10" class="data_box purple mb10"
@click=" @click="
handleShowSignDetail('签收数据 - 文员签收数 - 件', signforData_status, { handleShowSignDetail(
tip: '文员签收数', '签收数据 - 文员签收率 - %',
signforData_status,
{
tip: '文员签收率',
prop: 'clerkSignforScale', prop: 'clerkSignforScale',
}) },
'bar'
)
" "
> >
<div class="data mr5px underline"> <div class="data mr5px underline">
{{ signforData.clerkSignforScale || 0 }} {{ signforData.clerkSignforScale || 0 }}
</div> </div>
<div class=""></div> <div class="">%</div>
</div> </div>
<div class=""> <div class="">
<span>文员签收</span> <span>文员签收</span>
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box red mb10" class="data_box red mb10"
@click=" @click="
@ -1142,17 +1157,22 @@
</div> </div>
</div> </div>
<div class="text_center" v-if="signforData_status !== 'daySignData'"> <div class="text_center flex1" v-if="signforData_status !== 'daySignData'">
<div <div
class="data_box red mb10" class="data_box red mb10"
@click=" @click="
handleShowSignDetail('签收数据 - 签收超时率 - %', signforData_status, { handleShowSignDetail(
'签收数据 - 签收超时率 - %',
signforData_status,
{
tip: '签收超时率', tip: '签收超时率',
prop: 'clerkOverTimeScale', prop: 'clerkOverTimeScale',
},'bar') },
'bar'
)
" "
> >
<div class="data mr5px"> <div class="data mr5px underline">
{{ signforData.clerkOverTimeScale ? signforData.clerkOverTimeScale : 0 }} {{ signforData.clerkOverTimeScale ? signforData.clerkOverTimeScale : 0 }}
</div> </div>
<div class="">%</div> <div class="">%</div>
@ -1311,7 +1331,7 @@
</div> </div>
<div class="border pd10 flex-c-sb"> <div class="border pd10 flex-c-sb">
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box mb10" class="data_box mb10"
@click=" @click="
@ -1329,7 +1349,7 @@
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box orange mb10" class="data_box orange mb10"
@click=" @click="
@ -1347,14 +1367,22 @@
</div> </div>
</div> </div>
<div class="text_center" v-if="billSignforData_status !== 'dayBillLadingSignData'"> <div
class="text_center flex1 mr10"
v-if="billSignforData_status !== 'dayBillLadingSignData'"
>
<div <div
class="data_box blue mb10" class="data_box blue mb10"
@click=" @click="
handleShowSignDetail('自提签收数据 - 签收率 - %', billSignforData_status, { handleShowSignDetail(
'自提签收数据 - 签收率 - %',
billSignforData_status,
{
tip: '签收率', tip: '签收率',
prop: 'signScale', prop: 'signScale',
},'bar') },
'bar'
)
" "
> >
<div class="data mr5px underline"> <div class="data mr5px underline">
@ -1367,7 +1395,7 @@
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box purple mb10" class="data_box purple mb10"
@click=" @click="
@ -1385,27 +1413,35 @@
</div> </div>
</div> </div>
<div class="text_center"> <div
class="text_center flex1 mr10"
v-if="billSignforData_status !== 'dayBillLadingSignData'"
>
<div <div
class="data_box purple mb10" class="data_box purple mb10"
@click=" @click="
handleShowSignDetail('自提签收数据 - 文员签收数 - 件', billSignforData_status, { handleShowSignDetail(
'自提签收数据 - 文员签收数 - %',
billSignforData_status,
{
tip: '文员签收率', tip: '文员签收率',
prop: 'clerkSignforScale', prop: 'clerkSignforScale',
}) },
'bar'
)
" "
> >
<div class="data mr5px underline"> <div class="data mr5px underline">
{{ billSignforData.clerkSignforScale ? billSignforData.clerkSignforScale : 0 }} {{ billSignforData.clerkSignforScale ? billSignforData.clerkSignforScale : 0 }}
</div> </div>
<div class=""></div> <div class="">%</div>
</div> </div>
<div class=""> <div class="">
<span>文员签收</span> <span>文员签收</span>
</div> </div>
</div> </div>
<div class="text_center"> <div class="text_center flex1 mr10">
<div <div
class="data_box red mb10" class="data_box red mb10"
@click=" @click="
@ -1425,14 +1461,22 @@
</div> </div>
</div> </div>
<div class="text_center" v-if="billSignforData_status !== 'dayBillLadingSignData'"> <div
class="text_center flex1 mr10"
v-if="billSignforData_status !== 'dayBillLadingSignData'"
>
<div <div
class="data_box red mb10" class="data_box red mb10"
@click=" @click="
handleShowSignDetail('自提签收数据 - 超时签收任务 - %', billSignforData_status, { handleShowSignDetail(
'自提签收数据 - 超时签收任务 - %',
billSignforData_status,
{
tip: '超时签收任务', tip: '超时签收任务',
prop: 'clerkOverTimeScale', prop: 'clerkOverTimeScale',
},'bar') },
'bar'
)
" "
> >
<div class="data mr5px underline"> <div class="data mr5px underline">
@ -1628,13 +1672,53 @@ const details = reactive({
/** 签收数据 */ /** 签收数据 */
signforDataInfo: { signforDataInfo: {
/** 当日签收数据 */ /** 当日签收数据 */
daySignData: {}, daySignData: {
signNum: 0,
clerkOverTimeSignfoNum: 0,
clerkOverTimeScale: 0,
signScale: 0,
clerkSignNum: 0,
planNum: 0,
unSignNum: 0,
clerkSignforScale: 0,
data: [],
},
/** 当月签收数据 */ /** 当月签收数据 */
monthSignData: {}, monthSignData: {
signNum: 0,
clerkOverTimeSignfoNum: 0,
clerkOverTimeScale: 0,
signScale: 0,
clerkSignNum: 0,
planNum: 0,
unSignNum: 0,
clerkSignforScale: 0,
data: [],
},
/** 当日自提签收数据 */ /** 当日自提签收数据 */
dayBillLadingSignData: {}, dayBillLadingSignData: {
signNum: 0,
clerkOverTimeSignfoNum: 0,
clerkOverTimeScale: 0,
signScale: 0,
clerkSignNum: 0,
planNum: 0,
unSignNum: 0,
clerkSignforScale: 0,
data: [],
},
/** 当月自提签收数据 */ /** 当月自提签收数据 */
monthBillLadingSignData: {}, monthBillLadingSignData: {
signNum: 0,
clerkOverTimeSignfoNum: 0,
clerkOverTimeScale: 0,
signScale: 0,
clerkSignNum: 0,
planNum: 0,
unSignNum: 0,
clerkSignforScale: 0,
data: [],
},
}, },
loadingObj: { loadingObj: {
/** 开单数据 */ /** 开单数据 */
@ -1996,15 +2080,7 @@ const initDeliveryData = async () => {
/** 签收数据 */ /** 签收数据 */
const initSignforData = async () => { const initSignforData = async () => {
const _keyArr = [ const _keyArr = ['signNum', 'unSignNum', 'clerkSignNum', 'planNum', 'clerkOverTimeSignfoNum'];
'signNum',
'unSignNum',
'signScale',
'clerkSignNum',
'clerkSignforScale',
'clerkOverTimeSignfoNum',
'clerkOverTimeScale',
];
const _obj = { const _obj = {
daySignData: { data: [] }, daySignData: { data: [] },
@ -2030,6 +2106,8 @@ const initSignforData = async () => {
const item = _obj[key]; const item = _obj[key];
item[value] = 0; item[value] = 0;
console.log('item :>> ', item);
} }
} }
@ -2042,6 +2120,7 @@ const initSignforData = async () => {
const key = _keyArr[j]; const key = _keyArr[j];
const _val = isNumber(value[key]) ? Number(value[key]) : 0; const _val = isNumber(value[key]) ? Number(value[key]) : 0;
value[key] = _val;
// //
if (Number(value.type) === 1) { if (Number(value.type) === 1) {
@ -2063,6 +2142,106 @@ const initSignforData = async () => {
: // : //
_obj.monthBillLadingSignData.data.push(value); _obj.monthBillLadingSignData.data.push(value);
} }
_obj.monthBillLadingSignData.totalSinNum = computeNumber(
_obj.monthBillLadingSignData.signNum,
'+',
_obj.monthBillLadingSignData.unSignNum
).result;
_obj.monthSignData.totalSinNum = computeNumber(
_obj.monthSignData.signNum,
'+',
_obj.monthSignData.unSignNum
).result;
console.log('_obj :>> ', _obj);
//
if (
!isNumber(_obj.monthBillLadingSignData.signNum) ||
!isNumber(_obj.monthBillLadingSignData.totalSinNum) ||
Number(_obj.monthBillLadingSignData.totalSinNum) === 0
) {
_obj.monthBillLadingSignData.signScale = 0;
} else {
_obj.monthBillLadingSignData.signScale = computeNumber(
_obj.monthBillLadingSignData.signNum,
'/',
_obj.monthBillLadingSignData.totalSinNum
).result;
}
if (
!isNumber(_obj.monthSignData.signNum) ||
!isNumber(_obj.monthSignData.totalSinNum) ||
Number(_obj.monthSignData.totalSinNum) === 0
) {
_obj.monthSignData.signScale = 0;
} else {
_obj.monthSignData.signScale = computeNumber(
_obj.monthSignData.signNum,
'/',
_obj.monthSignData.totalSinNum
).result;
}
//
if (
!isNumber(_obj.monthBillLadingSignData.clerkSignNum) ||
!isNumber(_obj.monthBillLadingSignData.planNum) ||
Number(_obj.monthBillLadingSignData.planNum) === 0
) {
_obj.monthBillLadingSignData.clerkSignforScale = 0;
} else {
_obj.monthBillLadingSignData.clerkSignforScale = computeNumber(
Number(_obj.monthBillLadingSignData.clerkSignNum),
'/',
Number(_obj.monthBillLadingSignData.planNum)
).result;
}
if (
!isNumber(_obj.monthSignData.clerkSignNum) ||
!isNumber(_obj.monthSignData.planNum) ||
Number(_obj.monthSignData.planNum) === 0
) {
_obj.monthSignData.clerkSignforScale = 0;
} else {
_obj.monthSignData.clerkSignforScale = computeNumber(
Number(_obj.monthSignData.clerkSignNum),
'/',
Number(_obj.monthSignData.planNum)
).result;
}
//
if (
!isNumber(_obj.monthBillLadingSignData.clerkOverTimeSignfoNum) ||
!isNumber(_obj.monthBillLadingSignData.planNum) ||
Number(_obj.monthBillLadingSignData.planNum) === 0
) {
_obj.monthBillLadingSignData.clerkOverTimeScale = 0;
} else {
_obj.monthBillLadingSignData.clerkOverTimeScale = computeNumber(
_obj.monthBillLadingSignData.clerkOverTimeSignfoNum,
'/',
_obj.monthBillLadingSignData.planNum
).result;
}
if (
!isNumber(_obj.monthSignData.clerkOverTimeSignfoNum) ||
!isNumber(_obj.monthSignData.planNum) ||
Number(_obj.monthSignData.planNum) === 0
) {
_obj.monthSignData.clerkOverTimeScale = 0;
} else {
_obj.monthSignData.clerkOverTimeScale = computeNumber(
_obj.monthSignData.clerkOverTimeSignfoNum,
'/',
_obj.monthSignData.planNum
).result;
}
} }
// //
@ -2097,11 +2276,12 @@ const initSignforData = async () => {
} }
} }
details.signforDataInfo = data || []; // details.signforDataInfo = data || [];
} catch (error) { } catch (error) {
console.log('error :>> ', error); console.log('error :>> ', error);
} finally { } finally {
details.signforDataInfo = _obj; details.signforDataInfo = _obj;
console.log('details.signforDataInfo :>> ', details.signforDataInfo);
details.loadingObj.signforData = false; details.loadingObj.signforData = false;
} }
}; };
@ -2156,7 +2336,7 @@ const delivery_bill_info = computed(() => {
/** 签收数据 */ /** 签收数据 */
const signforData = computed<any>(() => { const signforData = computed<any>(() => {
const _obj: any = details.signforDataInfo[signforData_status.value] || {}; const _obj: any = details.signforDataInfo[signforData_status.value] || {};
console.log('_obj :>> ', _obj); // console.log('_obj :>> ', _obj);
_obj.signScaleNum ? _obj.signScaleNum : (_obj.signScaleNum = _obj.signScale || 0); _obj.signScaleNum ? _obj.signScaleNum : (_obj.signScaleNum = _obj.signScale || 0);
_obj.clerkSignforScaleNum _obj.clerkSignforScaleNum
@ -2202,7 +2382,6 @@ const billSignforData = computed<any>(() => {
type OptionObjType = { prop: string; tip: string }; type OptionObjType = { prop: string; tip: string };
// //
const colors = ['#008CBA', '#808080']; // const colors = ['#008CBA', '#808080']; //
// /** */ // /** */
@ -2317,7 +2496,12 @@ const getProportion = (value: number) => {
// }); // });
// }; // };
// //
const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, chartType: string = 'pie') => { const handleShowEcharts = (
data: any[],
title: string,
optionObj: OptionObjType,
chartType: string = 'pie'
) => {
console.log('data :>> ', data); console.log('data :>> ', data);
console.log('title :>> ', title); console.log('title :>> ', title);
console.log('optionObj :>> ', optionObj); console.log('optionObj :>> ', optionObj);
@ -2344,7 +2528,8 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
const item = _arr[j]; // _arr const item = _arr[j]; // _arr
if (item.value > value[optionObj.prop]) continue; // _arr if (item.value > value[optionObj.prop]) continue; // _arr
_arr.splice(j, 0, { // _arr.splice(j, 0, {
//
name: value.warehouseName, // name: value.warehouseName, //
value: value[optionObj.prop], // value: value[optionObj.prop], //
}); });
@ -2353,13 +2538,15 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
} }
if (isContinue) continue; // if (isContinue) continue; //
_arr.push({ // _arr.push({
//
name: value.warehouseName, // name: value.warehouseName, //
value: value[optionObj.prop], // value: value[optionObj.prop], //
}); });
} }
nextTick(() => { // DOM nextTick(() => {
// DOM
// //
const chartDom = document.getElementById('echartBox'); const chartDom = document.getElementById('echartBox');
if (!chartDom) return; // if (!chartDom) return; //
@ -2373,7 +2560,7 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
}, },
tooltip: { tooltip: {
trigger: 'item', // trigger: 'item', //
formatter: (params) => { formatter: params => {
if (chartType === 'pie') { if (chartType === 'pie') {
return `${params.name}: ${params.value} (${params.percent}%)`; // return `${params.name}: ${params.value} (${params.percent}%)`; //
} else { } else {
@ -2385,7 +2572,8 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
orient: 'vertical', // orient: 'vertical', //
left: 'left', // left: 'left', //
}, },
...(chartType === 'bar' && { // ...(chartType === 'bar' && {
//
xAxis: { xAxis: {
type: 'category', // x type: 'category', // x
data: _arr.map(item => item.name), // x data: _arr.map(item => item.name), // x
@ -2397,24 +2585,25 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
yAxis: { yAxis: {
type: 'value', // y type: 'value', // y
axisLabel: { axisLabel: {
formatter: (value) => { formatter: value => {
return getProportion(value); // y return getProportion(value); // y
} },
}, },
}, },
series: [ series: [
{ {
name: optionObj.tip, // name: optionObj.tip, //
type: 'bar', // type: 'bar', //
data: _arr.map(item => ({ // data: _arr.map(item => ({
//
name: item.name, // name: item.name, //
value: item.value, // value: item.value, //
})), })),
itemStyle: { itemStyle: {
color: (params) => { color: params => {
// //
return colors[params.dataIndex % 2]; return colors[params.dataIndex % 2];
} },
}, },
emphasis: { emphasis: {
itemStyle: { itemStyle: {
@ -2426,9 +2615,9 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
show: true, // show: true, //
fontSize: 20, // fontSize: 20, //
fontWeight: 'bold', // fontWeight: 'bold', //
formatter: (params) => { formatter: params => {
return getProportion(params.value); // return getProportion(params.value); //
} },
}, },
}, },
barGap: '30%', // barGap: '30%', //
@ -2437,12 +2626,14 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
}, },
], ],
}), }),
...(chartType === 'pie' && { // ...(chartType === 'pie' && {
//
series: [ series: [
{ {
name: optionObj.tip, // name: optionObj.tip, //
type: 'pie', // type: 'pie', //
data: _arr.map((item) => ({ // data: _arr.map(item => ({
//
name: item.name + ' - ' + getProportion(item.value / _total), // name: item.name + ' - ' + getProportion(item.value / _total), //
value: item.value, // value: item.value, //
})), })),
@ -2469,8 +2660,6 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType,
}); });
}; };
/** 请求详情 */ /** 请求详情 */
const handleDetails = async (type, title, optionObj: OptionObjType) => { const handleDetails = async (type, title, optionObj: OptionObjType) => {
details.popUpShow.isShow = true; details.popUpShow.isShow = true;
@ -2534,7 +2723,12 @@ const handleShowDeliveryDetail = (
handleShowEcharts(data, title, optionObj); handleShowEcharts(data, title, optionObj);
}; };
/** 显示售后异常数据 */ /** 显示售后异常数据 */
const handleShowAbnormalData = (title, type: 'dayData' | 'monthData', optionObj: any = {},chartType) => { const handleShowAbnormalData = (
title,
type: 'dayData' | 'monthData',
optionObj: any = {},
chartType
) => {
details.popUpShow.isShow = true; details.popUpShow.isShow = true;
details.title = title; details.title = title;
console.log(optionObj, 'optionObj'); console.log(optionObj, 'optionObj');

Loading…
Cancel
Save