Browse Source

财务

pre-production
马远东 12 months ago
parent
commit
aaf732e102
  1. 44
      src/api/financialsector/index.js
  2. 185
      src/option/distribution/distributionStockArticleSelf.js
  3. 4
      src/option/financialsector/index.js
  4. 76
      src/views/financialsector/CustomerBaseprice.vue
  5. 19
      src/views/financialsector/FinanceHome.vue
  6. 32
      src/views/financialsector/Financialse/FinancialBill.vue
  7. 61
      src/views/financialsector/Financialse/FinancialDelivery.vue
  8. 29
      src/views/financialsector/Financialse/FinancialTrunkLine.vue
  9. 55
      src/views/financialsector/Financialse/FinancialWarehousing.vue

44
src/api/financialsector/index.js

@ -8,22 +8,46 @@ export const $_priceTemplate = data => {
});
};
// 品牌
export const $_basicdataBrande = params => {
return request({
url: '/api/logpm-basicdata/basicdataBrand/lists',
method: 'get',
params,
});
};
return request({
url: '/api/logpm-basicdata/basicdataBrand/lists',
method: 'get',
params,
});
};
//查询列表接口
export const $_getpriceTemplate = params => {
return request({
url: '/api/logpm-basicdata/priceTemplate',
method: 'get',
params,
});
};
// 删除模板
export const $_deletelpriceTemplate = params => {
return request({
url: '/api/logpm-basicdata/priceTemplate',
method: 'delete',
params,
});
};
// 修改模板
export const $_putpriceTemplate = data => {
return request({
url: '/api/logpm-basicdata/priceTemplate',
method: 'put',
data,
});
};
// 查看详情
export const $_InfopriceTemplate = params => {
return request({
url: '/api/logpm-basicdata/priceTemplate',
url: '/api/logpm-basicdata/priceTemplate/' + params.id,
method: 'get',
params,
});
};

185
src/option/distribution/distributionStockArticleSelf.js

@ -44,7 +44,7 @@ export const columnList = [
label: '订单自编号',
type: 2,
values: '',
width: '260',
width: '200',
checkarr: [],
fixed: false,
sortable: true,
@ -60,187 +60,188 @@ export const columnList = [
sortable: true,
},
{
prop: 'allocation',
label: '货位信息',
type: 13,
prop: 'totalNumber',
label: '订单总件数',
type: 1,
values: '',
width: '250',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'descriptionGoods',
label: '货物名称',
type: 2,
prop: 'handQuantity',
label: '在库件数',
type: 1,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'isZeroName',
label: '是否零担',
type: 3,
prop: 'notReceived',
label: '未入库数量',
type: 1,
values: '',
width: '140',
checkarr: [
{
value: 0,
label: '否',
},
{
value: 1,
label: '是',
},
],
width: '100',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'warehouse',
label: '所在仓库',
type: 2,
prop: 'sortingQuantity',
label: '分拣数量',
type: 1,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'warehouseEntryTime',
label: '入库时间',
type: 4,
prop: 'deliveryQuantity',
label: '配送数量',
type: 1,
values: '',
width: '180',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
},
{
prop: 'warehouseEntryTimeEnd',
label: '最新入库时间',
type: 4,
prop: 'transferQuantity',
label: '中转数量',
type: 1,
values: '',
width: '180',
width: '100',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'storeTime',
label: '在库时间',
prop: 'signinQuantity',
label: '签收数量',
type: 1,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'consigneeUnit',
label: '位',
type: 2,
prop: 'allocation',
label: '货位信息',
type: 13,
values: '',
width: '140',
width: '200',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'consigneePerson',
label: '收货人',
prop: 'descriptionGoods',
label: '货物名称',
type: 2,
values: '',
width: '160',
width: '140',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'totalNumber',
label: '订单总件数',
type: 1,
prop: 'isZeroName',
label: '是否零担',
type: 3,
values: '',
width: '200',
checkarr: [],
width: '100',
checkarr: [
{
value: 0,
label: '否',
},
{
value: 1,
label: '是',
},
],
fixed: false,
sortable: true,
},
{
prop: 'handQuantity',
label: '在库件数',
type: 1,
prop: 'warehouse',
label: '库',
type: 2,
values: '',
width: '140',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'notReceived',
label: '未入库数量',
type: 1,
prop: 'warehouseEntryTime',
label: '入库时间',
type: 4,
values: '',
width: '200',
width: '180',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'sortingQuantity',
label: '分拣数量',
type: 1,
prop: 'warehouseEntryTimeEnd',
label: '最新入库时间',
type: 4,
values: '',
width: '140',
width: '180',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'deliveryQuantity',
label: '配送数量',
prop: 'storeTime',
label: '在库时间',
type: 1,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
},
{
prop: 'transferQuantity',
label: '中转数量',
type: 1,
prop: 'consigneeUnit',
label: '收货单位',
type: 2,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'signinQuantity',
label: '签收数量',
type: 1,
prop: 'consigneePerson',
label: '收货人',
type: 2,
values: '',
width: '140',
width: '160',
checkarr: [],
fixed: false,
isshowSummary: true,
sortable: true,
},
{
prop: 'groundingStatusName',
label: '上架状态',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [
// {
// value: '0',
@ -276,7 +277,7 @@ export const columnList = [
label: '品牌',
type: 1,
values: '',
width: '130',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -287,7 +288,7 @@ export const columnList = [
label: '所在托盘',
type: 1,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -297,7 +298,7 @@ export const columnList = [
label: '冻结状态',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [
// {
// value: '1',
@ -316,7 +317,7 @@ export const columnList = [
label: '订单状态',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -326,7 +327,7 @@ export const columnList = [
label: '预约状态',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -336,7 +337,7 @@ export const columnList = [
label: '备货状态',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -346,7 +347,7 @@ export const columnList = [
label: '入库状态',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -356,7 +357,7 @@ export const columnList = [
label: '是否齐套',
type: 14,
values: '',
width: '140',
width: '100',
checkarr: [
{
value: '2',
@ -385,7 +386,7 @@ export const columnList = [
label: '服务类型',
type: 3,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -395,7 +396,7 @@ export const columnList = [
label: '顾客名字',
type: 2,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -435,7 +436,7 @@ export const columnList = [
label: '创建人',
type: 1,
values: '',
width: '160',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -445,7 +446,7 @@ export const columnList = [
label: '创建时间',
type: 1,
values: '',
width: '140',
width: '100',
checkarr: [],
fixed: false,
sortable: true,

4
src/option/financialsector/index.js

@ -26,7 +26,7 @@ export const columnList = [
head: false,
},
{
prop: 'brandId',
prop: 'brandName',
label: '品牌',
type: 2,
values: '',
@ -85,7 +85,7 @@ export const columnList = [
label: '操作',
type: 6,
values: '',
width: '200',
width: '120',
checkarr: [],
fixed: 'right',
sortable: false,

76
src/views/financialsector/CustomerBaseprice.vue

@ -19,9 +19,13 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="AddInfo">
<el-button type="primary" @click="Addtemplate">
<el-icon><Plus /></el-icon> </el-button
>
<el-button type="primary" @click="Deletetemplate">
<el-icon><Delete /></el-icon> </el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
@ -49,7 +53,7 @@
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass">
<el-button @click="view(slotProps.scope)">查看</el-button>
<el-button @click="Modifytemplate(slotProps.scope.row)">价格体系配置</el-button>
</div>
</template>
</template>
@ -88,11 +92,11 @@
<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 { $_getpriceTemplate, $_deletelpriceTemplate } 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 { ElMessageBox, ElMessage } from 'element-plus';
import { downloadXls } from '@/utils/util';
import { useStore } from 'vuex';
import dayjs from 'dayjs';
@ -140,7 +144,7 @@ const details = reactive({
columnList,
/** 列表数据 */
data: [{}],
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
@ -217,7 +221,6 @@ const showdrawer = _flag => {
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
};
/** 表格表头时间选择 */
@ -260,7 +263,7 @@ const currentChange = val => {
//
const searchChangeS = () => {
details.search = false; //
priceTemplate()
priceTemplate();
};
//
const searchHide = () => {
@ -299,7 +302,62 @@ const priceTemplate = () => {
details.loadingObj.list = false;
});
};
priceTemplate()
priceTemplate();
//
const Addtemplate = () => {
$router.push({
path: '/financialsector/FinanceHome',
});
};
//
const Deletetemplate = () => {
console.log(details.selectionList, ' details.selectionList');
if (!details.selectionList.length) {
ElMessage({
message: '请勾选要删除的模板',
type: 'warning',
});
return;
}
ElMessageBox.confirm('是否删除选中模板?此操作不可撤销!', 'Warning', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
details.loadingObj.list = true;
let data = {
ids:details.selectionList.map(res => res.id).join(','),
};
$_deletelpriceTemplate(data).then(res => {
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
priceTemplate();
}
});
})
.catch(res => {
console.log(res, 'error');
})
.finally(() => {
details.loadingObj.list = false;
});
};
//
const Modifytemplate=(row)=>{
console.log(row);
$router.push({
query:{
id:row.id
},
path: '/financialsector/FinanceHome',
})
}
</script>
<style scoped lang="scss">
@ -307,6 +365,8 @@ priceTemplate()
border: none;
padding: 0;
background-color: transparent;
color: #02a7f0;
font-weight: 400;
}
:deep(.el-card) {
height: 100%;

19
src/views/financialsector/FinanceHome.vue

@ -75,9 +75,10 @@
</template>
<script setup>
import { ref, defineAsyncComponent } from 'vue';
import { ref, defineAsyncComponent,reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { $_basicdataBrande} from '@/api/financialsector/index'; //
import { $_basicdataBrande,$_InfopriceTemplate} from '@/api/financialsector/index'; //
const $route = useRoute(); //
//
const FinancialWarehousing = defineAsyncComponent(() =>
import('@/views/financialsector/Financialse/FinancialWarehousing.vue')
@ -123,6 +124,19 @@ function updateDictionary(targetArray, dictionaryType) {
}
//
const onLoad=()=>{
if($route.query.id){
let data={
id:$route.query.id
}
$_InfopriceTemplate(data).then(res=>{
console.log(res,'获取详情');
if(res.data.code == 200){
form.value=res.data.data
}
})
}
updateDictionary(ServiceList.value,'service_type');//
let data={
current:1,
@ -161,7 +175,6 @@ const removeTag = value => {
const provideData = (data) => {
console.log(data,'来自子页面的数据');
console.log(form.value,'form.value');
templateInfo.value = form.value;
if(data){
templateInfo.value.code=data;//

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

@ -73,7 +73,7 @@
<!-- 表格循环 -->
<div class="el_table_td" v-for="(item, index) in value.categories">
<div class="el_table_idNumber">{{ index }}</div>
<div class="el_table_idNumber">{{ index+1 }}</div>
<el-select
:ref="value.title + index"
class="el_Cselect"
@ -163,7 +163,7 @@ 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'; //
import { $_priceTemplate,$_putpriceTemplate } from '@/api/financialsector/index'; //
const emit = defineEmits(['request-data']);
defineComponent({
emits: ['request-data'],
@ -492,6 +492,8 @@ const handleSubmit = async() => {
} else {
details.form.brandId = props.templateData.brand; //ID
}
details.form.serviceType=props.templateData.ServiceType.join(',');//
const submitData = deepClone(details.form);//
submitData.pickupPricingType = submitData.pickupPricingType.join(',');//
//
@ -517,10 +519,29 @@ const handleSubmit = async() => {
details.form.pickupMinCostType=null
}
submitData.serviceType = '1'; //
delete submitData.billTemplateDetail;//
console.log(submitData,'要提交的数据');
let data = {
if(props.templateData.code){
//
let data = {
id: props.templateData.code, //ID
checkType:'1',
...submitData,
};
$_putpriceTemplate(data).then(res=>{
console.log(res,'编辑成功之后返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
})
}
})
}else{
//
let data = {
...submitData,
};
$_priceTemplate(data).then(res => {
@ -534,6 +555,9 @@ const handleSubmit = async() => {
}
// res.data.data
});
}
});
};
</script>

61
src/views/financialsector/Financialse/FinancialDelivery.vue

@ -122,18 +122,19 @@
/>
</el-select>
<div class="el_table_operation">
<span
@click="storagereduce(Item, item.id)"
v-if="item.reduce"
class="el_table_operation_span_a"
>-</span
>
<span
@click="storageplus(Item, item.id)"
v-if="item.plus"
class="el_table_operation_span_b"
>+</span
>
<span
@click="storagereduce(Item, item.id)"
v-if="item.reduce"
class="el_table_operation_span_a"
>-</span
>
</div>
</div>
</div>
@ -253,18 +254,19 @@
/>
</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
>
<span
@click="categoriesduce(item.id)"
v-if="item.reduce"
class="el_table_operation_span_a"
>-</span
>
</div>
</div>
</div>
@ -337,7 +339,7 @@ import { getDictionaryBiz } from '@/api/system/dict'; //字典
import { deepClone } from '@/utils/util';
import { postFindCategoryInfo } from '@/api/distribution/CreateOrder.js';
import { submit } from '@/api/base/region';
import { $_priceTemplate } from '@/api/financialsector/index'; //
import { $_priceTemplate ,$_putpriceTemplate} from '@/api/financialsector/index'; //
const emit = defineEmits(['request-data']);
defineComponent({
emits: ['request-data'],
@ -748,6 +750,9 @@ onLoad();
const handleSubmit = async() => {
await emit('request-data'); //
console.log(props, 'props');
if (!props.templateData.TemplateName) {
ElMessage({
message: '请输入模板名称',
@ -766,6 +771,9 @@ const handleSubmit = async() => {
} else {
form.value.brandId = props.templateData.brand; //ID
}
if(!form.value.dispatchServiceType){
ElMessage({
message: '请选择配送服务类型',
@ -780,8 +788,8 @@ const handleSubmit = async() => {
});
return;
}
form.value.serviceType = '4'; //
form.value.serviceType=props.templateData.ServiceType.join(',');//
console.log(form.value, '初始表单');
console.log(Commercialcial.value, 'Commercialcial');
//
@ -844,10 +852,31 @@ const handleSubmit = async() => {
}
console.log(Submit, '要提交的数据');
let data={
if(props.templateData.code){
console.log('走编辑接口');
//
let data={
id: props.templateData.code, //ID
checkType:'4',
...Submit,
}
$_putpriceTemplate(data).then(res=>{
console.log(res,'提交成功后返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
})
}
})
}else{
//
let data={
...Submit
}
console.log('走新增接口');
$_priceTemplate(data).then(res=>{
console.log(res,'提交成功后返回值');
if (res.data.code == 200) {
ElMessage({
@ -857,6 +886,8 @@ const handleSubmit = async() => {
emit('request-data',res.data.data);//
}
})
}
};
</script>

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

@ -73,7 +73,7 @@
<!-- 表格循环 -->
<div class="el_table_td" v-for="(item, index) in value.categories">
<div class="el_table_idNumber">{{ index }}</div>
<div class="el_table_idNumber">{{ index+1 }}</div>
<el-select
:ref="value.title + index"
class="el_Cselect"
@ -175,7 +175,7 @@ import { ref, reactive, getCurrentInstance, nextTick,defineEmits, defineComponen
import { debounce, deepClone } from '@/utils/util';
import { ElMessage, ElMessageBox } from 'element-plus';
import { getDictionaryBiz } from '@/api/system/dict';
import { $_priceTemplate } from '@/api/financialsector/index'; //
import { $_priceTemplate ,$_putpriceTemplate} from '@/api/financialsector/index'; //
import { postFindCategoryInfo } from '@/api/distribution/CreateOrder.js';
const emit = defineEmits(['request-data']);
defineComponent({
@ -508,6 +508,8 @@ const handleSubmit = async() => {
} else {
details.form.brandId = props.templateData.brand; //ID
}
details.form.serviceType=props.templateData.ServiceType.join(',');//
console.log(details.form,'初始表单');
const submitData = deepClone(details.form);//
//
@ -531,10 +533,28 @@ const handleSubmit = async() => {
}
})
}
submitData.serviceType = '2'; //线
delete submitData.billTemplateDetail;//
console.log(submitData,'处理好的参数');
let data={
if(props.templateData.code){
let data={
checkType:'2',
...submitData,//
id:props.templateData.code,//
}
//
$_putpriceTemplate(data).then(res=>{
console.log(res,'编辑成功之后返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
})
}
})
}else{
//
let data={
...submitData,//
}
$_priceTemplate(data).then(res=>{
@ -547,6 +567,7 @@ const handleSubmit = async() => {
emit('request-data',res.data.data);//
}
})
}
});
};
</script>

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

@ -102,15 +102,16 @@
/>
</el-select>
<div class="el_table_operation">
<span @click="storageplus(item.id)" v-if="item.plus" class="el_table_operation_span_b"
>+</span
>
<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>
@ -225,18 +226,19 @@
/>
</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
>
<span
@click="categoriesduce(item.id)"
v-if="item.reduce"
class="el_table_operation_span_a"
>-</span
>
</div>
</div>
</div>
@ -253,7 +255,7 @@
import { ref } from 'vue';
import { defineProps, defineEmits ,defineComponent} from 'vue';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { $_priceTemplate, $_basicdataBrande } from '@/api/financialsector/index'; //
import { $_priceTemplate, $_basicdataBrande,$_putpriceTemplate } from '@/api/financialsector/index'; //
import { ElMessage } from 'element-plus';
import { postFindCategoryInfo } from '@/api/distribution/CreateOrder.js';
const SelectOpin = ref(null); //
@ -484,6 +486,7 @@ onLoad();
const Submit = async () => {
await emit('request-data'); //
console.log(props, 'props');
if (!props.templateData.TemplateName) {
ElMessage({
message: '请输入模板名称',
@ -503,7 +506,8 @@ const Submit = async () => {
form.value.brandId = props.templateData.brand; //ID
}
form.value.serviceType = '3'; //
form.value.serviceType=props.templateData.ServiceType.join(',');//
//
if (categoriesDisplay.value) {
let storage = StoragecategoryList.value.find(res => !res.warehousePieceCategory); //
@ -541,10 +545,33 @@ const Submit = async () => {
}
console.log(form.value, '要提交的参数');
let data = {
if(props.templateData.code){
//
let data={
id:props.templateData.code,//
...form.value,
checkType:'3',//
}
console.log('编辑操作');
$_putpriceTemplate(data).then(res=>{
console.log(res,'编辑成功之后返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
})
}
})
}else{
let data = {
...form.value,
};
$_priceTemplate(data).then(res => {
//
console.log('新增操作');
$_priceTemplate(data).then(res => {
console.log(res, '提交成功之后返回值');
if (res.data.code == 200) {
ElMessage({
@ -555,6 +582,8 @@ const Submit = async () => {
}
// res.data.data
});
}
};
//
const categoriesDisplayChange = val => {

Loading…
Cancel
Save