Browse Source

仓储模板保存

dev-xx
马远东 1 year ago
parent
commit
5feb65d8d0
  1. 11
      src/api/financialsector/index.js
  2. 11
      src/option/warehouse/distributionStockArticle.js
  3. 23
      src/views/distribution/inventory/distrilbutionBillLadingView.vue
  4. 45
      src/views/financialsector/FinanceHome.vue
  5. 354
      src/views/financialsector/Financialse/FinancialWarehousing.vue
  6. 25
      src/views/warehouse/warehousesignedorder/distributionStockArticle.vue

11
src/api/financialsector/index.js

@ -7,3 +7,14 @@ export const $_priceTemplate = data => {
data,
});
};
// 品牌
export const $_basicdataBrande = params => {
return request({
url: '/api/logpm-basicdata/basicdataBrand/lists',
method: 'get',
params,
});
};

11
src/option/warehouse/distributionStockArticle.js

@ -159,6 +159,17 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'scanSigningTime',
label: '签收扫描时间',
type: 4,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'examineUserNames',
label: '审核人',

23
src/views/distribution/inventory/distrilbutionBillLadingView.vue

@ -594,7 +594,17 @@ export default {
sortable: true,
head: false,
},
{
prop: 'orderPackageStatusName',
label: '包件状态',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'orderPackageCode',//
// label: '',
@ -707,6 +717,17 @@ export default {
sortable: true,
head: false,
},
{
prop: 'orderStatusName',
label: '包件状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'firsts',
label: '一级品类',

45
src/views/financialsector/FinanceHome.vue

@ -6,6 +6,28 @@
<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.brand"
filterable
placeholder="请选择品牌"
:popper-append-to-body="false"
style="width: 340px"
>
<el-option
v-for="item in brand"
:key="item.value"
:label="item.brandName"
:value="item.id"
>
</el-option>
</el-select>
</div>
<!-- 服务类型 -->
<div class="el_Service">
<span class="name">服务类型</span>
@ -55,6 +77,7 @@
<script setup>
import { ref, defineAsyncComponent } from 'vue';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { $_basicdataBrande} from '@/api/financialsector/index'; //
//
const FinancialWarehousing = defineAsyncComponent(() =>
import('@/views/financialsector/Financialse/FinancialWarehousing.vue')
@ -73,10 +96,9 @@ const FinancialDelivery = defineAsyncComponent(() =>
);
const ServiceTypeLoading=ref(true);//
const form = ref({});
const brand=ref([]);//
const Tabmenu = ref('仓储');
const templateInfo = ref({
name: '参数',
});
const templateInfo = ref({});
//
const ServiceList = ref([]);
//
@ -102,6 +124,16 @@ function updateDictionary(targetArray, dictionaryType) {
//
const onLoad=()=>{
updateDictionary(ServiceList.value,'service_type');//
let data={
current:1,
size:1000,
}
$_basicdataBrande(data).then(res=>{
console.log(res,'品牌');
if(res.data.code == 200){
brand.value=res.data.data
}
})
}
onLoad()
//
@ -126,7 +158,12 @@ const removeTag = value => {
};
//
const provideData = () => {
const provideData = (data) => {
console.log(data,'来自子页面的数据');
console.log(form.value,'form.value');
if(data){
templateInfo.value.code=data;//
}
templateInfo.value = form.value;
};
</script>

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

@ -5,7 +5,7 @@
<span class="el_table_span">仓储计费类型</span>
<el-select
class="el_Cselect"
v-model="form.Storagebillingtype"
v-model="form.warehousePricingType"
filterable
clearable
placeholder="选择计费类型"
@ -25,7 +25,7 @@
<span class="el_table_span">仓储计费模式</span>
<el-select
class="el_Cselect"
v-model="form.Warehousebillingmode"
v-model="form.warehousePricingMode"
filterable
clearable
placeholder="选择仓储计费模式"
@ -42,7 +42,7 @@
<!-- 计算基准 -->
<div class="el_Storage">
<span class="el_table_span">计算基准</span>
<el-radio-group v-model="form.CalculationBasis" class="el_Cselect">
<el-radio-group v-model="form.warehouseCalculationBasis" class="el_Cselect">
<el-radio v-for="item in CalculationBasis" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
@ -52,7 +52,11 @@
<!-- 是否区分品类 -->
<div class="el_Storage">
<span class="el_table_span">是否区分品类</span>
<el-radio-group v-model="form.Distinguishcategories" class="el_Cselect">
<el-radio-group
@change="categoriesDisplayChange"
v-model="form.warehouseIsByCategory"
class="el_Cselect"
>
<el-radio v-for="item in Distinguishcategories" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
@ -60,7 +64,7 @@
</div>
<!-- 仓储品类配置 -->
<div class="el_Storage">
<div class="el_Storage" v-if="categoriesDisplay">
<div class="Storage-cont">
<span class="el_table_span">仓储品类配置</span>
<!-- 表格 -->
@ -78,12 +82,18 @@
<div class="el_table_idNumber">{{ item.id }}</div>
<el-select
class="el_Cselect"
v-model="item.WarehousecategoryInput"
v-model="item.warehousePieceCategory"
filterable
remote
clearable
reserve-keyword
placeholder="请选择品类"
style="width: 240px"
remote-show-suffix
:remote-method="categoriesearch"
@focus="categoriesSearchfocus(item)"
>
<!-- @remote-method="changeCategory(item.warehousePieceCategory)" -->
<el-option
v-for="items in item.Additionalcategories"
:key="items.value"
@ -117,7 +127,7 @@
<span class="el_table_span">附加费计价单位</span>
<el-select
class="el_Cselect"
v-model="form.Surchargepricingunit"
v-model="form.warehouseSubjoinFeeUnit"
filterable
clearable
placeholder="选择计费类型"
@ -135,7 +145,7 @@
<!-- 是否有管理费 -->
<div class="el_Storage">
<span class="el_table_span">是否有管理费</span>
<el-radio-group v-model="form.Managementfees" class="el_Cselect">
<el-radio-group v-model="form.warehouseIsManageFee" class="el_Cselect">
<el-radio v-for="item in Managementfees" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
@ -145,7 +155,7 @@
<!-- 是否有操作/装卸费 -->
<div class="el_Storage">
<span class="el_table_span">是否有操作/装卸费</span>
<el-radio-group v-model="form.Operatingunloading" class="el_Cselect">
<el-radio-group v-model="form.warehouseIsOperateFee" class="el_Cselect">
<el-radio v-for="item in Operatingunloading" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
@ -155,7 +165,7 @@
<!-- 是否有分拣费用 -->
<div class="el_Storage">
<span class="el_table_span">是否有分拣费用</span>
<el-radio-group v-model="form.Sortingfee" class="el_Cselect">
<el-radio-group v-model="form.warehouseIsSortFee" class="el_Cselect">
<el-radio v-for="item in Sortingfee" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
@ -164,26 +174,21 @@
<!-- 附加费用是否统一计费 -->
<div class="el_Storage">
<span class="el_table_span">附加费用是否统一计费</span>
<el-select
<span class="el_table_span">附加费是否按品类计费</span>
<el-radio-group
@change="AdditionalDisplayChange"
v-model="form.warehouseIsCategorySubjoin"
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>
<el-radio v-for="item in Additionalfeebilling" :key="item.label" :label="item.value">{{
item.label
}}</el-radio>
</el-radio-group>
</div>
<!-- 附加费品类配置 -->
<div class="el_Storage">
<div class="el_Storage" v-if="SurchargeDisplay">
<div class="Storage-cont">
<span class="el_table_span">附加费品类配置</span>
<!-- 表格 -->
@ -201,11 +206,16 @@
<div class="el_table_idNumber">{{ item.id }}</div>
<el-select
class="el_Cselect"
v-model="item.Additionalcategories"
v-model="item.warehousePieceCategory"
filterable
remote
clearable
reserve-keyword
placeholder="请选择品类"
style="width: 240px"
remote-show-suffix
:remote-method="categoriesearch"
@focus="categoriesSearchfocus(item)"
>
<el-option
v-for="items in item.Additionalcategories"
@ -241,13 +251,57 @@
<script setup>
import { ref } from 'vue';
import { defineProps , defineEmits} from 'vue';
import { defineProps, defineEmits } from 'vue';
import { getDictionaryBiz } from '@/api/system/dict'; //
import {$_priceTemplate} from '@/api/financialsector/index'; //
import { $_priceTemplate, $_basicdataBrande } from '@/api/financialsector/index'; //
import { defineComponent } from 'vue';
import { ElMessage } from 'element-plus';
import { postFindCategoryInfo } from '@/api/distribution/CreateOrder.js';
const SelectOpin = ref(null); //
// ()
const categoriesDisplay = ref(false); ///
const SurchargeDisplay = ref(false); //(/)
const categoriesSearchfocus = item => {
console.log(item, 'item');
SelectOpin.value = item; //
};
//
const categoriesearch = goodsName => {
console.log(goodsName, '当前搜索参数');
if (!goodsName) {
return;
}
let data = {
goodsName: goodsName,
};
let selectionList = null;
// StateName:'storage',//
// StateName:'additional',//
if (SelectOpin.value.StateName == 'storage') {
selectionList = StoragecategoryList.value.find(res => res.id == SelectOpin.value.id); //
} else {
selectionList = AdditionalcategoriesList.value.find(res => res.id == SelectOpin.value.id); //
}
console.log(selectionList, 'selectionList');
postFindCategoryInfo(data).then(res => {
console.log(res, '附加费品类计费');
if (res.data.code == 200) {
if (res.data.data.length) {
selectionList.Additionalcategories = []; //
res.data.data.forEach(item => {
selectionList.Additionalcategories.push({
label: item.goodsName,
value: item.goodsId,
});
});
}
}
});
};
const emit = defineEmits(['request-data']);
defineComponent({
emits: ['request-data']
emits: ['request-data'],
});
//
const props = defineProps({
@ -257,11 +311,12 @@ console.log(props, '来自父页面参数');
const Storageloading = ref(false); //
const goriesloading = ref(false); //
const form = ref({
CalculationBasis: '1', //
Distinguishcategories: '0', //
Managementfees: '0', //
Operatingunloading: '0', ///
Sortingfee: '0', //
warehouseCalculationBasis: '1', //
warehouseIsByCategory: '0', //
warehouseIsManageFee: '0', //
warehouseIsOperateFee: '0', ///
warehouseIsSortFee: '0', //
warehouseIsCategorySubjoin: '0', //
}); //
//
const Storagebillingtype = ref([]);
@ -288,16 +343,9 @@ const StoragecategoryList = ref([
id: 1,
plus: true,
reduce: false,
Additionalcategories: [
{
label: '衣柜',
value: '1',
},
{
label: '橱柜',
value: '2',
},
],
StateName: 'storage', //
warehousePieceCategory: '', //
Additionalcategories: [],
},
]);
//
@ -306,16 +354,9 @@ const AdditionalcategoriesList = ref([
id: 1,
plus: true,
reduce: false,
Additionalcategories: [
{
label: '衣柜',
value: '1',
},
{
label: '橱柜',
value: '2',
},
],
StateName: 'additional', //
warehousePieceCategory: '', //
Additionalcategories: [],
},
]);
//
@ -330,8 +371,7 @@ const Additionalcategories = ref([
},
]);
//
const Surchargepricingunit = ref([
]);
const Surchargepricingunit = ref([]);
//
const Managementfees = ref([]);
// /
@ -356,16 +396,18 @@ function removeItemById(array, id) {
clearTimeout(timerId); //
}, 300);
}
// StateName:'storage',//
// StateName:'additional',//
//
function addItemAfterId(array, id, data) {
function addItemAfterId(array, id, StateName) {
console.log(array);
const newItem = {
id: array.length + 1, // ID 1
plus: true, //
reduce: true, //
WarehousecategoryInput: '', //
Additionalcategories: [...data], //,
StateName, //
warehousePieceCategory: '', //
Additionalcategories: [], //,
};
const index = array.findIndex(item => item.id === id);
if (index !== -1) {
@ -388,15 +430,17 @@ const storagereduce = id => {
Storageloading.value = true; //
removeItemById(StoragecategoryList.value, id); //ID
};
// StateName:'storage',//
// StateName:'additional',//
//
const storageplus = id => {
Storageloading.value = true;
addItemAfterId(StoragecategoryList.value, id, Warehousecategory.value);
addItemAfterId(StoragecategoryList.value, id, 'storage');
};
//
const categoriesplus = id => {
goriesloading.value = true;
addItemAfterId(AdditionalcategoriesList.value, id, Additionalcategories.value);
addItemAfterId(AdditionalcategoriesList.value, id, 'additional');
};
//
const categoriesduce = id => {
@ -404,46 +448,154 @@ const categoriesduce = id => {
removeItemById(AdditionalcategoriesList.value, id);
};
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
if(res.data.code ==200){
if(res.data.data.length){
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
id: item.id,
});
getDictionaryBiz(dictionaryType)
.then(res => {
console.log(res, '字典');
if (res.data.code == 200) {
if (res.data.data.length) {
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
id: item.id,
});
});
}
}
if (dictionaryType == 'price_yes_no') {
Managementfees.value = { ...Distinguishcategories.value }; //
Operatingunloading.value = { ...Distinguishcategories.value }; ///
Sortingfee.value = { ...Distinguishcategories.value }; //
Additionalfeebilling.value = { ...Distinguishcategories.value }; //
}
})
.catch(() => {})
.finally(() => {});
}
//
const onLoad = () => {
updateDictionary(Storagebillingtype.value, 'warehouse_pricing_type'); //
updateDictionary(Warehousebillingmode.value, 'warehouse_pricing_mode'); //
updateDictionary(CalculationBasis.value, 'warehouse_calculation_basis'); //
updateDictionary(Distinguishcategories.value, 'price_yes_no'); //
updateDictionary(Surchargepricingunit.value, 'warehouse_pricing_unit'); //
};
onLoad();
//
const Submit = async () => {
emit('request-data','123')
return
await emit('request-data'); //
console.log(props, 'props');
if (!props.templateData.TemplateName) {
ElMessage({
message: '请输入模板名称',
type: 'warning',
});
}
return;
} else {
form.value.name = props.templateData.TemplateName; //
}
if (!props.templateData.brand) {
ElMessage({
message: '请选择品牌',
type: 'warning',
});
return;
} else {
form.value.brandId = props.templateData.brand; //ID
}
if(dictionaryType == 'price_yes_no'){
Managementfees.value ={...Distinguishcategories.value};//
Operatingunloading.value ={...Distinguishcategories.value};///
Sortingfee.value ={...Distinguishcategories.value};//
Additionalfeebilling.value ={...Distinguishcategories.value};//
form.value.serviceType = '3'; //
//
if (categoriesDisplay.value) {
let storage = StoragecategoryList.value.find(res => !res.warehousePieceCategory); //
if (storage) {
// ,
ElMessage({
message: '请填写仓储品类配置',
type: 'warning',
});
return;
} else {
console.log(StoragecategoryList.value, 'StoragecategoryList.value');
//
form.value.warehousePieceCategory = StoragecategoryList.value
.map(res => res.warehousePieceCategory)
.join(',');
}
}
}).catch(()=>{
}).finally(()=>{
});
}
//
const onLoad=()=>{
updateDictionary(Storagebillingtype.value,'warehouse_pricing_type');//
updateDictionary(Warehousebillingmode.value,'warehouse_pricing_mode');//
updateDictionary(CalculationBasis.value,'warehouse_calculation_basis');//
updateDictionary(Distinguishcategories.value,'price_yes_no');//
updateDictionary(Surchargepricingunit.value,'warehouse_pricing_unit');//
}
onLoad()
//
const Submit=()=>{
console.log(form.value,'表单');
emit('request-data');//
console.log(props);//
}
//
if (SurchargeDisplay.value) {
let Surcharge = AdditionalcategoriesList.value.find(res => !res.warehousePieceCategory); //
if (Surcharge) {
// ,
ElMessage({
message: '请填写附加品类配置',
type: 'warning',
});
return;
} else {
//
form.value.warehouseSubjoinCategory = AdditionalcategoriesList.value
.map(res => res.warehousePieceCategory)
.join(',');
}
}
console.log(form.value, '要提交的参数');
let data = {
...form.value,
};
$_priceTemplate(data).then(res => {
console.log(res, '提交成功之后返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
$emit('data-to-parent',res.data.data);
}
// res.data.data
});
};
//
const categoriesDisplayChange = val => {
console.log(val);
if (val == 1) {
categoriesDisplay.value = true;
StoragecategoryList.value = [
{
id: 1,
plus: true,
reduce: false,
StateName: 'storage', //
warehousePieceCategory: '', //
Additionalcategories: [],
},
];
} else {
categoriesDisplay.value = false;
}
};
//
const AdditionalDisplayChange = val => {
if (val == 1) {
SurchargeDisplay.value = true;
AdditionalcategoriesList.value = [
{
id: 1,
plus: true,
reduce: false,
StateName: 'additional', //
warehousePieceCategory: '', //
Additionalcategories: [],
},
];
} else {
SurchargeDisplay.value = false;
}
};
</script>
<style scoped lang="scss">
@ -557,9 +709,9 @@ const Submit=()=>{
}
.el_Surcharge {
}
.el_submit{
.el_submit {
width: 100%;
display: flex;
justify-content: flex-end;
display: flex;
justify-content: flex-end;
}
</style>

25
src/views/warehouse/warehousesignedorder/distributionStockArticle.vue

@ -32,6 +32,20 @@
/>
</el-form-item>
<el-form-item label="签收扫描时间">
<el-date-picker
v-model="TopQuery.scanSingnTime"
type="datetimerange"
start-placeholder="开始日期"
end-placeholder="结束日期"
format="YYYY-MM-DD"
date-format="YYYY/MM/DD"
time-format="A"
@change="Toptiem"
/>
</el-form-item>
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
@ -313,6 +327,17 @@ const searchChange = () => {
delete queryCarn.value.signingTimeStart;
delete queryCarn.value.signingTimeEnd;
}
//
if (TopQuery.value.scanSingnTime) {
queryCarn.value.scanSigningTimeStart = dayjs(TopQuery.value.scanSingnTime[0]).format(
'YYYY-MM-DD HH:mm:ss'
); //
queryCarn.value.scanSigningTimeEnd = dayjs(TopQuery.value.scanSingnTime[1]).format('YYYY-MM-DD HH:mm:ss'); //
} else {
delete queryCarn.value.scanSigningTimeStart;
delete queryCarn.value.scanSigningTimeEnd;
}
getrain();
};

Loading…
Cancel
Save