Browse Source

修复已知bug

dev-xx
马远东 8 months ago
parent
commit
7bf0c87565
  1. 33
      src/api/storagecost/index.js
  2. 8
      src/components/pric/tablePric.vue
  3. 34
      src/option/storagecost/ServiceProviderPrice.js
  4. 9
      src/views/cost/Deliverycostmanagement/DeliveryCostPricingTemplate.vue
  5. 178
      src/views/cost/Deliverycostmanagement/Deliverymaintenancecosts.vue
  6. 279
      src/views/cost/Deliverycostmanagement/ServiceProviderPrice.vue
  7. 12
      src/views/cost/Deliverycostmanagement/WarehousePricingTemplate.vue

33
src/api/storagecost/index.js

@ -286,3 +286,36 @@ export const $_expenseDispatchPriceOverZoneremove = params => {
params, params,
}); });
}; };
// 配送-服务商配置价格-列表
export const $_ServiceProviderPrice = params => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchPriceService/page',
method: 'get',
params,
});
};
// 配送-服务商配置价格-新增
export const $_ServiceProviderPricesave = data => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchPriceService/save',
method: 'post',
data,
});
};
// 配送-服务商配置价格-修改
export const $_ServiceProviderPriceupdate = data => {
return request({
url: '/api/logpm-statisticsdata/expenseDispatchPriceService/update',
method: 'post',
data,
});
};
// 获取司机(当前仓库)
export const $_getDriverList = params => {
return request({
url: '/api/logpm-basicdata/driverArtery/selectList',
method: 'get',
params,
});
};

8
src/components/pric/tablePric.vue

@ -4,6 +4,8 @@
border border
:style="{ width: '100%', maxHeight: height + 'px' }" :style="{ width: '100%', maxHeight: height + 'px' }"
class="el_row_table" class="el_row_table"
v-loading="loading"
element-loading-text="Loading..."
> >
<template v-for="column in Surcharge" :key="column.prop"> <template v-for="column in Surcharge" :key="column.prop">
<el-table-column <el-table-column
@ -101,6 +103,10 @@ const props = defineProps({
type: Array, type: Array,
required: true, required: true,
}, },
loading: {
required: false,
default: false,
},
Surcharge: { Surcharge: {
type: Array, type: Array,
required: true, required: true,
@ -110,7 +116,7 @@ const props = defineProps({
default: () => [], default: () => [],
}, },
}); });
console.log(props.height,'props'); console.log(props.height, 'props');
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">

34
src/option/storagecost/ServiceProviderPrice.js

@ -7,7 +7,7 @@ export const columnList = [
fixed: true, fixed: true,
}, },
{ {
prop: 'xh', prop: '',
label: '序号', label: '序号',
type: 12, type: 12,
values: '', values: '',
@ -15,8 +15,8 @@ export const columnList = [
fixed: true, fixed: true,
}, },
{ {
prop: 'a1', prop: 'driverName',
label: '承运方名称', label: '司机',
type: 2, type: 2,
values: '', values: '',
width: '150', width: '150',
@ -26,7 +26,7 @@ export const columnList = [
head: false, head: false,
}, },
{ {
prop: 'a2', prop: 'warehouseName',
label: '服务仓', label: '服务仓',
type: 2, type: 2,
values: '', values: '',
@ -36,21 +36,11 @@ export const columnList = [
sortable: true, sortable: true,
head: false, head: false,
}, },
{ {
prop: 'a3', prop: 'templateName',
label: '维护状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'a4',
label: '承运方计价模板', label: '承运方计价模板',
type: 1, type: 2,
values: '', values: '',
width: '150', width: '150',
checkarr: [], checkarr: [],
@ -59,9 +49,9 @@ export const columnList = [
head: false, head: false,
}, },
{ {
prop: 'a5', prop: 'updateTime',
label: '修改时间', label: '修改时间',
type: 1, type: 4,
values: '', values: '',
width: '150', width: '150',
checkarr: [], checkarr: [],
@ -70,9 +60,9 @@ export const columnList = [
head: false, head: false,
}, },
{ {
prop: 'a6', prop: 'createUserName',
label: '修改人', label: '修改人',
type: 3, type: 1,
values: '', values: '',
width: '150', width: '150',
checkarr: [ ], checkarr: [ ],
@ -82,7 +72,7 @@ export const columnList = [
}, },
{ {
prop: 'createUserName', prop: '',
label: '操作', label: '操作',
type: 6, type: 6,
values: '', values: '',

9
src/views/cost/Deliverycostmanagement/DeliveryCostPricingTemplate.vue

@ -1,5 +1,6 @@
<template> <template>
<div class="content"> <div class="content" v-loading="loading"
element-loading-text="Loading...">
<!-- 配置计价规则 --> <!-- 配置计价规则 -->
<el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick"> <el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick">
<el-tab-pane label="商配" :name="1"></el-tab-pane> <el-tab-pane label="商配" :name="1"></el-tab-pane>
@ -174,6 +175,7 @@ console.log(props, '来自父页面参数');
const $route = useRoute(); // const $route = useRoute(); //
const copyform = ref({}); const copyform = ref({});
const State = ref(false); // const State = ref(false); //
const loading=ref(false)
const form = ref({ const form = ref({
ynSurcharge: 0, // ynSurcharge: 0, //
ynChargedKilometer: 0, // ynChargedKilometer: 0, //
@ -247,6 +249,7 @@ const onLoad = () => {
// } else { // } else {
// data.templateId = '1821740515451240449'; // data.templateId = '1821740515451240449';
// } // }
loading.value=true;
$_expenseDispatchPriceRuledetail(data).then(res => { $_expenseDispatchPriceRuledetail(data).then(res => {
console.log(res, '详情'); console.log(res, '详情');
if (res.data.code == 200) { if (res.data.code == 200) {
@ -258,6 +261,10 @@ const onLoad = () => {
} }
console.log(State.value,'状态'); console.log(State.value,'状态');
} }
}).catch((error)=>{
console.log(error);
}).finally(()=>{
loading.value=false;
}); });
} }
}; };

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

@ -11,6 +11,7 @@
:Surcharge="dispatchSubjoinCategory" :Surcharge="dispatchSubjoinCategory"
@focus="handleRowFocus" @focus="handleRowFocus"
@search="search" @search="search"
:loading="Pageloading"
> >
<template #default="slotProps"> <template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'"> <template v-if="slotProps.scope.column.label === '操作'">
@ -161,7 +162,7 @@
><el-icon><Plus /></el-icon></el-button ><el-icon><Plus /></el-icon></el-button
> >
<SurchargeTable <SurchargeTable
:SurchargeData="form.Oversizedbilling" :SurchargeData="OversizedbillingData"
:Surcharge="Oversizedbilling" :Surcharge="Oversizedbilling"
@focus="handleRowFocus" @focus="handleRowFocus"
@search="search" @search="search"
@ -239,11 +240,11 @@
</template> </template>
</el-dialog> </el-dialog>
</div> </div>
<div class="footer"> <!-- <div class="footer">
<el-button type="primary" @click="preservation" <el-button type="primary" @click="preservation"
>保存<el-icon><Promotion /></el-icon >保存<el-icon><Promotion /></el-icon
></el-button> ></el-button>
</div> </div> -->
</template> </template>
<script> <script>
// //
@ -277,6 +278,7 @@ const props = defineProps({
templateData: Object, templateData: Object,
}); });
console.log(props, '来自父页面参数'); console.log(props, '来自父页面参数');
const Pageloading = ref(false);
const $router = useRouter(); // const $router = useRouter(); //
const $useStore = useStore(); // const $useStore = useStore(); //
const $route = useRoute(); // const $route = useRoute(); //
@ -290,6 +292,7 @@ const formLoad = ref({});
const optionsVehicle = ref([]); const optionsVehicle = ref([]);
const copyform = ref({}); const copyform = ref({});
const dispatchSubjoinCategoryData = ref([]); // const dispatchSubjoinCategoryData = ref([]); //
const OversizedbillingData = ref([]);
const loading = ref(false); //loading const loading = ref(false); //loading
const form = ref({ const form = ref({
kilometerCost: 0, // kilometerCost: 0, //
@ -583,7 +586,6 @@ const GetCategory = () => {
$_expenseDispatchPriceUnit(data).then(async res => { $_expenseDispatchPriceUnit(data).then(async res => {
console.log(res, '品类'); console.log(res, '品类');
if (res.data.code == 200) { if (res.data.code == 200) {
loading.value=false;
// 使 reduce // 使 reduce
let groupingData = await grouping(res.data.data.records); let groupingData = await grouping(res.data.data.records);
console.log(groupingData, '分好组的数据'); console.log(groupingData, '分好组的数据');
@ -607,7 +609,8 @@ const GetCategory = () => {
}); });
let flattenedData = Object.values(groupingData).flat(); // let flattenedData = Object.values(groupingData).flat(); //
console.log(flattenedData, '附加费'); console.log(flattenedData, '附加费');
Categorystatistics(flattenedData, form.value.asurcharge, 2); await Categorystatistics(flattenedData, form.value.asurcharge, 2);
loading.value = false;
} }
}); });
} }
@ -635,8 +638,8 @@ const configurationdetails = row => {
form.value.fuelCost = scope.fuelCost; // form.value.fuelCost = scope.fuelCost; //
console.log(scope, '详情参数'); console.log(scope, '详情参数');
// //
form.value.Oversizedbilling = []; OversizedbillingData.value = [];
console.log(form.value.Oversizedbilling, 'form.value.Oversizedbilling'); console.log(OversizedbillingData.value, 'OversizedbillingData.value');
if (scope.overZoneList?.length) { if (scope.overZoneList?.length) {
scope.overZoneList.forEach((item, index) => { scope.overZoneList.forEach((item, index) => {
let _data = { let _data = {
@ -650,10 +653,10 @@ const configurationdetails = row => {
loading: false, loading: false,
id: item.id, id: item.id,
}; };
form.value.Oversizedbilling.push(_data); OversizedbillingData.value.push(_data);
}); });
} }
console.log(form.value.Oversizedbilling, 'form.value.Oversizedbilling'); console.log(OversizedbillingData.value, 'OversizedbillingData.value');
// 使 reduce // 使 reduce
let groupingData = await grouping(scope.priceList); let groupingData = await grouping(scope.priceList);
console.log(groupingData, '分好组的数据'); console.log(groupingData, '分好组的数据');
@ -677,13 +680,15 @@ const configurationdetails = row => {
}); });
let flattenedData = Object.values(groupingData).flat(); // let flattenedData = Object.values(groupingData).flat(); //
console.log(flattenedData, '附加费'); console.log(flattenedData, '附加费');
Categorystatistics(res.data.data.addPriceList, form.value.asurcharge, 2); await Categorystatistics(res.data.data.addPriceList, form.value.asurcharge, 2);
loading.value = false;
} }
} }
}); });
}; };
// //
const EditRules = row => { const EditRules = row => {
loading.value = true;
dialogtitle.value = '编辑'; dialogtitle.value = '编辑';
console.log(row, 'row====>'); console.log(row, 'row====>');
editID.value = row.id; editID.value = row.id;
@ -696,16 +701,22 @@ const newlyadded = async row => {
dialogtitle.value = '新增'; dialogtitle.value = '新增';
// let _dispatchSubjoinCategoryDatacopy = deepClone(dispatchSubjoinCategoryData.value) ; // let _dispatchSubjoinCategoryDatacopy = deepClone(dispatchSubjoinCategoryData.value) ;
form.value = await deepClone(copyform.value); form.value = await deepClone(copyform.value);
OversizedbillingData.value=[]
form.value.dialogPricingrules = true; // form.value.dialogPricingrules = true; //
GetCategory(); // GetCategory(); //
}; };
// //
const Pricingrules = () => { const Pricingrules = () => {
if(loading.value){ if (loading.value) {
return return;
}
if (!form.value.carModel) {
ElMessage({
message: '请选择车型',
type: 'warning',
});
return;
} }
if(localStorag)
console.log(form.value);
// //
if (dialogtitle.value == '新增') { if (dialogtitle.value == '新增') {
submission(); submission();
@ -740,7 +751,7 @@ const Categoryprocessing = (value, data, type) => {
// //
// //
const Oversizedbillingprocessing = (value, data) => { const Oversizedbillingprocessing = (value, data) => {
form.value.Oversizedbilling.forEach(item => { OversizedbillingData.value.forEach(item => {
let _data = { let _data = {
province: item.region[0], // province: item.region[0], //
city: item.region[1], // city: item.region[1], //
@ -796,19 +807,27 @@ const submission = async () => {
2 2
); );
// //
await Oversizedbillingprocessing(form.value.Oversizedbilling, data['overZoneList']); await Oversizedbillingprocessing(OversizedbillingData.value, data['overZoneList']);
console.log(data, '要提交的数据'); console.log(data, '要提交的数据');
$_expenseDispatchPricesave(data).then(res => { loading.value = true;
console.log(res, '提交成功'); $_expenseDispatchPricesave(data)
if (res.data.code == 200) { .then(res => {
ElMessage({ console.log(res, '提交成功');
message: res.data.msg, if (res.data.code == 200) {
type: 'success', ElMessage({
}); message: res.data.msg,
form.value.dialogPricingrules = false; // type: 'success',
onLoad(); });
} form.value.dialogPricingrules = false; //
}); onLoad();
}
})
.catch(error => {
console.log(error);
})
.finally(() => {
loading.value = false;
});
} }
}; };
// //
@ -855,7 +874,7 @@ const Pricingrulesupdate = () => {
2 2
); );
// //
Oversizedbillingprocessing(form.value.Oversizedbilling, data['overZoneList']); Oversizedbillingprocessing(OversizedbillingData.value, data['overZoneList']);
console.log(data, '要提交的数据'); console.log(data, '要提交的数据');
$_expenseDispatchPriceupdate(data).then(res => { $_expenseDispatchPriceupdate(data).then(res => {
@ -881,33 +900,47 @@ const Oversizedbillingadd = () => {
options: [...regionList.value], options: [...regionList.value],
loading: false, loading: false,
}; };
form.value.Oversizedbilling.push(_data); OversizedbillingData.value.push(_data);
form.value.Oversizedbilling.forEach((item, index) => { OversizedbillingData.value.forEach((item, index) => {
item.index = index + 1; item.index = index + 1;
}); });
}; };
// //
const Oversizedbillingdel = row => { const Oversizedbillingdel = row => {
if (row.id) { ElMessageBox.confirm('是否确认删除?', '提示', {
let data = { confirmButtonText: '确认',
ids: row.id, cancelButtonText: '取消',
}; type: 'warning',
$_expenseDispatchPriceOverZoneremove(data).then(res => { })
if (res.data.code == 200) { .then(() => {
console.log(row, '删除超区费'); if (row.id) {
let indexToRemove = form.value.Oversizedbilling.findIndex(item => item.index === row.index); let data = {
ids: row.id,
};
$_expenseDispatchPriceOverZoneremove(data).then(res => {
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
console.log(row, '删除超区费');
let indexToRemove = OversizedbillingData.value.findIndex(
item => item.index === row.index
);
if (indexToRemove !== -1) {
OversizedbillingData.value.splice(indexToRemove, 1);
}
console.log(res, '删除成功');
}
});
} else {
let indexToRemove = OversizedbillingData.value.findIndex(item => item.index === row.index);
if (indexToRemove !== -1) { if (indexToRemove !== -1) {
form.value.Oversizedbilling.splice(indexToRemove, 1); OversizedbillingData.value.splice(indexToRemove, 1);
} }
console.log(res, '删除成功');
} }
}); })
} else { .catch(() => {});
let indexToRemove = form.value.Oversizedbilling.findIndex(item => item.index === row.index);
if (indexToRemove !== -1) {
form.value.Oversizedbilling.splice(indexToRemove, 1);
}
}
}; };
// //
@ -927,10 +960,10 @@ function updateDictionary(targetArray, dictionaryType) {
const GetRegion = () => { const GetRegion = () => {
$_ObtainRegion().then(res => { $_ObtainRegion().then(res => {
console.log(res, '地区。。。'); console.log(res, '地区。。。');
console.log(form.value.Oversizedbilling, 'form.value.Oversizedbilling'); console.log(OversizedbillingData.value, 'OversizedbillingData.value');
if (res.data.code === 200) { if (res.data.code === 200) {
regionList.value = res.data.data; regionList.value = res.data.data;
form.value.Oversizedbilling.forEach(item => { OversizedbillingData.value.forEach(item => {
item['options'] = res.data.data; item['options'] = res.data.data;
}); });
} }
@ -938,7 +971,9 @@ const GetRegion = () => {
}; };
const onLoad = async () => { const onLoad = async () => {
copyform.value = await deepClone(form.value); if(!Object.keys(copyform.value).length){
copyform.value = await deepClone(form.value);
}
console.log(copyform.value, 'copyform.value'); console.log(copyform.value, 'copyform.value');
if ($route.query.id || props.templateData.id) { if ($route.query.id || props.templateData.id) {
console.log('执行了'); console.log('执行了');
@ -947,26 +982,31 @@ const onLoad = async () => {
type: activeName.value, type: activeName.value,
templateId: $route.query.id || props.templateData.id, templateId: $route.query.id || props.templateData.id,
}; };
Pageloading.value = true;
$_expenseDispatchPricepage(data).then(res => { $_expenseDispatchPricepage(data)
console.log(res, '车型'); .then(res => {
if (res.data.code == 200) { console.log(res, '车型');
dispatchSubjoinCategoryData.value = []; if (res.data.code == 200) {
let _data = {}; dispatchSubjoinCategoryData.value = [];
if (res.data.data.records?.length) { let _data = {};
res.data.data.records.forEach((item, index) => { if (res.data.data.records?.length) {
_data = { res.data.data.records.forEach((item, index) => {
index: index + 1, _data = {
carModel: item.carModel, index: index + 1,
options: [...optionsVehicle.value], carModel: item.carModel,
loading: false, options: [...optionsVehicle.value],
id: item.id, loading: false,
}; id: item.id,
dispatchSubjoinCategoryData.value.push(_data); };
}); dispatchSubjoinCategoryData.value.push(_data);
});
}
} }
} })
}); .catch(error => {})
.finally(() => {
Pageloading.value = false;
});
} }
}; };
// //

279
src/views/cost/Deliverycostmanagement/ServiceProviderPrice.vue

@ -37,7 +37,13 @@
<!-- 头部左侧按钮模块 --> <!-- 头部左侧按钮模块 -->
<div class="avue-crud__left"> <div class="avue-crud__left">
<el-button type="primary" @click="AddInfo" <el-button type="primary" @click="AddInfo"
><el-icon><Plus /></el-icon></el-button ><el-icon><Download /></el-icon></el-button
>
<el-button type="primary" @click="AddInfo"
><el-icon><Upload /></el-icon></el-button
>
<el-button type="primary" @click="Informationadd"
><el-icon><Plus /></el-icon></el-button
> >
</div> </div>
<!-- 头部右侧按钮模块 --> <!-- 头部右侧按钮模块 -->
@ -65,7 +71,7 @@
> >
<template #default="slotProps"> <template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'"> <template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass"></div> <el-text size="small" @click="EditTemplate(slotProps.scope.row)"> </el-text>
</template> </template>
</template> </template>
</tablecmt> </tablecmt>
@ -90,6 +96,56 @@
</div> </div>
</el-row> </el-row>
</div> </div>
<el-dialog v-model="Priceconfiguration" :title="PriceconfigurationTitle" width="30%">
<el-form
:model="form"
label-width="auto"
v-loading="tcloading"
element-loading-text="Loading..."
>
<el-form-item label="服务仓:">
<el-select
@change="changServiceWarehouse"
v-model="form.warehouseId"
placeholder="请选择服务仓"
>
<el-option
v-for="item in ServiceWarehouse"
:key="item.value"
:label="item.label"
:value="item.value"
:disabled="item.disabled"
/>
</el-select>
</el-form-item>
<el-form-item label="司机:">
<el-select v-model="form.driverId" placeholder="请选择司机">
<el-option
v-for="item in driver"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="价格模板:">
<el-select v-model="form.templateId" placeholder="请选择价格模板">
<el-option
v-for="item in PriceTemplate"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-form>
<template #footer>
<div class="dialog-footer">
<el-button @click="Priceconfiguration = false">取消</el-button>
<el-button type="primary" @click="Priceconfigurationsubmission">提交</el-button>
</div>
</template>
</el-dialog>
</basic-container> </basic-container>
<!-- 列表配置显示 --> <!-- 列表配置显示 -->
<edittablehead <edittablehead
@ -107,7 +163,15 @@ import { columnList } from '@/option/storagecost/ServiceProviderPrice.js';
import { getDictionaryBiz } from '@/api/system/dict'; // import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util'; import { processRowProperty, setNodeHeight } from '@/utils/util';
import functions from '@/utils/functions.js'; import functions from '@/utils/functions.js';
import { $_getMyWarehouseList } from '@/api/storagecost/index.js'; import { getDriverList } from '@/api/basicdata/basicdataDriverArtery'; //
import {
$_getMyWarehouseList,
$_ServiceProviderPrice,
$_ServiceProviderPricesave,
$_WarehousePricingTemplate,
$_getDriverList,
$_ServiceProviderPriceupdate,
} from '@/api/storagecost/index.js';
import { ElMessageBox, ElMessage } from 'element-plus'; import { ElMessageBox, ElMessage } from 'element-plus';
import { downloadXls } from '@/utils/util'; import { downloadXls } from '@/utils/util';
import { useStore } from 'vuex'; import { useStore } from 'vuex';
@ -116,7 +180,16 @@ const $router = useRouter(); //跳转
const $useStore = useStore(); // const $useStore = useStore(); //
const $route = useRoute(); // const $route = useRoute(); //
const warehouseList = ref([]); const warehouseList = ref([]);
const queryTop=ref({}) const PriceconfigurationTitle = ref('价格配置(新增)');
const form = ref({});
const rowData = ref({});
const ServiceWarehouse = ref([]); //
const driver = ref([]); //
const tcloading = ref(false);
const PriceTemplate = ref([]); //
const Priceconfiguration = ref(false);
const WarehouseId = ref('');
const queryTop = ref({});
const details = reactive({ const details = reactive({
/** 是否开启搜索 */ /** 是否开启搜索 */
search: false, search: false,
@ -159,7 +232,7 @@ const details = reactive({
columnList, columnList,
/** 列表数据 */ /** 列表数据 */
data: [{}], data: [],
/** 页面loading */ /** 页面loading */
loadingObj: { loadingObj: {
/** 列表加载loading */ /** 列表加载loading */
@ -221,7 +294,7 @@ const showdrawer = _flag => {
const inputsc = (index, row) => { const inputsc = (index, row) => {
details.query[row.prop] = index; details.query[row.prop] = index;
processRowProperty(index, row, details); processRowProperty(index, row, details);
test(details.query); onLoad();
}; };
// //
const test = val => {}; const test = val => {};
@ -235,6 +308,7 @@ const timesc = (index, row) => {
if (!index) { if (!index) {
delete details.query[row.prop]; delete details.query[row.prop];
} }
onLoad();
}; };
/** 表格表头输入框搜索 */ /** 表格表头输入框搜索 */
@ -244,6 +318,7 @@ const btnsc = val => {
/** 表格表头下拉框选择 */ /** 表格表头下拉框选择 */
const selectsc = (index, row) => { const selectsc = (index, row) => {
processRowProperty(index, row, details); processRowProperty(index, row, details);
onLoad();
}; };
/** 表格表头复选框选择 */ /** 表格表头复选框选择 */
const selectionChange = list => { const selectionChange = list => {
@ -256,15 +331,18 @@ const searchChange = () => {
}; };
// //
const sizeChange = val => { const sizeChange = val => {
page.value.pageSize = val; details.page.pageSize = val;
onLoad();
}; };
/** 页码改变执行的回调 */ /** 页码改变执行的回调 */
const currentChange = val => { const currentChange = val => {
page.value.currentPage = val; details.page.currentPage = val;
onLoad();
}; };
// //
const searchChangeS = () => { const searchChangeS = () => {
details.search = false; // onLoad();
}; };
// //
const searchHide = () => { const searchHide = () => {
@ -285,27 +363,194 @@ function updateDictionary(targetArray, dictionaryType) {
}); });
}); });
} }
//
const disabledWarehouse = () => {
let WarehouseName = localStorage.getItem('WarehouseName');
console.log(WarehouseName, 'WarehouseName');
if (WarehouseName != 'undefined') {
let data = ServiceWarehouse.value.find(res => res.label == WarehouseName);
console.log(data, 'data====');
WarehouseId.value = data.value; //ID
ServiceWarehouse.value.forEach(item => {
item.disabled = true;
});
data.disabled = false;
}
};
// //
const MyWarehouseList = () => { const MyWarehouseList = async () => {
$_getMyWarehouseList().then(res => { await $_getMyWarehouseList().then(res => {
console.log(res, '仓库列表'); console.log(res, '仓库列表');
res.data.data.forEach(item => { res.data.data.forEach(item => {
warehouseList.value.push({ ServiceWarehouse.value.push({
value: item.name, value: item.id,
label: item.name, label: item.name,
}); });
}); });
disabledWarehouse();
});
};
const GetTemplate = () => {
let data = {
size: 1000,
current: 1,
warehouseName:
ServiceWarehouse.value.find(res => res.value == form.value.warehouseId)?.label || '',
};
//
form.value.templateId = '';
PriceTemplate.value = [];
$_WarehousePricingTemplate(data).then(res => {
console.log(res, '可选的模板');
if (res.data.code == 200) {
if (res.data.data.records?.length) {
res.data.data.records.forEach(item => {
PriceTemplate.value.push({
label: item.templateName,
value: item.id,
});
});
console.log(PriceTemplate.value, '模板');
}
}
}); });
}; };
// //
const onLoad = () => {}; const onLoad = value => {
const PageOnload = () => { let data = {
MyWarehouseList(); // current: details.page.currentPage,
size: details.page.pageSize,
warehouseId: WarehouseId.value,
...details.query,
...value,
};
details.loadingObj.list = true;
$_ServiceProviderPrice(data)
.then(res => {
console.log(res, 'rsss');
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;
});
};
const Getdriver = async () => {
if (form.value.warehouseId) {
let data = {
warehouseId: form.value.warehouseId,
};
await $_getDriverList(data).then(res => {
console.log(res, '司机列表');
if (res.data.code == 200) {
if (res.data.data.length) {
res.data.data.forEach(item => {
driver.value.push({
value: item.id,
label: item.name,
});
});
}
}
});
}
};
const PageOnload = async () => {
await MyWarehouseList(); //
onLoad();
}; };
// //
PageOnload(); PageOnload();
// //
const Priceconfigurationsubmission = () => {
let data = {
warehouseName:
ServiceWarehouse.value.find(res => res.value == form.value.warehouseId)?.label || '', //
warehouseId: form.value.warehouseId, //ID
driverId: form.value.driverId, //ID
driverName: driver.value.find(res => res.value == form.value.driverId)?.label || '', //
templateId: form.value.templateId, //ID
};
tcloading.value = true;
if (PriceconfigurationTitle.value == '价格配置(编辑)') {
data.id = rowData.value.id;
$_ServiceProviderPriceupdate(data)
.then(res => {
console.log(res, '提交成功');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
Priceconfiguration.value = false;
onLoad();
}
})
.catch(error => {
console.log(error, '提交失败');
})
.finally(() => {
tcloading.value = false;
});
} else {
$_ServiceProviderPricesave(data)
.then(res => {
console.log(res, '提交成功');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
Priceconfiguration.value = false;
onLoad();
}
})
.catch(error => {
console.log(error, '提交失败');
})
.finally(() => {
tcloading.value = false;
});
}
};
//
const Informationadd = () => {
form.value.driverId = '';
form.value.warehouseId = '';
form.value.templateId = '';
PriceTemplate.value = [];
driver.value = [];
Priceconfiguration.value = true;
PriceconfigurationTitle.value = '价格配置(新增)';
};
//
const changServiceWarehouse = () => {
GetTemplate(); //
Getdriver(); //
};
const EditTemplate = async row => {
rowData.value = row;
form.value.warehouseId = row.warehouseId; //
await Getdriver();
console.log(row);
Priceconfiguration.value = true;
PriceconfigurationTitle.value = '价格配置(编辑)';
form.value.driverId = row.driverId; //
form.value.templateId = row.templateId;
PriceTemplate.value = [
{
value: row.templateId,
label: row.templateName,
},
];
};
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">

12
src/views/cost/Deliverycostmanagement/WarehousePricingTemplate.vue

@ -244,6 +244,7 @@ const showdrawer = _flag => {
const inputsc = (index, row) => { const inputsc = (index, row) => {
details.query[row.prop] = index; details.query[row.prop] = index;
processRowProperty(index, row, details); processRowProperty(index, row, details);
onLoad();
}; };
// //
/** 表格表头时间选择 */ /** 表格表头时间选择 */
@ -256,6 +257,7 @@ const timesc = (index, row) => {
if (!index) { if (!index) {
delete details.query[row.prop]; delete details.query[row.prop];
} }
onLoad();
}; };
/** 表格表头输入框搜索 */ /** 表格表头输入框搜索 */
@ -277,15 +279,19 @@ const searchChange = () => {
}; };
// //
const sizeChange = val => { const sizeChange = val => {
page.value.pageSize = val; details.page.pageSize = val;
onLoad();
}; };
/** 页码改变执行的回调 */ /** 页码改变执行的回调 */
const currentChange = val => { const currentChange = val => {
page.value.currentPage = val; details.page.currentPage = val;
onLoad();
}; };
// //
const searchChangeS = () => { const searchChangeS = () => {
details.search = false; // onLoad();
}; };
// //
const searchHide = () => { const searchHide = () => {

Loading…
Cancel
Save