qb 4 months ago
parent
commit
facf036629
  1. 26
      src/api/storagecost/index.js
  2. 242
      src/option/storagecost/Traincostbreakdown.js
  3. 326
      src/views/cost/Deliverycostmanagement/Traincostbreakdown.vue
  4. 5
      src/views/desk/DataBoard.vue

26
src/api/storagecost/index.js

@ -1,4 +1,5 @@
import request from '@/axios';
import { p } from '@antfu/utils';
// 月度仓储成本统计表接口
export const $_Getlist = params => {
return request({
@ -138,6 +139,30 @@ export const $_expenseDispatchFinancialReview = params => {
export const $_Traincostbreakdown = params => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchTrainDetail/page',
method: 'get',
params,
});
};
// 配送成本-车辆成本结算表异动调整
export const $_Traincostbreakdownchange = data => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchTrainDetail/change',
method: 'post',
data,
});
};
// 配送成本-车辆成本结算表结算
export const $_Traincostbreakdownsubmit = data => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchTrainDetail/submit',
method: 'post',
data,
});
};
// 配送成本-车辆成本结算表结算-异动记录
export const $_Traincostbreakdownsubmitpage = params => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchTrainDetailChange/page',
method: 'get',
params,
});
@ -404,3 +429,4 @@ export const $_Warehouserentalmanagementremove = params => {
params,
});
};

242
src/option/storagecost/Traincostbreakdown.js

@ -15,9 +15,9 @@ export const columnList = [
fixed: true,
},
{
prop: 'trainNumber',
label: '车次号',
type: 2,
prop: 'deliveryVehicle',
label: '配送车辆',
type: 1,
values: '',
width: '150',
checkarr: [],
@ -26,8 +26,8 @@ export const columnList = [
head: false,
},
{
prop: 'deliveryDate',
label: '配送日期',
prop: 'distributionModel',
label: '配送车型',
type: 1,
values: '',
width: '150',
@ -37,8 +37,8 @@ export const columnList = [
head: false,
},
{
prop: 'destinationWarehouse',
label: '目的仓',
prop: 'trainNumber',
label: '车次号',
type: 1,
values: '',
width: '150',
@ -48,9 +48,9 @@ export const columnList = [
head: false,
},
{
prop: 'customerName',
label: '客户名称',
type: 3,
prop: 'settlementStatus',
label: '结算状态',
type: 1,
values: '',
width: '150',
checkarr: [],
@ -59,8 +59,8 @@ export const columnList = [
head: false,
},
{
prop: 'orderCode',
label: '订单自编号',
prop: 'deliveryDate',
label: '配送日期',
type: 1,
values: '',
width: '200',
@ -70,28 +70,30 @@ export const columnList = [
head: false,
},
{
prop: 'distributionType ',
prop: 'destinationWarehouse',
label: '目的仓',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'distributionType',
label: '配送类型',
type: 1,
values: '',
width: '150',
checkarr: [
{
label: '商配',
value: '商配',
},
{
label: '市配',
value: '市配',
},
],
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deliveryVehicle',
label: '配送车辆',
prop: 'carrierName',
label: '承运方名称',
type: 1,
values: '',
width: '150',
@ -101,8 +103,8 @@ export const columnList = [
head: false,
},
{
prop: 'distributionModel',
label: '配送车型',
prop: 'plannedTotalQuantity',
label: '计划总件数',
type: 1,
values: '',
width: '150',
@ -110,10 +112,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'carrierName',
label: '承运方名称',
prop: 'totalOrderQuantity',
label: '订单总数',
type: 1,
values: '',
width: '150',
@ -121,10 +124,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'carrierType',
label: '承运方类型',
prop: 'inventoryItemCount',
label: '库存品件数',
type: 1,
values: '',
width: '150',
@ -132,10 +136,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'deliveryDriver',
label: '配送司机',
prop: 'totalLoadedPieces',
label: '装车总件数',
type: 1,
values: '',
width: '150',
@ -143,10 +148,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'plannedTotalQuantity',
label: '计划总件数',
prop: 'totalReceiptCost',
label: '签收总件数',
type: 1,
values: '',
width: '150',
@ -154,10 +160,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalOrderQuantity',
label: '订单总数',
prop: 'totalDistributionCost',
label: '配送总成本',
type: 1,
values: '',
width: '150',
@ -165,10 +172,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'inventoryItemCount',
label: '库存品件数',
prop: 'distributionCost',
label: '配送成本',
type: 1,
values: '',
width: '150',
@ -176,10 +184,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalLoadedPieces',
label: '装车总件数',
prop: 'stairCarryingFee',
label: '上楼费成本',
type: 1,
values: '',
width: '150',
@ -187,10 +196,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalReceiptCost',
label: '签收总件数',
prop: 'goodsAllocationCost',
label: '分货费成本',
type: 1,
values: '',
width: '150',
@ -198,10 +208,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'totalDistributionCost',
label: '配送总成本',
prop: 'repositioningCost',
label: '平移费成本',
type: 1,
values: '',
width: '150',
@ -209,10 +220,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'distributionCost',
label: '配送成本',
prop: 'handlingCost',
label: '装卸费成本',
type: 1,
values: '',
width: '150',
@ -220,10 +232,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'inventoryDistributionCost',
label: '库存品配送成本',
prop: 'mileageCost',
label: '公里数成本',
type: 1,
values: '',
width: '150',
@ -231,10 +244,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'tagRemovalCost',
label: '撕标签成本',
prop: 'subsidizedKilometerCost',
label: '补贴公里数成本',
type: 1,
values: '',
width: '150',
@ -242,10 +256,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'stairCarryingFee',
label: '上楼费成本',
prop: 'excessZoneMileageCost',
label: '超区公里费成本',
type: 1,
values: '',
width: '150',
@ -253,10 +268,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'goodsAllocationCost',
label: '分货费成本',
prop: 'locationSubsidyCost',
label: '点位补贴费成本',
type: 1,
values: '',
width: '150',
@ -264,10 +280,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'repositioningCost',
label: '平移费成本',
prop: 'minimumGuaranteeCost',
label: '保底费成本',
type: 1,
values: '',
width: '150',
@ -275,10 +292,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'handlingCost',
label: '装卸费成本',
prop: 'fuelCost',
label: '费成本',
type: 1,
values: '',
width: '150',
@ -286,10 +304,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'mileageCost',
label: '公里数成本',
prop: 'otherCosts',
label: '其他成本',
type: 1,
values: '',
width: '150',
@ -297,10 +316,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'subsidizedKilometerCost',
label: '补贴公里数成本',
prop: 'changeAmount',
label: '异动金额',
type: 1,
values: '',
width: '150',
@ -308,10 +328,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'excessZoneMileageCost',
label: '超区公里费成本',
prop: 'changeTime',
label: '异动时间',
type: 1,
values: '',
width: '150',
@ -321,8 +342,8 @@ export const columnList = [
head: false,
},
{
prop: 'locationSubsidyCost',
label: '点位补贴费成本',
prop: 'changeOperator',
label: '异动操作人',
type: 1,
values: '',
width: '150',
@ -332,8 +353,8 @@ export const columnList = [
head: false,
},
{
prop: 'minimumGuaranteeCost',
label: '保底费成本',
prop: 'settlementAmount',
label: '结算金额',
type: 1,
values: '',
width: '150',
@ -341,10 +362,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'fuelCost',
label: '油费成本',
prop: 'settlementTime',
label: '结算时间',
type: 1,
values: '',
width: '150',
@ -354,8 +376,19 @@ export const columnList = [
head: false,
},
{
prop: 'otherCosts',
label: '其他成本',
prop: 'settlementNote',
label: '结算备注',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'settlementUser',
label: '结算人',
type: 1,
values: '',
width: '150',
@ -364,7 +397,6 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'createUserName',
label: '操作',
@ -376,3 +408,65 @@ export const columnList = [
sortable: false,
},
];
export const AbnormalrecordcolumnList = [
{
prop: 'checkbox',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: 'xh',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'changeAmount',
label: '异动金额',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'changeNote',
label: '异动备注',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'changeOperator',
label: '操作人',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'changeTime',
label: '异动操作时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
];

326
src/views/cost/Deliverycostmanagement/Traincostbreakdown.vue

@ -19,9 +19,9 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="exportExcel"
<!-- <el-button type="primary" @click="exportExcel"
><el-icon><Plus /></el-icon></el-button
>
> -->
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
@ -49,9 +49,21 @@
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass">
<el-text type="primary">异动调整</el-text>
<el-text type="primary">异动记录</el-text>
<el-text type="primary">结算</el-text>
<el-text
type="primary"
v-if="slotProps.scope.row.settlementStatus == '未结算'"
@click="AbnormaladjustmentClick(slotProps.scope.row)"
>异动调整</el-text
>
<el-text type="primary" @click="Abnormalrecord(slotProps.scope.row)"
>异动记录</el-text
>
<el-text
type="primary"
v-if="slotProps.scope.row.settlementStatus == '未结算'"
@click="confirmation(slotProps.scope.row)"
>结算</el-text
>
</div>
</template>
</template>
@ -77,6 +89,120 @@
</div>
</el-row>
</div>
<!-- 异动调整 -->
<el-dialog
v-model="Abnormaladjustment.dialogVisible"
title="异动调整"
width="500"
:before-close="handleClose"
>
<div v-loading="Abnormaladjustment.loading" element-loading-text="Loading...">
<el-form :model="Abnormaladjustment.form" label-width="auto" style="max-width: 600px">
<el-form-item label="异动费用:">
<el-input-number
v-model="Abnormaladjustment.form.changeAmount"
:min="0"
:controls="false"
:value-on-clear="0"
/>
</el-form-item>
<el-form-item label="异动费用备注:">
<el-input
v-model="Abnormaladjustment.form.changeNote"
style="width: 100%"
:rows="2"
type="textarea"
placeholder="请填写异动费用备注(必填)"
/>
</el-form-item>
</el-form>
</div>
<template #footer>
<div class="dialog-footer">
<el-button @click="Abnormaladjustment.dialogVisible = false">关闭</el-button>
<el-button
type="primary"
@click="AbnormaladjustmentSubmit"
:disabled="Abnormaladjustment.loading"
>
提交
</el-button>
</div>
</template>
</el-dialog>
<!-- 异动确认结算 -->
<el-dialog v-model="Confirmsettlement.dialogVisible" title="确认结算" width="500">
<div v-loading="Confirmsettlement.loading" element-loading-text="Loading...">
<el-form :model="Confirmsettlement.form" label-width="auto" style="max-width: 600px">
<el-form-item label="结算备注:">
<el-input
v-model="Confirmsettlement.form.settlementNote"
style="width: 100%"
:rows="4"
type="textarea"
placeholder="请填写结算备注(必填)"
/>
</el-form-item>
</el-form>
</div>
<template #footer>
<div class="dialog-footer">
<el-button @click="Confirmsettlement.dialogVisible = false">关闭</el-button>
<el-button
type="primary"
@click="SettlementconfirmationSubmit"
:disabled="Confirmsettlement.loading"
>
提交
</el-button>
</div>
</template>
</el-dialog>
<!-- 异动记录 -->
<el-dialog v-model="viewAbnormalrecord.dialogVisible" title="异动记录" width="50%">
<!-- 控件模块 -->
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left"></div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeSyd" 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-row>
<tablecmt
class="viewAbnormalrecord"
:columnList="details.AbnormalrecordcolumnList"
:tableData="Abnormalrecordcdata"
:loading="viewAbnormalrecord.list"
>
</tablecmt>
</el-row>
<!-- 分页模块 -->
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div></div>
<el-pagination
align="right"
background
@size-change="sizeChangeyd"
@current-change="currentChangeyd"
:current-page="pageyd.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="pageyd.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="pageyd.total"
>
</el-pagination>
</div>
</el-row>
</el-dialog>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@ -89,10 +215,17 @@
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/storagecost/Traincostbreakdown.js';
import { columnList, AbnormalrecordcolumnList } from '@/option/storagecost/Traincostbreakdown.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_getMyWarehouseList,$_Traincostbreakdown ,$_expenseDispatchTrainDetail} from '@/api/storagecost/index.js';
import {
$_getMyWarehouseList,
$_Traincostbreakdown,
$_expenseDispatchTrainDetail,
$_Traincostbreakdownchange,
$_Traincostbreakdownsubmit,
$_Traincostbreakdownsubmitpage,
} from '@/api/storagecost/index.js';
import { ElMessageBox, ElMessage } from 'element-plus';
import { downloadXls } from '@/utils/util';
import { useStore } from 'vuex';
@ -100,6 +233,26 @@ import dayjs from 'dayjs';
const $router = useRouter(); //
const $useStore = useStore(); //
const $route = useRoute(); //
//
const Abnormaladjustment = ref({
dialogVisible: false,
loading: false,
form: {
changeAmount: 0,
changeNote: '',
},
});
const Confirmsettlement = ref({
dialogVisible: false,
loading: false,
form: {
settlementNote: '',
},
});
const viewAbnormalrecord = ref({
dialogVisible: false,
list: false,
});
const details = reactive({
/** 是否开启搜索 */
search: false,
@ -137,9 +290,10 @@ const details = reactive({
],
/** 列表 */
columnList,
AbnormalrecordcolumnList,
/** 列表数据 */
data: [],
Abnormalrecordcdata: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
@ -156,7 +310,11 @@ const details = reactive({
pageSize: 50,
total: 0,
},
pageyd: {
currentPage: 1,
pageSize: 50,
total: 0,
},
/** 弹出层显示 */
popUpShow: {
/** 包件明细 */
@ -181,10 +339,12 @@ const {
query,
shortcuts,
data,
Abnormalrecordcdata,
loadingObj,
selectionList,
drawerShow,
page,
pageyd,
trickleLoadingPage,
zeroAdditionalRecordingInfo,
popUpShow,
@ -237,14 +397,23 @@ const sizeChange = val => {
details.page.pageSize = val;
onLoad();
};
//
const sizeChangeyd = val => {
details.pageyd.pageSize = val;
onLoad();
};
/** 页码改变执行的回调 */
const currentChange = val => {
details.page.currentPage = val;
onLoad();
};
const currentChangeyd = val => {
details.pageyd.currentPage = val;
onLoad();
};
//
const searchChangeS = () => {
details.search = false; //
onLoad();
};
//
const searchHide = () => {
@ -273,18 +442,21 @@ const onLoad = value => {
...details.query,
...value,
};
details.loadingObj.list=true;
$_Traincostbreakdown(data).then(res => {
console.log(res,'初始化数据');
if (res.data.code == 200) {
details.data = res.data.data.records || [];
details.page.total = res.data.data.total; //
}
}).catch((error)=>{
console.log(error);
}).finally(()=>{
details.loadingObj.list=false;
});
details.loadingObj.list = true;
$_Traincostbreakdown(data)
.then(res => {
console.log(res, '初始化数据');
if (res.data.code == 200) {
details.data = res.data.data.records || [];
details.page.total = res.data.data.total; //
}
})
.catch(error => {
console.log(error);
})
.finally(() => {
details.loadingObj.list = false;
});
};
//
@ -318,6 +490,116 @@ const exportExcel = () => {
})
.catch(() => {});
};
//
const AbnormaladjustmentClick = row => {
const { id, changeAmount, changeNote } = row;
Abnormaladjustment.value.dialogVisible = true;
Abnormaladjustment.value.form = { id, changeAmount, changeNote };
};
//
const AbnormaladjustmentSubmit = async () => {
if (!Abnormaladjustment.value.form.changeNote) {
ElMessage({
message: '请填写异动备注',
type: 'warning',
});
return;
}
try {
Abnormaladjustment.value.loading = true;
let Submit = {
...Abnormaladjustment.value.form,
};
let res = await $_Traincostbreakdownchange(Submit);
const { code, msg } = res.data;
if (code == 200) {
ElMessage({
message: msg,
type: 'success',
});
Abnormaladjustment.value.dialogVisible = false;
onLoad();
}
console.log(res);
} catch (e) {
console.log(e);
} finally {
Abnormaladjustment.value.loading = false;
}
};
const confirmation = row => {
const { id, settlementNote } = row;
Confirmsettlement.value.dialogVisible = true;
Confirmsettlement.value.form = { id, settlementNote };
};
//
const SettlementconfirmationSubmit = async row => {
if (!Confirmsettlement.value.form.settlementNote) {
ElMessage({
message: '请填写结算备注',
type: 'warning',
});
return;
}
try {
Confirmsettlement.value.loading = true;
let Submit = {
...Confirmsettlement.value.form,
};
let res = await $_Traincostbreakdownsubmit(Submit);
const { code, msg } = res.data;
if (code == 200) {
ElMessage({
message: msg,
type: 'success',
});
Confirmsettlement.value.dialogVisible = false;
onLoad();
}
console.log(res);
} catch (e) {
console.log(e);
} finally {
Confirmsettlement.value.loading = false;
}
};
const getAbnormalrecord = async () => {
try {
viewAbnormalrecord.value.list = true;
let submit = {
current: details.pageyd.currentPage,
size: details.pageyd.pageSize,
detailId: viewAbnormalrecord.value.detailId,
};
let res = await $_Traincostbreakdownsubmitpage(submit);
console.log(res);
const { code, data } = res.data;
if (code == 200) {
Abnormalrecordcdata.value = data.records;
details.pageyd.total = data.total;
}
} catch (e) {
console.log(e);
} finally {
viewAbnormalrecord.value.list = false;
}
};
//
const Abnormalrecord = async row => {
viewAbnormalrecord.value.id = row.id;
viewAbnormalrecord.value.dialogVisible = true;
nextTick(() => {
const _node = document.querySelector('.viewAbnormalrecord');
setNodeHeight(_node, '', true);
});
getAbnormalrecord();
};
const searchChangeSyd = () => {
getAbnormalrecord();
};
</script>
<style scoped lang="scss">

5
src/views/desk/DataBoard.vue

@ -839,7 +839,7 @@
class="data mr5px underline"
@click="
() =>
handleShowAbnormalData('异常数据-异常率-%', abnormal_status, {
handleShowAbnormalData('异常数据-处理率-%', abnormal_status, {
tip: '处理率',
prop: 'processingRate',
},'bar')
@ -1452,7 +1452,7 @@
<!-- 详情数据 -->
<el-dialog
v-model="details.popUpShow.isShow"
width="80%"
width="96%"
:append-to-body="false"
:destroy-on-close="true"
draggable
@ -2592,6 +2592,7 @@ onMounted(async () => {
//
:deep(.el-overlay) {
position: absolute;
height: 100vh;
}
:deep(.el-overlay-dialog) {

Loading…
Cancel
Save