Browse Source

Merge branch 'dev' into test

test
pref_mail@163.com 2 years ago
parent
commit
1327af8412
  1. 50
      src/api/distribution/distributionStock.js
  2. 11
      src/api/distribution/distributionStockArticle.js
  3. 11
      src/api/distribution/distributionStockList.js
  4. 12
      src/option/distribution/distributionStockArticle.js
  5. 336
      src/option/distribution/distrilbutionBillLading.js
  6. 27
      src/views/distribution/inventory/delivery/distributionStockArticle.vue
  7. 31
      src/views/distribution/inventory/delivery/distributionStockArticleDiscuss.vue
  8. 27
      src/views/distribution/inventory/delivery/distributionStockArticleMarket.vue
  9. 21
      src/views/distribution/inventory/delivery/distributionStockArticleSelf.vue
  10. 564
      src/views/distribution/inventory/distrilbutionBillLading.vue
  11. 576
      src/views/distribution/inventory/distrilbutionBillLadingList.vue

50
src/api/distribution/distributionStock.js

@ -0,0 +1,50 @@
import request from '@/axios';
export const getListStock = (current, size, params) => {
return request({
url: '/api/logpm-distribution/distributionStock/list',
method: 'get',
params: {
...params,
current,
size,
}
})
}
export const getDetail = (id) => {
return request({
url: '/api/logpm-distribution/distributionStock/detail',
method: 'get',
params: {
id
}
})
}
export const remove = (ids) => {
return request({
url: '/api/logpm-distribution/distributionStock/remove',
method: 'post',
params: {
ids,
}
})
}
export const add = (row) => {
return request({
url: '/api/logpm-distribution/distributionStock/submit',
method: 'post',
data: row
})
}
export const update = (row) => {
return request({
url: '/api/logpm-distribution/distributionStock/submit',
method: 'post',
data: row
})
}

11
src/api/distribution/distributionStockArticle.js

@ -11,6 +11,17 @@ export const getList = (current, size, params) => {
}
})
}
export const getListOne = (current, size, params) => { //查询订单数据
return request({
url: '/api/logpm-distribution/distributionStockArticle/list',
method: 'get',
params: {
...params,
current,
size,
}
})
}
export const getDetail = (id) => {
return request({

11
src/api/distribution/distributionStockList.js

@ -11,6 +11,17 @@ export const getList = (current, size, params) => {
}
})
}
export const getListStockList = (current, size, params) => {
return request({
url: '/api/logpm-distribution/distributionStockList/list',
method: 'get',
params: {
...params,
current,
size,
}
})
}
export const getDetail = (id) => {
return request({

12
src/option/distribution/distributionStockArticle.js

@ -423,7 +423,7 @@ export default {
},
{
label: "服务类型",
prop: "typeService",
prop: "typeName",
search: true,
},
{
@ -447,10 +447,10 @@ export default {
// prop: "genre",
// search: true,
// },
// {
// label: "状态;1 配送 2 待配送",
// prop: "state",
// search: true,
// },
{
label: "状态",
prop: "stateName",
search: true,
},
]
}

336
src/option/distribution/distrilbutionBillLading.js

@ -3,6 +3,245 @@ export default {
index: true,
border: true,
selection: true,
columnList: [
{
label: "主键",
prop: "id",
display: false,
hide: true,
},
{
label: "租户号",
prop: "tenantId",
display: false,
hide: true,
},
{
label: "创建人",
prop: "createUser",
display: false,
hide: true,
},
{
label: "创建时间",
prop: "createTime",
display: false,
hide: true,
},
{
label: "更新人",
prop: "updateUser",
display: false,
hide: true,
},
{
label: "更新时间",
prop: "updateTime",
display: false,
hide: true,
},
{
label: "状态",
prop: "status",
display: false,
hide: true,
},
{
label: "是否已删除",
prop: "isDeleted",
display: false,
hide: true,
},
{
label: "创建部门",
prop: "createDept",
display: false,
hide: true,
},
{
label: "预留1",
prop: "reserve1",
display: false,
hide: true,
},
{
label: "预留2",
prop: "reserve2",
display: false,
hide: true,
},
{
label: "预留3",
prop: "reserve3",
display: false,
hide: true,
},
{
label: "预留4",
prop: "reserve4",
display: false,
hide: true,
},
{
label: "预留5",
prop: "reserve5",
display: false,
hide: true,
},
{
label: "订单自编号",
prop: "orderSelfNumbering",
},
{
label: "一级品",
prop: "firsts",
},
{
label: "二级品",
prop: "second",
},
{
label: "品名",
prop: "material",
},
{
label: "总件数",
prop: "quantity",
},
// {
// label: "已提件数",
// prop: "pickUpTime",
// },
// {
// label: "未提件数",
// prop: "pickUpTime",
// },
],
columnStock: [
{
label: "主键",
prop: "id",
display: false,
hide: true,
},
{
label: "租户号",
prop: "tenantId",
display: false,
hide: true,
},
{
label: "创建人",
prop: "createUser",
display: false,
hide: true,
},
{
label: "创建时间",
prop: "createTime",
display: false,
hide: true,
},
{
label: "更新人",
prop: "updateUser",
display: false,
hide: true,
},
{
label: "更新时间",
prop: "updateTime",
display: false,
hide: true,
},
{
label: "状态",
prop: "status",
display: false,
hide: true,
},
{
label: "是否已删除",
prop: "isDeleted",
display: false,
hide: true,
},
{
label: "创建部门",
prop: "createDept",
display: false,
hide: true,
},
{
label: "预留1",
prop: "reserve1",
display: false,
hide: true,
},
{
label: "预留2",
prop: "reserve2",
display: false,
hide: true,
},
{
label: "预留3",
prop: "reserve3",
display: false,
hide: true,
},
{
label: "预留4",
prop: "reserve4",
display: false,
hide: true,
},
{
label: "预留5",
prop: "reserve5",
display: false,
hide: true,
},
{
label: "订单自编号",
prop: "orderSelfNumbering",
},
{
label: "商城名称",
prop: "mallName",
},
{
label: "品分类",
prop: "category",
},
{
label: "货物名称",
prop: "descriptionGoods",
},
{
label: "货物单位",
prop: "cargoUnit",
},
{
label: "总件数",
prop: "quantityStock",
},
{
label: "物流车次",
prop: "despatch",
},
{
label: "工厂车次",
prop: "factory",
},
],
column: [
{
label: "主键",
@ -88,6 +327,103 @@ export default {
display: false,
hide: true,
},
{
label: "提货批次",
prop: "pickUpTime",
width: 170
},
{
label: "服务号",
prop: "pickUpTime",
width: 170
},
{
label: "运单号",
prop: "pickUpTime",
width: 170
},
{
label: "收货单位",
prop: "pickUpTime",
width: 170
},
{
label: "收货人",
prop: "pickUpTime",
width: 170
},
{
label: "联系电话",
prop: "pickUpTime",
width: 170
},
{
label: "仓库",
prop: "pickUpTime",
width: 170
},
{
label: "入库时间",
prop: "pickUpTime",
width: 170
},
{
label: "到付运费",
prop: "pickUpTime",
width: 170
},
{
label: "搬运费",
prop: "pickUpTime",
width: 170
},
{
label: "仓储费",
prop: "pickUpTime",
},
{
label: "叉车费",
prop: "pickUpTime",
},
{
label: "总费用",
prop: "pickUpTime",
},
{
label: "应提件数",
prop: "pickUpTime",
},
{
label: "实提件数",
prop: "pickUpTime",
},
{
label: "品牌",
prop: "pickUpTime",
},
{
label: "服务类型",
prop: "pickUpTime",
width: 170
},
{
label: "货品信息",
prop: "pickUpTime",
width: 170
},
{
label: "提货手机",
prop: "pickUpTime",
},
{
label: "提货时间",
prop: "pickUpTime",
width: 170
},
{
label: "备注",
prop: "pickUpTime",
},
{
label: "提货时间",
prop: "pickUpTime",

27
src/views/distribution/inventory/delivery/distributionStockArticle.vue

@ -412,17 +412,20 @@ export default {
this.$message.warning("请选择至少一条数据");
return;
}
let a = '';
let b = '';
let c = '';
let d = true;
this.selectionList.forEach( i =>{
if(!!a){
}else{
a = i.customerName
let st = false;
this.selectionList.some( i =>{
if(i.stateName === "已预约"){
st = true;
this.$message.warning(i.orderSelfNumbering+" - 已预约,请勿重复预约!!!");
}
if(i.typeService === 3){
st = true;
this.$message.warning(i.orderSelfNumbering+" - 为自提单,无法预约!!!");
}
})
if(st){
return
}
// orderId
const notEqualFlag = this.selectionList.some(
(item) =>
@ -508,10 +511,13 @@ export default {
});
this.dialogFormVisible = false;
this.formCall={}
this.onLoad(this.page);
});
break;
case '2':
this.formService.stockArticleId = this.ids;
// console.log("",this.formService);
addService(this.formService).then(() =>{
this.$message({
type: "success",
@ -519,6 +525,7 @@ export default {
});
this.dialogFormService = false;
this.formService={}
this.onLoad(this.page);
})
break;
case '3':
@ -531,6 +538,7 @@ export default {
});
this.dialogFormCustomer = false;
this.formCustomer={}
this.onLoad(this.page);
})
break;
}
@ -768,6 +776,7 @@ export default {
this.query.genre = 1;
getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
const data = res.data.data;
this.page.total = data.total;
this.data = data.records;
this.loading = false;

31
src/views/distribution/inventory/delivery/distributionStockArticleDiscuss.vue

@ -20,9 +20,9 @@
<el-form-item label="品牌:">
<el-input v-model="query.brand" placeholder="请输入品牌"></el-input>
</el-form-item>
<el-form-item label="服务类型:">
<el-input v-model="query.typeService" placeholder="请输入服务类型"></el-input>
</el-form-item>
<!-- <el-form-item label="服务类型:">-->
<!-- <el-input v-model="query.typeService" placeholder="请输入服务类型"></el-input>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="类型;1 预约单 2库存单:">-->
<!-- <el-input v-model="query.genre" placeholder="请输入类型;1 预约单 2库存单"></el-input>-->
<!-- </el-form-item>-->
@ -412,17 +412,17 @@ export default {
this.$message.warning("请选择至少一条数据");
return;
}
let a = '';
let b = '';
let c = '';
let d = true;
this.selectionList.forEach( i =>{
if(!!a){
}else{
a = i.customerName
let st = false;
this.selectionList.some( i =>{
if(i.stateName === "已预约"){
st = true;
this.$message.warning(i.orderSelfNumbering+"已预约,请勿重复预约!!!");
}
})
if(st){
return
}
// orderId
const notEqualFlag = this.selectionList.some(
(item) =>
@ -431,7 +431,6 @@ export default {
&& ele.customerTelephone !== item.customerTelephone
&& ele.customerAddress !== item.customerAddress ).length >= 1
);
console.log("notEqualFlag=====",notEqualFlag);
// true,
// false,
if(!notEqualFlag){
@ -508,10 +507,12 @@ export default {
});
this.dialogFormVisible = false;
this.formCall={}
this.onLoad(this.page);
});
break;
case '2':
// console.log("",this.formService);
this.formService.stockArticleId = this.ids;
console.log("服务类型",this.formService);
addService(this.formService).then(() =>{
this.$message({
type: "success",
@ -519,6 +520,7 @@ export default {
});
this.dialogFormService = false;
this.formService={}
this.onLoad(this.page);
})
break;
case '3':
@ -531,6 +533,7 @@ export default {
});
this.dialogFormCustomer = false;
this.formCustomer={}
this.onLoad(this.page);
})
break;
}

27
src/views/distribution/inventory/delivery/distributionStockArticleMarket.vue

@ -20,9 +20,9 @@
<el-form-item label="品牌:">
<el-input v-model="query.brand" placeholder="请输入品牌"></el-input>
</el-form-item>
<el-form-item label="服务类型:">
<el-input v-model="query.typeService" placeholder="请输入服务类型"></el-input>
</el-form-item>
<!-- <el-form-item label="服务类型:">-->
<!-- <el-input v-model="query.typeService" placeholder="请输入服务类型"></el-input>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="类型;1 预约单 2库存单:">-->
<!-- <el-input v-model="query.genre" placeholder="请输入类型;1 预约单 2库存单"></el-input>-->
<!-- </el-form-item>-->
@ -412,17 +412,16 @@ export default {
this.$message.warning("请选择至少一条数据");
return;
}
let a = '';
let b = '';
let c = '';
let d = true;
this.selectionList.forEach( i =>{
if(!!a){
}else{
a = i.customerName
let st = false;
this.selectionList.some( i =>{
if(i.stateName === "已预约"){
st = true;
this.$message.warning(i.orderSelfNumbering+"已预约,请勿重复预约!!!");
}
})
if(st){
return
}
// orderId
const notEqualFlag = this.selectionList.some(
(item) =>
@ -508,9 +507,11 @@ export default {
});
this.dialogFormVisible = false;
this.formCall={}
this.onLoad(this.page);
});
break;
case '2':
this.formService.stockArticleId = this.ids;
// console.log("",this.formService);
addService(this.formService).then(() =>{
this.$message({
@ -519,6 +520,7 @@ export default {
});
this.dialogFormService = false;
this.formService={}
this.onLoad(this.page);
})
break;
case '3':
@ -531,6 +533,7 @@ export default {
});
this.dialogFormCustomer = false;
this.formCustomer={}
this.onLoad(this.page);
})
break;
}

21
src/views/distribution/inventory/delivery/distributionStockArticleSelf.vue

@ -20,9 +20,9 @@
<el-form-item label="品牌:">
<el-input v-model="query.brand" placeholder="请输入品牌"></el-input>
</el-form-item>
<el-form-item label="服务类型:">
<el-input v-model="query.typeService" placeholder="请输入服务类型"></el-input>
</el-form-item>
<!-- <el-form-item label="服务类型:">-->
<!-- <el-input v-model="query.typeService" placeholder="请输入服务类型"></el-input>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="类型;1 预约单 2库存单:">-->
<!-- <el-input v-model="query.genre" placeholder="请输入类型;1 预约单 2库存单"></el-input>-->
<!-- </el-form-item>-->
@ -508,9 +508,11 @@ export default {
});
this.dialogFormVisible = false;
this.formCall={}
this.onLoad(this.page);
});
break;
case '2':
this.formService.stockArticleId = this.ids;
// console.log("",this.formService);
addService(this.formService).then(() =>{
this.$message({
@ -519,6 +521,7 @@ export default {
});
this.dialogFormService = false;
this.formService={}
this.onLoad(this.page);
})
break;
case '3':
@ -531,6 +534,7 @@ export default {
});
this.dialogFormCustomer = false;
this.formCustomer={}
this.onLoad(this.page);
})
break;
}
@ -542,11 +546,20 @@ export default {
this.$message.warning("请选择至少一条数据");
return;
}
let st = false;
this.selectionList.some( i =>{
if(i.stateName === "已预约"){
st = true;
this.$message.warning(i.orderSelfNumbering+"已预约,请勿重复预约!!!");
}
})
if(st){
return
}
this.$router.push({
path: '/distribution/inventory/distrilbutionBillLading',
query:{
id: this.ids,
}
});
},

564
src/views/distribution/inventory/distrilbutionBillLading.vue

@ -1,133 +1,133 @@
<template>
<basic-container>
<!-- <div class="avue-crud">-->
<!-- <el-row :hidden="!search" style="padding:6px 18px">-->
<!-- &lt;!&ndash; 查询模块 &ndash;&gt;-->
<!-- <el-form :inline="true" :model="query">-->
<!-- <el-form-item label="提货证件:">-->
<!-- <el-input v-model="query.deliveryDocument" placeholder="请输入提货证件"></el-input>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="证件类型:">-->
<!-- <el-input v-model="query.certificateType" placeholder="请输入证件类型"></el-input>-->
<!-- </el-form-item>-->
<!-- &lt;!&ndash; 查询按钮 &ndash;&gt;-->
<!-- <el-form-item>-->
<!-- <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">-->
<!-- &lt;!&ndash; 头部左侧按钮模块 &ndash;&gt;-->
<!-- <div class="avue-crud__left">-->
<!-- <el-button type="primary" icon="el-icon-plus" @click="handleAdd"> </el-button>-->
<!-- <el-button type="danger" icon="el-icon-delete" @click="handleDelete" plain> </el-button>-->
<!-- </div>-->
<!-- &lt;!&ndash; 头部右侧按钮模块 &ndash;&gt;-->
<!-- <div class="avue-crud__right">-->
<!-- <el-button icon="el-icon-refresh" @click="searchChange" circle></el-button>-->
<!-- <el-button icon="el-icon-search" @click="searchHide" circle></el-button>-->
<!-- </div>-->
<!-- </div>-->
<!-- </el-row>-->
<!-- <el-row>-->
<!-- &lt;!&ndash; 列表模块 &ndash;&gt;-->
<!-- <el-table ref="table" v-loading="loading"-->
<!-- @selection-change="selectionChange"-->
<!-- :data="data"-->
<!-- :height="height"-->
<!-- style="width: 100%"-->
<!-- :border="option.border">-->
<!-- <el-table-column type="selection" v-if="option.selection" width="55" align="center"></el-table-column>-->
<!-- <el-table-column type="expand" v-if="option.expand" align="center"></el-table-column>-->
<!-- <el-table-column v-if="option.index" label="#" type="index" width="50" align="center">-->
<!-- </el-table-column>-->
<!-- <template v-for="(item,index) in option.column">-->
<!-- &lt;!&ndash; table字段 &ndash;&gt;-->
<!-- <el-table-column v-if="item.hide!==true"-->
<!-- :prop="item.prop"-->
<!-- :label="item.label"-->
<!-- :width="item.width"-->
<!-- :key="index">-->
<!-- </el-table-column>-->
<!-- </template>-->
<!-- &lt;!&ndash; 操作栏模块 &ndash;&gt;-->
<!-- <el-table-column prop="menu" label="操作" :width="220" align="center">-->
<!-- <template #="{row}">-->
<!-- <el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-edit" @click="handleEdit(row)">编辑</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>-->
<!-- </template>-->
<!-- </el-table-column>-->
<!-- </el-table>-->
<!-- </el-row>-->
<!-- <el-row>-->
<!-- <div class="avue-crud__pagination" style="width:100%">-->
<!-- &lt;!&ndash; 分页模块 &ndash;&gt;-->
<!-- <el-pagination align="right"-->
<!-- background-->
<!-- @size-change="sizeChange"-->
<!-- @current-change="currentChange"-->
<!-- :current-page="page.currentPage"-->
<!-- :page-sizes="[10, 20, 30, 40, 50, 100]"-->
<!-- :page-size="page.pageSize"-->
<!-- layout="total, sizes, prev, pager, next, jumper"-->
<!-- :total="page.total">-->
<!-- </el-pagination>-->
<!-- </div>-->
<!-- </el-row>-->
<!-- &lt;!&ndash; 表单模块 &ndash;&gt;-->
<!-- <el-dialog :title="title"-->
<!-- v-model="box"-->
<!-- width="50%"-->
<!-- :before-close="beforeClose"-->
<!-- append-to-body>-->
<!-- <el-form :disabled="view" ref="form" :model="form" label-width="80px">-->
<!-- &lt;!&ndash; 表单字段 &ndash;&gt;-->
<!-- <el-form-item label="提货时间" prop="pickUpTime">-->
<!-- <el-input v-model="form.pickUpTime" placeholder="请输入提货时间"/>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="提货人" prop="consignee">-->
<!-- <el-input v-model="form.consignee" placeholder="请输入提货人"/>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="提货车牌" prop="pickUpPlate">-->
<!-- <el-input v-model="form.pickUpPlate" placeholder="请输入提货车牌"/>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="提货证件" prop="deliveryDocument">-->
<!-- <el-input v-model="form.deliveryDocument" placeholder="请输入提货证件"/>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="证件类型" prop="certificateType">-->
<!-- <el-select v-model="form.certificateType" clearable placeholder="请选择证件类型">-->
<!-- <el-option-->
<!-- v-for="item in certificateTypeData"-->
<!-- :key="item.dictKey"-->
<!-- :label="item.dictValue"-->
<!-- :value="item.dictKey">-->
<!-- </el-option>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
<!-- <el-form-item label="费用合计" prop="totalCost">-->
<!-- <el-input v-model="form.totalCost" placeholder="请输入费用合计"/>-->
<!-- </el-form-item>-->
<!-- </el-form>-->
<!-- &lt;!&ndash; 表单按钮 &ndash;&gt;-->
<!-- <template #footer>-->
<!-- <span v-if="!view" class="dialog-footer">-->
<!-- <el-button type="primary" icon="el-icon-circle-check" @click="handleSubmit"> </el-button>-->
<!-- <el-button icon="el-icon-circle-close" @click="box = false"> </el-button>-->
<!-- </span>-->
<!-- </template>-->
<!-- </el-dialog>-->
<!-- </div>-->
<div class="avue-crud" :style="`height:`+ height ">
<!-- <div class="avue-crud">
<el-row :hidden="!search" style="padding:6px 18px">
&lt;!&ndash; 查询模块 &ndash;&gt;
<el-form :inline="true" :model="query">
<el-form-item label="提货证件:">
<el-input v-model="query.deliveryDocument" placeholder="请输入提货证件"></el-input>
</el-form-item>
<el-form-item label="证件类型:">
<el-input v-model="query.certificateType" placeholder="请输入证件类型"></el-input>
</el-form-item>
&lt;!&ndash; 查询按钮 &ndash;&gt;
<el-form-item>
<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">
&lt;!&ndash; 头部左侧按钮模块 &ndash;&gt;
<div class="avue-crud__left">
<el-button type="primary" icon="el-icon-plus" @click="handleAdd"> </el-button>
<el-button type="danger" icon="el-icon-delete" @click="handleDelete" plain> </el-button>
</div>
&lt;!&ndash; 头部右侧按钮模块 &ndash;&gt;
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChange" circle></el-button>
<el-button icon="el-icon-search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<el-row>
&lt;!&ndash; 列表模块 &ndash;&gt;
<el-table ref="table" v-loading="loading"
@selection-change="selectionChange"
:data="data"
:height="height"
style="width: 100%"
:border="option.border">
<el-table-column type="selection" v-if="option.selection" width="55" align="center"></el-table-column>
<el-table-column type="expand" v-if="option.expand" align="center"></el-table-column>
<el-table-column v-if="option.index" label="#" type="index" width="50" align="center">
</el-table-column>
<template v-for="(item,index) in option.column">
&lt;!&ndash; table字段 &ndash;&gt;
<el-table-column v-if="item.hide!==true"
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index">
</el-table-column>
</template>
&lt;!&ndash; 操作栏模块 &ndash;&gt;
<el-table-column prop="menu" label="操作" :width="220" align="center">
<template #="{row}">
<el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>
<el-button type="primary" text icon="el-icon-edit" @click="handleEdit(row)">编辑</el-button>
<el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>
</template>
</el-table-column>
</el-table>
</el-row>
<el-row>
<div class="avue-crud__pagination" style="width:100%">
&lt;!&ndash; 分页模块 &ndash;&gt;
<el-pagination align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[10, 20, 30, 40, 50, 100]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total">
</el-pagination>
</div>
</el-row>
&lt;!&ndash; 表单模块 &ndash;&gt;
<el-dialog :title="title"
v-model="box"
width="50%"
:before-close="beforeClose"
append-to-body>
<el-form :disabled="view" ref="form" :model="form" label-width="80px">
&lt;!&ndash; 表单字段 &ndash;&gt;
<el-form-item label="提货时间" prop="pickUpTime">
<el-input v-model="form.pickUpTime" placeholder="请输入提货时间"/>
</el-form-item>
<el-form-item label="提货人" prop="consignee">
<el-input v-model="form.consignee" placeholder="请输入提货人"/>
</el-form-item>
<el-form-item label="提货车牌" prop="pickUpPlate">
<el-input v-model="form.pickUpPlate" placeholder="请输入提货车牌"/>
</el-form-item>
<el-form-item label="提货证件" prop="deliveryDocument">
<el-input v-model="form.deliveryDocument" placeholder="请输入提货证件"/>
</el-form-item>
<el-form-item label="证件类型" prop="certificateType">
<el-select v-model="form.certificateType" clearable placeholder="请选择证件类型">
<el-option
v-for="item in certificateTypeData"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="费用合计" prop="totalCost">
<el-input v-model="form.totalCost" placeholder="请输入费用合计"/>
</el-form-item>
</el-form>
&lt;!&ndash; 表单按钮 &ndash;&gt;
<template #footer>
<span v-if="!view" class="dialog-footer">
<el-button type="primary" icon="el-icon-circle-check" @click="handleSubmit"> </el-button>
<el-button icon="el-icon-circle-close" @click="box = false"> </el-button>
</span>
</template>
</el-dialog>
</div>-->
<div class="avue-crud" :style="`height:`+ height+';overflow:auto;' " >
<el-form :disabled="view" ref="form" :model="form" label-width="80px">
<!-- 表单字段 -->
<el-row :gutter="20">
<el-col :span="10">
<el-col :span="12">
<el-form-item label="提货时间" prop="pickUpTime">
<!-- <el-input v-model="form.pickUpTime" placeholder="请输入提货时间"/>-->
<el-date-picker
<el-date-picker style="width: 100%"
v-model="form.pickUpTime"
type="datetime"
placeholder="请输入提货时间"
@ -136,28 +136,28 @@
/>
</el-form-item>
</el-col>
<el-col :span="10">
<el-col :span="12">
<el-form-item label="提货人" prop="consignee">
<el-input v-model="form.consignee" placeholder="请输入提货人"/>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="10">
<el-form-item label="提货车牌" prop="pickUpPlate">
<el-col :span="12">
<el-form-item label="提货车牌号码" prop="pickUpPlate" label-width="98px">
<el-input v-model="form.pickUpPlate" placeholder="请输入提货车牌"/>
</el-form-item>
</el-col>
<el-col :span="10">
<el-form-item label="提货证件" prop="deliveryDocument">
<el-col :span="12">
<el-form-item label="提货证件号码" prop="deliveryDocument" label-width="120px">
<el-input v-model="form.deliveryDocument" placeholder="请输入提货证件"/>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="10">
<el-col :span="12">
<el-form-item label="证件类型" prop="certificateType">
<el-select v-model="form.certificateType" clearable placeholder="请选择证件类型">
<el-select v-model="form.certificateType" clearable placeholder="请选择证件类型" style="width: 100%">
<el-option
v-for="item in certificateType"
:key="item.dictKey"
@ -167,7 +167,7 @@
</el-select>
</el-form-item>
</el-col>
<el-col :span="10">
<el-col :span="12">
</el-col>
</el-row>
@ -175,7 +175,7 @@
<el-col :span="24">
<el-form-item label="费用" prop="certificateType">
<el-checkbox-group v-model="form.freightMark" @change="handleCheckedCitiesChange">
<el-checkbox style="width: 18%;margin-bottom: 3%"
<el-checkbox style="width: 16%;margin-bottom: 3%"
v-for="(item,index) in clientType"
:key="item.dictKey"
:label="item.dictKey"
@ -196,19 +196,83 @@
<el-row :gutter="20">
<el-col :span="24">
<el-form-item label="物品明细" prop="certificateType">
<el-tabs type="border-card" style="width: 100%">
<el-tab-pane label="定制品">
<el-table ref="table" v-loading="loading"
@selection-change="selectionChange"
:data="dataList"
style="width: 100%"
:border="option.border">
<template v-for="(item,index) in option.columnList">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index">
</el-table-column>
</template>
<!-- 操作栏模块 -->
<!-- <el-table-column prop="menu" label="操作" :width="220" align="center">-->
<!-- <template #="{row}">-->
<!-- <el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-edit" @click="handleEdit(row)">编辑</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>-->
<!-- </template>-->
<!-- </el-table-column>-->
</el-table>
</el-tab-pane>
<el-tab-pane label="标准品">
<el-button type="primary" text icon="el-icon-view" @click="handleAddView(row)">新增</el-button>
<el-table ref="table" v-loading="loading"
@selection-change="selectionChange"
:data="data"
style="width: 100%"
:border="option.border">
<!-- <el-table-column type="selection" v-if="option.selection" width="50" align="center"></el-table-column>-->
<el-table-column type="expand" v-if="option.expand" align="center"></el-table-column>
<el-table-column v-if="option.index" label="序号" type="index" width="70" align="center">
</el-table-column>
<template v-for="(item,index) in option.columnStock">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index">
</el-table-column>
</template>
<!-- 操作栏模块 -->
<el-table-column prop="menu" label="添加数量" :width="220" align="center">
<template #="{row}">
<el-input v-model="row.inventoryQuantity" @blur="handleNumberRange($event,row)" ></el-input>
</template>
</el-table-column>
<!-- 操作栏模块 -->
<el-table-column prop="menu" label="操作" :width="220" align="center">
<template #="{row}">
<el-button type="primary" text icon="el-icon-delete" @click="rowStock(row)">移除</el-button>
</template>
</el-table-column>
</el-table>
</el-tab-pane>
</el-tabs>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="提货证件" prop="totalCost" label-width ='120px'>
<el-upload
v-model:file-list="fileList"
v-model:file-list="fileListSell"
class="upload-demo"
:action="action"
:headers="headers"
multiple
:on-preview="handlePreview"
:on-success="(response, file, fileList) => {uploadSuccess(fileListSell)}"
:on-remove="handleRemove"
list-type="picture"
>
@ -224,10 +288,13 @@
<el-col :span="8">
<el-form-item label="文员确定图片" prop="totalCost" label-width ='120px'>
<el-upload
v-model:file-list="fileList"
v-model:file-list="fileListClerk"
class="upload-demo"
action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15"
:action="action"
:headers="headers"
multiple
:on-preview="handlePreview"
:on-success="(response, file, fileList) => {uploadSuccess(fileListClerk)}"
:on-remove="handleRemove"
list-type="picture"
>
@ -243,10 +310,13 @@
<el-col :span="8">
<el-form-item label="库管签收图片" prop="totalCost" label-width ='120px'>
<el-upload
v-model:file-list="fileList"
v-model:file-list="fileListLibrary"
class="upload-demo"
action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15"
:action="action"
:headers="headers"
multiple
:on-preview="handlePreview"
:on-success="(response, file, fileList) => {uploadSuccess(fileListLibrary)}"
:on-remove="handleRemove"
list-type="picture"
>
@ -271,20 +341,74 @@
</div>
</div>
</div>
<el-dialog v-model="dialogFormVisible" title="添加标准品" style="width: 80% ">
<el-table ref="table" v-loading="loading"
@selection-change="selectionChangeStock"
:data="dataOwn"
style="width: 100%"
:border="option.border">
<el-table-column type="selection" v-if="option.selection" width="50" align="center"></el-table-column>
<el-table-column type="expand" v-if="option.expand" align="center"></el-table-column>
<el-table-column v-if="option.index" label="序号" type="index" width="70" align="center">
</el-table-column>
<template v-for="(item,index) in option.columnStock">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index">
</el-table-column>
</template>
<!-- 操作栏模块 -->
<!-- <el-table-column prop="menu" label="操作" :width="220" align="center">-->
<!-- <template #="{row}">-->
<!-- <el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-edit" @click="handleEdit(row)">编辑</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>-->
<!-- </template>-->
<!-- </el-table-column>-->
</el-table>
<div class="avue-crud__pagination" style="width:100%">
<!-- 分页模块 -->
<el-pagination align="right"
background
@size-change="sizeChangeStock"
@current-change="currentChangeStock"
:current-page="pageStock.currentPage"
:page-sizes="[10, 20, 30, 40, 50, 100]"
:page-size="pageStock.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="pageStock.total">
</el-pagination>
</div>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogFormVisible = false">取消</el-button>
<!-- <el-button type="primary" @click="dialogFormVisible = false"> 确定 </el-button>-->
<el-button type="primary" @click="callFordelivery('1')"> 确定 </el-button>
</span>
</template>
</el-dialog>
</basic-container>
</template>
<script>
import { getList, getDetail, add, update, remove } from "@/api/distribution/distrilbutionBillLading";
import { getListOwn } from "@/api/distribution/distributionParcelList";
import option from "@/option/distribution/distrilbutionBillLading";
import { mapGetters } from "vuex";
import { getDictionaryBiz } from '@/api/system/dict';
import { getToken } from '@/utils/auth';
import { getListStockList } from '@/api/distribution/distributionStockList';
import { getListOne} from "@/api/distribution/distributionStockArticle";
export default {
data () {
return {
dialogFormVisible: false,
height: 0,
//
title: '',
@ -304,32 +428,57 @@ export default {
pageSize: 10,
total: 40
},
//
pageStock: {
currentPage: 1,
pageSize: 10,
total: 40
},
//
form: {},
//
selectionList: [],
selectionListStock: [],//
//
option: option,
//
data: [],
dataList: [],
dataOwn: [],
clientType: [],
costList: [],
costListName: [],
certificateType: [],
fileList:[ {
name: 'food.jpeg',
url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
},
{
name: 'food2.jpeg',
url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
},]
fileListLibrary: [],
fileListSell: [],
fileListClerk: [],
fileList:[
// {
// name: 'food.jpeg',
// url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
// },
// {
// name: 'food2.jpeg',
// url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
// },
]
}
},
mounted () {
this.init();
this.onLoad(this.page);
},
watch:{
'$route.query.id':{
handler(newVal, oldVal) {
// console.log(newVal, oldVal);
this.onLoad(this.page);
this.onLoadOwn(this.page);
},
deep: true,
immediate: true
}
},
computed: {
...mapGetters(["permission",'tagWel','tagList']),
ids () {
@ -339,6 +488,13 @@ export default {
});
return ids.join(",");
},
stockIds () {
let ids = [];
this.selectionListStock.forEach(ele => {
ids.push(ele.id);
});
return ids.join(",");
},
headers() {
return {
"Blade-Auth":'Bearer ' + getToken()
@ -350,6 +506,55 @@ export default {
}
},
methods: {
//
rowStock (row) {
console.log(">>?>?><?",row);
this.data.forEach( i =>{
if(i.id === row.id){
this.data
}
})
let id1 = this.data.findIndex(item => {
if (item.id == row.id) {
return true
}
})
this.data.splice(id1, 1)
},
//
callFordelivery(inde){
this.dialogFormVisible = false;
this.selectionListStock.some( i =>{
console.log("asdgfasdv",i);
let a = this.data.filter((ele) => ele.id == i.id ).length >= 1
console.log("asdgfasdv",a);
if(!a){
this.data.push(i);
}
})
},
//
handleNumberRange(e,row) {
console.log("执行了2222",e,e.target.value,row);
if(e.target.value) {
e.target.value = e.target.value.replace(/[^\.\d]/g,'') //
if(e.target.value) { //
e.target.value = parseInt(e.target.value); //
}
if((e.target.value > row.quantityStock )) {
this.$message.error('数量不能大于订单数')
e.target.value = row.quantityStock;
return
}
}
},
uploadSuccess(fileList) {
console.log('123123123', fileList);
// this.form.fileName =
// this.$set(row, 'imageCos', fileList);
},
handleRemove(file, fileList) {
console.log(file, fileList);
},
@ -428,17 +633,17 @@ export default {
this.form.fei = Object.fromEntries(fei);
this.form.stockArticleId = this.$route.query.ids;
console.log("this.form",this.form);
add(this.form).then(() => {
this.box = false;
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
this.contextmenuFlag = false;
this.$store.commit('DEL_TAG_CURRENT');
this.$router.push(this.tagWel);
});
// add(this.form).then(() => {
// this.box = false;
// this.onLoad(this.page);
// this.$message({
// type: "success",
// message: "!"
// });
// this.contextmenuFlag = false;
// this.$store.commit('DEL_TAG_CURRENT');
// this.$router.push(this.tagWel);
// });
} else {
update(this.form).then(() => {
this.box = false;
@ -470,6 +675,10 @@ export default {
this.form = res.data.data;
});
},
handleAddView (row) {
this.dialogFormVisible = true;
this.onLoadList(this.pageStock);
},
handleDelete () {
if (this.selectionList.length === 0) {
this.$message.warning("请选择至少一条数据");
@ -517,10 +726,21 @@ export default {
selectionChange (list) {
this.selectionList = list;
},
selectionChangeStock (list) {
this.selectionListStock = list;
},
selectionClear () {
this.selectionList = [];
// this.$refs.table.clearSelection();
},
currentChangeStock (currentPage) {
this.pageStock.currentPage = currentPage;
this.onLoadList(this.pageStock);
},
sizeChangeStock (pageSize) {
this.pageStock.pageSize = pageSize;
this.onLoadList(this.pageStock);
},
currentChange (currentPage) {
this.page.currentPage = currentPage;
this.onLoad(this.page);
@ -529,12 +749,36 @@ export default {
this.page.pageSize = pageSize;
this.onLoad(this.page);
},
onLoad (page, params = {}) {
this.loading = true;
getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
params.id = this.$route.query.id;
getListOne(page.currentPage, page.pageSize, params).then(res => {
const data = res.data.data;
this.page.total = data.total;
this.data = data.records;
console.log(">>>>>>>>>===",data);
this.loading = false;
this.selectionClear();
});
} ,
//
onLoadList (page, params = {}) {
this.loading = true;
getListStockList(page.currentPage, page.pageSize,params ).then(res => {
const dataOwn = res.data.data;
this.pageStock.total = dataOwn.total;
this.dataOwn = dataOwn.records;
this.loading = false;
this.selectionClear();
});
} ,
//
onLoadOwn (page, params = {}) {
this.loading = true;
this.query.stockArticleId = this.$route.query.id;
getListOwn(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
const dataList = res.data.data;
this.page.total = dataList.total;
this.dataList = dataList.records;
this.loading = false;
this.selectionClear();
});

576
src/views/distribution/inventory/distrilbutionBillLadingList.vue

@ -0,0 +1,576 @@
<template>
<basic-container>
<div class="avue-crud">
<el-row :hidden="!search" style="padding:6px 18px">
<!-- 查询模块 -->
<el-form :inline="true" :model="query">
<el-form-item label="提货证件:">
<el-input v-model="query.deliveryDocument" placeholder="请输入提货证件"></el-input>
</el-form-item>
<el-form-item label="证件类型:">
<el-input v-model="query.certificateType" placeholder="请输入证件类型"></el-input>
</el-form-item>
<!-- 查询按钮 -->
<el-form-item>
<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" icon="el-icon-plus" @click="handleAdd"> </el-button>
<el-button type="danger" icon="el-icon-delete" @click="handleDelete" plain> </el-button>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChange" circle></el-button>
<el-button icon="el-icon-search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<el-row>
<!-- 列表模块 -->
<el-table ref="table" v-loading="loading"
@selection-change="selectionChange"
:data="data"
:height="height"
style="width: 100%"
:border="option.border">
<el-table-column type="selection" v-if="option.selection" width="55" align="center"></el-table-column>
<el-table-column type="expand" v-if="option.expand" align="center"></el-table-column>
<el-table-column v-if="option.index" label="序号" type="index" width="70" align="center">
</el-table-column>
<template v-for="(item,index) in option.column">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index">
</el-table-column>
</template>
<!-- 操作栏模块 -->
<el-table-column prop="menu" label="操作" :width="220" align="center">
<template #="{row}">
<el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>
<el-button type="primary" text icon="el-icon-edit" @click="handleEdit(row)">编辑</el-button>
<el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>
</template>
</el-table-column>
</el-table>
</el-row>
<el-row>
<div class="avue-crud__pagination" style="width:100%">
<!-- 分页模块 -->
<el-pagination align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[10, 20, 30, 40, 50, 100]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total">
</el-pagination>
</div>
</el-row>
<!-- 表单模块 -->
<el-dialog :title="title"
v-model="box"
width="50%"
:before-close="beforeClose"
append-to-body>
<el-form :disabled="view" ref="form" :model="form" label-width="80px">
<!-- 表单字段 -->
<el-form-item label="提货时间" prop="pickUpTime">
<el-input v-model="form.pickUpTime" placeholder="请输入提货时间"/>
</el-form-item>
<el-form-item label="提货人" prop="consignee">
<el-input v-model="form.consignee" placeholder="请输入提货人"/>
</el-form-item>
<el-form-item label="提货车牌" prop="pickUpPlate">
<el-input v-model="form.pickUpPlate" placeholder="请输入提货车牌"/>
</el-form-item>
<el-form-item label="提货证件" prop="deliveryDocument">
<el-input v-model="form.deliveryDocument" placeholder="请输入提货证件"/>
</el-form-item>
<el-form-item label="证件类型" prop="certificateType">
<el-select v-model="form.certificateType" clearable placeholder="请选择证件类型">
<el-option
v-for="item in certificateTypeData"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="费用合计" prop="totalCost">
<el-input v-model="form.totalCost" placeholder="请输入费用合计"/>
</el-form-item>
</el-form>
<!-- 表单按钮 -->
<template #footer>
<span v-if="!view" class="dialog-footer">
<el-button type="primary" icon="el-icon-circle-check" @click="handleSubmit"> </el-button>
<el-button icon="el-icon-circle-close" @click="box = false"> </el-button>
</span>
</template>
</el-dialog>
</div>
<!-- <div class="avue-crud" :style="`height:`+ height ">
<el-form :disabled="view" ref="form" :model="form" label-width="80px">
&lt;!&ndash; 表单字段 &ndash;&gt;
<el-row :gutter="20">
<el-col :span="10">
<el-form-item label="提货时间" prop="pickUpTime">
&lt;!&ndash; <el-input v-model="form.pickUpTime" placeholder="请输入提货时间"/>&ndash;&gt;
<el-date-picker
v-model="form.pickUpTime"
type="datetime"
placeholder="请输入提货时间"
format="YYYY-MM-DD hh:mm:ss"
value-format="YYYY-MM-DD hh:mm:ss"
/>
</el-form-item>
</el-col>
<el-col :span="10">
<el-form-item label="提货人" prop="consignee">
<el-input v-model="form.consignee" placeholder="请输入提货人"/>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="10">
<el-form-item label="提货车牌" prop="pickUpPlate">
<el-input v-model="form.pickUpPlate" placeholder="请输入提货车牌"/>
</el-form-item>
</el-col>
<el-col :span="10">
<el-form-item label="提货证件" prop="deliveryDocument">
<el-input v-model="form.deliveryDocument" placeholder="请输入提货证件"/>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="10">
<el-form-item label="证件类型" prop="certificateType">
<el-select v-model="form.certificateType" clearable placeholder="请选择证件类型">
<el-option
v-for="item in certificateType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey">
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="10">
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="24">
<el-form-item label="费用" prop="certificateType">
<el-checkbox-group v-model="form.freightMark" @change="handleCheckedCitiesChange">
<el-checkbox style="width: 18%;margin-bottom: 3%"
v-for="(item,index) in clientType"
:key="item.dictKey"
:label="item.dictKey"
>{{item.dictValue}}
<el-input type="number" v-model="item.remark" placeholder="请输入费用" :disabled = "this.form?.freightMark?.indexOf(item.dictKey) == -1"
@change="textbox($event,index)" style="width: 70%"/>
</el-checkbox>
</el-checkbox-group>
</el-form-item>
</el-col>
<el-col :span="24">
<el-form-item label="费用合计" prop="totalCost">
<el-input v-model="form.totalCost" placeholder="请输入费用合计"/>
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="24">
<el-form-item label="物品明细" prop="certificateType">
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="提货证件" prop="totalCost" label-width ='120px'>
<el-upload
v-model:file-list="fileList"
class="upload-demo"
:action="action"
:headers="headers"
multiple
:on-preview="handlePreview"
:on-remove="handleRemove"
list-type="picture"
>
<el-button type="primary">上传</el-button>
<template #tip>
<div class="el-upload__tip">
只能上传jpg/png文件且不超过500kb
</div>
</template>
</el-upload>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="文员确定图片" prop="totalCost" label-width ='120px'>
<el-upload
v-model:file-list="fileList"
class="upload-demo"
action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15"
:on-preview="handlePreview"
:on-remove="handleRemove"
list-type="picture"
>
<el-button type="primary">上传</el-button>
<template #tip>
<div class="el-upload__tip">
只能上传jpg/png文件且不超过500kb
</div>
</template>
</el-upload>
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="库管签收图片" prop="totalCost" label-width ='120px'>
<el-upload
v-model:file-list="fileList"
class="upload-demo"
action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15"
:on-preview="handlePreview"
:on-remove="handleRemove"
list-type="picture"
>
<el-button type="primary">上传</el-button>
<template #tip>
<div class="el-upload__tip">
只能上传jpg/png文件且不超过500kb
</div>
</template>
</el-upload>
</el-form-item>
</el-col>
</el-row>
</el-form>
&lt;!&ndash; 表单按钮 &ndash;&gt;
<div class="foot" v-if="!view" >
<div class="dialog-footer" >
<el-button type="primary" icon="el-icon-circle-check" @click="handleSubmit('form')"> </el-button>
&lt;!&ndash; <el-button icon="el-icon-circle-close" @click="box = false"> </el-button>&ndash;&gt;
</div>
</div>
</div>-->
</basic-container>
</template>
<script>
import { getList, getDetail, add, update, remove } from "@/api/distribution/distrilbutionBillLading";
import option from "@/option/distribution/distrilbutionBillLading";
import { mapGetters } from "vuex";
import { getDictionaryBiz } from '@/api/system/dict';
import { getToken } from '@/utils/auth';
export default {
data () {
return {
height: 0,
//
title: '',
//
box: false,
//
search: true,
//
loading: true,
//
view: false,
//
query: {},
//
page: {
currentPage: 1,
pageSize: 10,
total: 40
},
//
form: {},
//
selectionList: [],
//
option: option,
//
data: [],
clientType: [],
costList: [],
costListName: [],
certificateType: [],
fileList:[ {
name: 'food.jpeg',
url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
},
{
name: 'food2.jpeg',
url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
},]
}
},
mounted () {
this.init();
this.onLoad(this.page);
},
computed: {
...mapGetters(["permission",'tagWel','tagList']),
ids () {
let ids = [];
this.selectionList.forEach(ele => {
ids.push(ele.id);
});
return ids.join(",");
},
headers() {
return {
"Blade-Auth":'Bearer ' + getToken()
}
},
action() {
return '/api/logpm-basicdata/common/uploadFile'
// return '/api/blade-resource/oss/endpoint/put-file-attach'
}
},
methods: {
handleRemove(file, fileList) {
console.log(file, fileList);
},
handlePreview(file) {
console.log(file);
},
textbox(e,index) {
console.log("e,index",e,index);
this.costList[index+1] = e;
},
handleCheckedCitiesChange(value) {
console.log(">>>>>>>",value );
if(value.length < 1){
this.costList = [];
this.costListName = [];
}
this.clientType.forEach(i =>{
if(value.includes(i.dictKey)){
console.log(i);
i.pitch = true;
this.costListName = value;
}
});
},
init () {
this.height = this.setPx(document.body.clientHeight - 160);
//
getDictionaryBiz('delivery_cost').then(res => {
this.clientType = res.data.data;
}); //
getDictionaryBiz('certificate_type').then(res => {
this.certificateType = res.data.data;
});
},
searchHide () {
this.search = !this.search;
},
searchChange () {
this.onLoad(this.page);
},
searchReset () {
this.query = {};
this.page.currentPage = 1;
this.onLoad(this.page);
},
bianLier(costListName,clientType,costList,fei){
console.log(">>>>>>>>>",costListName,clientType,costList,fei);
this.pan = false;
for (let i = 0;i< costListName.length;i++){
if(!costList){ this.pan = true; return }
for(let a = 0;a < clientType.length;a++){
// console.log("",clientType[a].dictKey , costListName[i]);
if(clientType[a].dictKey == costListName[i]){
console.log("进来了",clientType[a].dictKey , costListName[i]);
let zhi = costList[costListName[i]];
if(!zhi){
this.pan = true;
continue;
}else{
//2.
fei.set(clientType[a].dictKey,zhi);
}
}
}
}
},
async handleSubmit () {
if (!this.form.id) {
let fei = new Map();
await this.bianLier(this.costListName,this.clientType,this.costList,fei);
this.form.fei = Object.fromEntries(fei);
this.form.stockArticleId = this.$route.query.ids;
console.log("this.form",this.form);
add(this.form).then(() => {
this.box = false;
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
this.contextmenuFlag = false;
this.$store.commit('DEL_TAG_CURRENT');
this.$router.push(this.tagWel);
});
} else {
update(this.form).then(() => {
this.box = false;
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
})
}
},
handleAdd () {
this.title = '新增'
this.form = {}
this.box = true
},
handleEdit (row) {
this.title = '编辑'
this.box = true
getDetail(row.id).then(res => {
this.form = res.data.data;
});
},
handleView (row) {
this.title = '查看'
this.view = true;
this.box = true;
getDetail(row.id).then(res => {
this.form = res.data.data;
});
},
handleDelete () {
if (this.selectionList.length === 0) {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择数据删除?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return remove(this.ids);
})
.then(() => {
this.selectionClear();
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
rowDel (row) {
this.$confirm("确定将选择数据删除?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return remove(row.id);
})
.then(() => {
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
beforeClose (done) {
done()
this.form = {};
this.view = false;
},
selectionChange (list) {
this.selectionList = list;
},
selectionClear () {
this.selectionList = [];
// this.$refs.table.clearSelection();
},
currentChange (currentPage) {
this.page.currentPage = currentPage;
this.onLoad(this.page);
},
sizeChange (pageSize) {
this.page.pageSize = pageSize;
this.onLoad(this.page);
},
onLoad (page, params = {}) {
this.loading = true;
getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
const data = res.data.data;
this.page.total = data.total;
this.data = data.records;
this.loading = false;
this.selectionClear();
});
}
}
};
</script>
<style >
.foot {
position: fixed;
right: 0;
bottom: 0;
left: 0;
z-index: 999;
height: 60px;
}
.foot .dialog-footer {
margin-bottom: 130px;
text-align: center;
}
.ca .el-radio__inner {
top: -18px;
left: -19px;
border-radius: 0;
border: 0;
width: 170px;
height: 34px;
background-color: transparent;
cursor: pointer;
box-sizing: border-box;
position: absolute;
}
.ca .el-radio__input.is-checked .el-radio__inner {
background: transparent;
}
</style>
Loading…
Cancel
Save