Browse Source

滞留页面重构,三方物料优化

dev-xx
马远东 9 months ago
parent
commit
52068e6c38
  1. 2
      src/api/warehouse/warehouseRetentionRecord.js
  2. 430
      src/option/warehouse/warehouseRetentionRecord.js
  3. 62
      src/page/login/aiqa.vue
  4. 6
      src/views/basicdata/TripartiteMaterial/list.vue
  5. 91
      src/views/cost/Deliverycostmanagement/Deliverymaintenancecosts.vue
  6. 696
      src/views/warehouse/warehouseRetentionRecord/warehouseRetentionRecord.vue

2
src/api/warehouse/warehouseRetentionRecord.js

@ -97,7 +97,7 @@ export const $_RetentionWarehouseRetentionRecord = params => {
export const $_warehouseRetentionRecordPage = params => { export const $_warehouseRetentionRecordPage = params => {
return request({ return request({
url: '/api/logpm-warehouse/warehouseRetentionRecord/page', url: '/api/logpm-warehouse/warehouseRetentionScan/page',
method: 'get', method: 'get',
params, params,
}); });

430
src/option/warehouse/warehouseRetentionRecord.js

@ -1,237 +1,195 @@
export default { export const columnList = [
height: 'auto', {
calcHeight: 30, prop: '',
tip: false, label: '复选框',
searchShow: false, type: 0,
searchMenuSpan: 6, values: '',
border: true, width: '55',
index: true, checkarr: [],
viewBtn: true, fixed: true,
selection: true, sortable: true,
menu: false, head: false,
dialogClickModal: false, },
column: [ {
{ prop: '',
label: '主键', label: '序号',
prop: 'id', type: 12,
type: 'input', values: '',
addDisplay: false, width: '55',
editDisplay: false, checkarr: [],
viewDisplay: false, fixed: true,
hide: true, sortable: true,
}, head: false,
{ },
label: '租户号', {
prop: 'tenantId', prop: 'trainNumber',
type: 'input', label: '车次号',
addDisplay: false, type: 1,
editDisplay: false, values: '',
viewDisplay: false, width: '180',
hide: true, checkarr: [],
}, fixed: false,
{ sortable: true,
label: '创建人', },
prop: 'createUser', {
type: 'input', prop: 'reservationCode',
addDisplay: false, label: '预约编号',
editDisplay: false, type: 1,
viewDisplay: false, values: '',
hide: true, width: '180',
}, checkarr: [],
{ fixed: false,
label: '创建时间', sortable: true,
prop: 'createTime', },
type: 'input', {
addDisplay: false, prop: 'waybillNumber',
editDisplay: false, label: '运单号',
viewDisplay: false, type: 1,
hide: true, values: '',
}, width: '180',
{ checkarr: [],
label: '更新人', fixed: false,
prop: 'updateUser', sortable: true,
type: 'input', },
addDisplay: false, {
editDisplay: false, prop: 'orderCode',
viewDisplay: false, label: '订单自编号',
hide: true, type: 2,
}, values: '',
{ width: '240',
label: '更新时间', checkarr: [],
prop: 'updateTime', fixed: false,
type: 'input', sortable: true,
addDisplay: false, head: false,
editDisplay: false, },
viewDisplay: false,
hide: true, {
}, prop: 'orderPackageCode',
{ label: '包条码',
label: '状态', type: 1,
prop: 'status', values: '',
type: 'input', width: '180',
addDisplay: false, checkarr: [],
editDisplay: false, fixed: false,
viewDisplay: false, sortable: true,
hide: true, },
},
{ {
label: '是否已删除', prop: 'materialNumber',
prop: 'isDeleted', label: '物料编码',
type: 'input', type: 2,
addDisplay: false, values: '',
editDisplay: false, width: '150',
viewDisplay: false, checkarr: [],
hide: true, fixed: false,
}, sortable: true,
{ head: false,
label: '创建部门', },
prop: 'createDept',
type: 'input', {
addDisplay: false, prop: 'materialName',
editDisplay: false, label: '物料名称',
viewDisplay: false, type: 2,
hide: true, values: '',
}, width: '150',
{ checkarr: [],
label: '预留1', fixed: false,
prop: 'reserve1', sortable: true,
type: 'input', head: false,
addDisplay: false, },
editDisplay: false,
viewDisplay: false, {
hide: true, prop: 'retentionScanTime',
}, label: '滞留扫描时间',
{ type: 1,
label: '预留2', values: '',
prop: 'reserve2', width: '180',
type: 'input', checkarr: [],
addDisplay: false, fixed: false,
editDisplay: false, sortable: true,
viewDisplay: false, },
hide: true, {
}, prop: 'retentionScanUsername',
{ label: '滞留操作人',
label: '预留3', type: 1,
prop: 'reserve3', values: '',
type: 'input', width: '180',
addDisplay: false, checkarr: [],
editDisplay: false, fixed: false,
viewDisplay: false, sortable: true,
hide: true, },
}, {
{ prop: 'retentionQuantity',
label: '预留4', label: '数量',
prop: 'reserve4', type: 1,
type: 'input', values: '',
addDisplay: false, width: '180',
editDisplay: false, checkarr: [],
viewDisplay: false, fixed: false,
hide: true, sortable: true,
}, },
{
label: '预留5', {
prop: 'reserve5', prop: 'warehouseName',
type: 'input', label: '仓库名称',
addDisplay: false, type: 1,
editDisplay: false, values: '',
viewDisplay: false, width: '180',
hide: true, checkarr: [],
}, fixed: false,
{ sortable: true,
label: '订单自编码', },
prop: 'orderCode',
type: 'input', {
}, prop: 'retentionWayName',
{ label: '滞留方式',
label: '包件码', type: 3,
prop: 'packageCode', values: '',
type: 'input', width: '180',
}, checkarr: [
{ {
label: '运单号', label: '扫描',
prop: 'waybillNo', value: 1,
type: 'input',
},
{
label: '滞留车次号',
prop: 'retentionCarId',
type: 'input',
addDisplay: false,
editDisplay: false,
viewDisplay: false,
hide: true,
},
{
label: '滞留车次号',
prop: 'retentionCarNo',
type: 'input',
},
{
label: '滞留仓库id',
prop: 'retentionWarehouseId',
type: 'input',
addDisplay: false,
editDisplay: false,
viewDisplay: false,
hide: true,
},
{
label: '滞留仓库名称',
prop: 'retentionWarehouseName',
type: 'input',
},
{
label: '滞留类型',
prop: 'retentionType',
type: 'select',
dicUrl: '/api/blade-system/dict-biz/dictionary?code=retention_type',
props: {
label: 'dictValue',
value: 'dictKey',
}, },
}, {
{ label: '文员',
label: '装车时间', value: 2,
prop: 'assembleCarDate', },
type: 'input', ],
}, fixed: false,
{ sortable: true,
label: '装车人id', },
prop: 'assembleCarPersonId', {
type: 'input', prop: 'scanTypeName',
addDisplay: false, label: '滞留操作类型',
editDisplay: false, type: 3,
viewDisplay: false, values: '',
hide: true, width: '180',
}, checkarr: [
{ {
label: '装车人名称', label: '包件',
prop: 'assembleCarPersonName', value: 1,
type: 'input', },
}, {
{ label: '订单',
label: '备注', value: 2,
prop: 'remark', },
type: 'input', {
}, label: '托盘',
{ value: 3,
label: '取消滞留人id', },
prop: 'cancelRetentionUserId', ],
type: 'input', fixed: false,
addDisplay: false, sortable: true,
editDisplay: false, },
viewDisplay: false, {
hide: true, prop: '',
}, label: '操作',
{ type: 6,
label: '取消滞留人名称', values: '',
prop: 'cancelRetentionUserName', width: '250',
type: 'input', checkarr: [],
}, fixed: 'right',
{ sortable: false,
label: '取消滞留备注', },
prop: 'cancelRemark', ];
type: 'input',
},
],
};

62
src/page/login/aiqa.vue

@ -1,7 +1,8 @@
<template> <template>
<div class="page-content"> <div class="page-content">
<div class="header"> <div class="header">
<div class="logo"><img :src="logo" /> <div class="logo">
<img :src="logo" />
<span>货无忧AI智能问答</span> <span>货无忧AI智能问答</span>
</div> </div>
<div class="icon-box"> <div class="icon-box">
@ -11,8 +12,7 @@
<div class="content"> <div class="content">
<div class="left"> <div class="left">
<div class="content-box" ref="chatContainer"> <div class="content-box" ref="chatContainer">
<div class="content-time">{{ time }}</div>
<div class="content-time">{{time}}</div>
<template v-for="(item, index) in Data.ChathistoryList" :key="index"> <template v-for="(item, index) in Data.ChathistoryList" :key="index">
<div <div
:class="{ :class="{
@ -21,8 +21,8 @@
}" }"
> >
<div class="icon"> <div class="icon">
<el-icon v-if=" item.state === 'user'"><Avatar /></el-icon> <el-icon v-if="item.state === 'user'"><Avatar /></el-icon>
<img v-else :src="logotx" /> <img v-else :src="logotx" />
</div> </div>
<div> <div>
<div <div
@ -132,6 +132,19 @@ const Data = ref({
{ {
content: '谷歌浏览器下载地址', content: '谷歌浏览器下载地址',
}, },
{
content: '东集pad安装初始密码是什么',
},
{
content: '东集pad-q7恢复出厂设置',
},
{
content: '货无忧的汇通物流公司编码是多少',
},
{
content: '蓝牙打印机芝柯tx453设备连接密码是多少',
},
], ],
ChathistoryList: [ ChathistoryList: [
// { // {
@ -200,9 +213,9 @@ const setCurrentTime = () => {
return `${year}${month}${day}${hours}:${minutes}:${seconds}`; return `${year}${month}${day}${hours}:${minutes}:${seconds}`;
}; };
const time = computed(()=>{ const time = computed(() => {
return setCurrentTime() return setCurrentTime();
}) });
// //
const inputData = value => { const inputData = value => {
Data.value.input = value; Data.value.input = value;
@ -237,7 +250,7 @@ const AiData = (value = '') => {
name: '货无忧智能AI', // name: '货无忧智能AI', //
content: aiResponse, // content: aiResponse, //
link: '', // link: '', //
time: setCurrentTime(),// time: setCurrentTime(), //
}; };
if (isFirstMessage.value) { if (isFirstMessage.value) {
@ -295,7 +308,28 @@ const AiData = (value = '') => {
} else if (lowercaseValue.includes('谷歌') || lowercaseValue.includes('谷歌浏览器下载地址')) { } else if (lowercaseValue.includes('谷歌') || lowercaseValue.includes('谷歌浏览器下载地址')) {
aiResponse = '谷歌浏览器下载地址如下:'; aiResponse = '谷歌浏览器下载地址如下:';
data.link = 'https://www.google.cn/intl/zh-CN/chrome/?'; data.link = 'https://www.google.cn/intl/zh-CN/chrome/?';
} else { } else if (
lowercaseValue.includes('东集pda初始密码') ||
lowercaseValue.includes('东集pad安装初始密码')
) {
aiResponse = '东集PDA安装初始密码是:4007770876';
}
else if (
lowercaseValue.includes('东集pad-q7恢复出厂设置')
) {
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 (
lowercaseValue.includes('货无忧的汇通物流公司编码是多少')
) {
aiResponse = '货无忧的汇通物流公司编码是:627683';
}
else if (
lowercaseValue.includes('蓝牙打印机芝柯tx453设备连接密码是多少') || lowercaseValue.includes('tx453')
) {
aiResponse = '蓝牙打印机芝柯xt453设备连接密码是:0000';
}
else {
aiResponse = '我不太理解您的问题,我正在努力学习中,请重新描述或输入其他问题,或联系管理员'; aiResponse = '我不太理解您的问题,我正在努力学习中,请重新描述或输入其他问题,或联系管理员';
} }
} }
@ -378,7 +412,7 @@ AiData(); //初始化AI机器人
.logo { .logo {
display: flex; display: flex;
align-items: center; align-items: center;
span{ span {
margin-left: 10px; margin-left: 10px;
} }
img { img {
@ -437,7 +471,7 @@ AiData(); //初始化AI机器人
justify-content: center; justify-content: center;
color: #d3832a; color: #d3832a;
font-size: 3em; font-size: 3em;
img{ img {
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
@ -500,7 +534,7 @@ AiData(); //初始化AI机器人
.el-input__wrapper { .el-input__wrapper {
box-shadow: none; box-shadow: none;
} }
.el-input__inner{ .el-input__inner {
font-size: 12px; font-size: 12px;
} }
.el-button { .el-button {
@ -531,7 +565,7 @@ AiData(); //初始化AI机器人
} }
} }
} }
.content-time{ .content-time {
text-align: center; text-align: center;
color: #9a9a9a; color: #9a9a9a;
font-size: 12px; font-size: 12px;

6
src/views/basicdata/TripartiteMaterial/list.vue

@ -192,15 +192,15 @@
</el-form-item> </el-form-item>
<el-form-item label="一级品"> <el-form-item label="一级品">
<el-input placeholder="请输入一级品" v-model="details.form.firsts"></el-input> <el-input placeholder="请输入一级品" v-model.trim="details.form.firsts"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="二级品"> <el-form-item label="二级品">
<el-input placeholder="请输入二级品" v-model="details.form.seconds"></el-input> <el-input placeholder="请输入二级品" v-model.trim="details.form.seconds"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="三级品"> <el-form-item label="三级品">
<el-input placeholder="请输入三级品" v-model="details.form.thirds"></el-input> <el-input placeholder="请输入三级品" v-model.trim="details.form.thirds"></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>

91
src/views/cost/Deliverycostmanagement/Deliverymaintenancecosts.vue

@ -45,65 +45,102 @@
<el-form :model="formLoad" class="el_pricing"> <el-form :model="formLoad" class="el_pricing">
<el-form-item label="是否有附加费"> <el-form-item label="是否有附加费">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large"></el-radio> <el-radio value="1" size="large"></el-radio>
<el-radio value=0 size="large"></el-radio> <el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="是否公里数计费"> <el-form-item label="是否公里数计费">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large"></el-radio> <el-radio value="1" size="large"></el-radio>
<el-radio value=0 size="large"></el-radio> <el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="公里计算规则"> <el-form-item label="公里计算规则">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large">总公里</el-radio> <el-radio value="1" size="large">总公里</el-radio>
<el-radio value=0 size="large">点位公里</el-radio> <el-radio value="0" size="large">点位公里</el-radio>
<el-radio value=0 size="large">最远点位公里数</el-radio> <el-radio value="0" size="large">最远点位公里数</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="是否计算返程"> <el-form-item label="是否计算返程">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large"></el-radio> <el-radio value="1" size="large"></el-radio>
<el-radio value=0 size="large"></el-radio> <el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="是否补贴起步公里数计费"> <el-form-item label="是否补贴起步公里数计费">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large"></el-radio> <el-radio value="1" size="large"></el-radio>
<el-radio value=0 size="large"></el-radio> <el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="补贴公里计算规则"> <el-form-item label="补贴公里计算规则">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large">总公里数</el-radio> <el-radio value="1" size="large">总公里数</el-radio>
<el-radio value=0 size="large">点位公里数</el-radio> <el-radio value="0" size="large">点位公里数</el-radio>
<el-radio value=0 size="large">最远点位公里数</el-radio> <el-radio value="0" size="large">最远点位公里数</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="是否计算返程"> <el-form-item label="是否计算返程">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large"></el-radio> <el-radio value="1" size="large"></el-radio>
<el-radio value=0 size="large"></el-radio> <el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="是否超区公里计费"> <el-form-item label="是否超区公里计费">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large"></el-radio> <el-radio value="1" size="large"></el-radio>
<el-radio value=0 size="large"></el-radio> <el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="超区公里数计算规则"> <el-form-item label="超区公里数计算规则">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large">总公里数</el-radio> <el-radio value="1" size="large">总公里数</el-radio>
<el-radio value=0 size="large">点位公里数</el-radio> <el-radio value="0" size="large">点位公里数</el-radio>
<el-radio value=0 size="large">最远点位公里数</el-radio> <el-radio value="0" size="large">最远点位公里数</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="超区点位计费模式"> <el-form-item label="超区点位计费模式">
<el-radio-group v-model="formLoad.a" class="ml-4"> <el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value=1 size="large">统一计费</el-radio> <el-radio value="1" size="large">统一计费</el-radio>
<el-radio value=0 size="large">区域计费</el-radio> <el-radio value="0" size="large">区域计费</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否计算返程">
<el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value="1" size="large"></el-radio>
<el-radio value="0" size="large"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否点位补贴计费">
<el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value="1" size="large"></el-radio>
<el-radio value="0" size="large"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否保底费">
<el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value="1" size="large"></el-radio>
<el-radio value="0" size="large"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否补贴油费">
<el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value="1" size="large"></el-radio>
<el-radio value="0" size="large"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="补贴油费计算规则">
<el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value="1" size="large">总公里数</el-radio>
<el-radio value="0" size="large">点位公里数</el-radio>
<el-radio value="0" size="large">最远点位公里数</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="是否计算返程">
<el-radio-group v-model="formLoad.a" class="ml-4">
<el-radio value="1" size="large"></el-radio>
<el-radio value="0" size="large"></el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
</el-form> </el-form>
@ -209,17 +246,17 @@ const newlyadded = row => {
cursor: pointer; cursor: pointer;
} }
} }
.el_pricing{ .el_pricing {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
:deep(.el-form-item){ :deep(.el-form-item) {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
width: 30%; width: 30%;
.el-form-item__content{ .el-form-item__content {
background-color: #f6f6f6; background-color: #f6f6f6;
padding: 0 10px; padding: 0 10px;
.el-radio-group{ .el-radio-group {
flex-wrap: nowrap; flex-wrap: nowrap;
} }
} }

696
src/views/warehouse/warehouseRetentionRecord/warehouseRetentionRecord.vue

@ -1,443 +1,327 @@
<template> <template>
<div class="maxContent"> <basic-container>
<!-- 搜索功能 --> <!-- 首页表格 -->
<div> <div class="avue-crud">
<div class="SoInput" v-show="searchSo"> <!-- 搜索模块 -->
<el-form :model="SoInfoData"> <el-row v-if="search">
<el-form-item label="滞留车次号:"> <!-- 查询模块 -->
<el-input v-model="SoInfoData.a" placeholder="请输入1" /> <el-form :inline="true" :model="query" class="el-fr-d">
</el-form-item> <!-- 查询按钮 -->
<el-form-item label="滞留类型:"> <el-form-item class="el-btn">
<el-input v-model="SoInfoData.b" placeholder="请输入2" /> <el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
</el-form-item> <el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
<el-form-item label="滞留创建人:">
<el-input v-model="SoInfoData.c" placeholder="请输入3" />
</el-form-item>
<el-form-item label="滞留时间:">
<el-input v-model="SoInfoData.d" placeholder="请输入4" />
</el-form-item> </el-form-item>
</el-form> </el-form>
<div class="SoBtn"> </el-row>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
</div>
</div>
<!-- 查询按钮 -->
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="Refresh" circle></el-button>
<el-button icon="el-icon-search" @click="searchSo = !searchSo" circle></el-button>
</div>
<!-- 表格开始 -->
<el-table
v-loading="loading"
element-loading-text="数据正在更新中..."
:data="ElData"
row-key="name"
border
height="600"
style="width: 100%"
ref="tableRef"
@select-all="selectAll"
@select="selectChange"
>
<el-table-column type="selection" width="55" fixed />
<el-table-column type="index" fixed width="50" height="100" label="#" align="center" />
<!-- <!-- 控件模块 -->
Type ===1 普通文本 <el-row>
Type ===2 图片显示 <div class="avue-crud__header">
Type ===3 操作功能 <!-- 头部左侧按钮模块 -->
label: 标题 <div class="avue-crud__left">
width: 宽度 <el-button type="primary" @click="AddInfo"
prop: 数据字段 ><el-icon><Download /></el-icon></el-button
--> >
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeS" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<el-table-column <!-- 首页表格 -->
:prop="item.prop" <el-row>
:label="item.label" <!-- 列表模块 -->
:width="item.width" <tablecmt
:fixed="item.fixed" class="tableNode"
align="center" :columnList="details.columnList"
v-for="(item, index) in menuData" :tableData="data"
:key="item.label" :loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
> >
<el-table-column <template #default="slotProps">
:prop="item.prop" <template v-if="slotProps.scope.column.label === '操作'">
:label="item.label" <div class="ElBtnClass">
:width="item.width" <el-button @click="view(slotProps.scope)">查看</el-button>
:fixed="item.fixed"
align="center"
>
<template #header>
<!-- <el-input
@change="InputSo(item)"
clearable
v-if="item.type == 4"
v-model="item.values"
:placeholder="`请输入${item.label}`"
/> -->
</template>
<template #default="props">
<img :src="props.row[item.prop]" class="el-Img" v-if="item.type === 2" />
<div :class="ElBtnClass" v-if="item.type == 3">
<el-button
:link="ElButtonS[0].link"
:class="ElButtonS[0].class"
:auto-insert-space="ElButtonS[0].space"
:size="ElButtonS[0].size"
:icon="ElButtonS[0].icon"
@click="ViewEvent(props.row)"
>滞留明细</el-button
>
</div> </div>
<span v-if="item.type == 6">{{
props.row[item.prop] == 1
? '装车滞留'
: props.row[item.prop] == 2
? '配送滞留'
: props.row[item.prop] == 3
? '出库滞留滞留'
: '/'
}}</span>
<span v-if="item.type == 1">{{
props.row[item.prop] ? props.row[item.prop] : '/'
}}</span>
</template> </template>
</el-table-column>
</el-table-column>
</el-table>
</div>
<!-- 表格翻页功能 -->
<div class="demo-pagination-block TCdemo-pagination-block">
<el-pagination
v-model:current-page="currentPage"
v-model:page-size="pageSize"
:page-sizes="pageList"
:disabled="disabled"
:background="background"
layout="total, sizes, prev, pager, next, jumper"
:total="total"
@size-change="PageSizeChange"
@current-change="SizeChange"
/>
</div>
<!-- 弹窗详情 -->
<el-dialog v-model="PopupDetails" title="详情数据展示" width="70%" :before-close="handleClose">
<el-tabs type="border-card" class="demo-tabs">
<el-tab-pane v-for="item in Tabs" :key="item.name">
<template #label>
<span class="custom-tabs-label">
<el-icon><component :is="item.icon" /></el-icon>
<span>{{ item.label }}</span>
</span>
</template> </template>
</el-tab-pane> </tablecmt>
</el-tabs> </el-row>
<template #footer>
<span class="dialog-footer"> <!-- 分页模块 -->
<el-button>Cancel</el-button> <el-row class="el-fy">
<el-button type="primary"> Confirm </el-button> <div class="avue-crud__pagination flex-c-sb" style="width: 100%">
</span> <div></div>
</template> <el-pagination
</el-dialog> align="right"
</div> background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
</div>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@setcolum="setnewcolum"
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
v-model="details.columnList"
></edittablehead>
</template> </template>
<script setup> <script setup>
import { ref, reactive, onMounted, computed } from 'vue'; import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { useRouter} from 'vue-router';
import { $_warehouseRetentionRecordPage } from '@/api/warehouse/warehouseRetentionRecord.js'; import { $_warehouseRetentionRecordPage } from '@/api/warehouse/warehouseRetentionRecord.js';
import { ElMessage } from 'element-plus'; import { columnList } from '@/option/warehouse/warehouseRetentionRecord';
const SoInfoData = ref({}); // import { getDictionaryBiz } from '@/api/system/dict'; //
const searchSo = ref(false); // import { processRowProperty, setNodeHeight } from '@/utils/util';
const ElData = ref([]); // import functions from '@/utils/functions.js';
const currentPage = ref(1); // import { ElMessageBox, ElMessage } from 'element-plus';
const pageSize = ref(20); // import { downloadXls } from '@/utils/util';
const pageList = ref([5, 10, 50, 100, 200]); // import { useStore } from 'vuex';
const background = ref(true); // import dayjs from 'dayjs';
const disabled = ref(false); // 使 const $router = useRouter(); //
const total = ref(10); // const $useStore = useStore(); //
const loading = ref(false); //Load const $route = useRoute(); //
const PopupDetails = ref(false); // const details = reactive({
const router = useRouter(); // /** 是否开启搜索 */
const Tabs = ref([ search: false,
// /** 表格搜索条件 */
{ label: '处理中', name: 0, icon: 'Monitor' }, query: {},
{ label: '理赔金额未出', name: 1, icon: 'Coin' }, /** 时间快捷选择设置 */
{ label: '处理完毕', name: 2, icon: 'Check' }, shortcuts: [
{ label: '完结', name: 3, icon: 'Reading' }, {
{ label: '仲裁中', name: 4, icon: 'List' }, text: '最近一周',
{ label: '全部', name: 5, icon: 'Notification' }, value: () => {
]); const end = new Date();
// const start = new Date();
const menuData = ref([ start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
{ return [start, end];
prop: 'retentionCarNo', },
label: '滞留车次号', },
type: 4, {
values: '', text: '最近一个月',
width: '200', value: () => {
checkarr: [], const end = new Date();
fixed: true, const start = new Date();
search: true, start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
head: true, return [start, end];
}, },
{ },
prop: 'retentionType', {
label: '滞留类型', text: '最近三个月',
type: 6, value: () => {
values: '', const end = new Date();
width: '150', const start = new Date();
checkarr: [], start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
fixed: false, return [start, end];
search: true, },
head: true, },
}, ],
{ /** 时间选择器数据 */
prop: 'assembleCarPersonName', stockupDate: [],
label: '装车人名称', /** 列表 */
type: 4, columnList,
values: '',
width: '200', /** 列表数据 */
checkarr: [], data: [],
fixed: false, /** 页面loading */
search: false, loadingObj: {
head: true, /** 列表加载loading */
}, list: true,
{ packageListLoading: false,
prop: 'retentionCreateUserName',
label: '滞留操作人',
type: 4,
values: '',
width: '200',
checkarr: [],
fixed: false,
search: false,
head: true,
},
{
prop: 'createTime',
label: '滞留时间',
type: 4,
values: '',
width: '200',
checkarr: [],
fixed: false,
search: false,
head: true,
},
{
prop: 'retentionQuantity',
label: '滞留数量',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
search: false,
head: true,
},
{
prop: 'retentionWarehouseName',
label: '仓库名称',
type: 4,
values: '',
width: '200',
checkarr: [],
fixed: false,
search: false,
head: true,
}, },
{ /** 列表复选框选中的数据 */
prop: 'retentionRemarks', selectionList: [],
label: '备注', /** 是否显示设置表格 */
type: 4, drawerShow: false,
values: '', /** 分页参数 */
width: '150', page: {
checkarr: [], currentPage: 1,
fixed: false, pageSize: 50,
search: false, total: 0,
head: true,
}, },
// {
// prop: '', /** 弹出层显示 */
// label: '1', popUpShow: {
// type: 4, /** 包件明细 */
// values: '', packageOrderListlVisited: false,
// width: '150', /** 二维码 */
// checkarr: [], QRCodeVisible: false,
// fixed: false, /** 修改客户信息 */
// search: false, editClientInfoVisible: false,
// head: true,
// },
// {
// prop: '',
// label: '2',
// type: 4,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// search: false,
// head: true,
// },
// {
// prop: '',
// label: '3',
// type: 4,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// search: false,
// head: true,
// },
// {
// prop: '',
// label: '4',
// type: 4,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// search: false,
// head: true,
// },
{
prop: '',
label: '操作',
type: 3,
values: '',
width: '200',
checkarr: [],
fixed: 'right',
search: false,
head: true,
}, },
]); // /** 列表Dom节点 */
// listNode: '',
const ElButtonS = ref([ form: {},
// 1.link (-false ,-tre) /** 全屏 */
// 2.class () fullscreenObj: {
// 3.space (true ,false) /** 包明细 */
// 4.size ('large'| 'default'| 'small') packageOrderListlVisited: false,
// 5.icon
// 6.table
{
link: false,
class: 'el-btn-view',
space: true,
size: 'small',
icon: 'el-icon-view',
table: '详情',
}, },
]); });
//
function onLoad() { const {
loading.value = true; // search,
let Data = { query,
current: currentPage.value, // shortcuts,
size: pageSize.value, // stockupDate,
}; data,
$_warehouseRetentionRecordPage(Data).then(res => { loadingObj,
console.log(res, '滞留初始化页面获取到的值'); selectionList,
ElData.value = res.data.data.records; drawerShow,
total.value = res.data.data.total; // page,
loading.value = false; // trickleLoadingPage,
}); zeroAdditionalRecordingInfo,
} popUpShow,
// recorddata,
onLoad(); } = toRefs(details);
const InputSo = val => {
/** 展开列表控件 */
const showdrawer = _flag => {
details.drawerShow = _flag;
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
test(details.query);
};
//
const test = val => {};
/** 表格表头时间选择 */
const timesc = (index, row) => {
console.log(index, row);
if (!!index) {
index = dayjs(index).format('YYYY-MM-DD');
}
details.query[row.prop] = index;
if (!index) {
delete details.query[row.prop];
}
};
/** 表格表头输入框搜索 */
const btnsc = val => {
console.log(val); console.log(val);
}; };
// /** 表格表头下拉框选择 */
const selectChange = () => { const selectsc = (index, row) => {
console.log('触发了选择'); processRowProperty(index, row, details);
}; };
// /** 表格表头复选框选择 */
const selectAll = () => { const selectionChange = list => {
console.log('触发了选择'); console.log(list);
details.selectionList = list;
}; };
// //
const searchReset = () => { const searchChange = () => {
SoInfoData.value = {}; details.search = false; //
}; };
// //
const ViewEvent = val => { const sizeChange = val => {
console.log(val); details.page.pageSize = val;
};
router.push({ /** 页码改变执行的回调 */
path: '/warehouse/warehouseRetentionRecord/warehouseRetentionDetails', const currentChange = val => {
query: { details.page.currentPage = val;
id: val.id,
name: val.retentionCarNo + '-滞留明细',
},
});
// console.log(val);
// PopupDetails.value = true;
}; };
// //
const handleClose = () => { const searchChangeS = () => {
PopupDetails.value = false; details.search = false; //
}; };
// () //
const Refresh = () => { const searchHide = () => {
onLoad(); // console.log(details);
details.search = !details.search;
const _node = document.querySelector('.tableNode');
setNodeHeight(_node, '', true);
};
//
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
});
});
});
}
//
const onLoad = () => {
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
};
$_warehouseRetentionRecordPage(data).then(res => {
console.log(res, '返回值');
details.data = res.data.data.records;
details.data.forEach(item => {
if (item.retentionWay == 1) {
item.retentionWayName = '扫描';
} else if (item.retentionWay == 2) {
item.retentionWayName = '文员';
}
if (item.scanType == 1) {
item.scanType = '包件';
} else if (item.scanType == 2) {
item.scanTypeName = '订单';
} else if (item.scanType == 3) {
item.scanTypeName = '托盘';
}
});
details.page.total = res.data.data.total;
details.loadingObj.list = false;
});
}; };
onLoad();
//
</script> </script>
<style lang="scss" scoped> <style scoped lang="scss">
.maxContent { .ElBtnClass button {
width: 100%; border: none;
box-sizing: border-box; padding: 0;
height: 100%; background-color: transparent;
display: flex;
flex-direction: column;
} }
.SoInput { :deep(.el-card) {
display: flex; height: 100%;
justify-content: space-between;
padding: 0 10px;
margin-top: 10px;
form {
display: flex;
flex-wrap: wrap;
margin-top: 5px;
:deep(.el-form-item) {
margin-bottom: 0;
}
}
.SoBtn {
display: flex;
align-items: center;
justify-content: center;
}
} }
.avue-crud__right { :deep(.el-card__body) {
margin-top: 5px; height: 100%;
display: flex; display: flex;
justify-content: flex-end; flex-direction: column;
margin-bottom: 5px;
padding: 0 10px;
}
:deep(.cell) {
padding: 0;
} }
.demo-pagination-block { .el-fy {
flex: 1; flex: 1;
display: flex; display: flex;
align-items: flex-end; align-items: flex-end;
margin-bottom: 8px; margin-bottom: 10px;
justify-content: flex-end;
margin-right: 6px;
} }
:deep(.el-table-column--selection) { .avue-crud {
text-align: center; height: 100%;
display: flex;
flex-direction: column;
} }
</style> </style>

Loading…
Cancel
Save