Browse Source

Squashed commit of the following:

commit 905bffef83
Merge: f40f2ec 08b1e3c
Author: big-y <804609860@qq.com>
Date:   Wed Aug 30 15:12:10 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit f40f2ec43b
Author: big-y <804609860@qq.com>
Date:   Wed Aug 30 15:11:51 2023 +0800

    产品包配置回显问题已调整完成

commit 08b1e3c369
Merge: bdcb96d 1db8162
Author: caoyizhong <1270296080@qq.com>
Date:   Wed Aug 30 14:35:59 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit bdcb96d90c
Author: caoyizhong <1270296080@qq.com>
Date:   Wed Aug 30 14:35:52 2023 +0800

    添加全部订单记录

commit 1db8162b7e
Author: 0.0 <1092404103.qq.com>
Date:   Wed Aug 30 11:04:35 2023 +0800

    1.仓库权限

commit e20a7de5db
Author: pref_mail@163.com <123456>
Date:   Tue Aug 29 22:30:16 2023 +0800

    修复预约

commit ec972fcd59
Author: kilo <wan.ren@foxmail.com>
Date:   Tue Aug 29 21:41:01 2023 +0800

    页面调整

commit 357d9cebd7
Author: caoyizhong <1270296080@qq.com>
Date:   Tue Aug 29 17:31:04 2023 +0800

    添加订单可空格查询

commit 7d75a1cf64
Author: pref_mail@163.com <123456>
Date:   Tue Aug 29 17:14:26 2023 +0800

    修改运单显示字段

commit 21771e8699
Author: 0.0 <1092404103.qq.com>
Date:   Tue Aug 29 17:08:25 2023 +0800

    1.禁用

commit d52dccc927
Merge: 42ee206 ea10e1c
Author: caoyizhong <1270296080@qq.com>
Date:   Tue Aug 29 11:15:07 2023 +0800

    Merge remote-tracking branch 'origin/dev' into dev

commit 42ee2067e0
Author: caoyizhong <1270296080@qq.com>
Date:   Tue Aug 29 11:14:32 2023 +0800

    修改班组人员添加

# Conflicts:
#	src/views/basicdata/team/basicdataTeamStaff.vue
fix_bug_pro20231227
zhangsiyu 2 years ago
parent
commit
0afad7e38a
  1. 18
      src/api/basicdata/basicdataGoodsArea.js
  2. 18
      src/api/basicdata/basicdataGoodsShelf.js
  3. 13
      src/api/distribution/distributionStockArticle.js
  4. 8
      src/option/basicdata/basicdataGoodsArea.js
  5. 2
      src/option/basicdata/basicdataGoodsShelf.js
  6. 18
      src/router/views/index.js
  7. 17
      src/views/basicdata/team/basicdataTeamGroup.vue
  8. 151
      src/views/basicdata/warehouse/goodsArea/basicdataGoodsArea.vue
  9. 150
      src/views/basicdata/warehouse/goodsShelf/basicdataGoodsShelf.vue
  10. 2
      src/views/distribution/deliverylist/distributionDeliveryListdis.vue
  11. 318
      src/views/distribution/deliverylist/distributionDeliveryListedt.vue
  12. 2
      src/views/distribution/deliverylist/distributionDeliveryListmar.vue
  13. 7
      src/views/distribution/inventory/delivery/distributionStockArticle.vue
  14. 5
      src/views/distribution/inventory/delivery/distributionStockArticleDiscuss.vue
  15. 5
      src/views/distribution/inventory/delivery/distributionStockArticleMarket.vue
  16. 5
      src/views/distribution/inventory/delivery/distributionStockArticleSelf.vue
  17. 1642
      src/views/distribution/inventory/delivery/distributionStockArticleWhole.vue
  18. 25
      src/views/distribution/inventory/distributionStockArticleDetails.vue
  19. 6
      src/views/distribution/reservation/reservation.vue
  20. 355
      src/views/distribution/reservation/reservationAddFrom.vue
  21. 5
      src/views/distribution/stockup/distributionStockup.vue
  22. 3
      src/views/distribution/stockup/distributionStockupSelf.vue
  23. 126
      src/views/distribution/turndelivery/deliveryDiscuss.vue
  24. 2
      src/views/reservation/order_list.vue
  25. 6
      src/views/system/tenant.vue
  26. 15
      src/views/warehouse/warehouseStock/warehouseStock.vue
  27. 6
      src/views/warehouse/warehouseWaybill.vue

18
src/api/basicdata/basicdataGoodsArea.js

@ -41,6 +41,24 @@ export const remove = (ids) => {
}
})
}
export const disable = (ids) => {
return request({
url: '/api/logpm-basicdata/goodsArea/disable',
method: 'post',
params: {
ids,
}
})
}
export const enable = (ids) => {
return request({
url: '/api/logpm-basicdata/goodsArea/enable',
method: 'post',
params: {
ids,
}
})
}
export const add = (row) => {
return request({

18
src/api/basicdata/basicdataGoodsShelf.js

@ -31,6 +31,24 @@ export const remove = (ids) => {
}
})
}
export const disable = (ids) => {
return request({
url: '/api/logpm-basicdata/goodsShelf/disable',
method: 'post',
params: {
ids,
}
})
}
export const enable = (ids) => {
return request({
url: '/api/logpm-basicdata/goodsShelf/enable',
method: 'post',
params: {
ids,
}
})
}
export const add = (row) => {
return request({

13
src/api/distribution/distributionStockArticle.js

@ -11,6 +11,17 @@ export const getList = (current, size, params) => {
}
})
}
export const getListStockArticleWhole = (current, size, params) => {
return request({
url: '/api/logpm-distribution/distributionStockArticle/listWhole',
method: 'get',
params: {
...params,
current,
size,
}
})
}
/**
* 查询客户的订单列表
@ -213,7 +224,7 @@ export const selectDiscussStockArticleInfoList = (current, size, params,delivery
})
}
export const selectUpdateAvailableStockArticle = (current, size,params) => {
export const selectUpdateAvailableStockArticle = (current, size, params) => {
return request({
url: '/api/logpm-distribution/reservation/selectUpdateAvailableStockArticle',
method: 'get',

8
src/option/basicdata/basicdataGoodsArea.js

@ -57,16 +57,10 @@ export default {
label: "货区名称",
prop: "headline",
},
{
label: "创建人名称",
prop: "createUserName",
display: false,
hide: true,
},
{
label: "货区状态",
prop: "enableStatus",
hide:true,
hide:false,
},
// {
// label: "预留1",

2
src/option/basicdata/basicdataGoodsShelf.js

@ -117,7 +117,7 @@ export default {
{
label: "启用状态",
prop: "enableStatus",
hide:true,
hide:false,
},
// {
// label: "货位名称",

18
src/router/views/index.js

@ -908,6 +908,24 @@ export default [
},
],
},
{
path: '/basicdata/team/basicdataTeamStaff',
component: Layout,
redirect: '/team/basicdataTeamStaffl',
children: [
{
path: '/basicdata/team/basicdataTeamStaff',
name: '班组列表',
meta: {
i18n: 'dict',
},
props: route => ({
id: route.query.id
}),
component: () => import('@/views/basicdata/team/basicdataTeamStaff.vue'),
},
],
},
// {
// path: 'basicdata/goodsShelf/basicdataGoodsShelfView',
// component: Layout,

17
src/views/basicdata/team/basicdataTeamGroup.vue

@ -41,7 +41,7 @@
: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 v-if="option.index" label="序号" type="index" width="70" align="center">
</el-table-column>
<template v-for="(item,index) in option.column">
<!-- table字段 -->
@ -56,6 +56,7 @@
<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-view" @click="handleList(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>
@ -330,6 +331,20 @@ export default {
}
},
//
handleList(row){
console.log("班组信息",row);
this.$router.push({
path: '/basicdata/team/basicdataTeamStaff',
query: {
id: row.id,
name: '班组人员 - ' + row.groupName,
type: '2'
}
});
},
async handleEdit (row) {
//
await this.getWarehouseList();

151
src/views/basicdata/warehouse/goodsArea/basicdataGoodsArea.vue

@ -53,6 +53,8 @@
<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>
<el-button type="danger" icon="el-icon-delete" @click="handleDisable" plain> </el-button>
<el-button type="danger" icon="el-icon-delete" @click="handleEnable" plain> </el-button>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
@ -102,7 +104,9 @@
<el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>
<el-button type="primary" text icon="el-icon-view" @click="handleExport(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>
<el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>
<!-- <el-button type="primary" text icon="el-icon-delete" v-if="row.enableStatus=='启用'" @click="rowDis(row)">禁用</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-delete" v-if="row.enableStatus=='禁用'" @click="rowEna(row)">启用</el-button>-->
</template>
</el-table-column>
</el-table>
@ -182,18 +186,18 @@
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="仓库:" prop="warehouseId" v-if="isShow" label-width="110px">
<el-select v-model="form.warehouseId" filterable placeholder="请选择仓库" style="width: 70%" >
<el-option
v-for="item in allWarehouse"
:key="item.id"
:label="item.name"
:value="item.id">
</el-option>
</el-select>
</el-form-item>
</el-col>
<!-- <el-col :span="12">-->
<!-- <el-form-item label="仓库:" prop="warehouseId" v-if="isShow" label-width="110px">-->
<!-- <el-select v-model="form.warehouseId" filterable placeholder="请选择仓库" style="width: 70%" >-->
<!-- <el-option-->
<!-- v-for="item in allWarehouse"-->
<!-- :key="item.id"-->
<!-- :label="item.name"-->
<!-- :value="item.id">-->
<!-- </el-option>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
<!-- </el-col>-->
</el-row>
</el-form>
<!-- 表单按钮 -->
@ -209,7 +213,7 @@
</template>
<script>
import { getList, getDetail, add, update, remove } from "@/api/basicdata/basicdataGoodsArea";
import { getList, getDetail, add, update, remove,enable ,disable} from "@/api/basicdata/basicdataGoodsArea";
import option from "@/option/basicdata/basicdataGoodsArea";
import { mapGetters } from "vuex";
import {getDictionaryBiz} from '@/api/system/dict';
@ -279,12 +283,9 @@ export default {
},
created() {
this.getListInfo();
},
mounted () {
this.init();
this.onLoad(this.page);
},
computed: {
...mapGetters(["permission"]),
@ -308,6 +309,7 @@ export default {
getDictionaryBiz( 'enable_status').then(res => {
this.enableStatus = res.data.data;
this.onLoad(this.page);
});
//
getWarehouseList().then(res=>{
@ -430,7 +432,7 @@ export default {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择数据删除?", {
this.$confirm("确定将选择仓库删除?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
@ -447,6 +449,50 @@ export default {
});
});
},
handleDisable () {
if (this.selectionList.length === 0) {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择仓库禁用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return disable(this.ids);
})
.then(() => {
this.selectionClear();
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
handleEnable () {
if (this.selectionList.length === 0) {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择仓库启用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return enable(this.ids);
})
.then(() => {
this.selectionClear();
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
rowDel (row) {
this.$confirm("确定将选择数据删除?", {
confirmButtonText: "确定",
@ -464,6 +510,40 @@ export default {
});
});
},
rowDis (row) {
this.$confirm("确定将选择仓库禁用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return disable(row.id);
})
.then(() => {
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
rowEna (row) {
this.$confirm("确定将选择仓库启用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return enable(row.id);
})
.then(() => {
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
beforeClose (done) {
done()
this.form = {};
@ -490,25 +570,26 @@ export default {
const data = res.data.data;
data.records.forEach(item=>{
//
// this.enableStatus.forEach(status=>{
// status.dictKey = parseInt(status.dictKey);
// if (item.enableStatus === status.dictKey){
// item.enableStatus = status.dictValue;
// }
// })
console.log(">>>>>>>",item);
if (item.enableStatus===1)
item.enableState =true;
else
item.enableState=false;
//
this.areaTypeData.forEach(areaType=>{
areaType.dictKey = parseInt(areaType.dictKey);
if (item.areaType === areaType.dictKey){
item.areaType = areaType.dictValue;
this.enableStatus.forEach(status=>{
if (item.enableStatus == status.dictKey){
item.enableStatus = status.dictValue;
}
console.log("item.enableStatus>>>>>",item.enableStatus);
console.log(" status.dictKey>>>>>", status.dictKey);
})
// if (item.enableStatus===1)
// item.enableState =true;
// else
// item.enableState=false;
//
// this.areaTypeData.forEach(areaType=>{
// areaType.dictKey = parseInt(areaType.dictKey);
// if (item.areaType === areaType.dictKey){
// item.areaType = areaType.dictValue;
// }
// })
})
this.page.total = data.total;
this.data = data.records;

150
src/views/basicdata/warehouse/goodsShelf/basicdataGoodsShelf.vue

@ -51,6 +51,8 @@
<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>
<el-button type="danger" icon="el-icon-delete" @click="handleDisable" plain> </el-button>
<el-button type="danger" icon="el-icon-delete" @click="handleEnable" plain> </el-button>
<!-- <el-button type="danger" icon="el-icon-delete" @click="aaa" plain>导出二维码</el-button>-->
<!-- <el-button type="danger" icon="el-icon-delete" @click="viewQrCode" plain>查看二维码</el-button>-->
@ -105,6 +107,8 @@
<el-button type="primary" text icon="el-icon-edit" @click="handleEdit(row)">编辑</el-button>
<el-button type="primary" text icon="el-icon-edit" @click="addAllocation(row)"> </el-button>
<el-button type="primary" text icon="el-icon-edit" @click="locationList(row)"> </el-button>
<!-- <el-button type="primary" text icon="el-icon-delete" v-if="row.enableStatus=='启用'" @click="rowDis(row)">禁用</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-delete" v-if="row.enableStatus=='禁用'" @click="rowEna(row)">启用</el-button>-->
<!-- <el-button type="primary" text icon="el-icon-edit" @click="enableStatus(row)">-->
<!-- <span v-if="row.enableStatus === '启用'">禁用</span>-->
<!-- <span v-else>启用</span>-->
@ -144,31 +148,31 @@
<!-- 表单字段 -->
<el-row>
<el-col :span="12" v-if="idShowStatus && !allocation" >
<el-form-item label="启用状态:" prop="enableStatus" label-width="100px" >
<!-- <el-input v-model="form.areaStatus" placeholder="请输入货区状态;1-启用,2-禁用"/>-->
<el-select v-model="form.enableStatus" clearable placeholder="请选择货区状态" style="width: 88%" >
<el-option
v-for="item in enableStatusData"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey">
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12" v-if="idShowStatus && !allocation" >
<el-form-item label="货架状态:" prop="goodsShelfStatus" label-width="100px" >
<el-select v-model="form.goodsShelfStatus" clearable placeholder="请选择货架状态" style="width: 88%" >
<el-option
v-for="item in goodsShelfStatusData"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey">
</el-option>
</el-select>
</el-form-item>
</el-col>
<!-- <el-col :span="12" v-if="idShowStatus && !allocation" >-->
<!-- <el-form-item label="启用状态:" prop="enableStatus" label-width="100px" >-->
<!-- &lt;!&ndash; <el-input v-model="form.areaStatus" placeholder="请输入货区状态;1-启用,2-禁用"/>&ndash;&gt;-->
<!-- <el-select v-model="form.enableStatus" clearable placeholder="请选择货区状态" style="width: 88%" >-->
<!-- <el-option-->
<!-- v-for="item in enableStatusData"-->
<!-- :key="item.dictKey"-->
<!-- :label="item.dictValue"-->
<!-- :value="item.dictKey">-->
<!-- </el-option>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
<!-- </el-col>-->
<!-- <el-col :span="12" v-if="idShowStatus && !allocation" >-->
<!-- <el-form-item label="货架状态:" prop="goodsShelfStatus" label-width="100px" >-->
<!-- <el-select v-model="form.goodsShelfStatus" clearable placeholder="请选择货架状态" style="width: 88%" >-->
<!-- <el-option-->
<!-- v-for="item in goodsShelfStatusData"-->
<!-- :key="item.dictKey"-->
<!-- :label="item.dictValue"-->
<!-- :value="item.dictKey">-->
<!-- </el-option>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
<!-- </el-col>-->
<el-col :span="12" v-if="!allocation">
<el-form-item label="货架名称:" prop="goodsShelfName" label-width="100px" >
<el-input v-model="form.goodsShelfName" placeholder="请输入货架名称" style="width: 88%;"/>
@ -300,7 +304,7 @@
</template>
<script>
import { getList, getDetail, add, update, remove,getQRCodeImg,getShowTemplate,getPrintTemplate,addAllocation } from "@/api/basicdata/basicdataGoodsShelf";
import { getList, getDetail, add, update, remove,getQRCodeImg,getShowTemplate,getPrintTemplate,addAllocation,disable,enable } from "@/api/basicdata/basicdataGoodsShelf";
import {getList as allgetList,update as allupdate} from "@/api/basicdata/basicdataGoodsAllocation";
import option from "@/option/basicdata/basicdataGoodsShelf";
import { mapGetters } from "vuex";
@ -399,7 +403,7 @@ export default {
type: "cascader",
labelWidth:'100',
clearable:true,
placeholder:'仓库/货区/货架',
placeholder:'仓库/货区',
dicUrl: '/api/logpm-basicdata/goodsAllocation/getNode',
// dicData:dicData ,
props: {
@ -619,12 +623,8 @@ export default {
this.goodsShelfStatusData = res.data.data;
});
getGoodsAreaNodeList().then(res=>{
console.log("res>>>>>>>>>>>>>>",res);
const data = this.formatCascaderData(res.data.data);
console.log("data>>>>>>>>>>>>>>",data);
this.optioner = data
console.log(">>>>>>>>>>>>>>>>optioner",this.optioner);
})
getTemplateData("9").then(res=>{
console.log(res.data.data);
@ -812,7 +812,7 @@ export default {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择数据删除?", {
this.$confirm("确定将选择货架删除?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
@ -829,6 +829,84 @@ export default {
});
});
},
handleDisable () {
if (this.selectionList.length === 0) {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择数据禁用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return disable(this.ids);
})
.then(() => {
this.selectionClear();
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
handleEnable () {
if (this.selectionList.length === 0) {
this.$message.warning("请选择至少一条数据");
return;
}
this.$confirm("确定将选择货架启用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return enable(this.ids);
})
.then(() => {
this.selectionClear();
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
rowDis (row) {
this.$confirm("确定将选择货架禁用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return disable(row.id);
})
.then(() => {
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
rowEna (row) {
this.$confirm("确定将选择货架启用?", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning"
})
.then(() => {
return enable(row.id);
})
.then(() => {
this.onLoad(this.page);
this.$message({
type: "success",
message: "操作成功!"
});
});
},
//
viewQrCode(){
if (this.selectionList.length === 0) {
@ -968,14 +1046,14 @@ export default {
}
Object.assign(this.query,ids)
}
getList(page.currentPage, page.pageSize, Object.assign(params, this.query )).then(res=>{
getList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res=>{
const data = res.data.data;
console.log(">>>>>",data);
data.records.forEach((item,index)=>{
if (item.enableStatus===1){
item.enableState=true;
if (item.enableStatus==1){
item.enableStatus='启用';
}else {
item.enableState=false;
item.enableStatus='禁用';
}
this.goodsShelfStatusData.forEach(goodsShelfStatus=>{
if (item.goodsShelfStatus === goodsShelfStatus.sort){

2
src/views/distribution/deliverylist/distributionDeliveryListdis.vue

@ -346,7 +346,7 @@ export default {
},
{
prop: 'typeName',
label: '配送类',
label: '配送类',
type: 1,
values: '',
width: '180',

318
src/views/distribution/deliverylist/distributionDeliveryListedt.vue

@ -70,43 +70,43 @@
</el-col>
</el-row>
<el-row style="margin-bottom: 1%">
<!-- 列表模块 -->
<el-table
ref="table"
v-loading="loading"
@selection-change="selectionChange"
:data="data"
style="width: 100%"
:border="option.border"
>
<template v-for="(item, index) in option.columnTakeOver">
<!-- table字段 -->
<el-table-column
v-if="item.hide !== true"
:prop="item.prop"
:label="item.label"
:width="item.width"
:key="index"
<el-row style="margin-bottom: 1%">
<!-- 列表模块 -->
<el-table
ref="table"
v-loading="loading"
@selection-change="selectionChange"
:data="data"
style="width: 100%"
:border="option.border"
>
</el-table-column>
</template>
<!-- &lt;!&ndash; 操作栏模块 &ndash;&gt;
<el-table-column prop="menu" label="操作" :width="220" align="center">
<template #="{ row }">
&lt;!&ndash; <el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>&ndash;&gt;
<el-button
type="primary"
text
icon="el-icon-edit"
@click="handleCallDelivery('3', row)"
>编辑</el-button
>
&lt;!&ndash; <el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>&ndash;&gt;
</template>
</el-table-column>-->
</el-table>
</el-row>
<template v-for="(item, index) in option.columnTakeOver">
<!-- table字段 -->
<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 }">
&lt;!&ndash; <el-button type="primary" text icon="el-icon-view" @click="handleView(row)">查看</el-button>&ndash;&gt;
<el-button
type="primary"
text
icon="el-icon-edit"
@click="handleCallDelivery('3', row)"
>编辑</el-button
>
&lt;!&ndash; <el-button type="primary" text icon="el-icon-delete" @click="rowDel(row)">删除</el-button>&ndash;&gt;
</template>
</el-table-column>-->
</el-table>
</el-row>
<el-divider>订单列表</el-divider>
<!-- <el-row>-->
@ -131,8 +131,8 @@
style="width: 100%"
:border="option.border"
>
<!-- align="center"-->
<el-table-column type="expand" v-if="option.expand" ></el-table-column>
<!-- align="center"-->
<el-table-column type="expand" v-if="option.expand"></el-table-column>
<template v-for="(item,index) in option.column">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
@ -141,17 +141,18 @@
:show-overflow-tooltip="true"
:width="item.width"
:key="index">
<!-- :align="center"-->
<!-- :align="center"-->
</el-table-column>
</template>
<!-- 操作栏模块 -->
<!-- align="center"-->
<el-table-column prop="menu" label="操作" :width="250" >
<!-- align="center"-->
<el-table-column prop="menu" label="操作" :width="250">
<template #="{row}">
<el-button type="primary" text icon="el-icon-view" @click="handleView(row)">
</el-button>
<el-button type="primary" text icon="el-icon-view" @click="handleCallDelivery('3', row)"> 辑收货人信息
<el-button type="primary" text icon="el-icon-view"
@click="handleCallDelivery('3', row)">
</el-button>
<!-- <el-button size="small" @click="handleEdit(slotProps.scope)"> </el-button>-->
<el-button type="primary" text icon="el-icon-view" @click="handleOne(row)"
@ -179,8 +180,8 @@
style="width: 100%"
:border="option.border"
>
<!-- align="center"-->
<el-table-column type="expand" v-if="ordoption.expand" ></el-table-column>
<!-- align="center"-->
<el-table-column type="expand" v-if="ordoption.expand"></el-table-column>
<template v-for="(item,index) in ordoption.column">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
@ -189,8 +190,8 @@
:show-overflow-tooltip="true"
:width="item.width"
:key="index">
<!-- :align="center"
-->
<!-- :align="center"
-->
</el-table-column>
</template>
</el-table>
@ -205,9 +206,9 @@
style="width: 100%"
:border="option.border"
>
<!-- align="center"-->center
<!-- align="center"-->center
<el-table-column type="expand" v-if="wrapoption.expand" ></el-table-column>
<el-table-column type="expand" v-if="wrapoption.expand"></el-table-column>
<template v-for="(item,index) in wrapoption.column">
<!-- table字段 -->
<el-table-column v-if="item.hide!==true"
@ -216,7 +217,7 @@
:show-overflow-tooltip="true"
:width="item.width"
:key="index">
<!-- :align="center"-->
<!-- :align="center"-->
</el-table-column>
</template>
@ -257,7 +258,7 @@
:show-overflow-tooltip="true"
:width="item.width"
:key="index">
<!-- :align="center"-->
<!-- :align="center"-->
</el-table-column>
</template>
@ -291,31 +292,57 @@
<!-- </el-pagination>-->
</div>
</el-row>
<el-dialog v-model="dialogFormCustomer" title="修改客户信息">
<el-form :model="formCustomer">
<el-form-item label="姓名" :label-width="formLabelWidth">
<el-input v-model="formCustomer.consignee" autocomplete="off" />
</el-form-item>
<el-form-item label="电话" :label-width="formLabelWidth">
<el-input v-model="formCustomer.deliveryPhone" autocomplete="off" />
</el-form-item>
<el-form-item label="地址" :label-width="formLabelWidth">
<el-input
v-model="formCustomer.deliveryAddress"
:rows="2"
type="textarea"
placeholder="请填写地址"
/>
</el-form-item>
</el-form>
<template #footer>
<el-dialog v-model="dialogFormCustomer" title="修改客户信息">
<el-form :model="formCustomer">
<el-form-item label="姓名" :label-width="formLabelWidth">
<el-input v-model="formCustomer.consignee" autocomplete="off"/>
</el-form-item>
<el-form-item label="电话" :label-width="formLabelWidth">
<el-input v-model="formCustomer.deliveryPhone" autocomplete="off"/>
</el-form-item>
<el-form-item label="地址" :label-width="formLabelWidth">
<el-input
v-model="formCustomer.deliveryAddress"
:rows="2"
type="textarea"
placeholder="请填写地址"
/>
</el-form-item>
<el-form-item label="加急" :label-width="formLabelWidth">
<el-radio-group v-model="formCustomer.isUrgent" >
<el-radio
:label="'1'" :value="'1'">
</el-radio>
<el-radio
:label="'2'" :value="'2'" >
</el-radio>
</el-radio-group>
</el-form-item>
<!-- <el-form-item label="加急:" prop="serveType" >-->
<!-- &lt;!&ndash; v-for="item in this.deliveryWayData"&ndash;&gt;-->
<!-- <el-radio-group v-model="form.isUrgent" v-for="item in this.whetherData">-->
<!-- <el-radio :label="3"></el-radio>-->
<!-- <el-radio :label="6"></el-radio>-->
<!-- </el-radio-group>-->
<!-- </el-form-item>-->
<!-- <br/>-->
<el-form-item label="备注" :label-width="formLabelWidth">
<el-input
v-model="formCustomer.remarks"
:rows="2"
type="textarea"
placeholder="请填写备注"
/>
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogFormCustomer = false">取消</el-button>
<!-- <el-button type="primary" @click="dialogFormVisible = false"> 确定 </el-button>-->
<!-- <el-button type="primary" @click="dialogFormVisible = false"> 确定 </el-button>-->
<el-button type="primary" @click="callFordelivery('3')"> 确定 </el-button>
</span>
</template>
</el-dialog>
</template>
</el-dialog>
<!-- 表单模块 -->
<el-dialog :title="title"
v-model="box"
@ -337,7 +364,7 @@
:show-overflow-tooltip="true"
:width="item.width"
:key="index">
<!-- :align="center"-->
<!-- :align="center"-->
</el-table-column>
</template>
@ -345,15 +372,15 @@
<div class="avue-crud__pagination" style="width:100%">
<!-- 分页模块 -->
<el-pagination
background
@size-change="wsizeChange"
@current-change="wcurrentChange"
:current-page="wpage.currentPage"
:page-sizes="[10, 20, 30, 40, 50, 100]"
:page-size="wpage.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="wpage.total">
<!-- :align="center"-->
background
@size-change="wsizeChange"
@current-change="wcurrentChange"
:current-page="wpage.currentPage"
:page-sizes="[10, 20, 30, 40, 50, 100]"
:page-size="wpage.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="wpage.total">
<!-- :align="center"-->
</el-pagination>
</div>
<!-- 表单按钮 -->
@ -535,14 +562,21 @@
width: '100px'
},
{
label: '是否加急',
prop: 'isUrgent',
label: '签收件数',
prop: 'receivedQuantity',
search: true,
width: '100px'
},
{
label: '签收件数',
prop: 'receivedQuantity',
label: '备注',
prop: 'remarks',
search: false,
width: '100px',
hide:true
},
{
label: '是否加急',
prop: 'isUrgentName',
search: true,
width: '100px'
},
@ -569,27 +603,32 @@
{
label: '订单自编号',
prop: 'orderIds',
search: true,
search: true
},
{
label: '收货人',
prop: 'consignee',
search: true,
search: true
},
{
label: '收货电话',
prop: 'deliveryPhone',
search: true,
search: true
},
{
label: '收货地址',
prop: 'deliveryAddress',
search: true,
search: true
},
],
{
label: '收货单位',
prop: 'receivingUnit',
search: true
}
]
},
//
@ -725,6 +764,25 @@
border: true,
selection: true,
column: [
{
label: '运单号',
prop: 'waybillNumber',
search: true,
width: '100px'
},
{
label: '服务号',
prop: 'serviceNumber',
search: true,
width: '100px'
},
{
search: true,
label: '订单自编号',
prop: 'waybillNumber',
width: '100px'
},
{
label: '包条码',
prop: 'orderPackageCode',
@ -737,6 +795,48 @@
search: true,
width: '100px'
},
{
label: '发站仓',
prop: 'sendWarehouseName',
search: true,
width: '100px'
},
{
label: '目的仓',
prop: 'acceptWarehouseName',
search: true,
width: '100px'
},
{
label: '发货时间',
prop: 'waybillNumber',
search: true,
width: '100px'
},
{
label: '入库时间',
prop: 'warehouseEntryTimeEnd',
search: true,
width: '100px'
},
// {
// label: '',
// prop: 'trainNumber',
// search: true,
// width: '100px'
// },
// {
// label: '',
// prop: 'trainNumber',
// search: true,
// width: '100px'
// },
{
label: '入库车次',
prop: 'trainNumber',
search: true,
width: '100px'
},
{
label: '一级品类',
prop: 'firsts',
@ -774,13 +874,13 @@
search: true,
width: '100px'
},
{
{
label: '冻结状态',
prop: 'orderPackageFreezeStatusName',
search: true,
width: '100px'
},
{
{
label: '上架状态',
prop: 'orderPackageGroundingStatusName',
search: true,
@ -822,7 +922,7 @@
// search: true,
// width: '150px'
// },
{
{
label: '签收扫描时间',
prop: 'scanTime',
search: true,
@ -931,7 +1031,7 @@
prop: 'readyStock',
search: true,
width: '100px'
},
}
]
},
@ -1089,7 +1189,7 @@
'$route.data': {
handler(newVal, oldVal) {
console.log(newVal, oldVal);
if (this.$router.data){
if (this.$router.data) {
this.fetchData();
}
this.onLoad(this.page);
@ -1118,18 +1218,17 @@
}
},
methods: {
callFordelivery(){
console.log("提交的数据》》》",this.formCustomer);
updateReservation(this.formCustomer).then(res =>{
console.log("返回的数据",res.data.data);
callFordelivery() {
console.log('提交的数据》》》', this.formCustomer);
updateReservation(this.formCustomer).then(res => {
console.log('返回的数据', res.data.data);
this.selectionClear();
this.onLoad(this.page);
this.$message({
type: 'success',
message: '操作成功!'
});
})
});
this.dialogFormCustomer = false;
@ -1150,10 +1249,17 @@
case '3':
this.dialogFormCustomer = true;
console.log('<><>', row);
this.formCustomer.id = row.id ;
this.formCustomer.id = row.id;
this.formCustomer.consignee = row.consignee;
this.formCustomer.deliveryPhone = row.deliveryPhone;
this.formCustomer.deliveryAddress = row.deliveryAddress;
this.formCustomer.remarks = row.remarks;
if (row.isUrgentName === '否' || row.isUrgentName === '1'){
this.formCustomer.isUrgent = '1'
}else {
this.formCustomer.isUrgent = '2'
}
break;
}
},
@ -1262,7 +1368,7 @@
if (valid) {
if (this.signtitle = '复核签收') {
let row = {};
console.log("this.signform.deliverySignPictures>>>>>>>>>",this.signform.deliverySignPictures);
console.log('this.signform.deliverySignPictures>>>>>>>>>', this.signform.deliverySignPictures);
row.id = this.signform.deliveryId;
row.deliverySignPictures = this.signform.deliverySignPictures;
row.clerkSignRemarks = this.signform.clerkSignRemarks;
@ -1516,7 +1622,7 @@
}
});
this.deliverydata.teamResponsibility = b.join(",");
this.deliverydata.teamResponsibility = b.join(',');
//this.deliverydata = data
this.data = data.reservationList;
});

2
src/views/distribution/deliverylist/distributionDeliveryListmar.vue

@ -331,7 +331,7 @@ export default {
},
{
prop: 'typeName',
label: '配送类',
label: '配送类',
type: 1,
values: '',
width: '180',

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

@ -6,7 +6,10 @@
<!-- 查询模块 -->
<el-form :inline="true" :model="query">
<el-form-item label="订单自编号:">
<el-input v-model="query.orderCode" placeholder="请输入订单自编号" ></el-input>
<el-input v-model="query.orderCodeNum" placeholder="请输入订单自编号" ></el-input>
</el-form-item>
<el-form-item label="运单">
<el-input v-model="query.waybillNum" placeholder="请输入运单编号" />
</el-form-item>
<el-form-item label="入库时间:">
<!-- <el-input v-model="query.stockupArea" placeholder="请输入备货区"></el-input>-->
@ -169,7 +172,7 @@
</el-select>
</el-form-item>
<el-form-item label="费用" :label-width="formLabelWidth">
<el-input v-model="formService.cost" autocomplete="off" placeholder="请填写费用"/>
<el-input v-model="formService.cost" autocomplete="off" placeholder="请填写费用 "/>
</el-form-item>
<el-form-item label="原因" :label-width="formLabelWidth">
<el-input

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

@ -6,7 +6,10 @@
<!-- 查询模块 -->
<el-form :inline="true" :model="query">
<el-form-item label="订单自编号:">
<el-input v-model="query.orderCode" placeholder="请输入订单自编号" ></el-input>
<el-input v-model="query.orderCodeNum" placeholder="请输入订单自编号" ></el-input>
</el-form-item>
<el-form-item label="运单">
<el-input v-model="query.waybillNum" placeholder="请输入运单编号" />
</el-form-item>
<el-form-item label="入库时间:">
<!-- <el-input v-model="query.stockupArea" placeholder="请输入备货区"></el-input>-->

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

@ -6,7 +6,10 @@
<!-- 查询模块 -->
<el-form :inline="true" :model="query">
<el-form-item label="订单自编号:">
<el-input v-model="query.orderCode" placeholder="请输入订单自编号" ></el-input>
<el-input v-model="query.orderCodeNum" placeholder="请输入订单自编号" ></el-input>
</el-form-item>
<el-form-item label="运单">
<el-input v-model="query.waybillNum" placeholder="请输入运单编号" />
</el-form-item>
<el-form-item label="入库时间:">
<!-- <el-input v-model="query.stockupArea" placeholder="请输入备货区"></el-input>-->

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

@ -6,7 +6,10 @@
<!-- 查询模块 -->
<el-form :inline="true" :model="query">
<el-form-item label="订单自编号:">
<el-input v-model="query.orderCode" placeholder="请输入订单自编号" ></el-input>
<el-input v-model="query.orderCodeNum" placeholder="请输入订单自编号" ></el-input>
</el-form-item>
<el-form-item label="运单">
<el-input v-model="query.waybillNum" placeholder="请输入运单编号" />
</el-form-item>
<el-form-item label="入库时间:">
<!-- <el-input v-model="query.stockupArea" placeholder="请输入备货区"></el-input>-->

1642
src/views/distribution/inventory/delivery/distributionStockArticleWhole.vue

File diff suppressed because it is too large Load Diff

25
src/views/distribution/inventory/distributionStockArticleDetails.vue

@ -429,8 +429,8 @@ export default {
fixed: true,
},
{
prop: 'warehouse',
label: '仓库',
prop: 'serviceNumber',
label: '服务号',
type: 2,
values: '',
width: '150',
@ -449,6 +449,27 @@ export default {
fixed: true,
sortable: true,
head: false,
}, {
prop: 'orderCode',
label: '订单自编号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouse',
label: '仓库',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageStatusName',

6
src/views/distribution/reservation/reservation.vue

@ -90,10 +90,10 @@
@selection="selectionChange"
>
<template #default="slotProps">
<el-button size="small" @click="viewReservation(slotProps.scope)">查看</el-button>
<el-button size="small" @click="editsolt(slotProps.scope)">编辑</el-button>
<el-button size="small" type="primary" link icon="el-icon-view" @click="viewReservation(slotProps.scope)">查看</el-button>
<el-button size="small" type="primary" link icon="el-icon-view" @click="editsolt(slotProps.scope)">编辑</el-button>
<br/>
<el-button size="small" @click="cancelReservation(slotProps.scope)">取消预约</el-button>
<el-button size="small" type="primary" link icon="el-icon-view" @click="cancelReservation(slotProps.scope)">取消预约</el-button>
<br/>
<!-- ${{slotProps.scope}}-->
<el-button v-if="this.query.reservationStatus==='1'?true:false " size="small" @click="confirmReservation(slotProps.scope)">确认预约</el-button>

355
src/views/distribution/reservation/reservationAddFrom.vue

@ -103,7 +103,6 @@
<!-- v-for="item in this.deliveryWayData"-->
<el-radio-group v-model="form.isUrgent" v-for="item in this.whetherData">
<el-radio
:label="item.dictKey"
:value="item.dictKey">{{item.dictValue}}&emsp;
</el-radio>
@ -117,15 +116,15 @@
<el-input v-model="form.otherFee" placeholder="请输入其他费用"/>
</el-form-item>
</el-col>
<el-col :span="10">
<el-form-item label="服务类型:" prop="serveType" label-width="120px">
<el-checkbox-group v-model="serveType" v-for="item in this.addvalueServeTypeData">
<el-checkbox :label="item.dictKey"
:value="item.dictKey">{{item.dictValue}}&emsp;
</el-checkbox>
</el-checkbox-group>
</el-form-item>
</el-col>
<!-- <el-col :span="10">-->
<!-- <el-form-item label="服务类型:" prop="serveType" label-width="120px">-->
<!-- <el-checkbox-group v-model="serveType" v-for="item in this.addvalueServeTypeData">-->
<!-- <el-checkbox :label="item.dictKey"-->
<!-- :value="item.dictKey">{{item.dictValue}}&emsp;-->
<!-- </el-checkbox>-->
<!-- </el-checkbox-group>-->
<!-- </el-form-item>-->
<!-- </el-col>-->
<el-col :span="10">
@ -591,7 +590,7 @@
// { required: true, message: '!', trigger: 'change' }
// ],
},
obj:{},
obj: {}
};
},
created() {
@ -610,7 +609,7 @@
this.onLoad(this.page);
this.getDictionary();
},
watch:{
watch: {
'$route.query.reservationId': {
handler(newVal, oldVal) {
console.log(newVal, oldVal);
@ -688,125 +687,9 @@
//
handleAddOrder() {
this.loading = true;
console.log('$$$$$$', this.orderData);
this.query.typeService = 2;
this.query.genre = '1';
const params = {};
const page = this.page;
if (this.reservationId){
console.log("------------>",'预约编辑');
//
//
// selectUpdateAvailableStockArticle(this.reservationId).then(res=>{
// console.log('res------------>', res);
// const data = res.data.data;
// this.stockArticleInfo = data
// this.stockArticleInfo.forEach((item, index) => {
// //
// this.checkOrder(item, index);
// if (this.orderData) {
// this.orderData.forEach(o => {
// if (o.id === item.id) {
// this.$nextTick(() => {
// this.$refs.orderList.toggleRowSelection(this.stockArticleInfo[index], true);
// });
// }
// });
// }else {
// this.orderList = [];
// }
// });
// })
this.onLoadEditOrder(this.page);
}else {
this.onLoadOrder(this.page);
// selectStockArticleInfoList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then( res => {
// console.log('res------------>', res);
// const data = res.data.data;
// this.stockArticleInfo = data.records;
// this.stockArticleInfo.forEach((item, index) => {
// //
// this.checkOrder(item, index);
// // if (this.orderData) {
// // this.orderData.forEach(o => {
// // if (o.id === item.id) {
// // this.$nextTick(() => {
// // this.$refs.orderList.toggleRowSelection(this.stockArticleInfo[index], true);
// // });
// // }
// // });
// // }else {
// // this.orderList = [];
// // }
// });
// this.orderList = [];
//
// });
}
//
this.onLoadOrder(this.page);
this.loading = false;
console.log("this.stockArticleInfo------------->",this.stockArticleInfo);
// if (this.reservationId) {
// //使使
// this.query.typeService = 2;
// this.query.genre = '1';
// //
// let page = this.page;
// let params = {};
// selectStockArticleInfoList(Object.assign(params, this.query)).then(res => {
// let orderListData = res.data.data;
// this.stockArticleInfo = orderListData;
// //
// let a = this.orderData;
// for (let i = 0; i < orderListData.length; i++) {
// for (let j = 0; j < a.length; j++) {
// if (orderListData[i].id === a[j].id){
// orderListData[i] = a[j];
// this.$nextTick(()=> {
// this.$refs.orderList.toggleRowSelection(this.stockArticleInfo[i],true);
// })
// }
// this.checkOrder(this.stockArticleInfo[i],i);
// }
// }
// this.loading = false;
// this.selectionClear();
// });
// } else {
// this.query.typeService = 2;
// this.query.genre = '1';
// let page = this.page;
// let params = {};
// selectStockArticleAndParcel(Object.assign(params, this.query)).then(res => {
// let orderData = res.data.data;
// orderData.forEach((item, index) => {
// item.reservationNum = item.handQuantity;
// item.reservationNum = '0';
// });
// this.stockArticleInfo = orderData;
// //
// if (this.orderData){
// this.stockArticleInfo.forEach((item,index)=>{
// this.orderData.forEach(o=>{
// if (item.id === o.id){
// this.$nextTick(()=> {
// this.$refs.orderList.toggleRowSelection(this.stockArticleInfo[index],true);
// })
// }
// })
// // if (item.reservationStatus === '30'){
// // this.$nextTick(()=> {
// // this.$refs.orderList.toggleRowSelection(this.stockArticleInfo[index],true);
// // })
// // }
// this.checkOrder(item,index);
// })
// }else {
// //
// }
// this.loading = false;
// this.selectionClear();
// });
// }
this.orderShow = true;
},
checkOrder(row, index) {
@ -930,29 +813,29 @@
console.log('>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>', row);
if (this.reservationId) {
//
let packageInfo = row.parcelListVOS
let packageInfo = row.parcelListVOS;
// this.packageData = row.parcelListVOS;
let packageListData = this.packageData;
if (row.packageList) {
let packageListInfo = row.packageList;
packageInfo.forEach((item,index)=>{
packageListInfo.forEach(p=>{
if (item.id===p.id){
this.$nextTick( ()=> {
this.$refs.packageList.toggleRowSelection(this.packageData[index],true);
})
packageInfo.forEach((item, index) => {
packageListInfo.forEach(p => {
if (item.id === p.id) {
this.$nextTick(() => {
this.$refs.packageList.toggleRowSelection(this.packageData[index], true);
});
}
})
})
}else {
});
});
} else {
//
packageInfo.forEach((item,index)=>{
this.$nextTick( ()=> {
this.$refs.packageList.toggleRowSelection(this.packageData[index],true);
})
})
packageInfo.forEach((item, index) => {
this.$nextTick(() => {
this.$refs.packageList.toggleRowSelection(this.packageData[index], true);
});
});
}
this.packageData =row.parcelListVOS;
this.packageData = row.parcelListVOS;
} else {
this.packageData = row.parcelListVOS;
//
@ -995,12 +878,11 @@
let page = this.page;
this.query.typeService = 2;
this.query.genre = 1;
if (this.reservationId){
this.onLoadEditOrder(this.page)
}else {
this.onLoadOrder(this.page)
}
// if (this.reservationId) {
// this.onLoadEditOrder(this.page);
// } else {
this.onLoadOrder(this.page);
// }
// selectStockArticleList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
// const data = res.data.data;
// data.records.forEach(item => {
@ -1042,11 +924,11 @@
this.$message.warning('请选择包件!!!');
return;
}
this.orderData.forEach(item=>{
if (item.id===this.obj.id){
this.orderData.forEach(item => {
if (item.id === this.obj.id) {
item.packageList = this.packageList;
}
})
});
console.log('this.orderData------------>', this.orderData);
this.isaddvalue = false;
},
@ -1076,11 +958,11 @@
this.form.inventoryList = inventoryList;
console.log('-------------->', this.orderData);
let order = this.orderData;
order.forEach(o=>{
if (!o.packageListInfo){
order.forEach(o => {
if (!o.packageListInfo) {
o.packageListInfo = o.packageList;
}
})
});
this.form.stockArticleList = order;
this.deliveryWayData.forEach(item => {
if (this.form.deliveryWay === item.dictValue) {
@ -1117,7 +999,7 @@
});
});
} else {
this.form.reservationStatus = '20'
this.form.reservationStatus = '20';
autonomouslySave(this.form).then(() => {
this.$message({
type: 'success',
@ -1224,12 +1106,12 @@
this.$message.warning('请选择至少一条数据');
return;
}
this.inventoryList.forEach(item=>{
if (item.reservationNum > item.applyNum){
this.inventoryList.forEach(item => {
if (item.reservationNum > item.applyNum) {
this.$message.warning('该库存品数量输入有误!!!');
return;
}
})
});
this.inventoryData = this.inventoryList;
// if (this.orderData.length) {
@ -1250,40 +1132,71 @@
*/
onSubmitOrder() {
console.log('-------------》', this.orderList);
if (this.orderList.length === 0) {
this.$message.warning('请选择至少一条数据');
return;
}
const list = this.orderList;
console.log("list--------",list);
let j = 0;
let name = list[0].customerName;
let address = list[0].customerAddress;
let phone = list[0].customerTelephone;
let name = list[0].customerName;
let address = list[0].customerAddress;
let phone = list[0].customerTelephone;
if (!!this.form.consignee) {
if (this.form.consignee !== name) {
this.$message.warning('请选择统一顾客订单!!!');
return;
}
}
if (!!this.form.customerAddress) {
if (this.form.customerAddress !== address) {
this.$message.warning('请选择统一顾客订单!!!');
return;
}
}
if (!!this.form.customerTelephone) {
if (this.form.customerTelephone !== phone) {
this.$message.warning('请选择统一顾客订单!!!');
return;
}
}
// ---
for (let i = 1; i < list.length; i++) {
if (list[i].customerName !== name || list[i].customerAddress !== address || list[i].customerTelephone !== phone){
if (list[i].customerName !== name || list[i].customerAddress !== address || list[i].customerTelephone !== phone) {
this.$message.warning('请选择统一顾客订单!!!');
return;
}
}
this.form.consignee = name;
this.form.deliveryAddress = address;
this.form.deliveryPhone = phone;
this.orderData = this.orderList;
let info = [];
// if (this.orderData){
// let a = this.orderData;
// data.forEach(item=>{
// a.forEach(order=>{
// if (item.id === order.id){
console.log("orderData----------------->",this.orderData);
// item = order;
// }
// })
// info.push(item);
// })
// }
// this.orderData = info;
//
const info = [];
this.stockArticleInfo.forEach((item, index) => {
this.orderList.forEach(order => {
// const newDate1 = this.orderData.map(item => { // map
// if (this.orderList.find(o => o.id !== item.id)) { //
// return item;
// });
// } info.push(order);
//
info.push(order);
this.stockArticleInfo.splice(index, 1);
});
});
if (this.orderData.length >= 1) {
let newDate1 = this.orderData.map(item => { // map
if (this.orderList.find(o => o.id !== item.id)) { //
return item;
}
});
console.log('newDate1-------------->', newDate1.length);
if (newDate1.length >= 1) {
console.log('newDate1-------------->', newDate1);
newDate1.forEach(a => {
this.orderData.push(a);
});
}
console.log('this.orderData------------->', this.orderData);
} else {
this.orderData = this.orderList;
}
// this.orderData.push(info);
this.orderShow = false;
},
selectionClear() {
@ -1293,28 +1206,39 @@
},
currentOrderChange(currentPage) {
this.page.currentPage = currentPage;
if (this.reservationId){
this.onLoadEditOrder(this.page,this.reservationId);
}else {
this.onLoadOrder(this.page);
}
// if (this.reservationId) {
// this.onLoadEditOrder(this.page, this.reservationId);
// } else {
// this.onLoadOrder(this.page);
// }
this.onLoadOrder(this.page);
},
sizeOrderChange(pageSize) {
this.page.pageSize = pageSize;
if (this.reservationId){
this.onLoadEditOrder(this.page,this.reservationId);
}else {
// if (this.reservationId) {
// this.onLoadEditOrder(this.page, this.reservationId);
// } else {
// this.onLoadOrder(this.page);
// }
this.onLoadOrder(this.page);
this.onLoadOrder(this.page);
}
},
onLoadEditOrder(arg,params = {}){
const page = arg;
selectUpdateAvailableStockArticle(page.currentPage, page.pageSize,this.reservationId,Object.assign(params, this.query)).then(res=>{
onLoadEditOrder(params = {}) {
this.query.typeService = 2;
this.query.genre = '1';
const page = this.page;
let a = [];
if (this.orderData) {
this.orderData.forEach(item => {
a.push(item.id);
});
}
this.query.orderIds = a.join(',');
this.query.reservationId = this.reservationId;
selectUpdateAvailableStockArticle(page.currentPage, page.pageSize, this.reservationId, Object.assign(params, this.query)).then(res => {
console.log('res------------>', res);
const data = res.data.data;
this.stockArticleInfo = data.records;
this.stockArticleInfo = data.records;
this.stockArticleInfo.forEach((item, index) => {
//
this.checkOrder(item, index);
@ -1327,24 +1251,30 @@
});
}
});
}else {
} else {
this.orderList = [];
}
});
this.page.total = data.total;
})
});
// this.query = {};
},
onLoadOrder(arg,params={}){
console.log("------------->arg",arg);
const page = arg;
console.log("------------->page",page);
selectStockArticleInfoList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then( res => {
onLoadOrder(page, params = {}) {
this.query.typeService = 2;
this.query.genre = '1';
// const page = this.page;
let a = [];
if (this.orderData) {
this.orderData.forEach(item => {
a.push(item.id);
});
}
this.query.orderIds = a.join(',');
console.log('-------------->', this.query);
selectStockArticleInfoList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
console.log('res------------>', res);
const data = res.data.data;
this.stockArticleInfo = data.records;
this.stockArticleInfo = data.records;
this.stockArticleInfo.forEach((item, index) => {
//
this.checkOrder(item, index);
@ -1362,7 +1292,6 @@
this.page.total = data.total;
});
this.orderList = [];
});
},

5
src/views/distribution/stockup/distributionStockup.vue

@ -671,8 +671,9 @@ export default {
let params ={
department: this.deptId
}
console.log("备货区参数>>>",params);
stockUp(params).then(res =>{
// console.log("res>>>",res.data.data);
console.log("备货区数据",res.data.data);
let fo =[];
res.data.data.forEach(i =>{
let v = {
@ -695,7 +696,7 @@ export default {
}
let a = false ;
this.selectionList.some(i =>{
if(i.assignStatus == "2"){
if(i.assignStatus == "20"){
a = true;
return;
}

3
src/views/distribution/stockup/distributionStockupSelf.vue

@ -736,8 +736,9 @@ export default {
let params ={
department: this.deptId
}
console.log("备货参数<><><>",params);
stockUp(params).then(res =>{
// console.log("res>>>",res.data.data);
console.log("备货区数据>>>",res.data.data);
let fo =[];
res.data.data.forEach(i =>{
let v = {

126
src/views/distribution/turndelivery/deliveryDiscuss.vue

@ -193,16 +193,16 @@
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="服务类型:" prop="serveType" label-width="100px">
<!-- <el-input v-model="form.serveType" clearable placeholder="请选择服务类型"/>-->
<el-checkbox-group v-model="serveType" v-for="item in this.addvalueServeTypeData">
<el-checkbox :label="item.dictKey" :value="item.dictKey"
>{{ item.dictValue }}&emsp;
</el-checkbox>
</el-checkbox-group>
</el-form-item>
</el-col>
<!-- <el-col :span="6">-->
<!-- <el-form-item label="服务类型:" prop="serveType" label-width="100px">-->
<!-- &lt;!&ndash; <el-input v-model="form.serveType" clearable placeholder="请选择服务类型"/>&ndash;&gt;-->
<!-- <el-checkbox-group v-model="serveType" v-for="item in this.addvalueServeTypeData">-->
<!-- <el-checkbox :label="item.dictKey" :value="item.dictKey"-->
<!-- >{{ item.dictValue }}&emsp;-->
<!-- </el-checkbox>-->
<!-- </el-checkbox-group>-->
<!-- </el-form-item>-->
<!-- </el-col>-->
</el-row>
<el-row>
<el-col :span="6">
@ -407,10 +407,10 @@
>
<el-form :inline="true" :model="query">
<el-form-item label="顾客电话:">
<el-input v-model="query.customerTelephone" placeholder="请输入服务类型"></el-input>
<el-input v-model="query.customerTelephone" placeholder="请输入顾客电话"></el-input>
</el-form-item>
<el-form-item label="顾客地址:">
<el-input v-model="query.customerAddress" placeholder="请输入服务类型"></el-input>
<el-input v-model="query.customerAddress" placeholder="请输入顾客地址"></el-input>
</el-form-item>
<!-- 查询按钮 -->
<el-form-item>
@ -1056,28 +1056,46 @@
console.log('>>>>>>>>>>>>', this.stockArticleList);
console.log('>>>>>>>>orderData', this.orderData);
const data = this.stockArticleList;
let info = [];
// if (this.orderData) {
// let a = this.orderData;
// data.forEach(item => {
// a.forEach(order => {
// if (item.id === order.id) {
// console.log('order----------------->', order);
// item = order;
// }
// });
// info.push(item);
// });
// }
data.map(item=>{
console.log(item);
this.orderData.forEach(order=>{
if (item.id !== order.id){
this.orderData.push(item);
}
const info = [];
this.stockArticleInfo.forEach((item, index) => {
this.stockArticleList.forEach(order => {
// const newDate1 = this.orderData.map(item => { // map
// if (this.orderList.find(o => o.id !== item.id)) { //
// return item;
// });
// } info.push(order);
//
info.push(order);
this.stockArticleInfo.splice(index, 1);
});
});
if (this.orderData.length >= 1) {
let newDate1 = this.orderData.map(item => { // map
if (this.stockArticleList.find(o => o.id !== item.id)) { //
return item;
}
});
console.log('newDate1-------------->', newDate1.length);
if (newDate1.length >= 1) {
console.log('newDate1-------------->', newDate1);
newDate1.forEach(a=>{
this.orderData.push(a);
})
})
// this.orderData = info;
}
console.log("this.orderData------------->",this.orderData);
} else {
this.orderData = this.stockArticleList;
}
// data.map(item=>{
// console.log(item);
// this.orderData.forEach(order=>{
// if (item.id !== order.id){
// this.orderData.push(item);
// }
// })
// })
// // this.orderData = info;
console.log('+++++++++++++++', this.orderData);
this.orderShow = false;
},
@ -1537,23 +1555,24 @@
this.query.genre = '1';
console.log('query------------->', this.query);
const page = this.page;
selectStockArticleInfoList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
console.log('------------------->', res);
const data = res.data.data;
this.stockArticleInfo = data.records;
if (this.orderData) {
this.stockArticleInfo.forEach((item, index) => {
this.orderData.forEach(order => {
if (item.id === order.id) {
console.log('----------->');
this.$nextTick(() => {
this.$refs.stockArticleTable.toggleRowSelection(this.stockArticleInfo[index], true);
});
}
});
});
}
});
this.onLoadOrder(page);
// selectStockArticleInfoList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
// console.log('------------------->', res);
// const data = res.data.data;
// this.stockArticleInfo = data.records;
// if (this.orderData) {
// this.stockArticleInfo.forEach((item, index) => {
// this.orderData.forEach(order => {
// if (item.id === order.id) {
// console.log('----------->');
// this.$nextTick(() => {
// this.$refs.stockArticleTable.toggleRowSelection(this.stockArticleInfo[index], true);
// });
// }
// });
// });
// }
// });
// selectStockArticleAndParcel(Object.assign(params,this.query)).then(res=>{
// console.log("res------------>",res.data.data);
// const data = res.data.data
@ -1626,6 +1645,13 @@
this.query.typeService = 1;
this.query.genre = '1';
const page = arg;
let a =[];
if (this.orderData){
this.orderData.forEach(item=>{
a.push(item.id)
})
}
this.query.orderIds = a.join(",");
selectStockArticleInfoList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
console.log(res.data.data);
const data = res.data.data;

2
src/views/reservation/order_list.vue

@ -969,7 +969,7 @@ export default {
// false,
if(!notEqualFlag){
this.$router.push({
path: '/distribution/reservation/reservationFrom',
path: '/distribution/reservation/order_listFrom',
query:{
id: this.ids,
}

6
src/views/system/tenant.vue

@ -128,6 +128,7 @@ import { getDetail as packageDetail } from '@/api/system/tenantpackage';
import { mapGetters } from 'vuex';
import { getMenuTree } from '@/api/system/menu';
import { validatenull } from '@/utils/validate';
import {getAppMenuTree} from "@/api/system/appmenu";
export default {
data() {
@ -375,6 +376,11 @@ export default {
const column = this.findObject(this.packageOption.column, 'menuId');
column.dicData = res.data.data;
});
getAppMenuTree().then(res => {
const columns = this.findObject(this.packageOption.column, 'appMenuId');
columns.dicData = res.data.data;
});
},
rowSave(row, done, loading) {
add(row).then(

15
src/views/warehouse/warehouseStock/warehouseStock.vue

@ -68,6 +68,17 @@ export default {
sortable: false,
head: false,
},
{
prop: 'scanNodeType',
label: '扫描详情',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: true,
sortable: false,
head: false,
},
{
prop: 'orderCode',
label: '订单自编码',
@ -181,7 +192,7 @@ export default {
{
prop: 'operatorName',
label: '操作员',
type: 2,
type: 1,
values: '',
width: '180',
checkarr: [],
@ -373,6 +384,8 @@ export default {
},
inputsc(index, row) {
console.log(index, row);
this.query[row.prop] = index;
this.onLoad(this.page);
},
init () {
this.height = this.setPx(document.body.clientHeight - 340);

6
src/views/warehouse/warehouseWaybill.vue

@ -425,7 +425,7 @@ export default {
head: false,
},
{
prop: 'destinationWarehouse',
prop: 'destinationWarehouseName',
label: '目的仓',
type: 2,
values: '',
@ -436,7 +436,7 @@ export default {
head: false,
},
{
prop: 'departureWarehouse',
prop: 'departureWarehouseName',
label: '发站仓',
type: 2,
values: '',
@ -1128,7 +1128,7 @@ export default {
for (let index = 0; index < this.orderlist.length; index++) {
const element = this.orderlist[index];
if(element.goods){
var o = element.goods[index]
var o = element.goods[0]
if(!o.splitNum){
this.$message({
type: 'waring',

Loading…
Cancel
Save