Browse Source

Merge branch 'dev' of http://47.108.105.48:3000/java_project/logpm_page into dev

pre-production
pref_mail@163.com 12 months ago
parent
commit
c96b2a2e07
  1. 20
      src/api/distribution/distributionStockList.js
  2. 11
      src/api/financialsector/index.js
  3. 93
      src/option/financialsector/index.js
  4. 18
      src/router/views/index.js
  5. 207
      src/views/distribution/inventory/distributionStockListDetails.vue
  6. 19
      src/views/distribution/inventory/distributionStockListMarket.vue
  7. 330
      src/views/financialsector/CustomerBaseprice.vue
  8. 2
      src/views/financialsector/FinanceHome.vue
  9. 87
      src/views/financialsector/Financialse/FinancialBill.vue
  10. 5
      src/views/financialsector/Financialse/FinancialTrunkLine.vue

20
src/api/distribution/distributionStockList.js

@ -230,4 +230,24 @@ export const $_cancelAddStockListByPackage = (row) => {
method: 'post',
data: row
})
}
// 查询拆包明细
export const $_stockListUnpackDetail = (params) => {
return request({
url: '/api/logpm-distribution/distributionUnpackingDetails/stockListUnpackDetail',
method: 'get',
params
})
}
// 拆包明细撤销
export const $_cancelUnpack = (params) => {
return request({
url: '/api/logpm-distribution/distributionUnpackingDetails/cancelUnpack',
method: 'get',
params
})
}

11
src/api/financialsector/index.js

@ -17,4 +17,13 @@ export const $_basicdataBrande = params => {
method: 'get',
params,
});
};
};
//查询列表接口
export const $_getpriceTemplate = params => {
return request({
url: '/api/logpm-basicdata/priceTemplate',
method: 'get',
params,
});
};

93
src/option/financialsector/index.js

@ -0,0 +1,93 @@
export const columnList = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'name',
label: '模板名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'brandId',
label: '品牌',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'serviceType',
label: '服务类型',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'createTime',
label: '创建时间',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'userName',
label: '创建人',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'templateType',
label: '模板类型',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'createUserName',
label: '操作',
type: 6,
values: '',
width: '200',
checkarr: [],
fixed: 'right',
sortable: false,
},
]

18
src/router/views/index.js

@ -1546,11 +1546,27 @@ export default [
keepAlive: true,
},
path: '/financialsector/FinanceHome',
name: '财务',
name: '价格体系模板配置',
component: () => import('@/views/financialsector/FinanceHome.vue'),
},
],
},
{
path: '/financialsector/CustomerBaseprice',
component: Layout,
redirect: '/financialsector/CustomerBaseprice',
children: [
{
meta: {
i18n: 'dict',
keepAlive: true,
},
path: '/financialsector/CustomerBaseprice',
name: '客户基础价格配置',
component: () => import('@/views/financialsector/CustomerBaseprice.vue'),
},
],
},
{
path: '/Pricesystem/PricesyHome',
component: Layout,

207
src/views/distribution/inventory/distributionStockListDetails.vue

@ -174,6 +174,45 @@
</el-pagination>
</div>
</el-tab-pane>
<el-tab-pane label="拆包明细" name="Unpacking">
<!-- <el-button type="danger" icon="el-icon-plus" @click="handleExport" plain
> </el-button
> -->
<tablecmt
:columnList="columnListarrs.columnUnpacking"
:tableData="data3"
:loading="loading"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
>
<template #default="slotProps">
<el-text
size="small"
@click="Unpackingrevoke(slotProps.scope.row)"
>撤销</el-text
>
</template>
</tablecmt>
<div class="avue-crud__pagination" style="width: 100%">
<!-- 分页模块 -->
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page3.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page3.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page3.total"
>
</el-pagination>
</div>
</el-tab-pane>
<!-- <el-tab-pane label="拆包记录" name="unpacking">
<el-table ref="table" v-loading="loading"
@selection-change="selectionChange"
@ -253,6 +292,8 @@ import {
showInventoryPackgeCode,
showInventorySourcePackageCode,
$_cancelAddStockListByPackage,
$_stockListUnpackDetail,
$_cancelUnpack,
} from '@/api/distribution/distributionStockList';
import option from '@/option/distribution/distributionStockList';
import { mapGetters } from 'vuex';
@ -387,6 +428,98 @@ export default {
hide: true,
},
],
//
columnUnpacking:[
{
prop: 'unpackUser',
label: '拆包操作人',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'createTime',
label: '操作时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'unpackingQuantity',
label: '拆包数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'marketName',
label: '商场名称',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'itemName',
label: '物料名称',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'specification',
label: '规格',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: 'warehouseName',
label: '仓库名称',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
head: false,
},
{
prop: '',
label: '操作',
type: 6,
values: '',
width: '230',
checkarr: [],
fixed: 'right',
hide: true,
},
],
//
column: [
// {
@ -694,6 +827,40 @@ export default {
})
.catch(() => {});
},
//
Unpackingrevoke(val){
console.log(val,'撤销');
ElMessageBox.confirm('撤销拆包操作,是否继续?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
this.loading = true;
let data={
stockListIds:this.$route.query.id,
ids:val.id,
}
$_cancelUnpack(data).then(res=>{
console.log(res,'撤销');
if(res.data.code ==200){
ElMessage({
message: res.data.msg,
type: 'success',
})
this.getunpacking(this.page3)
}
}).catch(res=>{
console.log(res,'错误');
}).finally(()=>{
this.loading = false;
})
})
.catch(() => {});
},
//
handleExport() {
let row = {};
@ -722,17 +889,39 @@ export default {
console.log(tab, event);
console.log(tab.props.name);
this.leibiao = tab.props.name;
console.log( this.leibiao,' this.leibiao');
if (this.leibiao == 'outbound') {
//
console.log('执行力啦啦啦');
this.getOnChu(this.page1);
} else if (this.leibiao == 'enter') {
//
this.getOnRu(this.page2);
} else if (this.leibiao == 'unpacking') {
//
this.getOnChai(this.page2);
} else if (this.leibiao == 'Unpacking') {
console.log('拆包明细');
// this.getOnChai(this.page2);
this.getunpacking(this.page3)
}
},
//
getunpacking(page){
let data={
stockListId: this.$route.query.id,
current: page.currentPage,
size:page.pageSize
}
this.loading = true;
$_stockListUnpackDetail(data).then(res=>{
console.log(res,'拆单明细');
if(res.data.code==200){
this.data3 = res.data.data.records
this.page3.total = res.data.data.total;
console.log( this.page3,' this.page3');
}
}).catch(res=>{
console.log(res,'错误');
}).finally(()=>{
this.loading = false;
})
},
init() {
this.height = this.setPx(document.body.clientHeight - 470);
@ -849,10 +1038,11 @@ export default {
//
this.page2.currentPage = currentPage;
this.getOnRu(this.page2);
} else if (!!this.leibiao && this.leibiao == 'unpacking') {
} else if (!!this.leibiao && this.leibiao == 'Unpacking') {
//
this.page3.currentPage = currentPage;
this.getOnRu(this.page3);
this.getunpacking(this.page3)
// this.getOnRu(this.page3);
} else {
//
this.page.currentPage = currentPage;
@ -866,9 +1056,10 @@ export default {
} else if (!!this.leibiao && this.leibiao == 'enter') {
this.page2.pageSize = pageSize;
this.getOnRu(this.page2);
} else if (!!this.leibiao && this.leibiao == 'unpacking') {
this.page3.pageSize = pageSize;
} else if (!!this.leibiao && this.leibiao == 'Unpacking') {
// this.page3.pageSize = pageSize;
this.getOnChai(this.page3);
this.getunpacking(this.page3)
} else {
this.page.pageSize = pageSize;
this.onLoad(this.page);

19
src/views/distribution/inventory/distributionStockListMarket.vue

@ -207,12 +207,14 @@
</el-select>
</el-form-item>
<el-form-item label="规格" style="width: 40%">
<el-input
<!-- <el-input
v-model="formInline.cargoNorms"
placeholder="请输入规格"
clearable
:disabled="FromDis"
/>
/> -->
<el-input-number :controls='false' placeholder="请输入规格" clearable :disabled="FromDis" v-model="formInline.cargoNorms" :min="0" />
</el-form-item>
<el-form-item label="产品编码" style="width: 40%">
<el-input
@ -223,19 +225,24 @@
/>
</el-form-item>
<el-form-item label="包装数量" style="width: 40%">
<el-input
<!-- <el-input
v-model="formInline.packageNum"
placeholder="请输入包装数量"
clearable
:disabled="FromDis"
/>
/> -->
<el-input-number :controls='false' placeholder="请输入包装数量" clearable :disabled="FromDis" v-model="formInline.packageNum" :min="0" />
</el-form-item>
<el-form-item label="拆箱数" style="width: 40%">
<el-input
<!-- <el-input
v-model="formInline.unpackingQuantity"
placeholder="请输入拆箱数"
clearable
/>
/> -->
<el-input-number :controls='false' placeholder="请输入请输入拆箱数" clearable v-model="formInline.unpackingQuantity" :min="0" />
</el-form-item>
</el-form>
</div>

330
src/views/financialsector/CustomerBaseprice.vue

@ -0,0 +1,330 @@
<template>
<basic-container>
<!-- 首页表格 -->
<div class="avue-crud">
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<!-- 控件模块 -->
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="AddInfo">
<el-icon><Plus /></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-row>
<!-- 列表模块 -->
<tablecmt
class="tableNode"
:columnList="columnList"
:tableData="data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass">
<el-button @click="view(slotProps.scope)">查看</el-button>
</div>
</template>
</template>
</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="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"
></edittablehead>
</template>
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/financialsector/index.js';
import {$_getpriceTemplate} from '@/api/financialsector/index'; //
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import functions from '@/utils/functions.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import { useStore } from 'vuex';
import dayjs from 'dayjs';
const $router = useRouter(); //
const $useStore = useStore(); //
const $route = useRoute(); //
const details = reactive({
/** 是否开启搜索 */
search: false,
/** 表格搜索条件 */
query: {},
/** 时间快捷选择设置 */
shortcuts: [
{
text: '最近一周',
value: () => {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
return [start, end];
},
},
{
text: '最近一个月',
value: () => {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
return [start, end];
},
},
{
text: '最近三个月',
value: () => {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
return [start, end];
},
},
],
/** 时间选择器数据 */
stockupDate: [],
/** 列表 */
columnList,
/** 列表数据 */
data: [{}],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
/** 是否显示设置表格 */
drawerShow: false,
/** 分页参数 */
page: {
currentPage: 1,
pageSize: 50,
total: 0,
},
/** 弹出层显示 */
popUpShow: {
/** 包件明细 */
packageOrderListlVisited: false,
/** 二维码 */
QRCodeVisible: false,
/** 修改客户信息 */
editClientInfoVisible: false,
},
/** 列表Dom节点 */
listNode: '',
form: {},
/** 全屏 */
fullscreenObj: {
/** 包明细 */
packageOrderListlVisited: false,
},
});
const {
search,
query,
shortcuts,
stockupDate,
data,
loadingObj,
selectionList,
drawerShow,
page,
trickleLoadingPage,
zeroAdditionalRecordingInfo,
popUpShow,
recorddata,
} = toRefs(details);
/**
* 设置列表 -- 固定函数
* 弹窗的勾选回调用于更改头部数组
* 固定搭配只需要更换 columnList
* */
const setnewcolum = (newarr, headarr, type) => {
if (type == 1) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'checkList', headarr);
} else if (type == 2) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'flexList', headarr);
} else if (type == 3) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'sortlist', headarr);
}
};
/** 展开列表控件 */
const showdrawer = _flag => {
details.drawerShow = _flag;
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
};
/** 表格表头时间选择 */
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);
};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
};
/** 表格表头复选框选择 */
const selectionChange = list => {
console.log(list);
details.selectionList = list;
};
//
const searchChange = () => {
details.search = false; //
};
//
const sizeChange = val => {
page.value.pageSize = val;
};
/** 页码改变执行的回调 */
const currentChange = val => {
page.value.currentPage = val;
};
//
const searchChangeS = () => {
details.search = false; //
priceTemplate()
};
//
const searchHide = () => {
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 priceTemplate = () => {
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
};
details.loadingObj.list = true;
$_getpriceTemplate(data)
.then(res => {
console.log(res, '当前参数');
details.page.total = res.data.data.total;
details.data = res.data.data.records;
})
.catch(() => {})
.finally(() => {
details.loadingObj.list = false;
});
};
priceTemplate()
</script>
<style scoped lang="scss">
.ElBtnClass button {
border: none;
padding: 0;
background-color: transparent;
}
:deep(.el-card) {
height: 100%;
}
:deep(.el-card__body) {
height: 100%;
display: flex;
flex-direction: column;
}
.el-fy {
flex: 1;
display: flex;
align-items: flex-end;
margin-bottom: 10px;
}
.avue-crud {
height: 100%;
display: flex;
flex-direction: column;
}
</style>

2
src/views/financialsector/FinanceHome.vue

@ -60,7 +60,7 @@
<el-tabs type="border-card" v-model="Tabmenu">
<template v-for="item in ServiceList" :key="item.label">
<el-tab-pane :name="item.label" v-if="item.state" :label="item.label">
<span v-if="item.label == '提货'"><FinancialBill /></span>
<span v-if="item.label == '提货'"><FinancialBill @request-data="provideData" :templateData="templateInfo"/></span>
<span v-if="item.label == '干线'"><FinancialTrunkLine @request-data="provideData" :templateData="templateInfo"/></span>
<span v-if="item.label == '仓储'"
><FinancialWarehousing @request-data="provideData" :templateData="templateInfo"

87
src/views/financialsector/Financialse/FinancialBill.vue

@ -158,13 +158,21 @@
</template>
<script setup lang="ts">
import { ref, reactive, getCurrentInstance, nextTick } from 'vue';
import { ref, reactive, getCurrentInstance, nextTick , defineEmits ,defineComponent} from 'vue';
import { debounce, deepClone } from '@/utils/util';
import { ElMessage, ElMessageBox } from 'element-plus';
import { getDictionaryBiz } from '@/api/system/dict';
import { postFindCategoryInfo } from '@/api/distribution/CreateOrder.js';
import { $_priceTemplate } from '@/api/financialsector/index'; //
const emit = defineEmits(['request-data']);
defineComponent({
emits: ['request-data'],
});
//
const props = defineProps({
templateData: Object,
});
console.log(props, '来自父页面参数');
const instance = getCurrentInstance();
/** 表单实例 */
@ -309,8 +317,8 @@ const handleTrunkLinePricingType = response => {
const _billTemplateDetailArr = [];
for (let i = 0; i < details.priceMethodType.length; i++) {
const value = details.priceMethodType[i];
_billTemplateDetailArr.push({
if(value.dictKey !='2'){
_billTemplateDetailArr.push({
title: value.dictValue + '计费品类',
code: value.dictKey,
categories: [
@ -325,6 +333,8 @@ const handleTrunkLinePricingType = response => {
},
],
});
}
}
details.form.billTemplateDetail = _billTemplateDetailArr;
@ -454,11 +464,76 @@ const resetFormData = () => {
};
/** 提交 */
const handleSubmit = () => {
const handleSubmit = async() => {
if (details.form.pickupPricingType.length === 0) ElMessage.error('请选择计价方式');
formRef.value.validate(async valid => {
if (!valid) return;
await emit('request-data'); //
console.log(props, 'props');
if (!props.templateData.TemplateName) {
ElMessage({
message: '请输入模板名称',
type: 'warning',
});
return;
} else {
details.form.name = props.templateData.TemplateName; //
}
if (!props.templateData.brand) {
ElMessage({
message: '请选择品牌',
type: 'warning',
});
return;
} else {
details.form.brandId = props.templateData.brand; //ID
}
const submitData = deepClone(details.form);//
submitData.pickupPricingType = submitData.pickupPricingType.join(',');//
//
if(details.form.pickupIsByCategory === '1'){
submitData.billTemplateDetail.forEach(item=>{
switch (item.code) {
case '1':
submitData.pickupPieceCategory = item.categories.filter(res => res.goodsId).map(res => res.goodsId).join(','); //
break;
case '3':
submitData.pickupCubeCategory = item.categories.filter(res => res.goodsId).map(res => res.goodsId).join(',');//
break;
case '4':
submitData.pickupWeightCategory = item.categories.filter(res => res.goodsId).map(res => res.goodsId).join(',');//
break;
default:
break;
}
})
}
// ()
if(details.form.pickupIsMinCost !== '1'){
details.form.pickupMinCostType=null
}
submitData.serviceType = '1'; //
delete submitData.billTemplateDetail;//
console.log(submitData,'要提交的数据');
let data = {
...submitData,
};
$_priceTemplate(data).then(res => {
console.log(res, '提交成功之后返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
emit('request-data',res.data.data);//
}
// res.data.data
});
});
};
</script>

5
src/views/financialsector/Financialse/FinancialTrunkLine.vue

@ -513,7 +513,9 @@ const handleSubmit = async() => {
//
submitData.trunklinePricingType= submitData.trunklinePricingType.join(',')
//
submitData.billTemplateDetail.forEach(item=>{
//
if(details.form.trunklineIsByCategory === '1'){
submitData.billTemplateDetail.forEach(item=>{
switch (item.code) {
case '1':
submitData.trunklinePieceCategory = item.categories.filter(res => res.goodsId).map(res => res.goodsId).join(',');
@ -528,6 +530,7 @@ const handleSubmit = async() => {
break;
}
})
}
submitData.serviceType = '2'; //线
delete submitData.billTemplateDetail;//
console.log(submitData,'处理好的参数');

Loading…
Cancel
Save