Browse Source

财务页面,修复提货bug

pre-production
马远东 1 year ago
parent
commit
de42a31327
  1. 8
      src/api/basicdata/basicClient.js
  2. 13
      src/api/distribution/distributionStockArticle.js
  3. 32
      src/router/views/index.js
  4. 32
      src/views/basicdata/brand/basicClient.vue
  5. 26
      src/views/basicdata/brand/basicStorageServices.vue
  6. 476
      src/views/distribution/inventory/distrilbutionBillLading.vue
  7. 116
      src/views/financialsector/FinanceHome.vue
  8. 585
      src/views/financialsector/Financialse/FinancialWarehousing.vue

8
src/api/basicdata/basicClient.js

@ -21,6 +21,14 @@ export const getListCode = (params) => {
}
})
}
export const $_getListlistName = (params) => {
return request({
url: '/api/logpm-basicdata/basicdataClient/listName',
method: 'get',
params
})
}
export const getListClient = (current, size, params) => {
return request({
url: '/api/logpm-basicdata/basicdataClient/list',

13
src/api/distribution/distributionStockArticle.js

@ -79,7 +79,18 @@ export const getListOne = (current, size, params) => {
},
});
};
export const $_getListOne = (current, size, params) => {
//查询订单数据
return request({
url: '/api/logpm-distribution/distributionStockArticle/selectStockArticleInfoList',
method: 'get',
params: {
...params,
current,
size,
},
});
};
export const getDetail = (current, size, params) => {
return request({
url: '/api/logpm-distribution/distributionStockArticle/detail',

32
src/router/views/index.js

@ -1489,6 +1489,38 @@ export default [
},
],
},
{
path: '/financialsector/Financialse/FinancialWarehousing',
component: Layout,
redirect: '/financialsector/Financialse/FinancialWarehousing',
children: [
{
meta: {
i18n: 'dict',
keepAlive: false,
},
path: '/financialsector/Financialse/FinancialWarehousing',
name: '新增模板',
component: () => import('@/views/financialsector/Financialse/FinancialWarehousing.vue'),
},
],
},
{
path: '/financialsector/FinanceHome',
component: Layout,
redirect: '/financialsector/FinanceHome',
children: [
{
meta: {
i18n: 'dict',
keepAlive: false,
},
path: '/financialsector/FinanceHome',
name: '财务',
component: () => import('@/views/financialsector/FinanceHome.vue'),
},
],
},
// {
// path: '/aftersales/aftersalesWorkOrderSS',

32
src/views/basicdata/brand/basicClient.vue

@ -196,7 +196,7 @@
/>
</el-form-item>
<el-form-item label="客户名称" prop="clientName">
<el-input v-model="form.clientName" placeholder="请输入客户名称" style="width: 100%" />
<el-input v-model="form.clientName" :validate-method="CustomerName" :disabled="CustomerEntd" placeholder="请输入客户名称" style="width: 100%" />
</el-form-item>
<el-form-item label="客户类型" prop="clientType">
<!-- <el-input v-model="form.clientName" placeholder="请输入客户名称" style="width: 100%"/>-->
@ -453,6 +453,7 @@ import {
updateCargoControl,
remove,
getListCode,
$_getListlistName,
} from '@/api/basicdata/basicClient';
import option from '@/option/basicdata/basicClient';
import { mapGetters } from 'vuex';
@ -689,6 +690,7 @@ export default {
view: false,
viewEntd: true,
viewClientEntd: false,
CustomerEntd:false,
//
query: {},
//
@ -755,6 +757,7 @@ export default {
clientName: [
{ required: true, message: '请输入客户名称', trigger: 'blur' },
// { min: 3, max: 5, message: ' 3 5 ', trigger: 'blur' }
{ validator: this.CustomerName, trigger: 'blur' },
],
typeService: [{ required: true, message: '请选择客户端类型', trigger: 'blur' }],
businessType: [
@ -938,7 +941,30 @@ export default {
}
});
},
//
CustomerName(value, a) {
// console.log("",value,a);
return new Promise((resolve, reject) => {
//
// { valid: true }
// 1
if (!this.CustomerEntd) {
setTimeout(async () => {
const response = { valid: false }; //
await $_getListlistName({ code: a }).then(res => {
console.log("客户名称校验",res.data);
if (res.data.data.length > 0) {
reject(new Error('客户名称已存在')); // reject()
} else {
resolve(); // resolve()
}
});
}, 200);
} else {
resolve();
}
});
},
coverCharge(num) {
this.distriType = false;
// console.log(num);
@ -1218,6 +1244,7 @@ export default {
this.box = true;
this.distriType = false;
this.viewClientEntd = false;
this.CustomerEntd=false;
},
handleAddSon(row) {
console.log(row);
@ -1236,6 +1263,7 @@ export default {
this.distriType = false;
this.viewEntd = false;
this.viewClientEntd = true;
this.CustomerEntd=true;
getDetail(row.id).then(res => {
this.form = res.data.data;
if (this.form.detailedly == '0' || this.form.detailedly == '-1') {

26
src/views/basicdata/brand/basicStorageServices.vue

@ -339,15 +339,30 @@ export default {
});
});
} else {
if(this.form.shopId.length < 10){
console.log(this.warehouseServeOptions,'123123123');
if(this.form.shopId){
if(this.form.shopId.length < 10){
this.form.clientId = null;
}
if(this.form.forwardingUnit.length < 10){
}
if(this.form.forwardingUnit){
if(this.form.forwardingUnit.length < 10){
this.form.forwardingUnit = null;
}
this.form.sendWarehouseId = this.form.sendWarehouseIds;
this.form.sendWarehouseIds = null;
}
// this.form.sendWarehouseId = this.form.sendWarehouseIds;
// this.form.sendWarehouseIds = ;
console.log(this.warehouseOptions,'warehouseOptions,发展');
console.log(this.form.sendWarehouseIds,'this.form.sendWarehouseIds');
let ids=''
ids= this.warehouseOptions.find(res=>res.id==this.form.sendWarehouseIds).id
this.form.sendWarehouseIds =[]
this.form.sendWarehouseIds.push(ids)
this.form.serveWarehouseId= this.warehouseServeOptions.find(res=>res.id==this.form.serveWarehouseId).id
this.form.serveWarehouseNam= this.warehouseServeOptions.find(res=>res.id==this.form.serveWarehouseId).name
this.form.sendWarehouseId= this.warehouseOptions.find(res=>res.id==this.form.sendWarehouseIds).id
this.form.sendWarehouseName= this.warehouseOptions.find(res=>res.id==this.form.sendWarehouseIds).name
console.log(this.form,'this.form');
update(this.form).then(() => {
this.box = false;
this.onLoad(this.page);
@ -379,6 +394,7 @@ export default {
getDetail(row.id).then(res => {
console.log("编辑<<<<<",res.data.data);
this.form = res.data.data;
console.log(this.form,'form');
this.form.shopId = row.storeName;
this.form.forwardingUnit = row.linkman;
this.form.sendWarehouseIds = row.sendWarehouseId;

476
src/views/distribution/inventory/distrilbutionBillLading.vue

@ -122,16 +122,16 @@
@click.stop="handleZeroOrder(slotProps.scope.row)"
>录入预约数量</el-button
>
<el-button
<!-- <el-button
v-if="
slotProps.scope.row.isZero === '1' && Number(this.$route.query.type) !== 2
"
type="primary"
text
text
icon="el-icon-delete"
@click.stop="handleStockZeroOrder(slotProps.scope.row)"
>维护在库数量</el-button
>
> -->
<el-button
type="primary"
text
@ -335,7 +335,7 @@
<!-- &lt;!&ndash; 表单按钮 &ndash;&gt; v-if="!view || viewSC"-->
<div class="foot" :disabled="view">
<div class="dialog-footer">
<el-button type="primary" icon="CircleClose"> </el-button>
<el-button type="primary" @click="lastpage" icon="CircleClose"> </el-button>
<el-button type="primary" icon="el-icon-circle-check" @click="handleSubmit('form')">
</el-button>
@ -522,7 +522,7 @@
<template #default="scope">
<el-input-number
size="small"
v-model="scope.row._quantity"
v-model="scope.row.tiQuantity"
:min="0"
:max="scope.row.maxNum"
/>
@ -631,7 +631,7 @@ import { mapGetters } from 'vuex';
import { getDictionaryBiz } from '@/api/system/dict';
import { getToken } from '@/utils/auth';
import { getListStockList } from '@/api/distribution/distributionStockList';
import { getListOne } from '@/api/distribution/distributionStockArticle';
import { getListOne ,$_getListOne} from '@/api/distribution/distributionStockArticle';
import dayjs from 'dayjs';
import { detail } from '@/api/flow/flow';
import { nextTick, ref } from 'vue';
@ -867,26 +867,6 @@ export default {
sortable: true,
isshowSummary: true,
},
{
prop: 'consigneeUnit',
label: '收货单位',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'handQuantity',
label: '在库件数',
@ -898,72 +878,94 @@ export default {
isshowSummary: true,
sortable: true,
},
{
prop: 'availableQuantity',
label: '可用数量',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'notReceived',
label: '未入库数量',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'sortingQuantity',
label: '分拣数量',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'deliveryQuantity',
label: '配送数量',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'transferQuantity',
label: '中转数量',
prop: 'consigneeUnit',
label: '收货单位',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'signinQuantity',
label: '签收数量',
type: 1,
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
// {
// prop: 'availableQuantity',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// isshowSummary: true,
// sortable: true,
// },
// {
// prop: 'notReceived',
// label: '',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// isshowSummary: true,
// sortable: true,
// },
// {
// prop: 'sortingQuantity',
// label: '',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// isshowSummary: true,
// sortable: true,
// },
// {
// prop: 'deliveryQuantity',
// label: '',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// isshowSummary: true,
// sortable: true,
// },
// {
// prop: 'transferQuantity',
// label: '',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// isshowSummary: true,
// sortable: true,
// },
// {
// prop: 'signinQuantity',
// label: '',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// isshowSummary: true,
// sortable: true,
// },
{
prop: 'groundingStatusName',
label: '上架状态',
@ -1325,7 +1327,7 @@ export default {
{
prop: 'totalNumber',
label: '订单总件数',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -1334,56 +1336,10 @@ export default {
isshowSummary: true,
head: false,
},
{
prop: 'consigneeUnit',
label: '收货单位',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'handQuantity',
label: '在库件数',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'availableQuantity',
label: '可用数量',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'notReceived',
label: '未入库数量',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -1393,53 +1349,111 @@ export default {
head: false,
},
{
prop: 'sortingQuantity',
label: '分拣数量',
type: 2,
prop: 'reservationNum',
label: '计划数量',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'deliveryQuantity',
label: '配送数量',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'transferQuantity',
label: '中转数量',
prop: 'consigneeUnit',
label: '收货单位',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'signinQuantity',
label: '签收数量',
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
// {
// prop: 'availableQuantity',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// isshowSummary: true,
// head: false,
// },
// {
// prop: 'notReceived',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// isshowSummary: true,
// head: false,
// },
// {
// prop: 'sortingQuantity',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// isshowSummary: true,
// head: false,
// },
// {
// prop: 'deliveryQuantity',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// isshowSummary: true,
// head: false,
// },
// {
// prop: 'transferQuantity',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// isshowSummary: true,
// head: false,
// },
// {
// prop: 'signinQuantity',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// isshowSummary: true,
// head: false,
// },
{
prop: 'groundingStatusName',
label: '上架状态',
@ -1621,7 +1635,7 @@ export default {
label: '操作',
type: 6,
values: '',
width: '200',
width: '300',
checkarr: [],
fixed: 'right',
hide: true,
@ -2139,9 +2153,11 @@ export default {
this.orderAdd = true;
getDetail(this.$route.query.id).then(res => {
let s = res.data.data;
console.log(res,'res');
this.form = s;
let f = [];
s.chargeList.forEach(c => {
if(s.chargeList){
s.chargeList.forEach(c => {
let a = this.clientType.find(i => c.cost == i.dictKey);
if (!!c.cost && c.cost != '-1') {
@ -2152,6 +2168,8 @@ export default {
this.costList[c.cost] = a.remark;
}
});
}
this.form.freightMark = f;
this.costListName = f;
this.form.totalCost = s.totalCost.substring(0, s.totalCost.lastIndexOf('.'));
@ -2566,48 +2584,86 @@ export default {
}
}
},
lastpage(){
this.$router.push('/distribution/inventory/distrilbutionBillLadingList')
},
//
async handleSubmit() {
const zeroOrderList = this.dataList.filter(val => val.isZero === '1');
if (this.$route.query.type !== '2') {
//
const wrongZeroOrder = zeroOrderList.find(val => !val.ParcelLisList);
console.log('zeroOrderList :>> ', zeroOrderList);
console.log('wrongZeroOrder :>> ', wrongZeroOrder);
if (wrongZeroOrder) {
return this.$message({
type: 'error',
message: `订单自编号为${wrongZeroOrder.orderCode}的物料数量未编辑`,
});
}
if (zeroOrderList) {
//
const isSubmit = zeroOrderList.every(item => {
return item.ParcelLisList.every(val => val.quantity);
});
if (!isSubmit)
return this.$message({
type: 'error',
message: '有零担物料未填写',
// console.log(this.dataList,'this.dataList');
// if (this.$route.query.type !== '2') {
// //
// const wrongZeroOrder = zeroOrderList.find(val => !val.ParcelLisList);
// console.log();
// console.log('zeroOrderList :>> ', zeroOrderList);
// console.log('wrongZeroOrder :>> ', wrongZeroOrder);
// if (wrongZeroOrder) {
// return this.$message({
// type: 'error',
// message: `${wrongZeroOrder.orderCode}`,
// });
// }
// if (zeroOrderList) {
// //
// const isSubmit = zeroOrderList.every(item => {
// return item.ParcelLisList.every(val => val.quantity);
// });
// if (!isSubmit)
// return this.$message({
// type: 'error',
// message: '',
// });
// }
// // if ()
// }
this.$refs.form.validate(async valid => {
if (valid) {
if(!this.dataList.length){
return ElMessage({
message: '请选择定制品',
type: 'warning',
});
}
// if ()
}
this.$refs.form.validate(async valid => {
console.log(this.data, '当前选择的数据');
let resState=this.dataList.find(res=>!res.reservationNum)
console.log(resState,'123');
if(resState){
return ElMessage({
message: `单自编号为${resState.orderCode}的计划数量为0请移除或者重新录入预约数量`,
type: 'warning',
plain: true,
})
}
const zeroOrderList = this.dataList.filter(val => val.isZero === '1');
if (this.data.length) {
const allQuantitiesAreFalsy = this.data.every(item => item.inventoryQuantity);
console.log(allQuantitiesAreFalsy, 'allQuantitiesAreFalsy');
if (!allQuantitiesAreFalsy) {
ElMessage({
return ElMessage({
message: '请移除添加数量为0的订单',
type: 'warning',
});
return;
}
}
if (valid) {
if (!this.form.id) {
// if (this.fileListSell.length === 0) {
// this.$message.warning('');
// return;
@ -2674,24 +2730,26 @@ export default {
this.form.stockArticleId != null
? this.form.stockArticleId + a.join(',')
: a.join(',');
}
}
// ParcelLisList
const submitFormData = this.form;
//
if (zeroOrderList.length !== 0) {
console.log(1);
submitFormData.parcelLisList = [];
// console.log(zeroOrderList,'zeroOrderList');
// console.log(1);
// submitFormData.parcelLisList = [];
submitFormData.zeroType = '2';
zeroOrderList.forEach(val => {
submitFormData.parcelLisList = [
...submitFormData.parcelLisList,
...val.ParcelLisList,
];
// val.ParcelLisList.forEach(item => {
// submitFormData.parcelLisList.push(item);
// });
});
submitFormData.parcelLisList.forEach(val => (val.quantity = val._quantity));
// zeroOrderList.forEach(val => {
// console.log(val,'val');
// submitFormData.parcelLisList = [
// ...submitFormData.parcelLisList,
// ...val.ParcelLisList,
// ];
// // val.ParcelLisList.forEach(item => {
// // submitFormData.parcelLisList.push(item);
// // });
// });
// submitFormData.parcelLisList.forEach(val => (val.quantity = val.tiQuantity));
} else {
submitFormData.zeroType = '1';
}
@ -2724,6 +2782,7 @@ export default {
this.Selfpickuploading = false; //
});
} else {
console.log('111 :>> ', 111);
// return
let fei = new Map();
@ -2747,7 +2806,7 @@ export default {
if (_flag) return this.$message.warning('请填写正确的费用信息!!!');
}
this.form.stockDTOList = this.data;
let o = [];
const fileListMapping = {
@ -2909,7 +2968,7 @@ export default {
params.typeService = 3;
params.reservation = '30';
params.isAll = 0;
getListOne(page.currentPage, page.pageSize, Object.assign(params, this.queryOrder)).then(
$_getListOne(page.currentPage, page.pageSize, Object.assign(params, this.queryOrder)).then(
res => {
const data = res.data.data;
this.pageOrder.total = data.total;
@ -3156,16 +3215,20 @@ export default {
// firsts: val.firsts,
// };
const zeroOrder = val;
// id
// id
zeroOrder.stockArticleId = val.stockArticleId;
//
zeroOrder.maxNum = val.libraryQuantity - val.deliveryQuantity;
// ,
if (row.completeSetName !== '是' && Number(this.$route.query.type) === 3)
zeroOrder._quantity = null;
else if (val.deliveryQuantity && Number(this.$route.query.type) === 2) {
zeroOrder._quantity = val.deliveryQuantity;
}
// if (row.completeSetName !== '' && Number(this.$route.query.type) === 3){
// zeroOrder.tiQuantity =zeroOrder.tiQuantity;
// console.log('a=>>>>');
// }
// else if (val.deliveryQuantity && Number(this.$route.query.type) === 2) {
// zeroOrder.tiQuantity = val.tiQuantity;
// console.log('b=>>>>');
// }
return zeroOrder;
});
}
@ -3174,11 +3237,22 @@ export default {
},
//
handleRowZeroOrder() {
console.log(this.zeroOrderFormList,'12121212');
let sum =0
this.zeroOrderFormList.forEach(res=>{
sum+= res.tiQuantity
})
console.log(sum,'总和');
this.dataList.find(res=>res.id==this.zeroOrderFormList[0].stockArticleId).reservationNum=sum
// dataList
this.dataList.find(val => val.id === this.zeroOrderFormList[0].stockArticleId).ParcelLisList =
this.zeroOrderFormList;
this.dataList.find(val => val.id === this.zeroOrderFormList[0].stockArticleId).ParcelLisList = this.zeroOrderFormList;
//
this.dialogFormZeroOrderVisible = false;
},
/**
* 显示维护在库零担数量

116
src/views/financialsector/FinanceHome.vue

@ -0,0 +1,116 @@
<template>
<div class="content_box">
<div class="header">
<!-- 模板名称 -->
<div class="el_Template">
<span class="name">模板名称</span>
<el-input v-model="form.TemplateName" style="width: 240px" placeholder="请输入模板名称" />
</div>
<!-- 服务类型 -->
<div class="el_Service">
<span class="name">服务类型</span>
<el-select
v-model="form.ServiceType"
filterable
placeholder="请选择服务类型"
:popper-append-to-body="false"
style="width: 340px"
multiple
@remove-tag="removeTag"
>
<el-option
v-for="item in ServiceList"
:key="item.value"
:label="item.label"
:value="item.value"
>
<el-checkbox v-model="item.check" @change="isChecked(item)">
{{ item.label }}
</el-checkbox>
</el-option>
</el-select>
</div>
</div>
</div>
</template>
<script setup>
import { ref } from 'vue';
const form = ref({});
const ServiceList = ref([
{
label: '提货',
value: '1',
},
{
label: '干线',
value: '2',
},
{
label: '仓储',
value: '3',
},
{
label: '配送',
value: '4',
},
{
label: '安装',
value: '5',
},
]);
const isChecked = val => {
console.log(val);
};
const removeTag=(value) =>{
console.log(value,'value');
ServiceList.value.find(res=>res.value==value).check=false
}
</script>
<style scoped lang="scss">
.content_box {
width: 100%;
height: 100%;
}
.header {
.el_Template {
.name {
font-size: 16px;
}
}
display: flex;
.el_Service {
margin-left: 30px;
.el-checkbox {
width: 100% !important;
padding: 0 30px;
.el-checkbox__label {
margin-left: 20px;
}
}
.name {
font-size: 16px;
}
}
}
.el-checkbox {
width: 100% !important;
padding-left: 10px;
box-sizing: border-box;
.el-checkbox__label {
margin-left: 20px;
}
}
.el-select-dropdown__item {
padding: 0;
}
.el-select-dropdown__item::after {
content: '';
display: none;
}
</style>

585
src/views/financialsector/Financialse/FinancialWarehousing.vue

@ -0,0 +1,585 @@
<template>
<div class="content_max">
<!-- 仓储计费类型 -->
<div class="el_Storage">
<span class="el_table_span">仓储计费类型</span>
<el-select
class="el_Cselect"
v-model="form.Storagebillingtype"
filterable
clearable
placeholder="选择计费类型"
style="width: 240px"
>
<el-option
v-for="item in Storagebillingtype"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
<!-- 仓储计费模式 -->
<div class="el_Storage">
<span class="el_table_span">仓储计费模式</span>
<el-select
class="el_Cselect"
v-model="form.Warehousebillingmode"
filterable
clearable
placeholder="选择仓储计费模式"
style="width: 240px"
>
<el-option
v-for="item in Warehousebillingmode"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
<!-- 计算基准 -->
<div class="el_Storage">
<span class="el_table_span">计算基准</span>
<el-radio-group v-model="form.CalculationBasis" class="el_Cselect">
<el-radio v-for="item in CalculationBasis" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
</el-radio-group>
</div>
<!-- 是否区分品类 -->
<div class="el_Storage">
<span class="el_table_span">是否区分品类</span>
<el-radio-group v-model="form.Distinguishcategories" class="el_Cselect">
<el-radio v-for="item in Distinguishcategories" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
</el-radio-group>
</div>
<!-- 仓储品类配置 -->
<div class="el_Storage">
<div class="Storage-cont">
<span class="el_table_span">仓储品类配置</span>
<!-- 表格 -->
<div
class="el_Storagecategory"
v-loading="Storageloading"
element-loading-text="Loading..."
>
<div class="el_table_span">
<div class="el_table_id">序号</div>
<div class="el_table_title">产品品类</div>
</div>
<!-- 表格循环 -->
<div class="el_table_td" v-for="item in StoragecategoryList" :key="item.id">
<div class="el_table_idNumber">{{ item.id }}</div>
<el-select
class="el_Cselect"
v-model="item.Warehousecategory"
filterable
clearable
placeholder="请选择品类"
style="width: 240px"
>
<el-option
v-for="item in Warehousecategory"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<div class="el_table_operation">
<span
@click="storagereduce(item.id)"
v-if="item.reduce"
class="el_table_operation_span_a"
>-</span
>
<span @click="storageplus(item.id)" v-if="item.plus" class="el_table_operation_span_b"
>+</span
>
</div>
</div>
</div>
</div>
</div>
<hr class="el_hr" />
<!-- 附加费 -->
<div class="el_Surcharge_title">
<span>附加费</span>
</div>
<div class="el_Surcharge">
<!-- 附加费计价单位 -->
<div class="el_Storage">
<span class="el_table_span">附加费计价单位</span>
<el-select
class="el_Cselect"
v-model="form.Surchargepricingunit"
filterable
clearable
placeholder="选择计费类型"
style="width: 240px"
>
<el-option
v-for="item in Surchargepricingunit"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
<!-- 是否有管理费 -->
<div class="el_Storage">
<span class="el_table_span">是否有管理费</span>
<el-radio-group v-model="form.Managementfees" class="el_Cselect">
<el-radio v-for="item in Managementfees" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
</el-radio-group>
</div>
<!-- 是否有操作/装卸费 -->
<div class="el_Storage">
<span class="el_table_span">是否有操作/装卸费</span>
<el-radio-group v-model="form.Operatingunloading" class="el_Cselect">
<el-radio v-for="item in Operatingunloading" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
</el-radio-group>
</div>
<!-- 是否有分拣费用 -->
<div class="el_Storage">
<span class="el_table_span">是否有分拣费用</span>
<el-radio-group v-model="form.Sortingfee" class="el_Cselect">
<el-radio v-for="item in Sortingfee" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
</el-radio-group>
</div>
<!-- 附加费用是否统一计费 -->
<div class="el_Storage">
<span class="el_table_span">附加费用是否统一计费</span>
<el-select
class="el_Cselect"
v-model="form.Additionalfeebilling"
filterable
clearable
placeholder="附加费用是否统一计费"
style="width: 240px"
>
<el-option
v-for="item in Additionalfeebilling"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
<!-- 附加费品类配置 -->
<div class="el_Storage">
<div class="Storage-cont">
<span class="el_table_span">附加费品类配置</span>
<!-- 表格 -->
<div
class="el_Storagecategory"
v-loading="goriesloading"
element-loading-text="Loading..."
>
<div class="el_table_span">
<div class="el_table_id">序号</div>
<div class="el_table_title">产品品类</div>
</div>
<!-- 表格循环 -->
<div class="el_table_td" v-for="item in AdditionalcategoriesList" :key="item.id">
<div class="el_table_idNumber">{{ item.id }}</div>
<el-select
class="el_Cselect"
v-model="item.Additionalcategories"
filterable
clearable
placeholder="请选择品类"
style="width: 240px"
>
<el-option
v-for="item in Additionalcategories"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<div class="el_table_operation">
<span
@click="categoriesduce(item.id)"
v-if="item.reduce"
class="el_table_operation_span_a"
>-</span
>
<span
@click="categoriesplus(item.id)"
v-if="item.plus"
class="el_table_operation_span_b"
>+</span
>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</template>
<script setup>
import { ref } from 'vue';
const Storageloading = ref(false); //
const goriesloading = ref(false); //
const form = ref({
CalculationBasis: '1', //
Distinguishcategories: '1', //
Managementfees: '1', //
Operatingunloading: '1', ///
Sortingfee: '1', //
}); //
//
const Storagebillingtype = ref([
{
value: '1',
label: '按件',
},
{
value: '2',
label: '按方',
},
{
value: '3',
label: '按重量(KG)',
},
{
value: '4',
label: '按吨',
},
]);
//
const Warehousebillingmode = ref([
{
value: '1',
label: '分段式计费',
},
{
value: '2',
label: '最高标准计费',
},
]);
//
const CalculationBasis = ref([
{
value: '1',
label: '按件/天',
},
{
value: '2',
label: '按件/月',
},
]);
//
const Distinguishcategories = ref([
{
value: '1',
label: '是',
},
{
value: '2',
label: '否',
},
]);
//
const Warehousecategory = ref([
{
label: '衣柜',
value: '1',
},
{
label: '橱柜',
value: '2',
},
]);
//
const StoragecategoryList = ref([
{
id: 1,
plus: true,
reduce: false,
},
{
id: 2,
plus: true,
reduce: true,
},
]);
//
const AdditionalcategoriesList = ref([
{
id: 1,
plus: true,
reduce: false,
},
{
id: 2,
plus: true,
reduce: true,
},
]);
//
const Additionalcategories = ref([
{
label: '衣柜',
value: '1',
},
{
label: '橱柜',
value: '2',
},
]);
//
const Surchargepricingunit = ref([
{
label: '件',
value: '1',
},
{
label: '方',
value: '2',
},
{
label: '重量(KG)',
value: '3',
},
{
label: '吨(KG)',
value: '4',
},
]);
//
const Managementfees = ref([
{
value: '1',
label: '是',
},
{
value: '0',
label: '否',
},
]);
// /
const Operatingunloading = ref([
{
value: '1',
label: '是',
},
{
value: '0',
label: '否',
},
]);
//
const Sortingfee = ref([
{
value: '1',
label: '是',
},
{
value: '0',
label: '否',
},
]);
//
const Additionalfeebilling = ref([
{
value: '1',
label: '是',
},
{
value: '2',
label: '否',
},
]);
//
function removeItemById(array, id) {
const index = array.findIndex(item => item.id === id);
if (index !== -1) {
array.splice(index, 1);
array.forEach((item, index) => {
item.id = index + 1;
});
}
let timerId = setTimeout(() => {
goriesloading.value = false;
Storageloading.value = false;
clearTimeout(timerId); //
}, 300);
}
//
function addItemAfterId(array, id) {
const newItem = {
id: array.length + 1, // ID 1
plus: true,
reduce: true,
};
const index = array.findIndex(item => item.id === id);
if (index !== -1) {
array.splice(index + 1, 0, newItem); // ID
// ID
array.forEach((item, index) => {
item.id = index + 1;
});
}
let timerId = setTimeout(() => {
goriesloading.value = false;
Storageloading.value = false;
clearTimeout(timerId); //
}, 300);
//
}
//
const storagereduce = val => {
console.log(val);
Storageloading.value = true;
removeItemById(StoragecategoryList.value, val);
};
//
const storageplus = val => {
Storageloading.value = true;
addItemAfterId(StoragecategoryList.value, val);
};
//
const categoriesplus = val => {
goriesloading.value = true;
addItemAfterId(AdditionalcategoriesList.value, val);
};
//
const categoriesduce = val => {
goriesloading.value = true;
removeItemById(AdditionalcategoriesList.value, val);
};
</script>
<style scoped lang="scss">
.content_max {
padding: 10px;
}
.el_Storage {
margin-bottom: 30px;
.el_Cselect {
margin-left: 10px;
}
.el_table_span {
font-size: 16px;
font-weight: 500;
display: inline-block;
width: 160px;
}
.Storage-cont {
/* 禁止双击选中文本 */
-webkit-user-select: none; /* Safari */
-moz-user-select: none; /* Firefox */
-ms-user-select: none; /* IE 10+/Edge */
user-select: none; /* Standard syntax */
display: flex;
.el_Storagecategory {
border: 1px solid #ccc;
.el_table_span {
display: flex;
width: 100%;
background-color: #ebeef5;
padding: 4px;
box-sizing: border-box;
}
.el_table_id {
width: 62px;
font-weight: 600;
color: #606266;
}
.el_table_title {
font-weight: 600;
color: #606266;
}
.el_table_td {
display: flex;
height: 40px;
align-items: center;
border-bottom: 1px solid #ccc;
position: relative;
.el_table_operation {
width: 70px;
height: 100%;
display: flex;
align-items: center;
justify-content: space-between;
position: absolute;
right: -80px;
.el_table_operation_span_a,
.el_table_operation_span_b {
font-size: 20px;
font-weight: bold;
width: 40%;
border: 2px solid #f00;
color: #f00;
height: 70%;
border-radius: 6px;
display: block;
line-height: 23px;
text-align: center;
cursor: pointer;
}
.el_table_operation_span_b {
border: 2px solid #0d83b7;
color: #0d83b7;
}
.el_table_operation_span_a:hover {
background-color: #f00;
color: #ccc;
}
.el_table_operation_span_b:hover {
background-color: #0d83b7;
color: #ccc;
}
}
}
.el_table_idNumber {
width: 50px;
text-align: center;
font-size: 16px;
font-weight: 400;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
border-right: 1px solid #ccc;
}
:deep(.el-input__wrapper) {
box-shadow: none;
}
}
}
}
.el_hr {
height: 1px;
background-color: #378cbe;
border: none;
border-radius: 10px;
}
.el_Surcharge_title {
margin-bottom: 10px;
}
.el_Surcharge {
}
</style>
Loading…
Cancel
Save