刘忱 1 year ago
parent
commit
582c17f3de
  1. 16
      api/index.js
  2. 6
      api/request.js
  3. 60
      api/request2.js
  4. 15
      common/balance.js
  5. 6
      common/basic.js
  6. 8
      common/calc.js
  7. 8
      common/classify.data.js
  8. 140
      common/detail.js
  9. 49
      common/directory.js
  10. 36
      common/record.js
  11. 8
      common/scan.js
  12. 4
      common/style/new_style.css
  13. 8
      common/style/pdabasic.css
  14. 6
      mycomponents/balance/handleBalance.vue
  15. 10
      mycomponents/balance/recommendBalance.vue
  16. 2
      mycomponents/detail/comDetailCard.vue
  17. 4
      mycomponents/item/itemDetailInfo.vue
  18. 14
      mycomponents/item/itemQty.vue
  19. 6
      mycomponents/item/itemSelect.vue
  20. 6
      mycomponents/package/packageDetailPopup.vue
  21. 6
      mycomponents/partCode/partCodeSelect.vue
  22. 40
      mycomponents/popup/selectList.vue
  23. 70
      mycomponents/qty/CountQtyEdit.vue
  24. 2
      mycomponents/qty/balanceQty.vue
  25. 24
      mycomponents/qty/balanceQtyEdit.vue
  26. 33
      mycomponents/qty/compareQty.vue
  27. 26
      mycomponents/qty/recommendQtyEdit.vue
  28. 2
      mycomponents/recommend/recommend.vue
  29. 13
      mycomponents/recommend/recommendCount.vue
  30. 10
      mycomponents/record/recordComDetailCard.vue
  31. 33
      mycomponents/scan/winComScan.vue
  32. 99
      mycomponents/scan/winScanItem.vue
  33. 134
      mycomponents/scan/winScanPackAndLocation.vue
  34. 16
      mycomponents/scan/winScanPackAndPosition.vue
  35. 3
      mycomponents/status/balanceStatus.vue
  36. 10
      mycomponents/workStation/workStation.vue
  37. 20
      pages.json
  38. 2
      pages/container/coms/comContainerBindCard.vue
  39. 4
      pages/container/coms/comPalletRecord.vue
  40. 6
      pages/container/record/containerBindRecord.vue
  41. 8
      pages/container/record/containerUnBindRecord.vue
  42. 27
      pages/count/coms/comCountDetailCard.vue
  43. 797
      pages/count/job/countDetail.vue
  44. 43
      pages/count/record/countRecord.vue
  45. 4
      pages/customerReturn/coms/comReturnRecord.vue
  46. 8
      pages/customerReturn/job/returnDetail.vue
  47. 7
      pages/customerReturn/record/returnRecord.vue
  48. 76
      pages/customerReturn/request/customerReturnRequestCreate.vue
  49. 46
      pages/deliver/coms/comDeliverRequestPopup.vue
  50. 97
      pages/deliver/coms/comScanDeliverPack.vue
  51. 59
      pages/deliver/job/deliverDetail.vue
  52. 5
      pages/deliver/record/deliverRecord.vue
  53. 8
      pages/deliver/request/deliverRequestCreate.vue
  54. 12
      pages/demo/demo.vue
  55. 2
      pages/index/index.vue
  56. 34
      pages/inspect/coms/inspectEdit.vue
  57. 22
      pages/inspect/job/inspectDetail.vue
  58. 53
      pages/inspect/job/inspectFullDetail.vue
  59. 8
      pages/inspect/job/inspectResult.vue
  60. 4
      pages/inventoryMove/coms/comMoveRecord.vue
  61. 17
      pages/inventoryMove/coms/comMoveRecordCard.vue
  62. 8
      pages/inventoryMove/job/inventoryMoveDetail.vue
  63. 2
      pages/issue-按批次推荐/coms/comIssueJobCard.vue
  64. 2
      pages/issue-按批次推荐/coms/comScanIssuePack.vue
  65. 12
      pages/issue-按批次推荐/job/issueDetail.vue
  66. 25
      pages/issue/coms/comIssueDetailCard.vue
  67. 37
      pages/issue/coms/comIssueRequestCreator.vue
  68. 271
      pages/issue/coms/comIssueRequestPopup.vue
  69. 38
      pages/issue/coms/comScanIssuePack.vue
  70. 100
      pages/issue/job/issueDetail.vue
  71. 9
      pages/issue/js/issue.js
  72. 140
      pages/issue/record/issueRecord.vue
  73. 65
      pages/issue/request/issueRequestCreate.vue
  74. 2
      pages/package/coms/comOverRecord.vue
  75. 2
      pages/package/coms/comPackageRecord.vue
  76. 10
      pages/package/record/mergePackageRecord.vue
  77. 2
      pages/package/record/overPackageRecord.vue
  78. 20
      pages/package/record/splitPackageRecord.vue
  79. 2
      pages/productDismantle/coms/comProductJobCard.vue
  80. 2
      pages/productDismantle/coms/comProductRecord.vue
  81. 198
      pages/productPutaway/coms/comProductRecord.vue
  82. 4
      pages/productPutaway/coms/comPutawayRequestCard.vue
  83. 6
      pages/productPutaway/job/productPutawayDetail.vue
  84. 2
      pages/productPutaway/record/productPutawayRecord.vue
  85. 2
      pages/productPutaway/request/putawayRequest.vue
  86. 30
      pages/productPutaway/request/putawayRequestCreate.vue
  87. 4
      pages/productPutaway/request/putawayRequestDetail.vue
  88. 2
      pages/productReceipt/coms/comProductRecord.vue
  89. 8
      pages/productReceipt/job/productReceiptDetail.vue
  90. 31
      pages/productReceipt/record/productReceiptRecord.vue
  91. 2
      pages/productionReceipt/coms/comProductionRecord.vue
  92. 35
      pages/productionReceipt/job/productionReceiptDetail.vue
  93. 1
      pages/productionReceipt/record/productionReceiptRecord.vue
  94. 8
      pages/productionReturn/coms/comReturn.vue
  95. 14
      pages/productionReturn/coms/comReturnCommonRequest.vue
  96. 15
      pages/productionReturn/coms/comReturnRecord.vue
  97. 35
      pages/productionReturn/coms/comReturnRequestCreator.vue
  98. 95
      pages/productionReturn/coms/comReturnRequestPopup.vue
  99. 65
      pages/productionReturn/coms/comScanReturnPack.vue
  100. 8
      pages/productionReturn/job/returnDetail.vue

16
api/index.js

@ -140,14 +140,14 @@ export const getBalancesAsync = (params) => promise(
}); });
//根据零件、箱码、托码、批次、库位类型、库存状态查询库存 //根据物料、箱码、托码、批次、库位类型、库存状态查询库存
export const getBalancesByFilter = (params) => request( export const getBalancesByFilter = (params) => request(
devUrl + "/api/pda/inventory/balances/by-balances-request-many-parameter", { devUrl + "/api/pda/inventory/balances/by-balances-request-many-parameter", {
method: 'post', method: 'post',
data: params data: params
}); });
//根据零件、箱码、托码、批次、库位类型、库存状态查询库存 //根据物料、箱码、托码、批次、库位类型、库存状态查询库存
export const getBalancesByFilterAsync = (params) => promise( export const getBalancesByFilterAsync = (params) => promise(
devUrl + "/api/pda/inventory/balances/by-balances-request-many-parameter", { devUrl + "/api/pda/inventory/balances/by-balances-request-many-parameter", {
method: 'post', method: 'post',
@ -170,7 +170,7 @@ export const getBalancesByStatus = (params) => request(
data: params data: params
}); });
//根据库位和零件号查询库存 //根据库位和物料号查询库存
export const getBalancesByLocationAndItem = (params) => request( export const getBalancesByLocationAndItem = (params) => request(
devUrl + "/api/pda/inventory/balances/get-by-location-and-item?locationCode=" + params.locationCode + devUrl + "/api/pda/inventory/balances/get-by-location-and-item?locationCode=" + params.locationCode +
"&itemCode=" + params.itemCode, { "&itemCode=" + params.itemCode, {
@ -179,7 +179,7 @@ export const getBalancesByLocationAndItem = (params) => request(
}); });
//根据库位和零件号查询库存 //根据库位和物料号查询库存
export const getBalancesByLocationAndItemAsync = (params) => promise( export const getBalancesByLocationAndItemAsync = (params) => promise(
devUrl + "/api/pda/inventory/balances/get-by-location-and-item?locationCode=" + params.locationCode + devUrl + "/api/pda/inventory/balances/get-by-location-and-item?locationCode=" + params.locationCode +
"&itemCode=" + params.itemCode, { "&itemCode=" + params.itemCode, {
@ -203,15 +203,15 @@ export const summary = (params) => request(
data: params data: params
}); });
//零件 //物料
//查询零件信息 //查询物料信息
export const getitems = (code) => request( export const getitems = (code) => request(
devUrl + "/api/pda/item/" + code, { devUrl + "/api/pda/item/" + code, {
method: 'get', method: 'get',
data: code data: code
}); });
//根据库位查询零件 //根据库位查询物料
export const getItemsByLocation = (params) => promise( export const getItemsByLocation = (params) => promise(
devUrl + "/api/pda/inventory/balances/get-item-by-location", { devUrl + "/api/pda/inventory/balances/get-item-by-location", {
method: 'get', method: 'get',
@ -427,7 +427,7 @@ export const locationByType = (type) => request(
data: type data: type
}); });
//根据库位查询零件 //根据库位查询物料
export const getLocationByItem = (params) => promise( export const getLocationByItem = (params) => promise(
devUrl + "/api/pda/inventory/balances/get-location-by-item", { devUrl + "/api/pda/inventory/balances/get-location-by-item", {
method: 'get', method: 'get',

6
api/request.js

@ -481,7 +481,7 @@ export function getPurchaseReturnRequestList(params) {
/** /**
* 原料上架 * 采购上架
* @param {*} * @param {*}
* status 任务状态 * status 任务状态
* CreationTimeStart 开始日期 * CreationTimeStart 开始日期
@ -500,7 +500,7 @@ export function getPutawayJobList(params) {
/** /**
* *
* @param {*} id 任务id * @param {*} id 任务id
* 原料上架获取任务明细 * 采购上架获取任务明细
*/ */
export function putawayGetJobDetail(id) { export function putawayGetJobDetail(id) {
return request({ return request({
@ -511,7 +511,7 @@ export function putawayGetJobDetail(id) {
} }
/** /**
* *
* @param {*} number 任务编号 * @param {*} number 任务编号
* 按任务编号查询任务 * 按任务编号查询任务

60
api/request2.js

@ -96,6 +96,19 @@ export function updateUserPwd(oldPassword, newPassword) {
}) })
} }
/**
* 获取仓库代码
* @param {*}
*
*/
export function getWarehouseCodeList(pageNo,pageSize) {
return request({
url: baseApi + "/wms/warehouse/page?pageNo="+pageNo+"&pageSize="+pageSize,
method: "get",
data: {},
});
}
/** /**
* 获取消息列表 * 获取消息列表
* @param {*} * @param {*}
@ -375,7 +388,7 @@ export function getBasicLocationByCode(code) {
/** /**
* 校验库位零件关系 * 校验库位物料关系
* @param {*} * @param {*}
* *
*/ */
@ -968,7 +981,7 @@ export function inspectJobSubmit(params) {
/** /**
* 原料上架 任务 * 采购上架 任务
* status 任务状态 * status 任务状态
* 开始日期 * 开始日期
* 结束日期 * 结束日期
@ -984,7 +997,7 @@ export function getPutawayJobList(params) {
} }
/** /**
* 原料上架 获取任务明细 * 采购上架 获取任务明细
* @param {*} id 任务id * @param {*} id 任务id
* *
*/ */
@ -997,7 +1010,7 @@ export function getPutawayJobDetail(id) {
} }
/** /**
* 原料上架 承接任务 * 采购上架 承接任务
* @param {*} id * @param {*} id
* *
*/ */
@ -1010,7 +1023,7 @@ export function takePutawayJob(id) {
} }
/** /**
* 原料上架 放弃承接 * 采购上架 放弃承接
* @param {*} id * @param {*} id
* *
*/ */
@ -1023,7 +1036,7 @@ export function cancleTakePutawayJob(id) {
} }
/** /**
* 原料上架 任务提交 * 采购上架 任务提交
* @param {*} params * @param {*} params
*/ */
export function putawayJobSubmit(params) { export function putawayJobSubmit(params) {
@ -1035,7 +1048,7 @@ export function putawayJobSubmit(params) {
} }
/** /**
* 原料上架申请 获取任务列表 * 采购上架申请 获取任务列表
* 任务状态 * 任务状态
* 开始日期 * 开始日期
* 结束日期 * 结束日期
@ -1051,7 +1064,7 @@ export function getPutawayRequestList(params) {
} }
/** /**
* 原料上架申请 获取任务明细 * 采购上架申请 获取任务明细
* @param {*} id 任务id * @param {*} id 任务id
* *
*/ */
@ -1064,7 +1077,7 @@ export function getPutawayRequestDetail(id) {
} }
/** /**
* 原料上架申请 提交 * 采购上架申请 提交
* @param {*} params * @param {*} params
*/ */
export function putawayRequestSubmit(params) { export function putawayRequestSubmit(params) {
@ -1076,7 +1089,7 @@ export function putawayRequestSubmit(params) {
} }
/** /**
* 原料上架申请 关闭任务 * 采购上架申请 关闭任务
* @param {*} params * @param {*} params
*/ */
export function putawayRequestClose(id) { export function putawayRequestClose(id) {
@ -1088,7 +1101,7 @@ export function putawayRequestClose(id) {
} }
/** /**
* 原料上架申请 提交审批 * 采购上架申请 提交审批
* @param {*} params * @param {*} params
*/ */
export function putawayRequestApprove(id) { export function putawayRequestApprove(id) {
@ -1100,7 +1113,7 @@ export function putawayRequestApprove(id) {
} }
/** /**
* 原料上架申请 提交审批通过 * 采购上架申请 提交审批通过
* @param {*} params * @param {*} params
*/ */
export function putawayRequestApproveAgree(id) { export function putawayRequestApproveAgree(id) {
@ -1112,7 +1125,7 @@ export function putawayRequestApproveAgree(id) {
} }
/** /**
* 原料上架申请 审批驳回 * 采购上架申请 审批驳回
* @param {*} params * @param {*} params
*/ */
export function putawayRequestApproveRefused(id) { export function putawayRequestApproveRefused(id) {
@ -1124,7 +1137,7 @@ export function putawayRequestApproveRefused(id) {
} }
/** /**
* 原料上架申请 处理 * 采购上架申请 处理
* @param {*} params * @param {*} params
*/ */
export function putawayRequestHandle(id) { export function putawayRequestHandle(id) {
@ -1136,7 +1149,7 @@ export function putawayRequestHandle(id) {
} }
/** /**
* 原料上架申请 重新添加 * 采购上架申请 重新添加
* @param {*} params * @param {*} params
*/ */
export function putawayRequestAddAgain(id) { export function putawayRequestAddAgain(id) {
@ -1150,7 +1163,7 @@ export function putawayRequestAddAgain(id) {
/** /**
* 原料上架记录 提交 * 采购上架记录 提交
* @param {*} params * @param {*} params
*/ */
export function putawayRecordSubmit(params) { export function putawayRecordSubmit(params) {
@ -3509,7 +3522,7 @@ export function getBalanceByFilter(param) {
} }
/** /**
* 查询管理精度多个零件多个库位 * 查询管理精度多个物料多个库位
* @param {*} * @param {*}
* *
*/ */
@ -3537,6 +3550,19 @@ export function deleteFileById(id) {
}); });
} }
/**
* 删除文件(多个文件)
* @param {*}
*
*/
export function deleteFileByTable(tableName, tableId) {
return request({
url: baseApi + "/infra/file/deleteByTable?tableName=" + tableName + "&tableId=" + tableId,
method: "delete",
data: {},
});
}
/** /**
* 获取文件列表 * 获取文件列表

15
common/balance.js

@ -263,6 +263,11 @@ export function byBatch(label, locationCode, fromInventoryStatuses, callback) {
action: "==", action: "==",
value: label.batch value: label.batch
}) })
filters.push({
column: "packingNumber",
action: "==",
value: null
})
filters.push({ filters.push({
column: "locationCode", column: "locationCode",
action: "==", action: "==",
@ -325,6 +330,16 @@ export function byQuantity(label, locationCode, fromInventoryStatuses, callback)
action: "==", action: "==",
value: label.itemCode value: label.itemCode
}) })
filters.push({
column: "packingNumber",
action: "==",
value: null
})
filters.push({
column: "batch",
action: "==",
value: null
})
filters.push({ filters.push({
column: "locationCode", column: "locationCode",
action: "==", action: "==",

6
common/basic.js

@ -476,7 +476,7 @@ export function getInspectReasonList(value) {
// else return '其他' // else return '其他'
// } // }
// //零件状态 // //物料状态
// export function getItemStatusStyle(val) { // export function getItemStatusStyle(val) {
// if (val == "wpztUNK") return 'item_unk' // if (val == "wpztUNK") return 'item_unk'
// else if (val == "wpztENABLE") return 'item_active' // else if (val == "wpztENABLE") return 'item_active'
@ -498,7 +498,7 @@ export function getInspectReasonList(value) {
// } // }
// //零件状态描述 // //物料状态描述
// export function getItemStatusDesc(val) { // export function getItemStatusDesc(val) {
// if (val == "wpztUNK") return '未知' // if (val == "wpztUNK") return '未知'
// else if (val == "wpztENABLE") return '可用' // else if (val == "wpztENABLE") return '可用'
@ -541,7 +541,7 @@ export function getInspectReasonList(value) {
// if (val == 0) return '未知' // if (val == 0) return '未知'
// else if (val == 1) return '库位盘点' // else if (val == 1) return '库位盘点'
// else if (val == 2) return '物品盘点' // else if (val == 2) return '物品盘点'
// else if (val == 3) return '库位零件盘点' // else if (val == 3) return '库位物料盘点'
// else return '其他' // else return '其他'
// } // }

8
common/calc.js

@ -2,16 +2,16 @@
import { Decimal } from 'decimal.js';//引入 import { Decimal } from 'decimal.js';//引入
class Calc { class Calc {
add(num1,num2) { add(num1,num2) {
return new Decimal(num1).add(new Decimal(num2)) return new Decimal(num1).add(new Decimal(num2)).toNumber()
} }
sub(num1,num2) { sub(num1,num2) {
return new Decimal(num1).sub(new Decimal(num2)) return new Decimal(num1).sub(new Decimal(num2)).toNumber()
} }
mul(num1,num2) { mul(num1,num2) {
return new Decimal(num1).mul(new Decimal(num2)) return new Decimal(num1).mul(new Decimal(num2)).toNumber()
} }
div(num1,num2) { div(num1,num2) {
return new Decimal(num1).div(new Decimal(num2)) return new Decimal(num1).div(new Decimal(num2)).toNumber()
} }
} }
export const calc = new Calc(); export const calc = new Calc();

8
common/classify.data.js

@ -1,7 +1,7 @@
export default [{ export default [{
"name": "库存查询", "name": "库存查询",
"children": [{ "children": [{
"name": "按零件查询库存", "name": "按物料查询库存",
"icon": "/static/menus/menu_search_lj.svg", "icon": "/static/menus/menu_search_lj.svg",
"url": "pages/query/item", "url": "pages/query/item",
"index": 1, "index": 1,
@ -55,13 +55,13 @@ export default [{
}, },
{ {
"name": "原料上架任务", "name": "采购上架任务",
"icon": "/static/menus/menu_search_lj.svg", "icon": "/static/menus/menu_search_lj.svg",
"url": "/pages/putaway/job/putawayJob", "url": "/pages/putaway/job/putawayJob",
"index": 3, "index": 3,
}, },
{ {
"name": "原料上架记录", "name": "采购上架记录",
"icon": "/static/menus/menu_search_lj.svg", "icon": "/static/menus/menu_search_lj.svg",
"url": "/pages/putaway/record/putawayRecord", "url": "/pages/putaway/record/putawayRecord",
"index": 3, "index": 3,
@ -309,7 +309,7 @@ export default [{
"index": 8, "index": 8,
}, },
{ {
"name": "原料上架申请", "name": "采购上架申请",
"icon": "/static/menus/menu_search_lj.svg", "icon": "/static/menus/menu_search_lj.svg",
"url": "/pages/putaway/request/putawayRequest", "url": "/pages/putaway/request/putawayRequest",
"index": 8, "index": 8,

140
common/detail.js

@ -1,77 +1,83 @@
import { calc } from '@/common/calc' import {
export function getDataSource(subList) { calc
let items = []; } from '@/common/calc'
subList.forEach(detail => {
var item = items.find(r =>
r.itemCode == detail.itemCode)
if (item == undefined) {
item = createItemInfo(detail);
let newDetail = createDetailInfo(detail); //
item.subList.push(newDetail);
items.push(item)
} else {
item.qty = calc.add(item.qty,detail.qty)
let newDetail = createDetailInfo(detail); //
item.subList.push(newDetail);
}
})
return items;
}
export function createItemInfo(detail) { import { Decimal } from 'decimal.js';//引入
let item = { export function getDataSource(subList) {
itemCode: detail.itemCode, let items = [];
itemName: detail.itemName, subList.forEach(detail => {
stdPackQty: Number(detail.stdPackQty)||undefined, var item = items.find(r =>
stdPackUnit: detail.stdPackUnit, r.itemCode == detail.itemCode)
qty: Number(detail.qty), if (item == undefined) {
handleQty: 0, item = createItemInfo(detail);
uom: detail.uom, let newDetail = createDetailInfo(detail); //
subList: [] item.subList.push(newDetail);
items.push(item)
} else {
item.qty = calc.add(item.qty, detail.qty)
let newDetail = createDetailInfo(detail); //
item.subList.push(newDetail);
}
})
return items;
}
export function createItemInfo(detail) {
let item = {
itemCode: detail.itemCode,
itemName: detail.itemName,
stdPackQty: Number(detail.stdPackQty) || undefined,
stdPackUnit: detail.stdPackUnit,
qty: Number(detail.qty),
handleQty: 0,
uom: detail.uom,
subList: []
}
return item;
} }
return item;
}
export function createDetailInfo(data) { export function createDetailInfo(data) {
data.scaned = false; data.scaned = false;
// data.record = {}; // data.record = {};
let detail = data; let detail = data;
return detail; return detail;
} }
//根据明细创建记录 //根据明细创建记录
export function createRecordInfo(detail, balance) { export function createRecordInfo(detail, balance) {
var record = {} var record = {}
// let record = JSON.parse(JSON.stringify(detail)); // let record = JSON.parse(JSON.stringify(detail));
//克隆对象,深度克隆,防止双向绑定同一个变量 //克隆对象,深度克隆,防止双向绑定同一个变量
Object.assign(record, detail) Object.assign(record, detail)
detail.scaned = true; detail.scaned = true;
detail.balance = balance; detail.balance = balance;
detail.recommendInventoryStatus = detail.inventoryStatus; detail.recommendInventoryStatus = detail.inventoryStatus;
detail.inventoryStatus = balance.inventoryStatus; detail.inventoryStatus = balance.inventoryStatus;
record.qty = Number(balance.qty); record.qty = Number(balance.qty);
return record; return record;
} }
//计算实际数量 //计算实际数量
export function calcHandleQty(detailSource) { export function calcHandleQty(detailSource) {
for (let item of detailSource) { for (let item of detailSource) {
item.handleQty = 0; item.handleQty = new Decimal(0).toNumber();
for (let detail of item.subList) { item.qty = new Decimal(0).toNumber();
if (detail != undefined && detail.scaned) { for (let detail of item.subList) {
item.handleQty += Number(detail.handleQty) if (detail != undefined && detail.scaned) {
item.handleQty = calc.add(item.handleQty,detail.handleQty);
item.qty = calc.add(item.qty,detail.qty);
}
} }
} }
} }
}
export function getScanCount(subList) { export function getScanCount(subList) {
let items = subList.filter(r => { let items = subList.filter(r => {
if (r.scaned) { if (r.scaned) {
return r; return r;
} }
}) })
let scanCount = items != null ? items.length : 0; let scanCount = items != null ? items.length : 0;
return scanCount; return scanCount;
} }

49
common/directory.js

@ -1,5 +1,6 @@
let jobStatusList = []; let jobStatusList = [];
let itemStatusList = []; let itemStatusList = [];
let itemTypeList =[];
let locationTypeList = []; let locationTypeList = [];
let uomList = []; let uomList = [];
let inventoryStatusList = []; let inventoryStatusList = [];
@ -39,6 +40,7 @@ export function getBusinessTypeDesc(type) {
export function clearCacheData() { export function clearCacheData() {
jobStatusList = []; jobStatusList = [];
itemStatusList = []; itemStatusList = [];
itemTypeList =[];
locationTypeList = []; locationTypeList = [];
uomList = []; uomList = [];
inventoryStatusList = []; inventoryStatusList = [];
@ -143,16 +145,57 @@ export function getJobStateStyle(value) {
} }
} }
//获取库位描述 //获取库位描述(多个库位)
export function getListLocationTypeDesc(lst) { export function getListLocationTypeDesc(list) {
let desc = ''; let desc = '';
lst.forEach(res => { list.forEach(res => {
desc += getLocationTypeInfo(res).label + "," desc += getLocationTypeInfo(res).label + ","
}) })
desc = desc.slice(0, -1); desc = desc.slice(0, -1);
return desc; return desc;
} }
//获取物品状态(多个状态)
export function getListItemStateDesc(list) {
let desc = '';
list.forEach(res => {
desc += getItemStateInfo(res).label + ","
})
desc = desc.slice(0, -1);
return desc;
}
//获取物品类型(多个)
export function getListItemTypeDesc(list) {
let desc = '';
list.forEach(res => {
desc += getItemTypeInfo(res).label + ","
})
desc = desc.slice(0, -1);
return desc;
}
//获取物品类型
export function getItemTypeInfo(value) {
var resultInfo = "";
if (itemTypeList.length == 0) {
itemTypeList = getDirectoryInfo("item_type")
}
if (itemTypeList.length > 0) {
for (let item of itemTypeList) {
if (item.value == value) {
resultInfo = item
break;
}
}
}
return resultInfo
}
//获取物品状态 //获取物品状态
export function getItemStateInfo(value) { export function getItemStateInfo(value) {
var resultInfo = ""; var resultInfo = "";

36
common/record.js

@ -6,6 +6,10 @@ import {
getDirectoryItemArray, getDirectoryItemArray,
} from '@/common/directory.js'; } from '@/common/directory.js';
import { calc } from '@/common/calc' import { calc } from '@/common/calc'
import { Decimal } from 'decimal.js';//引入
import {
deepCopyData
} from '@/common/basic.js';
export function createItemInfo(balance, pack) { export function createItemInfo(balance, pack) {
let item = { let item = {
@ -13,24 +17,24 @@ export function createItemInfo(balance, pack) {
itemName: pack.itemName, itemName: pack.itemName,
stdPackQty: pack.stdPackQty, stdPackQty: pack.stdPackQty,
stdPackUnit: pack.stdPackUnit, stdPackUnit: pack.stdPackUnit,
qty: Number(balance.qty), qty: new Decimal(balance.qty).toNumber(),
handleQty: 0, handleQty:new Decimal(0).toNumber(),
uom: pack.uom, uom: pack.uom,
subList: [] subList: []
} }
return item; return item;
} }
export function createDetailInfo(data, pack) { export function createDetailInfo(balance, pack) {
data.scaned = true; balance.scaned = true;
// data.toInventoryStatus = this.toInventoryStatus == "" ? data.inventoryStatus : this.toInventoryStatus; // data.toInventoryStatus = this.toInventoryStatus == "" ? data.inventoryStatus : this.toInventoryStatus;
// data.inventoryStatus = data.inventoryStatus; // data.inventoryStatus = data.inventoryStatus;
let detail = {}; let detail = deepCopyData(balance);
Object.assign(detail, data) detail.balanceQty = new Decimal(detail.qty).toNumber()
detail.balanceQty = Number(detail.qty) detail.qty = new Decimal(detail.qty).toNumber();
detail.stdPackQty = Number(pack.stdPackQty) detail.stdPackQty = new Decimal(pack.stdPackQty).toNumber()
detail.stdPackUnit = pack.stdPackUnit detail.stdPackUnit = pack.stdPackUnit
detail.handleQty =0; detail.handleQty = new Decimal(detail.qty).toNumber() ;
detail.package = pack; detail.package = pack;
return detail; return detail;
@ -39,10 +43,14 @@ export function createDetailInfo(data, pack) {
//计算实际数量 //计算实际数量
export function calcHandleQty(detailSource) { export function calcHandleQty(detailSource) {
for (let item of detailSource) { for (let item of detailSource) {
item.qty = 0; item.handleQty = new Decimal(0).toNumber();
item.qty = new Decimal(0).toNumber();
for (let detail of item.subList) { for (let detail of item.subList) {
if (detail != undefined && detail.scaned) { if(detail!=undefined){
item.qty = calc.add(item.qty,detail.qty); if(detail.scaned){
item.handleQty = calc.add(item.handleQty,detail.handleQty);
}
item.qty = calc.add(item.qty,detail.qty);
} }
} }
} }
@ -54,6 +62,8 @@ export function getBusinessType(typeCode, callback) {
businessType: '', businessType: '',
fromlocationTypeList: '', fromlocationTypeList: '',
tolocationTypeList: '', tolocationTypeList: '',
itemCodeTypeList:"",
useOnTheWay:"FALSE",
fromInventoryStatuses: '', fromInventoryStatuses: '',
toInventoryStatuses: '', toInventoryStatuses: '',
message: '' message: ''
@ -63,8 +73,10 @@ export function getBusinessType(typeCode, callback) {
result.businessType = res.data.list[0]; result.businessType = res.data.list[0];
result.fromlocationTypeList = getDirectoryItemArray(res.data.list[0].outLocationTypes) result.fromlocationTypeList = getDirectoryItemArray(res.data.list[0].outLocationTypes)
result.tolocationTypeList = getDirectoryItemArray(res.data.list[0].inLocationTypes) result.tolocationTypeList = getDirectoryItemArray(res.data.list[0].inLocationTypes)
result.itemCodeTypeList = getDirectoryItemArray(res.data.list[0].itemTypes)
result.fromInventoryStatuses = res.data.list[0].outInventoryStatuses; result.fromInventoryStatuses = res.data.list[0].outInventoryStatuses;
result.toInventoryStatuses = res.data.list[0].inInventoryStatuses; result.toInventoryStatuses = res.data.list[0].inInventoryStatuses;
result.useOnTheWay =res.data.list[0].useOnTheWay
callback(result) callback(result)
} else { } else {
result.success = false; result.success = false;

8
common/scan.js

@ -125,7 +125,7 @@ export function analyseScanInfo(scanMsg) {
//解析完工收货标签 //解析完工收货标签
//P2250229RAA;L220408;Q100;N62840610;SB0000107;UEA;DU571LS;FA;E2022-4-8 //P2250229RAA;L220408;Q100;N62840610;SB0000107;UEA;DU571LS;FA;E2022-4-8
//P零件号,L批次,Q数量,N生产计划号,S箱码,U计量单位,D生产线,F班次,E日期,M零件名称(待添加) //P物料号,L批次,Q数量,N生产计划号,S箱码,U计量单位,D生产线,F班次,E日期,M物料名称(待添加)
//解析规则 //解析规则
//P:itemCode 物料号 //P:itemCode 物料号
//L:lot批次 //L:lot批次
@ -240,7 +240,7 @@ export function analyseProductLabelInfo(scanMsg) {
//解析天津mes标签 //解析天津mes标签
//1#2546319FL#254FL003#202207110009: //1#2546319FL#254FL003#202207110009:
//1.序号1,2.生产号2546311FL,3.零件号254FL004,4.批序号202207110009 //1.序号1,2.生产号2546311FL,3.物料号254FL004,4.批序号202207110009
export function analyseTJMesQRCode(scanMsg) { export function analyseTJMesQRCode(scanMsg) {
let scanResult = { let scanResult = {
success: false, success: false,
@ -269,7 +269,7 @@ export function analyseTJMesQRCode(scanMsg) {
seq: datas[0], //序号 seq: datas[0], //序号
produceNo: datas[1], //生产号 produceNo: datas[1], //生产号
// projectNo: datas[2], //项目号 // projectNo: datas[2], //项目号
itemCode: itemCode, //配置码(零件号) itemCode: itemCode, //配置码(物料号)
lot: datas[3], //批次 lot: datas[3], //批次
position: location //上层、下层 position: location //上层、下层
} }
@ -282,7 +282,7 @@ export function analyseTJMesQRCode(scanMsg) {
seq: seq, //序号 seq: seq, //序号
produceNo: 'N', //生产号 produceNo: 'N', //生产号
projectNo: 'N', //项目号 projectNo: 'N', //项目号
itemCode: 'N', //配置码(零件号) itemCode: 'N', //配置码(物料号)
lot: 'N', //批次 lot: 'N', //批次
position: '' position: ''
} }

4
common/style/new_style.css

@ -115,7 +115,7 @@ uni-page-head .uni-page-head__title {
} }
/* /*
零件状态 物料状态
未知可用隔离新增规划禁用 未知可用隔离新增规划禁用
*/ */
@ -2439,7 +2439,7 @@ button[disabled] {
font-size: 38rpx; font-size: 38rpx;
} }
.text_stock { .text_balance {
font-size: 36rpx; font-size: 36rpx;
} }

8
common/style/pdabasic.css

@ -417,7 +417,7 @@
/* //零件状态 /* //物料状态
export function getItemTypeStyle(val) { export function getItemTypeStyle(val) {
if (val == 0) return 'active' if (val == 0) return 'active'
else if (val == 1) return 'hold' else if (val == 1) return 'hold'
@ -428,7 +428,7 @@ export function getItemTypeStyle(val) {
} }
*/ */
/* 零件状态 */ /* 物料状态 */
.active { .active {
background-color: #5FCB94; background-color: #5FCB94;
color: #FFFFFF; color: #FFFFFF;
@ -460,7 +460,7 @@ export function getItemTypeStyle(val) {
font-weight: bolder; font-weight: bolder;
} }
/* 零件编号字体 */ /* 物料编号字体 */
.text-itemcode { .text-itemcode {
/* font-size: 26rpx; */ /* font-size: 26rpx; */
color: #000; color: #000;
@ -472,7 +472,7 @@ export function getItemTypeStyle(val) {
/* font-size: 22rpx; */ /* font-size: 22rpx; */
} }
/* 零件编号字体 */ /* 物料编号字体 */
.text-bolder { .text-bolder {
color: #000; color: #000;
font-weight: bolder; font-weight: bolder;

6
mycomponents/balance/handleBalance.vue

@ -1,12 +1,12 @@
<template> <template>
<view :class="detail.scaned?'scan_view':''" style="background-color: #ffffff;"> <view :class="detail.scaned?'scan_view':''" style="background-color: #ffffff;">
<view class="space_between"> <view class="space_between center" >
<view > <view style="word-break: break-all;width: 60%;">
<pack v-if="isShowPack" :packingCode="detail.packingNumber"></pack> <pack v-if="isShowPack" :packingCode="detail.packingNumber"></pack>
<batch v-if="isShowBatch" :batch="detail.batch"></batch> <batch v-if="isShowBatch" :batch="detail.batch"></batch>
<location v-if="isShowLocation" :locationCode="detail.fromLocationCode"></location> <location v-if="isShowLocation" :locationCode="detail.fromLocationCode"></location>
</view> </view>
<view > <view style="word-break: break-all;">
<recommend-qty v-if="detail.record==null || detail.record==undefined" :dataContent="detail" <recommend-qty v-if="detail.record==null || detail.record==undefined" :dataContent="detail"
:isShowStdPack="false"></recommend-qty> :isShowStdPack="false"></recommend-qty>

10
mycomponents/balance/recommendBalance.vue

@ -1,17 +1,17 @@
<template> <template>
<view :class="detail.scaned?'scan_view':''" style="background-color: #ffffff;"> <view :class="detail.scaned?'scan_view':''" style="background-color: #fff;">
<view class="uni-flex uni-row space-between center "> <view class="uni-flex uni-row space-between center ">
<view class="uni-flex uni-row center "> <view class="uni-flex uni-row " style="width: 60%;margin-left: 30rpx;" >
<view style=" width: 20px;color: #32C1E8;"> <view style=" width: 25rpx;color: #32C1E8;">
推荐 推荐
</view> </view>
<view > <view style="word-break: break-all">
<pack v-if="isShowPack" :packingCode="detail.packingNumber"></pack> <pack v-if="isShowPack" :packingCode="detail.packingNumber"></pack>
<batch v-if="isShowBatch" :batch="detail.batch"></batch> <batch v-if="isShowBatch" :batch="detail.batch"></batch>
<location v-if="isShowLocation" :locationCode="detail.fromLocationCode"></location> <location v-if="isShowLocation" :locationCode="detail.fromLocationCode"></location>
</view> </view>
</view> </view>
<view > <view style="word-break: break-all">
<recommend-qty v-if="detail.Records==null || detail.Records.length==0" :dataContent="detail" <recommend-qty v-if="detail.Records==null || detail.Records.length==0" :dataContent="detail"
:isShowStdPack="false" :isShowStatus="false"></recommend-qty> :isShowStdPack="false" :isShowStatus="false"></recommend-qty>
<compare-qty v-else :dataContent="detail" :recommendQty="Number( detail.qty)" <compare-qty v-else :dataContent="detail" :recommendQty="Number( detail.qty)"

2
mycomponents/detail/comDetailCard.vue

@ -3,7 +3,7 @@
<uni-collapse ref="collapse1" @change=""> <uni-collapse ref="collapse1" @change="">
<uni-collapse-item :open="true"> <uni-collapse-item :open="true">
<template v-slot:title> <template v-slot:title>
<item-compare-qty :dataContent="dataContent" :handleQty="Number(dataContent.handleQty)" :isShowStdPack="false"> <item-compare-qty :dataContent="dataContent" :handleQty="dataContent.handleQty" :isShowStdPack="false">
</item-compare-qty> </item-compare-qty>
</template> </template>
<u-line></u-line> <u-line></u-line>

4
mycomponents/item/itemDetailInfo.vue

@ -2,11 +2,11 @@
<uni-popup ref="popup"> <uni-popup ref="popup">
<view class="uni-flex uni-column" style="background-color: white;width: 200px; height:60%;"> <view class="uni-flex uni-column" style="background-color: white;width: 200px; height:60%;">
<view class="uni-flex"> <view class="uni-flex">
<text>零件</text> <text>物料</text>
<text>{{dataContent.code}}</text> <text>{{dataContent.code}}</text>
</view> </view>
<view class="uni-flex"> <view class="uni-flex">
<text>零件名称</text> <text>物料名称</text>
<text>{{dataContent.name}}</text> <text>{{dataContent.name}}</text>
</view> </view>
<view class="uni-flex"> <view class="uni-flex">

14
mycomponents/item/itemQty.vue

@ -4,9 +4,11 @@
<item :dataContent="dataContent"></item> <item :dataContent="dataContent"></item>
</view> </view>
<view> <view>
<balanceQty v-if="showItemQty" :dataContent="dataContent"></balanceQty>
<!-- showBalanceQty -->
<balanceQty v-if="isShowBalanceQty" :dataContent="dataContent"></balanceQty>
<compare-qty v-else :dataContent="dataContent" :recommendQty="Number(dataContent.qty)" <compare-qty v-else :dataContent="dataContent" :recommendQty="Number(dataContent.qty)"
:handleQty="Number(handleQty)" :isShowStatus="false"> :handleQty="dataContent.handleQty" :isShowStatus="false" :isShowStdPack="showStdPack">
</compare-qty> </compare-qty>
</view> </view>
<!-- <view v-else> <!-- <view v-else>
@ -43,10 +45,14 @@
type: Number, type: Number,
default: 0 default: 0
}, },
showItemQty: { isShowBalanceQty: {
type: Boolean, type: Boolean,
default: true default: true
} },
showStdPack: {
type: Boolean,
default: false
},
}, },
watch: { watch: {

6
mycomponents/item/itemSelect.vue

@ -1,9 +1,9 @@
<template> <template>
<view class="" style="background-color:#fff;"> <view class="" style="background-color:#fff;">
<view class="uni-flex uni-row" style="display: flex;align-items: center;"> <view class="uni-flex uni-row" style="display: flex;align-items: center;">
零件 物料
<uni-easyinput ref='scanInput' v-model="partCode" @confirm="confirmPartCode" @clear="clear" <uni-easyinput ref='scanInput' v-model="partCode" @confirm="confirmPartCode" @clear="clear"
style='font-size: 18px;padding: 10rpx 20rpx;' placeholder="请输入零件号" @iconClick=""> style='font-size: 18px;padding: 10rpx 20rpx;' placeholder="请输入物料号" @iconClick="">
</uni-easyinput> </uni-easyinput>
</view> </view>
<view class=""> <view class="">
@ -39,7 +39,7 @@
confirmPartCode() { confirmPartCode() {
if (this.partCode == '') { if (this.partCode == '') {
uni.showToast({ uni.showToast({
title: "请扫描零件" title: "请扫描物料"
}) })
return; return;
} }

6
mycomponents/package/packageDetailPopup.vue

@ -61,13 +61,13 @@
this.dataList.length = 0; this.dataList.length = 0;
this.dataList.push(...[{ this.dataList.push(...[{
item_title: '包装号', item_title: '包装号',
text_wrap: this.dataContent.number content: this.dataContent.number
}, { }, {
item_title: '物料代码', item_title: '物料代码',
text_wrap: this.dataContent.itemCode content: this.dataContent.itemCode
}, { }, {
item_title: '物品名称', item_title: '物品名称',
text_wrap: this.dataContent.itemName content: this.dataContent.itemName
}, { }, {
item_title: '物品描述1', item_title: '物品描述1',
content: this.dataContent.itemDesc1 content: this.dataContent.itemDesc1

6
mycomponents/partCode/partCodeSelect.vue

@ -1,9 +1,9 @@
<template> <template>
<view class="" style="background-color:#fff;"> <view class="" style="background-color:#fff;">
<view class="uni-flex uni-row" style="display: flex;align-items: center;"> <view class="uni-flex uni-row" style="display: flex;align-items: center;">
零件 物料
<uni-easyinput ref='scanInput' v-model="partCode" @confirm="confirmPartCode" @clear="clear" <uni-easyinput ref='scanInput' v-model="partCode" @confirm="confirmPartCode" @clear="clear"
style='font-size: 18px;padding: 10rpx 20rpx;' placeholder="请输入零件号" @iconClick=""> style='font-size: 18px;padding: 10rpx 20rpx;' placeholder="请输入物料号" @iconClick="">
</uni-easyinput> </uni-easyinput>
</view> </view>
<view class=""> <view class="">
@ -39,7 +39,7 @@
confirmPartCode() { confirmPartCode() {
if (this.partCode == '') { if (this.partCode == '') {
uni.showToast({ uni.showToast({
title: "请扫描零件" title: "请扫描物料"
}) })
return; return;
} }

40
mycomponents/popup/selectList.vue

@ -1,28 +1,31 @@
<template> <template>
<uni-popup ref="popupItems"> <uni-popup ref="popupItems">
<com-popup @onClose="closePopup"> <com-popup @onClose="closePopup">
<view class=""> <view class="uni-center" style="position: relative;height:900rpx ;">
<view class="uni-center" style="font-size: 40rpx;margin-top: 10rpx;margin-bottom: 10rpx;"> <view class="" style="position: absolute;font-size: 38rpx;height: 50rpx; margin-top: 10rpx;margin-bottom: 10rpx;left: 0;top: 0;right: 0;">
选择零件 选择物料
</view> </view>
<u-line/> <u-line/>
<view style="margin: 20rpx;" v-for="(item, index) in showList" :key="index" > <view class="" style="position: absolute;height: 720rpx; font-size: 40rpx;top: 70rpx;bottom: 80rpx;left: 0;right: 0;">
<view class="" style="padding: 10rpx;" @click="selectItem(item)"> <view style="margin: 15rpx;text-align: left;" v-for="(item, index) in showList" :key="index" >
零件: {{item.itemCode}} <view class="" style="padding: 10rpx;font-size: 30rpx; " @click="selectItem(item)">
({{index+1}}) 物料: {{item.itemCode}}
</view>
<u-line/>
</view> </view>
<u-line/>
</view> </view>
</view> <view class="" style="position: absolute; height:80rpx ;left: 0;bottom: 0;right: 0;">
<view class="flex uni-center" style="width: 100%;justify-content: center;margin-top: 10rpx;margin-bottom: 10rpx;" > <view class="flex uni-center" style="width: 100%;justify-content: center;margin-top: 10rpx;margin-bottom: 10rpx;" >
<view class=""> <view class="">
当前页{{ pageCurrent }}数据总量{{ total }}每页数据{{ pageSize }} 当前页{{ pageCurrent }}数据总量{{ total }}每页数据{{ pageSize }}
</view>
</view>
<view class="">
<uni-pagination :page-size="pageSize" :current="pageCurrent" :total="total" @change="change" />
</view>
</view> </view>
</view> </view>
<view class="">
<uni-pagination :page-size="pageSize" :current="pageCurrent" :total="total" @change="change" />
</view>
</com-popup> </com-popup>
</uni-popup> </uni-popup>
@ -31,7 +34,6 @@
<script> <script>
import { import {
getProductionlineItem,
getCustomerItemList getCustomerItemList
} from '@/api/request2.js'; } from '@/api/request2.js';
import comPopup from '@/mycomponents/common/comPopup.vue' import comPopup from '@/mycomponents/common/comPopup.vue'
@ -73,8 +75,8 @@
this.$forceUpdate() this.$forceUpdate()
this.$refs['popupItems'].open("center"); this.$refs['popupItems'].open("center");
} else { } else {
//线 //线
// this.showErrorMessage('线' + lineCode + ''); // this.showErrorMessage('线' + lineCode + '');
this.$refs['popupItems'].open("center"); this.$refs['popupItems'].open("center");
} }
}).catch(error => { }).catch(error => {

70
mycomponents/qty/CountQtyEdit.vue

@ -16,7 +16,7 @@
<view class="uni-flex uni-row space-between padding title "> <view class="uni-flex uni-row space-between padding title ">
<text>标包个数 : </text> <text>标包个数 : </text>
<view class="uni-flex uni-row u-col-center"> <view class="uni-flex uni-row u-col-center">
<uni-number-box @change="calcQty($event,stdCount)" :value="stdCount"> <uni-number-box @change="calcQty($event,stdCount)" :value="stdCount" :focus="false">
</uni-number-box> </uni-number-box>
<view class="std_pack"> <view class="std_pack">
{{getStdPackUnitInfo(dataContent.stdPackUnit)}} {{getStdPackUnitInfo(dataContent.stdPackUnit)}}
@ -38,12 +38,13 @@
<text>数量 : </text> <text>数量 : </text>
<view class="uni-flex uni-row uni-center" style="align-items: center;"> <view class="uni-flex uni-row uni-center" style="align-items: center;">
<input class="qty_input" v-model="allQty" :focus="true" type="number" <input class="qty_input" v-model="allQty" :focus="true" type="number"
@mousedown="mousedown" /> @mousedown="mousedown" @input="checkNum" :maxlength="maxlength" />
<uom :uom="dataContent.uom"></uom> <uom :uom="dataContent.uom"></uom>
</view> </view>
</view> </view>
<u-line /> <u-line />
<view v-if="isShowBalance" class="uni-flex uni-row space-between padding title u-col-center"> <view v-if="isShowBalance"
class="uni-flex uni-row space-between padding title u-col-center">
<text>库存数量 : </text> <text>库存数量 : </text>
<view class="uni-flex uni-row uni-center" style="align-items: center;"> <view class="uni-flex uni-row uni-center" style="align-items: center;">
<text class="text_recommend">{{Number(dataContent.balanceQty)}}</text> <text class="text_recommend">{{Number(dataContent.balanceQty)}}</text>
@ -55,7 +56,7 @@
style="align-items: center; padding-left: 30rpx;"> style="align-items: center; padding-left: 30rpx;">
<text>库存状态 : </text> <text>库存状态 : </text>
<view class="uni-flex uni-row uni-center" style="align-items: center;"> <view class="uni-flex uni-row uni-center" style="align-items: center;">
<balanceStatus ref="balanceStatus" :status="inventoryStatus" :allowEdit='false' <balanceStatus ref="balanceStatus" :status="inventoryStatus" :allowEdit='true'
@updateStatus="updateStatus" @onOpen="clickState"> @updateStatus="updateStatus" @onOpen="clickState">
</balanceStatus> </balanceStatus>
</view> </view>
@ -107,7 +108,9 @@
seconds: 0, seconds: 0,
timer: {}, timer: {},
showConfirmCountdown: false, showConfirmCountdown: false,
detaiList: [] detailList: [],
maxlength: 10,
mode: 'add' //add edit
} }
}, },
watch: { watch: {
@ -140,26 +143,52 @@
}, },
}, },
methods: { methods: {
openEditPopup(item, detaiList) { checkNum(e) {
this.dataContent = item let value = e.detail.value;
this.inventoryStatus = this.dataContent.inventoryStatus; let dot = value.indexOf('.'); //
this.allQty = Number(this.dataContent.qty) let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
},
//
openEditPopup(item, detailList) {
this.initData(item, detailList);
// this.dataContent = item
// this.inventoryStatus = this.dataContent.inventoryStatus;
// this.allQty = Number(this.dataContent.qty)
// this.stdCount = Math.ceil(this.allQty / this.dataContent.stdPackQty);
// this.detailList = detailList
this.showConfirmCountdown = false; this.showConfirmCountdown = false;
this.detaiList = detaiList this.mode = 'edit';
this.$refs.popup.open('bottom') this.$refs.popup.open('bottom')
clearInterval(this.timer) clearInterval(this.timer)
}, },
openEditPopupShowSeconds(item, detaiList) { //
this.dataContent = item; openEditPopupShowSeconds(item, detailList) {
this.inventoryStatus = this.dataContent.inventoryStatus; this.initData(item, detailList);
this.allQty = Number(this.dataContent.qty);
this.showConfirmCountdown = true; this.showConfirmCountdown = true;
this.detaiList = detaiList; this.mode = 'add';
this.$refs.popup.open('bottom') this.$refs.popup.open('bottom')
this.startTimer() this.startTimer()
},
initData(item, detailList) {
this.dataContent = item;
this.inventoryStatus = this.dataContent.inventoryStatus;
this.allQty = Number(this.dataContent.handleQty);
this.stdCount = Math.ceil(this.allQty / this.dataContent.stdPackQty);
this.detailList = detailList;
}, },
mousedown() { mousedown() {
this.showConfirmCountdown = false; this.showConfirmCountdown = false;
clearInterval(this.timer) clearInterval(this.timer)
@ -172,6 +201,7 @@
closeEditPopup() { closeEditPopup() {
clearInterval(this.timer) clearInterval(this.timer)
this.$emit("close");
this.$refs.popup.close() this.$refs.popup.close()
}, },
confirm() { confirm() {
@ -186,26 +216,28 @@
this.timer = setInterval(() => { this.timer = setInterval(() => {
this.seconds-- this.seconds--
if (this.seconds <= 0) { if (this.seconds <= 0) {
this.cancel() this.confirm();
// this.cancel()
return return
} }
}, 1000) }, 1000)
}, },
calcQty(val) { calcQty(val) {
if(val>0){ if (val > 0) {
this.allQty = val * Number(this.dataContent.stdPackQty); this.allQty = val * Number(this.dataContent.stdPackQty);
} }
}, },
setValue() { setValue() {
this.dataContent.handleQty = Number(this.allQty) this.dataContent.handleQty = Number(this.allQty)
this.$emit("confirm"); this.$emit("confirm", Number(this.allQty), this.inventoryStatus, this.mode);
this.closeEditPopup(); this.closeEditPopup();
}, },
updateStatus(value) { updateStatus(value) {
this.inventoryStatus = value this.inventoryStatus = value
console.log(this.inventoryStatus)
}, },
getStdPackUnitInfo(value) { getStdPackUnitInfo(value) {
return getStdPackUnitInfo(value).name return getStdPackUnitInfo(value).name
} }

2
mycomponents/qty/balanceQty.vue

@ -1,7 +1,7 @@
<template> <template>
<view> <view>
<view class="center"> <view class="center">
<view class="uni-flex uni-row" style="font-size: 40rpx;"> <view class="uni-flex uni-row text_balance">
<text> <text>
{{Number(dataContent.qty)}} {{Number(dataContent.qty)}}
</text> </text>

24
mycomponents/qty/balanceQtyEdit.vue

@ -36,7 +36,7 @@
<text>数量 : </text> <text>数量 : </text>
<view class="uni-flex uni-row uni-center" style="align-items: center;"> <view class="uni-flex uni-row uni-center" style="align-items: center;">
<input class="qty_input" v-model="allQty" :focus="true" type="number" <input class="qty_input" v-model="allQty" :focus="true" type="number"
@confirm="confirm()" /> @confirm="confirm()" @input="checkNum" :maxlength="maxlength" />
<uom :uom="dataContent.uom"></uom> <uom :uom="dataContent.uom"></uom>
</view> </view>
</view> </view>
@ -77,7 +77,7 @@
import StdUom from '@/mycomponents/qty/StdUom.vue' import StdUom from '@/mycomponents/qty/StdUom.vue'
import balanceStatus from '@/mycomponents/status/balanceStatus.vue' import balanceStatus from '@/mycomponents/status/balanceStatus.vue'
import comMessage from '@/mycomponents/common/comMessage.vue' import comMessage from '@/mycomponents/common/comMessage.vue'
export default { export default {
components: { components: {
uom, uom,
@ -94,7 +94,8 @@
inventoryStatus: "", inventoryStatus: "",
originalInventoryStatus: "", originalInventoryStatus: "",
dataContent: {}, dataContent: {},
handleQty: 0 handleQty: 0,
maxlength: 10
} }
}, },
watch: { watch: {
@ -123,11 +124,26 @@
} }
}, },
methods: { methods: {
checkNum(e) {
let value = e.detail.value;
let dot = value.indexOf('.'); //
let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
},
openEditPopup(item, handleQty) { openEditPopup(item, handleQty) {
this.dataContent = item this.dataContent = item
this.inventoryStatus = this.dataContent.inventoryStatus this.inventoryStatus = this.dataContent.inventoryStatus
this.originalInventoryStatus =this.dataContent.inventoryStatus;
this.toInventoryStatus = this.dataContent.toInventoryStatus this.toInventoryStatus = this.dataContent.toInventoryStatus
this.allQty = Number(handleQty) this.allQty = handleQty
setTimeout(res => { setTimeout(res => {
this.$refs.popup.open('bottom') this.$refs.popup.open('bottom')
}, 500) }, 500)

33
mycomponents/qty/compareQty.vue

@ -3,25 +3,35 @@
<view class="uni-flex uni-row "> <view class="uni-flex uni-row ">
<status v-show="isShowStatus" :status='dataContent.inventoryStatus'></status> <status v-show="isShowStatus" :status='dataContent.inventoryStatus'></status>
<view class="uni-flex uni-row center"> <view class="uni-flex uni-row center">
<view v-if ="Number(handleQty)!=0"> <view v-if="Number(handleQty)!=0">
<view v-if="Number(recommendQty)>Number(handleQty)" class="text_greater"> <view v-if="isShowRecommendQty">
<view v-if="Number(recommendQty)>Number(handleQty)" class="text_greater">
{{Number(handleQty)}} {{Number(handleQty)}}
</view> </view>
<view v-else-if="Number(recommendQty)<Number(handleQty)" class="text_less"> <view v-else-if="Number(recommendQty)<Number(handleQty)" class="text_less">
{{Number(handleQty)}}
</view>
<view v-else-if="Number(recommendQty) ==Number(handleQty)" class="text_equal">
{{Number(handleQty)}} {{Number(handleQty)}}
</view>
</view> </view>
<view v-else-if="Number(recommendQty) ==Number( handleQty)" class="text_equal"> <view v-else>
<view class="text_balance">
{{Number(handleQty)}} {{Number(handleQty)}}
</view>
</view> </view>
</view> </view>
<view class="center" v-if="isShowRecommendQty">
<view v-if="Number(handleQty)!=0" class="std_split">/</view> <view v-if="Number(handleQty)!=0" class="std_split">/</view>
<view v-if="isShowRecommendQty" class="text_recommend center"> <view class="text_recommend ">
{{Number(recommendQty)}} {{Number(recommendQty)}}
</view> </view>
</view>
</view> </view>
<uom v-show="Number(handleQty)!=0||(isShowRecommendQty&&Number(recommendQty)>0)" :uom="dataContent.uom"></uom> <uom v-show="!isShowStdPack" :uom="dataContent.uom">
</uom>
<!-- <uom v-show="Number(handleQty)!=0||(isShowRecommendQty&&Number(recommendQty)>0)" :uom="dataContent.uom">
</uom> -->
</view> </view>
<view> <view>
<std-pack-qty v-show="isShowStdPack" :dataContent="dataContent"></std-pack-qty> <std-pack-qty v-show="isShowStdPack" :dataContent="dataContent"></std-pack-qty>
@ -81,8 +91,7 @@
}, },
watch: { watch: {
handleQty: { handleQty: {
handler(newName, oldName) { handler(newName, oldName) {},
},
immediate: true, immediate: true,
deep: true deep: true
} }

26
mycomponents/qty/recommendQtyEdit.vue

@ -31,12 +31,13 @@
</view> </view>
</view> </view>
<u-line /> <u-line />
<view class="uni-flex uni-row space-between padding title u-col-center"> <view class="uni-flex uni-row space-between padding title u-col-center">
<text>总数量 : </text> <text>总数量 : </text>
<view class="uni-flex uni-row uni-center" style="align-items: center;"> <view class="uni-flex uni-row uni-center" style="align-items: center;">
<input class="qty_input" v-model="allQty" :focus="false" type="number" <input class="qty_input" v-model="allQty" :focus="false" type="number"
@confirm="confirm()" /> @input="checkNum" @confirm="confirm()" :maxlength="maxlength" />
<uom :uom="dataContent.uom"></uom> <uom :uom="dataContent.uom"></uom>
</view> </view>
</view> </view>
@ -69,7 +70,8 @@
allQty: 0, allQty: 0,
stdCount: 0, stdCount: 0,
labelQty: 0, labelQty: 0,
recommendQty: 0 recommendQty: 0,
maxlength: 10
} }
}, },
watch: { watch: {
@ -104,6 +106,20 @@
}, },
}, },
methods: { methods: {
checkNum(e) {
let value = e.detail.value;
let dot = value.indexOf('.'); //
let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
},
openEditPopup() { openEditPopup() {
this.$refs.popup.open('bottom') this.$refs.popup.open('bottom')
}, },
@ -148,7 +164,8 @@
} else { } else {
if (this.recommendQty != 0) { if (this.recommendQty != 0) {
if (this.allQty > this.recommendQty) { if (this.allQty > this.recommendQty) {
if (this.settingParam.allowBiggerQty != null && this.settingParam.allowBiggerQty == "TRUE") { if (this.settingParam.allowBiggerQty != null && this.settingParam.allowBiggerQty ==
"TRUE") {
this.callback(); this.callback();
} else { } else {
this.$refs.comMessage.showErrorMessage('数量[' + this.allQty + ']不允许大于推荐数量[' + this.$refs.comMessage.showErrorMessage('数量[' + this.allQty + ']不允许大于推荐数量[' +
@ -159,7 +176,8 @@
}) })
} }
} else if (this.allQty < this.recommendQty) { } else if (this.allQty < this.recommendQty) {
if (this.settingParam.allowSmallerQty != null && this.settingParam.allowSmallerQty == "TRUE") { if (this.settingParam.allowSmallerQty != null && this.settingParam.allowSmallerQty ==
"TRUE") {
this.callback(); this.callback();
} else { } else {
this.$refs.comMessage.showErrorMessage('数量[' + this.allQty + ']不允许小于推荐数量[' + this.$refs.comMessage.showErrorMessage('数量[' + this.allQty + ']不允许小于推荐数量[' +

2
mycomponents/recommend/recommend.vue

@ -2,7 +2,7 @@
<view :class="detail.scaned?'scan_view':''" style="background-color: #ffffff; border-bottom: 1upx solid #EEEEEE;"> <view :class="detail.scaned?'scan_view':''" style="background-color: #ffffff; border-bottom: 1upx solid #EEEEEE;">
<view class="uni-flex uni-row space-between" style="align-items: center"> <view class="uni-flex uni-row space-between" style="align-items: center">
<!-- uni-inline-item 暂时拿掉--> <!-- uni-inline-item 暂时拿掉-->
<view style="word-break: break-all;width: 50%;"> <view style="word-break: break-all;">
<pack v-if="isShowPack" :packingCode="detail.packingNumber"></pack> <pack v-if="isShowPack" :packingCode="detail.packingNumber"></pack>
<batch v-if="isShowBatch" :batch="detail.batch"></batch> <batch v-if="isShowBatch" :batch="detail.batch"></batch>
<location v-if="isShowFromLocation" title="来源库位" :locationCode="detail.fromLocationCode"> <location v-if="isShowFromLocation" title="来源库位" :locationCode="detail.fromLocationCode">

13
mycomponents/recommend/recommendCount.vue

@ -10,15 +10,16 @@
<location v-if="isShowToLocation" title="目标库位" :locationCode="detail.toLocationCode"> <location v-if="isShowToLocation" title="目标库位" :locationCode="detail.toLocationCode">
</location> </location>
</view> </view>
<view> <view class="uni-flex uni-row center">
<!-- <recommend-qty v-if="detail.handleQty==null || detail.handleQty==undefined" :dataContent="detail" <!-- <recommend-qty v-if="detail.handleQty==null || detail.handleQty==undefined" :dataContent="detail"
:isShowStdPack="false"></recommend-qty> --> :isShowStdPack="false"></recommend-qty> -->
<compare-qty :dataContent="detail" :recommendQty="Number(detail.qty)" :isShowRecommendQty="isShowRecommendQty" <!-- {{detail.scaned}} -->
<compare-qty :dataContent="detail" :recommendQty="Number(detail.qty)"
:isShowRecommendQty="isShowRecommendQty" :isShowStatus="isShowRecommendQty || detail.scaned==true"
:handleQty="Number(detail.handleQty)" :isShowStdPack="false"> :handleQty="Number(detail.handleQty)" :isShowStdPack="false">
</compare-qty> </compare-qty>
<view class="uni-flex uni-row" style="vertical-align:center" v-if="isDevlement()"> <view class="uni-flex uni-row" style="vertical-align:center" v-if="isDevlement()">
<text style="font-size: 30rpx;color: #2979ff; " <text style="font-size: 30rpx;color: #2979ff; " @click="copy">复制采购</text>
@click="copy">复制采购</text>
<text style="font-size: 30rpx;color: #2979ff;" @click="copyPro">|制品</text> <text style="font-size: 30rpx;color: #2979ff;" @click="copyPro">|制品</text>
</view> </view>
</view> </view>
@ -73,7 +74,7 @@
type: String, type: String,
default: '库位' default: '库位'
}, },
isShowRecommendQty:{ isShowRecommendQty: {
type: Boolean, type: Boolean,
default: true default: true
} }
@ -109,7 +110,7 @@
} }
) )
}, },
isDevlement(){ isDevlement() {
return getApp().globalData.isDevelopment; return getApp().globalData.isDevelopment;
} }
} }

10
mycomponents/record/recordComDetailCard.vue

@ -6,7 +6,7 @@
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeItem($event,dataContent)" :right-options="removeOptions"> <uni-swipe-action-item @click="removeItem($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty" <item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty"
:isShowBalance="true" :showItemQty="isShowItemQty"></item-qty> :isShowBalance="true" :isShowBalanceQty="isShowBalanceQty"></item-qty>
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
</template> </template>
@ -86,9 +86,9 @@
default: true default: true
}, },
isShowItemQty: { isShowBalanceQty: {
type: Boolean, type: Boolean,
default: true default: false
}, },
}, },
watch: { watch: {
@ -129,7 +129,7 @@
methods: { methods: {
removeItem(e, dataContent) { removeItem(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')
@ -150,7 +150,7 @@
edit(item) { edit(item) {
this.editItem = item; this.editItem = item;
this.$refs.balanceQtyEdit.openEditPopup(this.editItem, this.editItem.qty); this.$refs.balanceQtyEdit.openEditPopup(this.editItem, this.editItem.handleQty);
}, },
detail(item) { detail(item) {

33
mycomponents/scan/winComScan.vue

@ -10,7 +10,7 @@
@input="handelScanMsg" :cursor="cursorIndex"></textarea> @input="handelScanMsg" :cursor="cursorIndex"></textarea>
</view> </view>
<view class="uni-flex uni-row space-between u-col-center" > <view class="uni-flex uni-row space-between u-col-center">
<!-- <view class="paizhao" @click="scanQRCode()" v-if="true"> <!-- <view class="paizhao" @click="scanQRCode()" v-if="true">
<image src="/static/icons/icons_camera.svg" alt="" /> <image src="/static/icons/icons_camera.svg" alt="" />
</view> --> </view> -->
@ -84,7 +84,7 @@
type: Boolean, type: Boolean,
default: true default: true
}, },
headerType:{ headerType: {
type: String, type: String,
default: 'HPQ' //HLB HMQ HCQ HPQ default: 'HPQ' //HLB HMQ HCQ HPQ
} }
@ -103,7 +103,7 @@
} }
}, },
mounted() { mounted() {
if(document.querySelector('textarea')!=null){ if (document.querySelector('textarea') != null) {
document.querySelector('textarea').setAttribute('inputmode', 'none') document.querySelector('textarea').setAttribute('inputmode', 'none')
} }
// if (this.$el.querySelector('textarea') != null) { // if (this.$el.querySelector('textarea') != null) {
@ -134,31 +134,34 @@
this.handelScanMsg(); this.handelScanMsg();
}, },
handelScanMsg() { handelScanMsg() {
let that = this;
// //
// uni.showLoading({
// title: '...',
// mask: true
// })
let that = this;
let index = that.scanMsg.indexOf('\n'); let index = that.scanMsg.indexOf('\n');
if (index > 0) { if (index >= 0) {
// that.scanMsg = 'HPQ;V1.0;ICE115F11161AG;PP20230427000027;B20230427002;Q50'; // that.scanMsg = 'HPQ;V1.0;ICE115F11161AG;PP20230427000027;B20230427002;Q50';
setTimeout(() => { setTimeout(() => {
that.losefocus(); that.losefocus();
let content = uni.$u.trim(that.scanMsg) let content = uni.$u.trim(that.scanMsg)
if (content == "") { if (content == "") {
//
// this.$refs.comMessage.showErrorMessage('', res => {
// if (res) {
// that.getfocus();
// }
// })
that.getfocus(); that.getfocus();
this.$refs.comMessage.showErrorMessage("扫描内容为空,请重新扫描", res => {
if (res) {
that.scanMsg=""
that.getfocus();
}
})
return; return;
} }
if (that.isShowHistory) { if (that.isShowHistory) {
that.scanList.unshift(content); that.scanList.unshift(content);
} }
getLabelInfo(content, this.headerType, callback => {
getLabelInfo(content,this.headerType, callback => { // uni.hideLoading();
let scanResult = callback; let scanResult = callback;
if (scanResult.success) { if (scanResult.success) {
that.clear(); that.clear();

99
mycomponents/scan/winScanItem.vue

@ -13,26 +13,40 @@
</view> </view>
<view class=""> <view class="">
<view class=""> <view class="">
<win-com-scan ref="scan" @getResult="getScanResult" :placeholder='title' :clearResult="false"> <win-com-scan ref="scan" @getResult="getScanResult" :placeholder='title' :clearResult="false"
headerType="HMQ,HPQ">
</win-com-scan> </win-com-scan>
</view> </view>
</view> </view>
</view> </view>
</uni-popup> </uni-popup>
<comMessage ref="comMessage"></comMessage>
</view> </view>
</template> </template>
<script> <script>
import {
getBasicItemByCode
} from '@/api/request2.js';
import {
checkDirectoryItemExist,
getListItemTypeDesc,
getItemTypeInfo
} from '@/common/directory.js';
import winComScan from '@/mycomponents/scan/winComScan.vue' import winComScan from '@/mycomponents/scan/winComScan.vue'
import comMessage from '@/mycomponents/common/comMessage.vue'
export default { export default {
name: 'winScanItem', name: 'winScanItem',
components: { components: {
winComScan winComScan,
comMessage
}, },
emits: ["getScanCode"], emits: ["getScanCode", 'getScanResult'],
props: { props: {
title: { title: {
type: String, type: String,
@ -41,11 +55,16 @@
isShowRecord: { isShowRecord: {
type: Boolean, type: Boolean,
default: true default: true
} },
itemCodeTypeList: {
type: Array,
default: []
},
}, },
data() { data() {
return { return {
code: '', code: '',
result: {},
isShow: false, isShow: false,
expand: false, expand: false,
scanList: [], scanList: [],
@ -76,20 +95,76 @@
this.$refs.scan.clearScanValue(); this.$refs.scan.clearScanValue();
}, },
getScanResult(result) { getScanResult(result) {
if (result.label.barType == "QRCode") { uni.showLoading({
this.code = result.label.itemCode; title: '扫描中...',
} else if (result.label.barType == "BarCode") { mask: true
this.code = result.label.code; });
var scanResult = result;
if (scanResult.label.barType == "QRCode") {
this.code = scanResult.label.itemCode;
} else if (scanResult.label.barType == "BarCode") {
this.code = scanResult.label.code;
}
if (this.code == undefined) {
uni.hideLoading();
this.showErrorMessage("扫描物料[" + this.code + "]为空,请输入正确的物料")
return
} }
this.callBack(); getBasicItemByCode(this.code).then(res => {
uni.hideLoading();
if (res.data != null && res.data.list.length > 0) {
var result =res.data.list[0];
var status =result.status;
var type = result.type;
var itemCode = result.code
var itemName =result.name
var uom = result.uom
var std = result.uom
result.package = scanResult.package
if(status=="ENABLE"){
if(checkDirectoryItemExist(this.itemCodeTypeList,type)){
this.result =result;
this.callBack()
}else {
var hint = getListItemTypeDesc(this.itemCodeTypeList);
this.showErrorMessage("扫描物料[" + this.code + "]是[" +
getItemTypeInfo(type).label + "],需要的物料类型是[" + hint + "]")
}
}else {
this.showErrorMessage('物料【' + this.code + '】不可用');
}
} else {
this.showErrorMessage('未查找到物料【' + this.code + '】');
}
}).catch(error => {
uni.hideLoading();
this.showErrorMessage(error)
})
}, },
callBack() { callBack() {
this.closeScanPopup();
this.$refs.scan.clear(); this.$refs.scan.clear();
this.$emit("getScanCode", this.code); // this.$emit("getScanCode", this.code);
this.$emit("getScanResult", this.code, this.result);
}, },
change(e) { change(e) {
this.isShow = e.show this.isShow = e.show
} },
showErrorMessage(message) {
this.losefocus();
this.$refs.comMessage.showErrorMessage(message, res => {
this.code = '';
this.getfocus();
})
},
getfocus() {
this.$refs.scan.getfocus();
},
losefocus() {
this.$refs.scan.losefocus();
},
} }
} }
</script> </script>

134
mycomponents/scan/winScanPackAndLocation.vue

@ -28,14 +28,13 @@
<view v-if='allowModifyLocation'> <view v-if='allowModifyLocation'>
<uni-combox :candidates="fromLocationList" v-model="fromLocationCode" placeholder="请扫描来源库位" <uni-combox :candidates="fromLocationList" v-model="fromLocationCode" placeholder="请扫描来源库位"
@confirm="scanLocation" style='height: 30rpx;border:1px solid #fff ;'></uni-combox> @confirm="" style='height: 30rpx;border:1px solid #fff ;'></uni-combox>
</view> </view>
<view v-else> <view v-else>
<text style="padding: 5px"> <text style="padding: 5px">
{{fromLocationCode}} {{fromLocationCode}}
</text> </text>
</view> </view>
</view> </view>
</view> </view>
<view class=""> <view class="">
@ -72,7 +71,7 @@
} from '@/common/directory.js'; } from '@/common/directory.js';
export default { export default {
name: 'winScanPack', name: 'winScanPack',
emits: ["getResult", "close"], emits: ["getResult", "close", "getCountScanResult"],
components: { components: {
winComScan, winComScan,
comMessage, comMessage,
@ -91,6 +90,11 @@
type: Boolean, type: Boolean,
default: false default: false
}, },
//
noShowBalanceMessage: {
type: Boolean,
default: false
},
// //
allowModifyLocation: { allowModifyLocation: {
type: Boolean, type: Boolean,
@ -117,7 +121,8 @@
businessType: {}, businessType: {},
inventoryStatus: [], inventoryStatus: [],
managementPrecision: '', managementPrecision: '',
fromInventoryStatuses: "" fromInventoryStatuses: "",
isCheck:false
} }
}, },
created() { created() {
@ -163,20 +168,30 @@
this.$emit("close", ''); this.$emit("close", '');
}, },
scanLocation() {
scanLocation(scanResult) {
var isCheck = false;
if (this.fromLocationCode == '') { if (this.fromLocationCode == '') {
this.showMessage('来源库位不能为空', callback => { this.showErrorMessage('来源库位不能为空', callback => {
this.locationGetFocus(); this.locationGetFocus();
}) })
return; return;
} }
if(this.fromLocationList.length>0){
if(!this.isInLocationList(this.fromLocationCode)){
this.showErrorMessage("扫描库位【"+this.fromLocationCode+'】不在任务来源库位中', callback => {
this.locationGetFocus();
})
return;
}
}
uni.showLoading({ uni.showLoading({
title: '扫描中...', title: '扫描中...',
mask: true mask: true
}); });
getBasicLocationByCode(this.fromLocationCode).then(res => { getBasicLocationByCode(this.fromLocationCode).then(res => {
uni.hideLoading();
if (res.data.total > 0) { if (res.data.total > 0) {
let result = res.data.list[0]; let result = res.data.list[0];
var type = result.type; var type = result.type;
@ -184,8 +199,10 @@
if (available == "TRUE") { if (available == "TRUE") {
if (checkDirectoryItemExist(this.fromLocationTypeArray, type)) { if (checkDirectoryItemExist(this.fromLocationTypeArray, type)) {
this.location = result; this.location = result;
this.packGetFocus(); // this.packGetFocus();
this.checkPackage(scanResult);
} else { } else {
uni.hideLoading();
var hint = getListLocationTypeDesc(this.fromLocationTypeArray); var hint = getListLocationTypeDesc(this.fromLocationTypeArray);
this.showErrorMessage("库位[" + this.fromLocationCode + "]是" + this.showErrorMessage("库位[" + this.fromLocationCode + "]是" +
getLocationTypeName(type) + ",<br>需要的库位类型是[" + hint + "]", callback => { getLocationTypeName(type) + ",<br>需要的库位类型是[" + hint + "]", callback => {
@ -193,11 +210,13 @@
}) })
} }
} else { } else {
uni.hideLoading();
this.showErrorMessage("扫描库位[" + this.fromLocationCode + "]不可用", res => { this.showErrorMessage("扫描库位[" + this.fromLocationCode + "]不可用", res => {
this.locationGetFocus(); this.locationGetFocus();
}) })
} }
} else { } else {
uni.hideLoading();
this.showErrorMessage('未查询到库位[' + this.fromLocationCode + ']', res => { this.showErrorMessage('未查询到库位[' + this.fromLocationCode + ']', res => {
this.locationGetFocus(); this.locationGetFocus();
}) })
@ -210,35 +229,50 @@
}) })
}, },
getScanResult(result) { getScanResult(result) {
console.log("扫描", result) // console.log("", result)
if (this.fromLocationCode == '' || this.fromLocationCode == null) { // if (this.fromLocationCode == '' || this.fromLocationCode == null) {
this.showMessage('请先扫描来源库位', callback => { // this.showMessage('', callback => {
this.locationGetFocus(); // this.locationGetFocus();
}) // })
return; // return;
} else { // } else
if (result.label != null) { this.scanLocation(result);
this.scanResult = result; // debugger
getBalanceByManagementPrecision(result.label, this.fromLocationCode, this.fromInventoryStatuses, // if(this.isCheck){
res => { // this.checkPackage(result);
if (res.success) { // }
this.managementPrecision = res.managementPrecision },
this.afterQueryBalance(res.data.list);
} else { checkPackage(result){
this.showErrorMessage(res.message, res => { if (result.label != null) {
this.packGetFocus(); this.scanResult = result;
}) // uni.showLoading({
} // title: '...',
// mask: true
}); // })
} getBalanceByManagementPrecision(result.label, this.fromLocationCode, this.fromInventoryStatuses,
res => {
uni.hideLoading();
if (res.success) {
this.managementPrecision = res.managementPrecision
this.afterQueryBalance(res.data.list);
} else {
this.showErrorMessage(res.message, res => {
this.packGetFocus();
})
}
// uni.hideLoading();
});
} }
}, },
afterQueryBalance(datas) { afterQueryBalance(datas) {
if (this.allowNullBalance) { if (this.allowNullBalance) {
this.allowNoneBalance(datas); this.allowNoneBalance(datas);
} else if (this.noShowBalanceMessage) {
this.countCallBack(datas);
} else { } else {
this.mustHavaBalance(datas); this.mustHavaBalance(datas);
} }
@ -267,7 +301,7 @@
this.packCallBack(balance); this.packCallBack(balance);
// 20231228 // 20231228
// if (balance.qty > 0) { // if (balance.qty > 0) {
// this.packCallBack(balance); // this.packCallBack(balance);
// } else { // } else {
@ -298,6 +332,20 @@
// } // }
}, },
//
countCallBack(datas) {
this.$refs.comscan.clear();
//
let data = {
label: this.scanResult.label,
package: this.scanResult.package,
balance: datas,
fromLocationCode: this.fromLocationCode,
}
this.packGetFocus();
this.$emit("getCountScanResult", data);
},
packCallBack(item) { packCallBack(item) {
this.$refs.comscan.clear(); this.$refs.comscan.clear();
// //
@ -334,22 +382,22 @@
let status = getInventoryStatusDesc(this.inventoryStatus); let status = getInventoryStatusDesc(this.inventoryStatus);
switch (this.managementPrecision) { switch (this.managementPrecision) {
case 'BY_PACKAGING': case 'BY_PACKAGING':
condition = condition + '零件号=[' + label.itemCode + ']<br>箱码=[' + label.packingNumber + condition = condition + '物料号=[' + label.itemCode + ']<br>箱码=[' + label.packingNumber +
']<br>批次=[' + ']<br>批次=[' +
label.batch + label.batch +
']<br>库位=[' + this.fromLocationCode + ']' ']<br>库位=[' + this.fromLocationCode + ']'
break; break;
case 'BY_BATCH': case 'BY_BATCH':
condition = condition + '零件号=[' + label.itemCode + ']<br>批次=[' + condition = condition + '物料号=[' + label.itemCode + ']<br>批次=[' +
label.batch + label.batch +
']<br>库位=[' + this.fromLocationCode + ']' ']<br>库位=[' + this.fromLocationCode + ']'
break; break;
case 'BY_QUANTITY': case 'BY_QUANTITY':
condition = condition + '零件号=[' + label.itemCode + ']<br>库位=[' + this.fromLocationCode + ']' condition = condition + '物料号=[' + label.itemCode + ']<br>库位=[' + this.fromLocationCode + ']'
break; break;
case 'BY_UNIQUEID': case 'BY_UNIQUEID':
condition = condition + '零件号=[' + label.itemCode + ']' condition = condition + '物料号=[' + label.itemCode + ']'
break; break;
} }
if (this.inventoryStatus.length > 0) { if (this.inventoryStatus.length > 0) {
@ -376,6 +424,20 @@
change(e) { change(e) {
this.show = e.show this.show = e.show
}, },
isInLocationList(location) {
var item = this.fromLocationList.find(res => res == location)
if (item = undefined) {
return false
}
return true
},
addLocationCode(code) {
if (!this.isInLocationList(code)) {
this.fromLocationList.push(code)
}
}
} }
} }
</script> </script>

16
mycomponents/scan/winScanPackAndPosition.vue

@ -94,7 +94,6 @@
}, },
methods: { methods: {
openScanPopup() { openScanPopup() {
if (this.positionList.length == 0) { if (this.positionList.length == 0) {
uni.showLoading({ uni.showLoading({
title: "数据加载中....", title: "数据加载中....",
@ -111,6 +110,21 @@
this.$refs.popup.open('bottom'); this.$refs.popup.open('bottom');
}, },
initData(){
this.positionInfo = "请选择位置";
this.positionList = [];
this.productionLineCode = '';
this.rawLocationCode = "";
this.fgLocationCode = "";
this.workshopCode = "";
this.workStationCode ="";
this.workShopName = "";
this.productionLineName="";
this.workStationName="";
this.show = false;
this.isEditPosition = true
},
closeScanPopup() { closeScanPopup() {
this.$refs.popup.close(); this.$refs.popup.close();

3
mycomponents/status/balanceStatus.vue

@ -3,7 +3,8 @@
<status :status='status' style='font-size: 70rpx;'></status> <status :status='status' style='font-size: 70rpx;'></status>
<text :class="statusStyle(status)" style='font-size: 38rpx;margin-right: 15rpx;'> <text :class="statusStyle(status)" style='font-size: 38rpx;margin-right: 15rpx;'>
{{statusDesc(status) }}</text> {{statusDesc(status) }}</text>
<image style="width: 40rpx; height:40rpx" src="/static/icons/icons_edit.svg" v-show="allowEdit" @click="open"> <!-- v-show="allowEdit" -->
<image v-if="allowEdit" style="width: 40rpx; height:40rpx" src="/static/icons/icons_edit.svg" @click="open">
</image> </image>
</view> </view>
<status-edit :status='status' ref="statusEdit" @updateStatus="updateStatus"></status-edit> <status-edit :status='status' ref="statusEdit" @updateStatus="updateStatus"></status-edit>

10
mycomponents/workStation/workStation.vue

@ -2,6 +2,11 @@
<view class="header_job_top"> <view class="header_job_top">
<view class="cen_card"> <view class="cen_card">
<view class="cell_box uni-flex uni-row"> <view class="cell_box uni-flex uni-row">
<view class="cell_info" v-if="fromWarehouseCode!=''">
<view class="text_lightblue">仓库</view>
<view>{{fromWarehouseCode}}</view>
</view>
<view class="cell_info"> <view class="cell_info">
<view class="text_lightblue">车间</view> <view class="text_lightblue">车间</view>
<view>{{workshopCode}}</view> <view>{{workshopCode}}</view>
@ -37,6 +42,11 @@
watch: {}, watch: {},
props: { props: {
fromWarehouseCode:{
type: String,
default: ""
},
workshopCode: { workshopCode: {
type: String, type: String,
default: "" default: ""

20
pages.json

@ -263,7 +263,7 @@
{ {
"path": "pages/putaway/job/putawayJob", "path": "pages/putaway/job/putawayJob",
"style": { "style": {
"navigationBarTitleText": "原料上架", "navigationBarTitleText": "采购上架",
"enablePullDownRefresh": false, "enablePullDownRefresh": false,
"titleNView": { "titleNView": {
// "autoBackButton": "true", // "autoBackButton": "true",
@ -292,21 +292,21 @@
{ {
"path": "pages/putaway/job/putawayDetail", "path": "pages/putaway/job/putawayDetail",
"style": { "style": {
"navigationBarTitleText": "原料上架详情", "navigationBarTitleText": "采购上架详情",
"enablePullDownRefresh": false "enablePullDownRefresh": false
} }
}, },
{ {
"path": "pages/putaway/record/putawayRecord", "path": "pages/putaway/record/putawayRecord",
"style": { "style": {
"navigationBarTitleText": "原料上架记录", "navigationBarTitleText": "采购上架记录",
"enablePullDownRefresh": false "enablePullDownRefresh": false
} }
}, },
{ {
"path": "pages/putaway/request/putawayRequest", "path": "pages/putaway/request/putawayRequest",
"style": { "style": {
"navigationBarTitleText": "原料上架申请", "navigationBarTitleText": "采购上架申请",
"enablePullDownRefresh": true, "enablePullDownRefresh": true,
"titleNView": { "titleNView": {
// "autoBackButton": "true", // "autoBackButton": "true",
@ -333,14 +333,14 @@
{ {
"path": "pages/putaway/request/putawayRequestDetail", "path": "pages/putaway/request/putawayRequestDetail",
"style": { "style": {
"navigationBarTitleText": "原料上架申请详情", "navigationBarTitleText": "采购上架申请详情",
"enablePullDownRefresh": false "enablePullDownRefresh": false
} }
}, },
{ {
"path": "pages/putaway/request/putawayRequestCreate", "path": "pages/putaway/request/putawayRequestCreate",
"style": { "style": {
"navigationBarTitleText": "原料上架申请创建", "navigationBarTitleText": "采购上架申请创建",
"enablePullDownRefresh": false "enablePullDownRefresh": false
} }
}, },
@ -466,7 +466,7 @@
{ {
"path": "pages/issue/record/issueRecord", "path": "pages/issue/record/issueRecord",
"style": { "style": {
"navigationBarTitleText": "直接发料", "navigationBarTitleText": "直接发料记录",
"enablePullDownRefresh": true, "enablePullDownRefresh": true,
"titleNView": { "titleNView": {
"autoBackButton": "true" "autoBackButton": "true"
@ -561,14 +561,14 @@
{ {
"path": "pages/productionReturn/record/returnToStore", "path": "pages/productionReturn/record/returnToStore",
"style": { "style": {
"navigationBarTitleText": "合格退料", "navigationBarTitleText": "合格退料记录",
"enablePullDownRefresh": false "enablePullDownRefresh": false
} }
}, },
{ {
"path": "pages/productionReturn/record/returnToHold", "path": "pages/productionReturn/record/returnToHold",
"style": { "style": {
"navigationBarTitleText": "隔离退料", "navigationBarTitleText": "隔离退料记录",
"enablePullDownRefresh": false "enablePullDownRefresh": false
} }
}, },
@ -671,7 +671,7 @@
"path": "pages/query/item", "path": "pages/query/item",
"style": { "style": {
"enablePullDownRefresh": false, // "enablePullDownRefresh": false, //
"navigationBarTitleText": "按零件查询库存", "navigationBarTitleText": "按物料查询库存",
"titleNView": { "titleNView": {
"autoBackButton": "true", "autoBackButton": "true",
"buttons": [{}] "buttons": [{}]

2
pages/container/coms/comContainerBindCard.vue

@ -131,7 +131,7 @@
methods: { methods: {
removeData(e, dataContent) { removeData(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

4
pages/container/coms/comPalletRecord.vue

@ -5,7 +5,7 @@
<template v-slot:title> <template v-slot:title>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions"> <uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty" <item-qty :dataContent="dataContent"
:isShowBalance="true"></item-qty> :isShowBalance="true"></item-qty>
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
@ -123,7 +123,7 @@
methods: { methods: {
removeData(e, dataContent) { removeData(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

6
pages/container/record/containerBindRecord.vue

@ -57,6 +57,10 @@
getDirectoryItemArray getDirectoryItemArray
} from '@/common/directory.js'; } from '@/common/directory.js';
import {
calc
} from '@/common/calc.js';
import { import {
getBusinessType, getBusinessType,
createItemInfo, createItemInfo,
@ -226,7 +230,7 @@
item.subList.push(newDetail); item.subList.push(newDetail);
items.push(item) items.push(item)
} else { } else {
item.qty += detail.qty item.qty = calc.add(item.qty,detail.qty)
let newDetail = this.createDetailInfo(detail); // let newDetail = this.createDetailInfo(detail); //
item.subList.push(newDetail); item.subList.push(newDetail);
} }

8
pages/container/record/containerUnBindRecord.vue

@ -51,6 +51,10 @@
import { import {
goHome goHome
} from '@/common/basic.js'; } from '@/common/basic.js';
import {
calc
} from '@/common/calc.js';
import { import {
getDirectoryItemArray getDirectoryItemArray
@ -171,7 +175,7 @@
item.subList.push(newDetail); item.subList.push(newDetail);
items.push(item) items.push(item)
} else { } else {
item.qty += detail.qty item.qty = calc.add(item.qty,detail.qty)
let newDetail = this.createDetailInfo(detail); // let newDetail = this.createDetailInfo(detail); //
item.subList.push(newDetail); item.subList.push(newDetail);
} }
@ -297,7 +301,7 @@
detail.itemCode = detail.itemCode; detail.itemCode = detail.itemCode;
detail.batch = detail.batch; detail.batch = detail.batch;
detail.inventoryStatus = detail.inventoryStatus; detail.inventoryStatus = detail.inventoryStatus;
detail.qty =detail.handleQty;
detail.package = null; detail.package = null;
subList.push(detail) subList.push(detail)
} }

27
pages/count/coms/comCountDetailCard.vue

@ -5,19 +5,25 @@
<template v-slot:title> <template v-slot:title>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions"> <uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty"></item-qty> <item-qty v-if="settingParam.isOpenCount=='TRUE'" :dataContent="dataContent"
:handleQty="dataContent.handleQty" :isShowBalanceQty="false">
</item-qty>
<item-qty v-else :dataContent="dataContent" :handleQty="dataContent.handleQty"
:isShowBalanceQty="true" :showRecommendQty="false" :showStdPack="true">
</item-qty>
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
</template> </template>
<u-line />
<view class="" v-for="(item,index) in dataContent.subList"> <view class="" v-for="(item,index) in dataContent.subList">
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="swipeClick($event,item)" <uni-swipe-action-item @click="swipeClick($event,item)"
:right-options="item.scaned?scanOptions:detailOptions"> :right-options="item.scaned?scanOptions:detailOptions">
<recommendCount :detail="item" :isShowFromLocation="false" :isShowRecommendQty="settingParam.isOpenCount=='TRUE'"></recommendCount> <recommend-count :detail="item" :isShowFromLocation="false" style='margin:1px 0px;'
:isShowRecommendQty="settingParam.isOpenCount=='TRUE'">
</recommend-count>
<u-line />
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
<u-line color="#D8D8D8"></u-line>
</view> </view>
</uni-collapse-item> </uni-collapse-item>
</uni-collapse> </uni-collapse>
@ -28,6 +34,7 @@
<script> <script>
import itemQty from '@/mycomponents/item/itemQty.vue' import itemQty from '@/mycomponents/item/itemQty.vue'
import item from '@/mycomponents/item/item.vue'
import recommendCount from '@/mycomponents/recommend/recommendCount.vue' import recommendCount from '@/mycomponents/recommend/recommendCount.vue'
import detailInfoPopup from '@/pages/count/coms/detailInfoPopup.vue' import detailInfoPopup from '@/pages/count/coms/detailInfoPopup.vue'
import comMessage from '@/mycomponents/common/comMessage.vue' import comMessage from '@/mycomponents/common/comMessage.vue'
@ -40,6 +47,7 @@
export default { export default {
components: { components: {
item,
itemQty, itemQty,
recommendCount, recommendCount,
detailInfoPopup, detailInfoPopup,
@ -97,10 +105,16 @@
methods: { methods: {
removeData(e, dataContent) { removeData(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空该物料下面扫描的信息吗?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') dataContent.handleQty = 0;
dataContent.subList.forEach(res=>{
res.scaned = false;
res.handleQty= 0
})
this.$emit('clear')
// this.$emit('removeItem', this.dataContent) // this.$emit('removeItem', this.dataContent)
} }
}); });
@ -120,7 +134,6 @@
this.$emit("editItem", detail) this.$emit("editItem", detail)
}, },
detail(item) { detail(item) {
this.showItem = item; this.showItem = item;
this.$refs.detailInfoPopup.openPopup(item); this.$refs.detailInfoPopup.openPopup(item);

797
pages/count/job/countDetail.vue

@ -48,10 +48,12 @@
</view> </view>
<win-scan-button @goScan='openScanPopup'></win-scan-button> <win-scan-button @goScan='openScanPopup'></win-scan-button>
<win-scan-pack-and-location ref="scanPopup" @getResult='getScanResult'></win-scan-pack-and-location> <win-scan-pack-and-location ref="scanPopup" :noShowBalanceMessage="true" @getCountScanResult='getScanResult'>
<count-qty-edit ref="countQtyEdit" @confirm="editConfirm" :isShowStatus="true" :allowEditStatus="false" </win-scan-pack-and-location>
:isShowBalance="jobContent.isOpenCount=='TRUE'"> <count-qty-edit ref="countQtyEdit" @confirm="editConfirm" @close="editClose" :isShowStatus="true"
:allowEditStatus="editInventoryStatus" :isShowBalance="jobContent.isOpenCount=='TRUE'">
</count-qty-edit> </count-qty-edit>
<balance-select ref="balanceSelect" @onSelectItem='selectBalanceItem'></balance-select>
<com-message ref="comMessage"></com-message> <com-message ref="comMessage"></com-message>
</view> </view>
</template> </template>
@ -63,6 +65,9 @@
cancleTakeCountJob, cancleTakeCountJob,
countJobSubmit countJobSubmit
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import { import {
goHome, goHome,
@ -72,7 +77,7 @@
import { import {
getCountStageName getCountStageName
} from '@/common/directory.js'; } from '@/common/directory.js';
import { calc } from '@/common/calc'
import winScanButton from '@/mycomponents/scan/winScanButton.vue' import winScanButton from '@/mycomponents/scan/winScanButton.vue'
import winScanPack from '@/mycomponents/scan/winScanPack.vue' import winScanPack from '@/mycomponents/scan/winScanPack.vue'
@ -82,6 +87,7 @@
import winScanPackAndLocation from "@/mycomponents/scan/winScanPackAndLocation.vue" import winScanPackAndLocation from "@/mycomponents/scan/winScanPackAndLocation.vue"
import countQtyEdit from '@/mycomponents/qty/countQtyEdit.vue' import countQtyEdit from '@/mycomponents/qty/countQtyEdit.vue'
import jobTop from '@/mycomponents/job/jobTop.vue' import jobTop from '@/mycomponents/job/jobTop.vue'
import balanceSelect from '@/mycomponents/balance/balanceSelect.vue'
export default { export default {
name: 'receipt_detail', name: 'receipt_detail',
@ -93,20 +99,25 @@
comMessage, comMessage,
winScanPackAndLocation, winScanPackAndLocation,
countQtyEdit, countQtyEdit,
jobTop jobTop,
balanceSelect
}, },
data() { data() {
return { return {
id: '', id: '',
receiptJob: {}, receiptJob: {},
received: false,
fromLocationCode: '', fromLocationCode: '',
isShowPackingCode: true, isShowPackingCode: true,
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
subList: [], //subList subList: [], //subList
detailSource: [], // detailSource: [], //
itemEditInfo: {} balance: {}, //
editInventoryStatus: false,
package: {}, //
label: {}, //
currentEditItem: {},
jobStatus: ""
}; };
}, },
onLoad(option) { onLoad(option) {
@ -115,7 +126,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -133,7 +143,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from === 'backbutton') { if (e.from === 'backbutton') {
if (this.received) { if (this.jobStatus == "2") {
// //
cancleTakeCountJob(this.id).then(res => { cancleTakeCountJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -143,7 +153,6 @@
} else { } else {
uni.navigateBack(); uni.navigateBack();
} }
return true; return true;
} }
}, },
@ -180,6 +189,7 @@
that.showMessage('未获取到详情'); that.showMessage('未获取到详情');
} else { } else {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status;
that.fromLocationCode = that.jobContent.locationCode; that.fromLocationCode = that.jobContent.locationCode;
that.subList = res.data.subList; that.subList = res.data.subList;
that.detailSource = that.getDataSource(that.subList) that.detailSource = that.getDataSource(that.subList)
@ -203,8 +213,8 @@
item.subList.push(newDetail); item.subList.push(newDetail);
items.push(item) items.push(item)
} else { } else {
console.log("数量",item.qty) console.log("数量", item.qty)
item.qty = calc.add(item.qty,detail.qty) item.qty = calc.add(item.qty, detail.qty)
let newDetail = this.createDetailInfo(detail); // let newDetail = this.createDetailInfo(detail); //
item.subList.push(newDetail); item.subList.push(newDetail);
} }
@ -250,354 +260,551 @@
calcHandleQty() { calcHandleQty() {
for (let item of this.detailSource) { for (let item of this.detailSource) {
item.handleQty = 0; item.handleQty = new Decimal(0).toNumber();
item.qty = new Decimal(0).toNumber();
for (let detail of item.subList) { for (let detail of item.subList) {
if (detail != undefined && detail.scaned) { if (detail!= undefined) {
item.handleQty = calc.add(item.handleQty,detail.qty) if (detail.scaned) {
item.handleQty = calc.add(item.handleQty, detail.handleQty);
} }
item.qty = calc.add(item.qty, detail.qty);
} }
} }
this.$forceUpdate(); }
}, this.$forceUpdate();
},
updateData() {
this.calcHandleQty();
},
editConfirm() { updateData() {
this.calcHandleQty(); this.calcHandleQty();
this.scanPopupGetFocus(); },
},
openScanPopup() { openScanPopup() {
let fromlocationCode = ''; let fromlocationCode = '';
let fromlocationList = []; let fromlocationList = [];
for (var i = 0; i < this.detailSource.length; i++) { for (var i = 0; i < this.detailSource.length; i++) {
let item = this.detailSource[i]; let item = this.detailSource[i];
item.subList.forEach(l => { item.subList.forEach(l => {
// //
var location = fromlocationList.find(res => res == l.fromLocationCode) var location = fromlocationList.find(res => res == l.fromLocationCode)
if (location == undefined) { if (location == undefined) {
fromlocationList.push(l.fromLocationCode); fromlocationList.push(l.fromLocationCode);
} }
// //
if (fromlocationCode == '') { if (fromlocationCode == '') {
if (!l.scaned) { if (!l.scaned) {
fromlocationCode = l.fromLocationCode; fromlocationCode = l.fromLocationCode;
}
} }
}) }
} })
this.$refs.scanPopup.openScanPopupForJob(fromlocationCode, fromlocationList, this.jobContent); }
}, this.$refs.scanPopup.openScanPopupForJob(fromlocationCode, fromlocationList, this.jobContent);
closeScanPopup() { },
if(this.$refs.scanPopup!=undefined){
this.$refs.scanPopup.closeScanPopup();
}
},
scanPopupGetFocus() { closeScanPopup() {
if(this.$refs.scanPopup!=undefined){ if (this.$refs.scanPopup != undefined) {
this.$refs.scanPopup.packGetFocus(); this.$refs.scanPopup.closeScanPopup();
} }
}, },
getScanResult(result) { scanPopupGetFocus() {
try { if (this.$refs.scanPopup != undefined) {
var packingNumber = result.balance.packingNumber; this.$refs.scanPopup.packGetFocus();
var batch = result.balance.batch; }
var balanceQty = result.balance.qty; },
var itemCode = result.balance.itemCode;
var inventoryStatus = result.balance.inventoryStatus;
var detail = this.detailSource.find(r => r.itemCode == itemCode);
var itemEditInfo;
//
if (detail == undefined) {
//
this.addNewItemCodeToList(result)
} else {
//
itemEditInfo = detail.subList.find(item => { scanPopupLoseFocus() {
if (item.packingNumber == packingNumber && if (this.$refs.scanPopup != undefined) {
item.batch == batch && this.$refs.scanPopup.packLoseFocus();
item.inventoryStatus == inventoryStatus) { }
return item; },
}
})
if (itemEditInfo == undefined) { //
// getScanResult(result) {
this.addExistItemCodeToList(detail, result); if (this.jobContent.isOpenCount) {
this.getOpenCountResult(result);
} else {
this.getUnOpenCountResult(result);
}
},
getOpenCountResult(result) {
try {
let that = this;
that.package = result.package;
that.label = result.label;
var item = this.detailSource.find(r => r.itemCode == that.package.itemCode);
if (item == undefined) {
that.scanByBalance(result);
} else {
// let subItem = item.subList.find(item => {
// if (item.packingNumber == that.label.packingNumber &&
// item.batch == that.label.batch && item.scaned == true) {
// return item;
// }
// })
let subItems = item.subList.filter(item => {
if (item.packingNumber == that.label.packingNumber &&
item.batch == that.label.batch) {
return item;
}
})
//
if (subItems.length > 1) {
let subItem = subItems.find(r => r.scaned == false)
if (subItem == undefined) {
subItem = subItems[0];
that.editCountResult(item, subItem);
} else { } else {
// that.scanByBalance(result);
if (itemEditInfo.scaned) { }
this.$refs.comMessage.showSelectMessageModal("箱码【" + packingNumber + } else if (subItems.length == 1) {
"】已经完成盘点,是否要编辑数量", let subItem = subItems[0];
res => { if (subItem.scaned) {
if (res) { that.editCountResult(item, subItem);
this.$refs.countQtyEdit.openEditPopup(itemEditInfo, // this.$refs.comMessage.showQuestionMessage("" + that.label.packingNumber +
detail.subList); // ",?",
} else { // res => {
this.scanPopupGetFocus(); // if (res) {
} // this.currentEditItem = subItem;
}) // this.$refs.countQtyEdit.openEditPopup(subItem,
// item.subList);
// // this.$refs.countQtyEdit.openEditPopupShowSeconds(subItem,
// // item.subList);
// } else {
// this.scanPopupGetFocus();
// }
// })
} else {
that.scanByBalance(result);
}
} else if (subItems.length == 0) {
that.scanByBalance(result);
}
}
} catch (e) {
this.showErrorMessage(e.message)
}
},
//
editCountResult(item, subItem) {
let that = this;
this.$refs.comMessage.showQuestionMessage("箱码【" + that.label.packingNumber +
"】已经完成盘点,是否要编辑盘点结果?",
res => {
if (res) {
this.currentEditItem = subItem;
this.$refs.countQtyEdit.openEditPopup(subItem,
item.subList);
// this.$refs.countQtyEdit.openEditPopupShowSeconds(subItem,
// item.subList);
} else {
this.scanPopupGetFocus();
}
})
},
getUnOpenCountResult(result) {
try {
let that = this;
that.package = result.package;
that.label = result.label;
var item = this.detailSource.find(r => r.itemCode == that.package.itemCode);
if (item == undefined) {
this.$refs.comMessage.showQuestionMessage("没有物料【" + that.package.itemCode +
"】的盘点明细,是否继续盘点?",
res => {
if (res) {
that.scanByLabel(result);
} else { } else {
itemEditInfo.scaned = true; this.scanPopupGetFocus();
itemEditInfo.handleQty = balanceQty;
itemEditInfo.balanceQty = balanceQty;
itemEditInfo.stdPackQty = result.package.stdPackQty;
itemEditInfo.stdPackUnit = result.package.stdPackUnit;
this.$refs.countQtyEdit.openEditPopupShowSeconds(itemEditInfo, detail
.subList);
this.updateData()
} }
})
} else {
let subItem = item.subList.find(item => {
if (item.packingNumber == that.label.packingNumber &&
item.batch == that.label.batch && item.scaned == true) {
return item;
} }
})
if (subItem != undefined) {
this.$refs.comMessage.showQuestionMessage("箱码【" + that.label.packingNumber +
"】已经完成盘点,是否要编辑盘点结果?",
res => {
if (res) {
this.currentEditItem = subItem;
this.$refs.countQtyEdit.openEditPopup(subItem,
item.subList);
} else {
this.scanPopupGetFocus();
}
})
} else {
that.scanByLabel(result);
} }
} catch (e) {
this.showErrorMessage(e.message)
} }
}, } catch (e) {
this.showErrorMessage(e.message)
}
},
addNewItemCodeToList(result) { //
this.$refs.comMessage.showSelectMessageModal("物料[" + result.balance.itemCode + "]不在列表中,是否添加到列表?", scanByBalance(result) {
let that = this;
if (result.balance.length == 0) {
that.scanPopupLoseFocus()
that.$refs.comMessage.showQuestionMessage("该包装在来源库位[" + that.fromLocationCode +
"],未查找到库存,是否继续盘点?",
res => { res => {
if (res) { if (res) {
var item = this.createAddItemInfo(result.balance, result.package); that.editInventoryStatus = true;
let newDetail = this.createAddDetailInfo(result.balance, result.package); // let item = that.package;
item.subList.push(newDetail); item.packingNumber = that.label.packingNumber;
this.detailSource.push(item) item.qty = 0
this.updateData() item.handleQty = Number(that.label.qty);
item.balanceQty = 0;
item.inventoryStatus = "OK";
that.balance = item;
that.$refs.countQtyEdit.openEditPopupShowSeconds(item,
null);
} else {
//
that.scanPopupGetFocus();
} }
}) })
} else if (result.balance.length == 1) {
this.countByBalance(result.balance[0]);
} else {
//
this.$refs.balanceSelect.openPopup(result.balance);
}
},
}, //
scanByLabel(result) {
let that = this;
that.scanPopupLoseFocus()
let item = that.package;
item.packingNumber = that.label.packingNumber;
item.qty = 0
item.handleQty = Number(that.label.qty);
item.balanceQty = 0;
item.inventoryStatus = "OK";
that.balance = item;
that.$refs.countQtyEdit.openEditPopupShowSeconds(item,
null);
},
addExistItemCodeToList(detail, result) { selectBalanceItem(balance) {
this.$refs.comMessage.showSelectMessageModal("箱码[" + result.balance.packingNumber + this.countByBalance(balance);
"]不在列表中,是否添加到列表?", },
res => {
if (res) { countByBalance(balance) {
detail.qty += Number(detail.qty) this.balance = balance;
let newDetail = this.createAddDetailInfo(result.balance, result.package); // // this.balance.qty = 0
detail.subList.push(newDetail); this.balance.handleQty = Number(this.label.qty);
this.updateData() this.balance.balanceQty = this.balance.qty;
this.balance.stdPackQty = this.package.stdPackQty;
this.balance.stdPackUnit = this.package.stdPackUnit;
this.$refs.countQtyEdit.openEditPopupShowSeconds(this.balance,
null);
},
editConfirm(qty, inventoryStatus, mode) {
let that = this;
//
if (mode == 'edit') {
this.currentEditItem.handleQty = qty;
this.currentEditItem.inventoryStatus = inventoryStatus;
} else {
//
//
var detail = that.detailSource.find(r => r.itemCode == that.label.itemCode);
if (detail == undefined) {
//
that.addNewItemCodeToList(qty, inventoryStatus)
} else {
var itemEditInfo = detail.subList.find(item => {
if (item.packingNumber == that.label.packingNumber &&
item.batch == that.label.batch &&
item.inventoryStatus == inventoryStatus) {
return item;
} }
}) })
},
createAddItemInfo(balance, pack) {
let item = {
itemCode: balance.itemCode,
itemName: pack.itemName,
stdPackQty: pack.stdPackQty,
stdPackUnit: pack.stdPackUnit,
qty: Number(balance.qty),
handleQty: 0,
uom: pack.uom,
subList: [],
if (itemEditInfo == undefined) {
//
that.addExistItemCodeToList(detail, qty, inventoryStatus);
} else { //
itemEditInfo.scaned = true;
itemEditInfo.handleQty = qty;
itemEditInfo.inventoryStatus = inventoryStatus;
itemEditInfo.balanceQty = that.balance.qty;
itemEditInfo.stdPackQty = that.package.stdPackQty;
itemEditInfo.stdPackUnit = that.package.stdPackUnit;
}
} }
return item;
},
createAddDetailInfo(balance, pack) { setTimeout(r => {
var detail = { this.calcHandleQty();
id: "0", this.scanPopupGetFocus();
scaned: true, }, 100)
countDetailNumber: "", }
ownerCode: balance.ownerCode,
packingNumber: balance.packingNumber,
containerNumber: pack.containerNumber,
batch: balance.batch,
inventoryStatus: balance.inventoryStatus,
itemCode: pack.itemCode,
itemName: pack.itemName,
itemDesc1: pack.itemDesc1,
itemDesc2: pack.itemDesc2,
projectCode: "",
qty: 0,
handleQty: balance.qty,
uom: balance.uom,
number: this.jobContent.number,
remark: "",
countQty: balance.qty,
balanceQty: balance.qty,
fromLocationCode: balance.locationCode,
stdPackQty: pack.stdPackQty,
stdPackUnit: pack.stdPackUnit,
creator:this.$store.state.user.id
}
return detail; },
},
scanLocationCode(location, code) { openEditConfirm() {
this.$refs.comMessage.showQuestionMessage("是否把所有的目标库位都变成默认库位[" + code + "]", res => {
this.toLocationCode = code
this.detailSource.forEach(item => {
item.subList.forEach(detail => {
detail.toLocationCode = code
})
})
})
}, },
getScanCount() { unOpenEditConfirm() {
var scanCount = 0;
this.detailSource.forEach(item => { },
item.subList.forEach(detail => {
if (detail.scaned) { editClose() {
scanCount = scanCount + 1; this.scanPopupGetFocus();
} },
})
addNewItemCodeToList(qty, inventoryStatus) {
this.$refs.comMessage.showQuestionMessage("物料[" + this.package.itemCode + "]不在列表中,是否添加到列表?",
res => {
if (res) {
var item = this.createAddItemInfo(this.balance, this.package);
let newDetail = this.createAddDetailInfo(qty, inventoryStatus); //
item.subList.push(newDetail);
this.detailSource.push(item)
this.showMessage('添加成功');
this.updateData()
this.scanPopupGetFocus();
}
}) })
return scanCount; },
},
addExistItemCodeToList(detail, qty, inventoryStatus) {
let that = this;
that.scanPopupLoseFocus();
this.$refs.comMessage.showQuestionMessage("盘点结果不在明细列表中,是否添加到列表?",
res => {
if (res) {
// detail.qty = calc.add(qty, qty)
let newDetail = that.createAddDetailInfo(qty, inventoryStatus); //
detail.subList.push(newDetail);
this.showMessage('添加成功');
that.updateData()
}
that.scanPopupGetFocus();
})
},
createAddItemInfo() {
let item = {
itemCode: this.package.itemCode,
itemName: this.package.itemName,
stdPackQty: this.package.stdPackQty,
stdPackUnit: this.package.stdPackUnit,
// qty: Number(qty),
qty: 0,
handleQty: 0,
uom: this.package.uom,
subList: [],
}
return item;
},
//
createAddDetailInfo(qty, inventoryStatus) {
var detail = {
id: "0", //
scaned: true,
countDetailNumber: "",
ownerCode: this.balance.ownerCode,
packingNumber: this.package.number,
containerNumber: this.balance.containerNumber,
batch: this.package.batch,
inventoryStatus: inventoryStatus,
itemCode: this.package.itemCode,
itemName: this.package.itemName,
itemDesc1: this.package.itemDesc1,
itemDesc2: this.package.itemDesc2,
stdPackQty: this.package.stdPackQty,
stdPackUnit: this.package.stdPackUnit,
projectCode: "",
qty: 0,
handleQty: qty,
uom: this.package.uom,
number: this.jobContent.number,
remark: "",
countQty: qty,
balanceQty: this.balance.qty,
fromLocationCode: this.balance.locationCode,
creator: this.$store.state.user.id
}
return detail;
},
getTotalCount() { scanLocationCode(location, code) {
var totalCount = 0; this.$refs.comMessage.showQuestionMessage("是否把所有的目标库位都变成默认库位[" + code + "]", res => {
this.toLocationCode = code
this.detailSource.forEach(item => { this.detailSource.forEach(item => {
item.subList.forEach(detail => { item.subList.forEach(detail => {
totalCount = totalCount + 1; detail.toLocationCode = code
}) })
}) })
return totalCount; })
},
},
commit() { getScanCount() {
this.scanCount = this.getScanCount(); var scanCount = 0;
this.detailSource.forEach(item => {
item.subList.forEach(detail => {
if (detail.scaned) {
scanCount = scanCount + 1;
}
})
})
return scanCount;
},
if (this.scanCount == this.getTotalCount()) { getTotalCount() {
this.submitJob(); var totalCount = 0;
} else if (this.scanCount < this.getTotalCount()) { this.detailSource.forEach(item => {
// item.subList.forEach(detail => {
if (this.jobContent.allowPartialComplete == "TRUE") { totalCount = totalCount + 1;
// })
this.$refs.comMessage.showQuestionMessage("已经扫描[" + this.scanCount + })
"]总共[" + this return totalCount;
.getTotalCount() + "],是否把未扫描的盘点数量设置为0?", },
res => {
if (res) { commit() {
this.detailSource.forEach(item => { this.scanCount = this.getScanCount();
item.subList.forEach(detail => {
if (!detail.scaned) { if (this.scanCount == this.getTotalCount()) {
detail.countQty = 0; this.submitJob();
} } else if (this.scanCount < this.getTotalCount()) {
}) //
if (this.jobContent.allowPartialComplete == "TRUE") {
//
this.$refs.comMessage.showQuestionMessage("已经扫描[" + this.scanCount +
"]总共[" + this
.getTotalCount() + "],是否把未扫描的盘点数量设置为0?",
res => {
if (res) {
this.detailSource.forEach(item => {
item.subList.forEach(detail => {
if (!detail.scaned) {
detail.countQty = 0;
}
}) })
this.submitJob(); })
} this.submitJob();
}); }
});
} else { } else {
// //
this.$refs.comMessage.showErrorMessage('请完成扫描后,再进行提交<br>' + "已经扫描[" + this.scanCount + this.$refs.comMessage.showErrorMessage('请完成扫描后,再进行提交<br>' + "已经扫描[" + this.scanCount +
"]总共[" + this "]总共[" + this
.getTotalCount() + "]", res => { .getTotalCount() + "]", res => {
if (res) { if (res) {
this.openScanPopup(); this.openScanPopup();
} }
}); });
}
} }
}
}, },
submitJob() { submitJob() {
uni.showLoading({ uni.showLoading({
title: "提交中....", title: "提交中....",
mask: true mask: true
}); });
var params = this.setParams() var params = this.setParams()
console.log("提交参数", JSON.stringify(params)); console.log("提交参数", JSON.stringify(params));
countJobSubmit(params).then(res => { countJobSubmit(params).then(res => {
uni.hideLoading() uni.hideLoading()
if (res.data) { if (res.data) {
this.showCommitSuccessMessage("提交成功<br>生成盘点记录<br>" + res.data) this.showCommitSuccessMessage("提交成功<br>生成盘点记录<br>" + res.data)
} else { } else {
this.showErrorMessage("提交失败[" + res.msg + "]") this.showErrorMessage("提交失败[" + res.msg + "]")
} }
}).catch(error => { }).catch(error => {
uni.hideLoading() uni.hideLoading()
this.showErrorMessage(error) this.showErrorMessage(error)
}) })
}, },
setParams() { setParams() {
var subList = [] var subList = []
var creator = this.$store.state.user.id var creator = this.$store.state.user.id
this.detailSource.forEach(item => { this.detailSource.forEach(item => {
item.subList.forEach(detail => { item.subList.forEach(detail => {
if (detail.scaned) { if (detail.scaned) {
detail.countQty = detail.handleQty; detail.countQty = detail.handleQty;
} }
subList.push(detail) subList.push(detail)
})
}) })
})
this.jobContent.subList = subList
this.jobContent.creator = creator;
return this.jobContent;
},
this.jobContent.subList = subList
this.jobContent.creator = creator;
return this.jobContent;
},
showMessage(message) {
this.$refs.comMessage.showMessage(message, res => {
if (res) {
this.afterCloseMessage()
}
});
},
showErrorMessage(message) {
this.$refs.comMessage.showErrorMessage(message, res => {
if (res) {
this.afterCloseMessage()
}
});
},
showScanMessage(message) { showMessage(message) {
this.$refs.comMessage.showScanMessage(message); this.$refs.comMessage.showMessage(message, res => {
}, if (res) {
this.afterCloseMessage()
}
});
},
showErrorMessage(message) {
this.$refs.comMessage.showErrorMessage(message, res => {
if (res) {
this.afterCloseMessage()
}
});
},
afterCloseMessage() { showScanMessage(message) {
this.scanPopupGetFocus(); this.$refs.comMessage.showScanMessage(message);
}, },
closeScanMessage() { afterCloseMessage() {
this.scanPopupGetFocus(); this.scanPopupGetFocus();
}, },
editItem(item) { closeScanMessage() {
var detail = this.detailSource.find(r => r.itemCode == item.itemCode); this.scanPopupGetFocus();
this.$refs.countQtyEdit.openEditPopup(item, },
detail.subList);
},
showCommitSuccessMessage(hint) { editItem(item) {
this.$refs.comMessage.showSuccessMessage(hint, res => { this.currentEditItem = item;
navigateBack(1); var detail = this.detailSource.find(r => r.itemCode == item.itemCode);
}) this.$refs.countQtyEdit.openEditPopup(item,
}, detail.subList);
getCountStageName(value) { },
return getCountStageName(value)
},
isOpenCount(value) {
return value == "TRUE" ? "明盘" : "盲盘"
}
showCommitSuccessMessage(hint) {
this.$refs.comMessage.showSuccessMessage(hint, res => {
navigateBack(1);
})
},
getCountStageName(value) {
return getCountStageName(value)
},
isOpenCount(value) {
return value == "TRUE" ? "明盘" : "盲盘"
} }
} }
}
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">

43
pages/count/record/countRecord.vue

@ -34,7 +34,7 @@
</view> </view>
<win-scan-button @goScan='openScanPopup'></win-scan-button> <win-scan-button @goScan='openScanPopup'></win-scan-button>
</view> </view>
<win-scan-pack-and-location ref="scanPopup" @getResult='getScanResult'></win-scan-pack-and-location> <win-scan-pack-and-location ref="scanPopup" @getResult='getScanResult'></win-scan-pack-and-location>
<win-scan-location ref="scanFromLocationCode" title="盘点库位" @getLocation='getLocation' <win-scan-location ref="scanFromLocationCode" title="盘点库位" @getLocation='getLocation'
:locationTypeList="fromLocationTypeArray"></win-scan-location> :locationTypeList="fromLocationTypeArray"></win-scan-location>
@ -50,11 +50,15 @@
getDataSource, getDataSource,
navigateBack navigateBack
} from '@/common/basic.js'; } from '@/common/basic.js';
import {
calc
} from '@/common/calc.js';
import { import {
getDirectoryItemArray getDirectoryItemArray
} from '@/common/directory.js'; } from '@/common/directory.js';
import { import {
getBusinessType, getBusinessType,
} from '@/common/record.js'; } from '@/common/record.js';
@ -119,7 +123,7 @@
this.showErrorMessage(res.message) this.showErrorMessage(res.message)
} }
}); });
}, },
// //
onNavigationBarButtonTap(e) { onNavigationBarButtonTap(e) {
@ -136,8 +140,7 @@
uni.stopPullDownRefresh(); uni.stopPullDownRefresh();
}, },
mounted() { mounted() {},
},
methods: { methods: {
calcScanCount(closeScan) { calcScanCount(closeScan) {
let items = this.subList.filter(r => { let items = this.subList.filter(r => {
@ -153,10 +156,14 @@
calcHandleQty() { calcHandleQty() {
for (let item of this.detailSource) { for (let item of this.detailSource) {
item.handleQty = 0; item.handleQty = new Decimal(0).toNumber();
item.qty = new Decimal(0).toNumber();
for (let detail of item.subList) { for (let detail of item.subList) {
if (item.scaned) { if(detail!=undefined){
item.handleQty += Number(detail.qty) if(detail.scaned){
item.handleQty = calc.add(item.handleQty,detail.handleQty);
}
item.qty = calc.add(item.qty,detail.qty);
} }
} }
} }
@ -195,7 +202,7 @@
balanceByLocation(this.fromLocationCode, res => { balanceByLocation(this.fromLocationCode, res => {
this.subList = res.data.list; this.subList = res.data.list;
this.detailSource = getDataSource(this.subList); this.detailSource = getDataSource(this.subList);
}); });
}, },
@ -218,13 +225,13 @@
}, },
closeScanPopup() { closeScanPopup() {
if(this.$refs.scanPopup!=undefined){ if (this.$refs.scanPopup != undefined) {
this.$refs.scanPopup.closeScanPopup(); this.$refs.scanPopup.closeScanPopup();
} }
}, },
scanPopupGetFocus() { scanPopupGetFocus() {
if(this.$refs.scanPopup!=undefined){ if (this.$refs.scanPopup != undefined) {
this.$refs.scanPopup.packGetFocus(); this.$refs.scanPopup.packGetFocus();
} }
}, },
@ -237,12 +244,12 @@
var itemCode = result.balance.itemCode; var itemCode = result.balance.itemCode;
var inventoryStatus = result.balance.inventoryStatus; var inventoryStatus = result.balance.inventoryStatus;
var detail = this.detailSource.find(r => r.itemCode == itemCode); var detail = this.detailSource.find(r => r.itemCode == itemCode);
// //
if (detail == undefined) { if (detail == undefined) {
// //
this.addNewItemCodeToList(result) this.addNewItemCodeToList(result)
} else { } else {
// //
this.itemEditInfo = detail.subList.find(item => { this.itemEditInfo = detail.subList.find(item => {
if (item.packingNumber == packingNumber && if (item.packingNumber == packingNumber &&
@ -263,9 +270,7 @@
if (res) { if (res) {
this.$refs.CountQtyEdit.openEditPopup(this.itemEditInfo, this.$refs.CountQtyEdit.openEditPopup(this.itemEditInfo,
detail.subList); detail.subList);
} } else {
else
{
this.scanPopupGetFocus(); this.scanPopupGetFocus();
} }
}) })
@ -303,7 +308,7 @@
return record; return record;
}, },
addExistItemCodeToList(detail, result) { addExistItemCodeToList(detail, result) {
detail.qty += detail.qty detail.qty = calc.add(detail.qty,detail.qty)
let newDetail = this.createAddDetailInfo(result.balance, result.package); // let newDetail = this.createAddDetailInfo(result.balance, result.package); //
detail.subList.push(newDetail); detail.subList.push(newDetail);
}, },

4
pages/customerReturn/coms/comReturnRecord.vue

@ -5,7 +5,7 @@
<template v-slot:title> <template v-slot:title>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions"> <uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty" <item-qty :dataContent="dataContent"
:isShowBalance="true"></item-qty> :isShowBalance="true"></item-qty>
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
@ -102,7 +102,7 @@
methods: { methods: {
removeData(e, dataContent) { removeData(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

8
pages/customerReturn/job/returnDetail.vue

@ -82,7 +82,6 @@
data() { data() {
return { return {
id: '', id: '',
received: false,
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
subList: [], //subList subList: [], //subList
@ -92,6 +91,7 @@
toLocationCode: "", toLocationCode: "",
toLocationInfo: {}, toLocationInfo: {},
tolocationTypeList: [], tolocationTypeList: [],
jobStatus:""
}; };
}, },
onLoad(option) { onLoad(option) {
@ -100,7 +100,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -118,7 +117,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeCustomerReturnJob(this.id).then(res => { cancleTakeCustomerReturnJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -167,8 +166,9 @@
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.subList = res.data.subList; that.subList = res.data.subList;
that.jobStatus = res.data.status
that.detailSource = getDataSource(that.subList) that.detailSource = getDataSource(that.subList)
that.fromLocationCode = that.subList[0].fromLocationCode that.fromLocationCode = that.subList[0].fromLocationCode
that.toLocationCode = that.subList[0].toLocationCode that.toLocationCode = that.subList[0].toLocationCode
that.tolocationTypeList = getDirectoryItemArray(that.jobContent.toLocationTypes) that.tolocationTypeList = getDirectoryItemArray(that.jobContent.toLocationTypes)

7
pages/customerReturn/record/returnRecord.vue

@ -1,7 +1,7 @@
<template> <template>
<view class="page-wraper"> <view class="page-wraper">
<view class=""> <view class="">
<com-blank-view @goScan='getLocation' v-if="detailSource.length==0"></com-blank-view> <com-blank-view @goScan='showFromLocationPopup' v-if="detailSource.length==0"></com-blank-view>
</view> </view>
<view class="page-wraper" v-if="detailSource.length>0"> <view class="page-wraper" v-if="detailSource.length>0">
<view class="page-main"> <view class="page-main">
@ -149,8 +149,10 @@
} }
}) })
if (item == undefined) { if (item == undefined) {
var itemp = createItemInfo(balance, pack); var itemp = createItemInfo(balance, pack);
let newDetail = createDetailInfo(balance, pack); // let newDetail = createDetailInfo(balance, pack); //
itemp.subList.push(newDetail); itemp.subList.push(newDetail);
this.detailSource.push(itemp) this.detailSource.push(itemp)
} else { } else {
@ -316,7 +318,6 @@
}, },
setParams() { setParams() {
var subList = [] var subList = []
var creator = this.$store.state.user.id var creator = this.$store.state.user.id
this.detailSource.forEach(item => { this.detailSource.forEach(item => {
@ -346,7 +347,7 @@
submitItem.fromLocationCode = detail.locationCode; submitItem.fromLocationCode = detail.locationCode;
submitItem.toLocationCode = detail.toLocationCode; submitItem.toLocationCode = detail.toLocationCode;
submitItem.qty = detail.handleQty!=0?detail.handleQty:detail.qty; submitItem.qty = detail.handleQty;
submitItem.package =""; submitItem.package ="";
subList.push(submitItem) subList.push(submitItem)

76
pages/customerReturn/request/customerReturnRequestCreate.vue

@ -1,13 +1,13 @@
<template> <template>
<view class="page-wraper"> <view class="page-wraper">
<view class=""> <view class="">
<com-blank-view @goScan='getLocation' v-if="detailSource.length==0"></com-blank-view> <com-blank-view @goScan='showFromLocationPopup' v-if="detailSource.length==0"></com-blank-view>
</view> </view>
<view class="page-wraper" v-if="detailSource.length>0"> <view class="page-wraper" v-if="detailSource.length>0">
<view class="uni-flex uni-row padding title u-col-center" @click="showSelect"> <view class="uni-flex uni-row padding title u-col-center" @click="showSelect" style="font-size: 35rpx;">
<text>客户 : </text> <text style="font-size: 32rpx;">客户 : </text>
<view class="uni-flex u-col-center uni-row" @click="showSelect"> <view class="uni-flex u-col-center uni-row" @click="showSelect">
<view class="" style="margin-left: 20rpx;"> <view class="" style="margin-left: 20rpx;font-size: 32rpx;">
{{customerName}} {{customerName}}
</view> </view>
<u-select v-model="showCustomer" mode="single-column" :list="customerList" @confirm="confirmSelect"> <u-select v-model="showCustomer" mode="single-column" :list="customerList" @confirm="confirmSelect">
@ -17,13 +17,12 @@
<view class="page-main"> <view class="page-main">
<scroll-view scroll-y="true" class="page-main-scroll"> <scroll-view scroll-y="true" class="page-main-scroll">
<view class="detail-list" v-for="(item, index) in detailSource" :key="item.id"> <view class="detail-list" v-for="(item, index) in detailSource" :key="item.id">
<view class=""> <view class="">
<record-com-detail-card :dataContent="item" :index="index" :isShowLocation="true" <record-com-detail-card :dataContent="item" :index="index" :isShowLocation="true"
:isShowToLocation="false" @removeItem="removeItem(index,item)" @updateData="updateData" :isShowBalanceQty="false" :isShowToLocation="false" @removeItem="removeItem(index,item)"
@removePack="removePack"> @updateData="updateData" @removePack="removePack">
</record-com-detail-card> </record-com-detail-card>
</view> </view>
</view> </view>
@ -56,6 +55,9 @@
</template> </template>
<script> <script>
import {
calc
} from '@/common/calc'
import { import {
customerReturnRequestSubmit, customerReturnRequestSubmit,
getBasicCustomerList getBasicCustomerList
@ -71,6 +73,7 @@
import { import {
goHome, goHome,
updateTitle, updateTitle,
deepCopyData,
getPackingNumberAndBatchByList getPackingNumberAndBatchByList
} from '@/common/basic.js'; } from '@/common/basic.js';
@ -210,7 +213,7 @@
}); });
}, },
calcHandleQty() { calcHandleQty() {
calcHandleQty(this.detailSource) calcHandleQty(this.detailSource);
this.$forceUpdate(); this.$forceUpdate();
}, },
@ -269,10 +272,10 @@
}, },
commit() { commit() {
// if (this.toLocationCode == "") { if (this.customerName == ""||this.customerName == "请选择退货客户") {
// this.showMessage("") this.showErrorMessage("请选择退货客户")
// return; return;
// } }
if (this.detailSource.length > 0 && this.detailSource[0].subList.length > 0) { if (this.detailSource.length > 0 && this.detailSource[0].subList.length > 0) {
// //
uni.showLoading({ uni.showLoading({
@ -328,40 +331,47 @@
setParams() { setParams() {
var subList = [] var subList = []
var creator = this.$store.state.user.id var creator = this.$store.state.user.id
this.dataContent.subList = subList;
this.dataContent.creator = creator;
this.dataContent.customerCode = 'CF';
this.dataContent.fromWarehouseCode = this.fromLocation.warehouseCode;
this.dataContent.toWarehouseCode = this.toWarehouseCode;
this.detailSource.forEach(item => { this.detailSource.forEach(item => {
item.subList.forEach(detail => { item.subList.forEach(detail => {
if (detail.scaned) { if (detail.scaned) {
detail.itemCode = detail.itemCode; var submitItem = deepCopyData(detail)
detail.itemName = detail.package.itemName; submitItem.itemCode = detail.itemCode;
detail.itemDesc1 = detail.package.itemDesc1; submitItem.itemName = detail.package.itemName;
detail.itemDesc2 = detail.package.itemDesc2; submitItem.itemDesc1 = detail.package.itemDesc1;
submitItem.itemDesc2 = detail.package.itemDesc2;
detail.inventoryStatus = detail.inventoryStatus; submitItem.inventoryStatus = detail.inventoryStatus;
detail.toInventoryStatus = 'HOLD'; submitItem.toInventoryStatus = 'HOLD';
detail.fromPackingNumber = detail.packingNumber; submitItem.fromPackingNumber = detail.packingNumber;
detail.toPackingNumber = detail.packingNumber; submitItem.toPackingNumber = detail.packingNumber;
detail.fromContainerNumber = detail.containerNumber; submitItem.fromContainerNumber = detail.containerNumber;
detail.toContainerNumber = detail.containerNumber submitItem.toContainerNumber = detail.containerNumber
detail.fromBatch = detail.batch; submitItem.fromBatch = detail.batch;
detail.toBatch = detail.batch; submitItem.toBatch = detail.batch;
detail.fromLocationCode = detail.locationCode; submitItem.qty = detail.handleQty;
detail.toLocationCode = 'HOLD';
subList.push(detail) submitItem.fromLocationCode = detail.locationCode;
submitItem.toLocationCode = 'HOLD';
submitItem.package = ""
subList.push(submitItem)
} }
}) })
}) })
this.dataContent.subList = subList;
this.dataContent.creator = creator;
this.dataContent.customerCode = this.customerCode;
this.dataContent.fromWarehouseCode = this.fromLocation.warehouseCode;
this.dataContent.toWarehouseCode = this.toWarehouseCode;
return this.dataContent; return this.dataContent;
}, },
@ -414,6 +424,8 @@
this.toLocationCode = ''; this.toLocationCode = '';
this.dataContent = {} this.dataContent = {}
this.toWarehouseCode = "" this.toWarehouseCode = ""
this.customerName ="请选择退货客户"
this.customerCode =""
}, },
updateData() { updateData() {

46
pages/deliver/coms/comDeliverRequestPopup.vue

@ -26,10 +26,10 @@
<u-line /> <u-line />
<view class="uni-flex uni-row padding title u-col-center"> <view class="uni-flex uni-row padding title u-col-center">
<text>零件 : </text> <text>物料 : </text>
<view class="uni-flex u-col-center uni-row"> <view class="uni-flex u-col-center uni-row">
<u-input v-model="itemCode" :focus="itemCodeFocus" :border="true" <u-input v-model="itemCode" :focus="itemCodeFocus" :border="true"
placeholder="请输入需求零件" @confirm="itemCodeConfirm" /> placeholder="请输入需求物料" @confirm="itemCodeConfirm" />
<image src="/static/search.svg" mode="" <image src="/static/search.svg" mode=""
style=" width: 40rpx;height: 40rpx;margin-left: 10rpx;" @click="itemCodeClick"> style=" width: 40rpx;height: 40rpx;margin-left: 10rpx;" @click="itemCodeClick">
</image> </image>
@ -42,10 +42,13 @@
<text>数量 : </text> <text>数量 : </text>
<view class="uni-flex uni-row uni-center" <view class="uni-flex uni-row uni-center"
style="align-items: center;margin-left: 20rpx;"> style="align-items: center;margin-left: 20rpx;">
<uni-number-box :value="counQty" @change="change" style='margin-left: 10rpx;' <input style="text-align: center;" class="qty_input" v-model="counQty" type="number"
:focus="numberFocus" @blur='numberFocus = false'> @confirm="confirm()" :focus="numberFocus" @input="checkNum" :maxlength="maxlength" />
</uni-number-box>
<uom :uom="uom"></uom> <uom :uom="uom"></uom>
<!-- <view class="" v-if="stdPackInfo!=undefined" style="display: flex;flex-direction: row;margin-left: 10rpx;">
(<stdPackQty :dataContent="stdPackInfo"></stdPackQty>)
</view> -->
</view> </view>
</view> </view>
@ -101,7 +104,7 @@
requestInfo: null, requestInfo: null,
itemCodeList: [], itemCodeList: [],
isCheckItemCode: false, isCheckItemCode: false,
counQty: 0, counQty: undefined,
editPosition: true, editPosition: true,
numberFocus: false, numberFocus: false,
uom: "", uom: "",
@ -109,7 +112,9 @@
isModifiedPosition: true, isModifiedPosition: true,
customerList: [], customerList: [],
customerName: "请选择客户", customerName: "请选择客户",
customerCode:"" customerCode:"",
maxlength:10,
stdPackInfo:undefined
} }
}, },
props: { props: {
@ -119,6 +124,21 @@
}, },
}, },
methods: { methods: {
checkNum(e) {
let value = e.detail.value;
let dot = value.indexOf('.'); //
let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
this.change(value)
},
openRequestPopup(editPosition) { openRequestPopup(editPosition) {
if (this.customerList.length == 0) { if (this.customerList.length == 0) {
getBasicCustomerList().then(res => { getBasicCustomerList().then(res => {
@ -142,6 +162,7 @@
this.itemCode = ""; this.itemCode = "";
this.uom = "" this.uom = ""
this.qty = 0 this.qty = 0
this.counQty =undefined;
this.itemCodeGetFocus(); this.itemCodeGetFocus();
} }
@ -176,9 +197,14 @@
confirm() { confirm() {
if (this.itemCode == "" || !this.isCheckItemCode) { if (this.itemCode == "" || !this.isCheckItemCode) {
this.showErrorMessage("请输入零件", "itemCode") this.showErrorMessage("请输入物料", "itemCode")
return
}
if (this.counQty == undefined) {
this.showErrorMessage("请输入数量")
return return
} }
if (this.qty == 0) { if (this.qty == 0) {
this.showErrorMessage("数量必须大于0") this.showErrorMessage("数量必须大于0")
return return
@ -194,7 +220,7 @@
}, },
checkItemCode() { checkItemCode() {
// //
getBasicItemByCode(this.itemCode).then(res => { getBasicItemByCode(this.itemCode).then(res => {
uni.hideLoading(); uni.hideLoading();
if (res.data != null && res.data.list.length > 0) { if (res.data != null && res.data.list.length > 0) {
@ -204,7 +230,7 @@
this.numberFocus = true this.numberFocus = true
this.uom = res.data.list[0].uom this.uom = res.data.list[0].uom
} else { } else {
this.showErrorMessage('未查找到零件【' + this.itemCode + '】', "itemCode"); this.showErrorMessage('未查找到物料【' + this.itemCode + '】', "itemCode");
} }
}).catch(error => { }).catch(error => {

97
pages/deliver/coms/comScanDeliverPack.vue

@ -3,10 +3,17 @@
<uni-popup ref="popup" :maskClick='false'> <uni-popup ref="popup" :maskClick='false'>
<view class=""> <view class="">
<view class="popup_box"> <view class="popup_box">
<view class="pop_title"> <view class="pop_title uni-flex space-between">
扫描箱码 <view class="" style="font-size: 35rpx;">
<text class="fr" @click="closeScanPopup()">关闭</text> 扫描箱码
</view>
<view class="">
<image class="fr icons_scan_close" src="/static/icons/icons_scan_close.svg"
@click="closeScanPopup()"></image>
</view>
</view> </view>
<!-- <view class="uni-flex uni-row" style="align-items: center; <!-- <view class="uni-flex uni-row" style="align-items: center;
background-color: #fff; background-color: #fff;
margin-left: 20rpx; margin-left: 20rpx;
@ -45,8 +52,8 @@
<view class=""> <view class="">
<view class=""> <view class="">
<win-com-scan ref="comscan" placeholder="箱标签" @getResult="onScan" :clearResult="true" :headerType="headerType" <win-com-scan ref="comscan" placeholder="箱标签" @getResult="onScan" :clearResult="true"
:isShowHistory="false"> :headerType="headerType" :isShowHistory="false">
</win-com-scan> </win-com-scan>
<view style="width: 100%;"> <view style="width: 100%;">
@ -102,6 +109,11 @@
getDetailOption, getDetailOption,
getDetailEditRemoveOption getDetailEditRemoveOption
} from '@/common/array.js'; } from '@/common/array.js';
import {
calc
} from '@/common/calc.js';
import { import {
getWorkShopLineStation getWorkShopLineStation
} from '@/api/request2.js'; } from '@/api/request2.js';
@ -128,7 +140,7 @@
type: String, type: String,
default: "HPQ,HMQ" default: "HPQ,HMQ"
}, },
}, },
data() { data() {
@ -150,9 +162,9 @@
positionInfo: "请选择位置", positionInfo: "请选择位置",
positionList: [], positionList: [],
defaultValueList: [], defaultValueList: [],
label:{}, label: {},
fromInventoryStatuses :"", fromInventoryStatuses: "",
packageInfo:{} packageInfo: {}
} }
}, },
created() { created() {
@ -185,14 +197,14 @@
let that = this; let that = this;
that.fromLocationList = []; that.fromLocationList = [];
if (that.dataContent != null) { if (that.dataContent != null) {
that.fromInventoryStatuses =this.jobContent.outInventoryStatuses that.fromInventoryStatuses = this.jobContent.outInventoryStatuses
that.toLocation = that.dataContent[0]; that.toLocation = that.dataContent[0];
that.toLocationCode = that.dataContent[0].toLocationCode; that.toLocationCode = that.dataContent[0].toLocationCode;
that.fromLocationList = that.getFromLocationList(); that.fromLocationList = that.getFromLocationList();
} }
}, },
showBalanceSelect(items,packageInfo) { showBalanceSelect(items, packageInfo) {
this.packageInfo = packageInfo; this.packageInfo = packageInfo;
this.$refs.balanceSelect.openPopup(items); this.$refs.balanceSelect.openPopup(items);
}, },
@ -238,7 +250,7 @@
let lot = result.label.batch; let lot = result.label.batch;
let item = that.toLocation.Items.find(r => r.itemCode == itemCode); let item = that.toLocation.Items.find(r => r.itemCode == itemCode);
if (item == undefined) { if (item == undefined) {
that.showErrorMessage('未查找到零件【' + itemCode + '】的发货明细', that.showErrorMessage('未查找到物料【' + itemCode + '】的发货明细',
res => { res => {
that.getfocus(); that.getfocus();
} }
@ -250,38 +262,39 @@
title: '加载中', title: '加载中',
mask: true mask: true
}) })
getBalanceByManagementPrecision(result.label, that.fromLocationCode, that.fromInventoryStatuses, balanceRes => { getBalanceByManagementPrecision(result.label, that.fromLocationCode, that.fromInventoryStatuses,
if (balanceRes.success) { balanceRes => {
if (balanceRes.data.list.length == 0) { if (balanceRes.success) {
this.showErrorMessage('在来源库位[' + this.fromLocationCode + '],未查找到该包装的库存记录', if (balanceRes.data.list.length == 0) {
res => { this.showErrorMessage('在来源库位[' + this.fromLocationCode + '],未查找到该包装的库存记录',
this.packGetFocus(); res => {
}) this.packGetFocus();
} else if (balanceRes.data.list.length == 1) { })
let balance = balanceRes.data.list[0]; } else if (balanceRes.data.list.length == 1) {
this.afterGetBalance(result.label, balance,packageInfo); let balance = balanceRes.data.list[0];
this.afterGetBalance(result.label, balance, packageInfo);
} else {
this.label = result.label;
this.showBalanceSelect(balanceRes.data.list, packageInfo);
}
} else { } else {
this.label =result.label; this.showErrorMessage(balanceRes.message.message);
this.showBalanceSelect(balanceRes.data.list,packageInfo);
} }
} else { uni.hideLoading();
this.showErrorMessage(balanceRes.message.message); });
}
uni.hideLoading();
});
} }
} catch (e) { } catch (e) {
this.showErrorMessage(e.stack) this.showErrorMessage(e.stack)
uni.hideLoading(); uni.hideLoading();
} }
}, },
selectBalanceItem(balance) { selectBalanceItem(balance) {
this.afterGetBalance(this.label, balance,this.packageInfo); this.afterGetBalance(this.label, balance, this.packageInfo);
}, },
afterGetBalance(label, balance,packageInfo) {
afterGetBalance(label, balance, packageInfo) {
try { try {
let that = this; let that = this;
let itemCode = label.itemCode; let itemCode = label.itemCode;
@ -302,11 +315,11 @@
if (batch.Recommends.length > 0) { if (batch.Recommends.length > 0) {
let recommend = batch.Recommends.find(r => r.packingNumber == packingCode); let recommend = batch.Recommends.find(r => r.packingNumber == packingCode);
if (recommend != undefined) { if (recommend != undefined) {
that.addRecord(batch, label, balance,packageInfo) that.addRecord(batch, label, balance, packageInfo)
} else { } else {
// //
if (this.jobContent.allowModifyPackingNumber == 'TRUE') { if (this.jobContent.allowModifyPackingNumber == 'TRUE') {
that.addRecord(batch, label, balance,packageInfo); that.addRecord(batch, label, balance, packageInfo);
} else { } else {
that.showErrorMessage('未查找到该箱码【' + packingCode + '】的明细', that.showErrorMessage('未查找到该箱码【' + packingCode + '】的明细',
res => { res => {
@ -316,7 +329,7 @@
} }
} }
} else { } else {
that.addRecord(batch, label, balance,packageInfo) that.addRecord(batch, label, balance, packageInfo)
} }
} else { } else {
that.showErrorMessage('箱码【' + packingCode + '】已经扫描,请继续扫描下一箱', that.showErrorMessage('箱码【' + packingCode + '】已经扫描,请继续扫描下一箱',
@ -371,14 +384,14 @@
return batch; return batch;
}, },
creatRecord(label, balance,packageInfo) { creatRecord(label, balance, packageInfo) {
balance.stdPackQty = packageInfo.stdPackQty balance.stdPackQty = packageInfo.stdPackQty
balance.stdPackUnit = packageInfo.stdPackUnit balance.stdPackUnit = packageInfo.stdPackUnit
let record = { let record = {
itemCode: label.itemCode, itemCode: label.itemCode,
packingNumber: label.packingNumber, packingNumber: label.packingNumber,
batch: label.batch, batch: label.batch,
qty: Number(label.qty)>Number(balance.qty)?Number(balance.qty):Number(label.qty), qty: Number(label.qty) > Number(balance.qty) ? Number(balance.qty) : Number(label.qty),
uom: balance.uom, uom: balance.uom,
inventoryStatus: balance.inventoryStatus, inventoryStatus: balance.inventoryStatus,
balance: balance, balance: balance,
@ -391,13 +404,13 @@
calcBatchHandleQty(batch) { calcBatchHandleQty(batch) {
let handleQty = 0; let handleQty = 0;
batch.Records.forEach(res => { batch.Records.forEach(res => {
handleQty += Number(res.qty) handleQty = calc.add(handleQty,res.qty)
}) })
batch.handleQty = handleQty; batch.handleQty = handleQty;
}, },
addRecord(batch, label, balance,packageInfo) { addRecord(batch, label, balance, packageInfo) {
let record = this.creatRecord(label, balance,packageInfo); let record = this.creatRecord(label, balance, packageInfo);
batch.Records.push(record); batch.Records.push(record);
this.issueRecord.unshift(record) this.issueRecord.unshift(record)
this.calcBatchHandleQty(batch); this.calcBatchHandleQty(batch);

59
pages/deliver/job/deliverDetail.vue

@ -2,9 +2,9 @@
<view class="page-wraper"> <view class="page-wraper">
<view class="page-header"> <view class="page-header">
<view class="header_job_top"> <view class="header_job_top">
<job-top :dataContent="jobContent" ></job-top> <job-top :dataContent="jobContent"></job-top>
</view> </view>
<view class="header_item" > <view class="header_item">
申请单号{{jobContent.requestNumber}} 申请单号{{jobContent.requestNumber}}
</view> </view>
<u-line color="#D8D8D8"></u-line> <u-line color="#D8D8D8"></u-line>
@ -22,7 +22,7 @@
<u-line /> <u-line />
</view> </view>
</view> </view>
<view class="page-main"> <view class="page-main">
<scroll-view scroll-y="true" class=""> <scroll-view scroll-y="true" class="">
<view v-for="(toLocation, index) in detailSource"> <view v-for="(toLocation, index) in detailSource">
@ -55,6 +55,10 @@
deliverJobSubmit deliverJobSubmit
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import { import {
goHome, goHome,
updateTitle, updateTitle,
@ -80,7 +84,7 @@
import comScanDeliverPack from '@/pages/deliver/coms/comScanDeliverPack.vue' import comScanDeliverPack from '@/pages/deliver/coms/comScanDeliverPack.vue'
import comMessage from '@/mycomponents/common/comMessage.vue' import comMessage from '@/mycomponents/common/comMessage.vue'
import jobTop from '@/mycomponents/job/jobTop.vue' import jobTop from '@/mycomponents/job/jobTop.vue'
export default { export default {
name: 'issueDetail', name: 'issueDetail',
components: { components: {
@ -99,9 +103,9 @@
detailSource: [], // detailSource: [], //
detailOptions: [], detailOptions: [],
scanOptions: [], scanOptions: [],
status:"", status: "",
received :false, toLocationCode: "",
toLocationCode:"" jobStatus:""
}; };
}, },
@ -115,7 +119,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -133,12 +136,21 @@
// //
onBackPress(e) { onBackPress(e) {
// //
if (this.received) { if (e.from == 'backbutton') {
// if (this.jobStatus=="2") {
cancleTakeDeliverJob(this.id).then(res => {}).catch(error => { //
this.showMessage(err); cancleTakeDeliverJob(this.id).then(res => {
}) uni.navigateBack();
}).catch(error => {
uni.navigateBack();
})
} else {
uni.navigateBack();
}
return true;
} }
}, },
methods: { methods: {
@ -166,9 +178,11 @@
} else { } else {
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status;
that.subList = res.data.subList; that.subList = res.data.subList;
that.detailSource = getDataSource(that.detailSource, that.subList) that.detailSource = getDataSource(that.detailSource, that.subList)
that.toLocationCode =that.subList[0].toLocationCode that.toLocationCode = that.subList[0].toLocationCode
that.resizeCollapse(); that.resizeCollapse();
} else { } else {
that.showMessage('列表数据为0'); that.showMessage('列表数据为0');
@ -192,7 +206,7 @@
}); });
}, },
submit() { submit() {
uni.showLoading({ uni.showLoading({
@ -204,13 +218,13 @@
var itemCodes = [] var itemCodes = []
let locationCode = this.detailSource[0].toLocationCode let locationCode = this.detailSource[0].toLocationCode
this.detailSource.forEach(toLocationCode => { this.detailSource.forEach(toLocationCode => {
toLocationCode.Items.forEach(item=>{ toLocationCode.Items.forEach(item => {
itemCodes.push(item.itemCode) itemCodes.push(item.itemCode)
}) })
}) })
//使 //使
if (this.jobContent.useOnTheWayLocation == 'TRUE') { if (locationCode == null) {
this.submitJob(); this.submitJob();
} else { } else {
// //
@ -235,7 +249,7 @@
if (res.data) { if (res.data) {
this.showCommitSuccessMessage("提交成功<br>生成发货记录" + res.data) this.showCommitSuccessMessage("提交成功<br>生成发货记录" + res.data)
} else { } else {
this.showErrorMessage("提交失败[" + res.msg+"]") this.showErrorMessage("提交失败[" + res.msg + "]")
} }
}).catch(error => { }).catch(error => {
uni.hideLoading() uni.hideLoading()
@ -266,8 +280,7 @@
record.supplierCode = r.supplierCode; record.supplierCode = r.supplierCode;
//使 //使
if (this.jobContent.useOnTheWayLocation == if (this.toLocationCode ==null) {
'TRUE') {
record.toPackingNumber = r record.toPackingNumber = r
.packingNumber; .packingNumber;
record.toBatch = r.batch; record.toBatch = r.batch;
@ -298,7 +311,7 @@
cancel() { cancel() {
let that = this; let that = this;
this.$refs.comMessage.showQuestionMessage('是否要清空已扫描的零件和目标库位信息?', res => { this.$refs.comMessage.showQuestionMessage('是否要清空已扫描的物料和目标库位信息?', res => {
if (res) { if (res) {
that.clearInfo(); that.clearInfo();
} }
@ -338,10 +351,10 @@
let handleQty = 0; let handleQty = 0;
if (batch != undefined) { if (batch != undefined) {
batch.Records.forEach(res => { batch.Records.forEach(res => {
handleQty += Number(res.qty) handleQty = calc.add(handleQty, res.qty)
}) })
batch.handleQty = handleQty; batch.handleQty = handleQty;
itemHandleQty += handleQty; itemHandleQty = calc.add(itemHandleQty, handleQty)
} }
}) })
} }

5
pages/deliver/record/deliverRecord.vue

@ -172,9 +172,8 @@
} }
}) })
if (item == undefined) { if (item == undefined) {
var itemp = createItemInfo(balance.qty, pack); var itemp = createItemInfo(balance, pack);
let newDetail = createDetailInfo(balance, pack); // let newDetail = createDetailInfo(balance, pack); //
if(labelQty)
itemp.subList.push(newDetail); itemp.subList.push(newDetail);
this.detailSource.push(itemp) this.detailSource.push(itemp)
} else { } else {
@ -380,7 +379,7 @@
submitItem.fromLocationCode = detail.locationCode; submitItem.fromLocationCode = detail.locationCode;
submitItem.toLocationCode = detail.toLocationCode; submitItem.toLocationCode = detail.toLocationCode;
submitItem.qty = detail.handleQty!=0?detail.handleQty:detail.qty; submitItem.qty = detail.handleQty;
submitItem.package =""; submitItem.package ="";
subList.push(submitItem) subList.push(submitItem)

8
pages/deliver/request/deliverRequestCreate.vue

@ -28,6 +28,10 @@
deliverRequestSubmit, deliverRequestSubmit,
issueRecordSubmit issueRecordSubmit
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import { import {
goHome, goHome,
@ -123,7 +127,7 @@
} else { } else {
// //
result[0].qty += item.qty result[0].qty = calc.add(result[0].qty,item.qty)
} }
} }
@ -136,7 +140,7 @@
caclcQty() { caclcQty() {
var totalQty = 0; var totalQty = 0;
this.detailSource.subList.forEach(res => { this.detailSource.subList.forEach(res => {
totalQty += res.qty totalQty = calc.add(totalQty,res.qty)
}) })
this.detailSource.totalQty = totalQty; this.detailSource.totalQty = totalQty;
}, },

12
pages/demo/demo.vue

@ -178,25 +178,25 @@
</view> </view>
<u-gap height="5" bg-color="#bbb"></u-gap> <u-gap height="5" bg-color="#bbb"></u-gap>
<!-- 零件组件 --> <!-- 物料组件 -->
<view> <view>
<view class="title-1"> <view class="title-1">
零件组件 物料组件
</view> </view>
<view class=""> <view class="">
<view class="title-2">零件 item</view> <view class="title-2">物料 item</view>
<view class="view-com"> <view class="view-com">
<view class="uni-flex uni-row "> <view class="uni-flex uni-row ">
<item :dataContent="detailDataContent"></item> <item :dataContent="detailDataContent"></item>
</view> </view>
</view> </view>
<view class="title-2">零件数量 itemQty</view> <view class="title-2">物料数量 itemQty</view>
<view class="view-com"> <view class="view-com">
<item-qty :dataContent="detailDataContent" :handleQty="recordDataContent.qty"></item-qty> <item-qty :dataContent="detailDataContent" :handleQty="recordDataContent.qty"></item-qty>
</view> </view>
<view class="title-2">零件数量 itemQty</view> <view class="title-2">物料数量 itemQty</view>
<view class="view-com"> <view class="view-com">
<partCodeSelect :list="list"></partCodeSelect> <partCodeSelect :list="list"></partCodeSelect>
</view> </view>
@ -309,7 +309,7 @@
</view> </view>
<view class=""> <view class="">
<view class="title-1"> <view class="title-1">
零件状态组件-itemStatus 物料状态组件-itemStatus
</view> </view>
<view class="uni-flex uni-row space-between" style="margin:20rpx"> <view class="uni-flex uni-row space-between" style="margin:20rpx">

2
pages/index/index.vue

@ -317,7 +317,7 @@
}, },
getDictory() { getDictory() {
var params = { var params = {
types: ["job_status", "location_type", "item_status", "uom", types: ["job_status", "location_type", "item_status","item_type","uom",
"inventory_status", "container_type", "pack_unit", "unplanned_receipt_reason", "inventory_status", "container_type", "pack_unit", "unplanned_receipt_reason",
"unplanned_issue_reason", "scrap_reason", "inspect_failed_reason", "unplanned_issue_reason", "scrap_reason", "inspect_failed_reason",
"request_status", "inspect_type", "next_action", "sample_method", "transfer_mode", "request_status", "inspect_type", "next_action", "sample_method", "transfer_mode",

34
pages/inspect/coms/inspectEdit.vue

@ -17,7 +17,7 @@
<view class="list_cell uni-flex uni-row space-between"> <view class="list_cell uni-flex uni-row space-between">
<view class="title">不合格数量</view> <view class="title">不合格数量</view>
<view class="uni-flex uni-row u-col-center" style=""> <view class="uni-flex uni-row u-col-center" style="">
<input class="qty_inspect_input" v-model="dataContent.failedQty" :focus="true" type="number" /> <input class="qty_inspect_input" v-model="dataContent.failedQty" :focus="true" type="number" @input="checkNum" :maxlength="maxlength" />
<uom :uom="dataContent.uom"></uom> <uom :uom="dataContent.uom"></uom>
</view> </view>
@ -25,7 +25,7 @@
<view class="list_cell uni-flex uni-row space-between"> <view class="list_cell uni-flex uni-row space-between">
<view class="title">报废数量</view> <view class="title">报废数量</view>
<view class="uni-flex uni-row u-col-center" style=""> <view class="uni-flex uni-row u-col-center" style="">
<input class="qty_inspect_input" v-model="dataContent.crackQty" :focus="true" type="number" /> <input class="qty_inspect_input" v-model="dataContent.crackQty" :focus="true" type="number" @input="checkNum" :maxlength="maxlength" />
<uom :uom="dataContent.uom"></uom> <uom :uom="dataContent.uom"></uom>
</view> </view>
@ -68,9 +68,13 @@
} from '@/common/directory.js'; } from '@/common/directory.js';
import { import {
deepCopyData deepCopyData,
} from '@/common/basic.js'; } from '@/common/basic.js';
import {
calc,
} from '@/common/calc.js';
import { import {
uploadFile, uploadFile,
getFileList, getFileList,
@ -94,7 +98,8 @@
failedReasonArray: [], failedReasonArray: [],
dataContent: {}, dataContent: {},
inspectResultArray: [], inspectResultArray: [],
picInfoList: [] picInfoList: [],
maxlength: 10
} }
}, },
props: { props: {
@ -110,6 +115,20 @@
}, },
methods: { methods: {
checkNum(e) {
let value = e.detail.value;
let dot = value.indexOf('.'); //
let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
},
openEditPopup(item) { openEditPopup(item) {
this.failedReasonArray = getInspectFailedReasonList(); this.failedReasonArray = getInspectFailedReasonList();
this.inspectResultArray =getInspectResultList() this.inspectResultArray =getInspectResultList()
@ -222,8 +241,8 @@
var failedQty = Number(this.dataContent.failedQty); var failedQty = Number(this.dataContent.failedQty);
var crackQty = Number(this.dataContent.crackQty); var crackQty = Number(this.dataContent.crackQty);
var qty = Number(this.dataContent.qty); var qty = Number(this.dataContent.qty);
if (crackQty + failedQty > qty) { if (calc.add(crackQty,failedQty)> qty) {
var total = crackQty + failedQty; var total = calc.add(crackQty,failedQty)
this.showMessage("不合格数[" + failedQty + "]+报废数量[" + crackQty + "]等于[" + total + "]大于收货数量[" + this.showMessage("不合格数[" + failedQty + "]+报废数量[" + crackQty + "]等于[" + total + "]大于收货数量[" +
qty + "]") qty + "]")
return return
@ -242,7 +261,8 @@
this.dataContent.failedQty = failedQty; this.dataContent.failedQty = failedQty;
this.dataContent.crackQty = crackQty this.dataContent.crackQty = crackQty
this.dataContent.goodQty = this.dataContent.handleQty - failedQty - crackQty var temp=calc.sub(this.dataContent.handleQty,failedQty);
this.dataContent.goodQty =calc.sub(temp,failedQty,crackQty);
this.afterSave() this.afterSave()

22
pages/inspect/job/inspectDetail.vue

@ -40,8 +40,8 @@
cancleTakeInspectJob, cancleTakeInspectJob,
getInspectJobDetail, getInspectJobDetail,
inspectJobSubmit, inspectJobSubmit,
deleteFileById, getFileList,
getFileList deleteFileByTable
} from '@/api/request2.js'; } from '@/api/request2.js';
import { import {
goHome, goHome,
@ -147,25 +147,15 @@
}, },
methods: { methods: {
deleteFileById(id) { deleteFileByTable(id) {
deleteFileById(id).then(res => { debugger
deleteFileByTable("jobInspectDetail", id).then(res=>{
})
},
getFileList(id) {
getFileList("jobInspectDetail", id).then(res => {
if (res.data) {
res.data.forEach(res => {
this.deleteFileById(res.id)
})
}
}) })
}, },
clearPicList(subList) { clearPicList(subList) {
subList.forEach(item => { subList.forEach(item => {
this.getFileList(item.id) this.deleteFileByTable(item.id)
}) })
}, },

53
pages/inspect/job/inspectFullDetail.vue

@ -41,7 +41,8 @@
getInspectJobDetail, getInspectJobDetail,
inspectJobSubmit, inspectJobSubmit,
deleteFileById, deleteFileById,
getFileList getFileList,
deleteFileByTable
} from '@/api/request2.js'; } from '@/api/request2.js';
import { import {
goHome, goHome,
@ -59,6 +60,10 @@
getManagementPrecisions getManagementPrecisions
} from '@/common/balance.js'; } from '@/common/balance.js';
import {
calc
} from '@/common/calc.js';
import { import {
getDataSource, getDataSource,
createRecordInfo, createRecordInfo,
@ -87,7 +92,6 @@
data() { data() {
return { return {
id: '', id: '',
received: false,
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
subList: [], //subList subList: [], //subList
@ -96,6 +100,7 @@
fromInventoryStatuses: "", fromInventoryStatuses: "",
managementList: [], managementList: [],
selectedItem: {}, selectedItem: {},
jobStatus:""
}; };
}, },
onLoad(option) { onLoad(option) {
@ -104,7 +109,6 @@
// // // //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -123,7 +127,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeInspectJob(this.id).then(res => { cancleTakeInspectJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -148,27 +152,17 @@
}, },
methods: { methods: {
deleteFileById(id) { deleteFileByTable(id) {
deleteFileById(id).then(res => { deleteFileByTable("jobInspectDetail", id).then(res=>{
}) })
}, },
getFileList(id) {
getFileList("jobInspectDetail", id).then(res => {
if (res.data) {
res.data.forEach(res => {
this.deleteFileById(res.id)
})
}
})
},
clearPicList(subList) { clearPicList(subList) {
subList.forEach(item => { subList.forEach(item => {
this.getFileList(item.id) this.deleteFileByTable(item.id)
}) })
}, },
// //
receive(callback) { receive(callback) {
uni.showLoading({ uni.showLoading({
@ -200,6 +194,7 @@
} else { } else {
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status
this.jobContent.failedQty = 0; this.jobContent.failedQty = 0;
this.jobContent.crackQty = 0; this.jobContent.crackQty = 0;
this.jobContent.notPassedQty = 0; this.jobContent.notPassedQty = 0;
@ -254,8 +249,8 @@
for (let item of this.detailSource) { for (let item of this.detailSource) {
for (let detail of item.subList) { for (let detail of item.subList) {
if (detail != undefined && detail.scaned) { if (detail != undefined && detail.scaned) {
failedQty += Number(detail.failedQty) failedQty= calc.add(failedQty,detail.failedQty)
crackQty += Number(detail.crackQty) crackQty= calc.add(crackQty,detail.crackQty)
} }
} }
} }
@ -325,8 +320,9 @@
let balanceStatus = getInventoryStatusName(result.balance.inventoryStatus); let balanceStatus = getInventoryStatusName(result.balance.inventoryStatus);
let itemStatus = getInventoryStatusName(itemDetail.inventoryStatus); let itemStatus = getInventoryStatusName(itemDetail.inventoryStatus);
if (itemDetail.inventoryStatus != result.balance.inventoryStatus) { if (itemDetail.inventoryStatus != result.balance.inventoryStatus) {
if(this.jobContent.allowModifyInventoryStatus=="TRUE"){ if (this.jobContent.allowModifyInventoryStatus == "TRUE") {
this.showQuestionMessage('任务中允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' + itemStatus + this.showQuestionMessage('任务中允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' +
itemStatus +
']不一致,是否继续检验?', res => { ']不一致,是否继续检验?', res => {
if (res) { if (res) {
itemDetail.scaned = true; itemDetail.scaned = true;
@ -337,13 +333,14 @@
this.scanPopupGetFocus(); this.scanPopupGetFocus();
} }
}); });
}else { } else {
this.showQuestionMessage('任务中不允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' + itemStatus + this.showQuestionMessage('任务中不允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' +
itemStatus +
']不一致,不允许转移!', res => { ']不一致,不允许转移!', res => {
this.scanPopupGetFocus(); this.scanPopupGetFocus();
}); });
} }
} else { } else {
itemDetail.scaned = true; itemDetail.scaned = true;
itemDetail.balance = result.balance; itemDetail.balance = result.balance;
@ -467,7 +464,8 @@
detail.failedQty = detail.failedQty; detail.failedQty = detail.failedQty;
detail.crackQty = detail.crackQty; detail.crackQty = detail.crackQty;
detail.notPassedQty = detail.failedQty; detail.notPassedQty = detail.failedQty;
detail.goodQty = detail.handleQty - detail.failedQty - detail.crackQty; var tempQty = calc.sub(detail.handleQt,detail.failedQty)
detail.goodQty = calc.sub(tempQty,detail.crackQty) ;
detail.inspectUser = this.$store.state.user.id detail.inspectUser = this.$store.state.user.id
//== //==
@ -522,7 +520,6 @@
height: 100%; height: 100%;
background-color: #fff; background-color: #fff;
} }
.page-wraper { .page-wraper {
display: flex; display: flex;
flex-direction: column; flex-direction: column;

8
pages/inspect/job/inspectResult.vue

@ -12,7 +12,7 @@
</view> </view>
<view class="pda-list-cell"> <view class="pda-list-cell">
<view class="pda-list-cell-left"> <view class="pda-list-cell-left">
<view class="uni-label">零件</view> <view class="uni-label">物料</view>
</view> </view>
<view class="pda-list-cell-db"> <view class="pda-list-cell-db">
<view class="uni-flex space-between"> <view class="uni-flex space-between">
@ -173,7 +173,6 @@
failedReasonArray: [], failedReasonArray: [],
nextStep: '', nextStep: '',
submitting: false, submitting: false,
received: false,
locations: [], locations: [],
value: ['0'], value: ['0'],
jobContent: {}, // jobContent: {}, //
@ -181,6 +180,7 @@
detailSource: [], // detailSource: [], //
nextActionList: [], nextActionList: [],
nextAction: null, nextAction: null,
jobStatus:""
} }
}, },
@ -199,7 +199,6 @@
// // // //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -210,7 +209,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeInspectJob(this.id).then(res => { cancleTakeInspectJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -257,6 +256,7 @@
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.detailList = res.data.subList; that.detailList = res.data.subList;
that.jobStatus = res.data.status
that.inspectType = that.jobContent.inspectType; that.inspectType = that.jobContent.inspectType;
that.jobContent.goodQty = null, // that.jobContent.goodQty = null, //
that.jobContent.failedQty = null, // that.jobContent.failedQty = null, //

4
pages/inventoryMove/coms/comMoveRecord.vue

@ -247,7 +247,7 @@
if (r.packingNumber == balance.packingNumber && if (r.packingNumber == balance.packingNumber &&
r.batch == balance.batch && r.batch == balance.batch &&
r.fromLocationCode == balance.locationCode && r.fromLocationCode == balance.locationCode &&
r.inventoryStatus == balance.inventoryStatus && r.toInventoryStatus == balance.inventoryStatus &&
r.scaned == true) { r.scaned == true) {
return r; return r;
} }
@ -421,7 +421,7 @@
submitItem.package = null; submitItem.package = null;
submitItem.Records = null; submitItem.Records = null;
submitItem.qty = detail.handleQty!=0?detail.handleQty:detail.qty; submitItem.qty = detail.handleQty;
subList.push(submitItem) subList.push(submitItem)
} }

17
pages/inventoryMove/coms/comMoveRecordCard.vue

@ -5,7 +5,8 @@
<template v-slot:title> <template v-slot:title>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions"> <uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty" <item-qty :dataContent="dataContent"
:isShowBalanceQty="false"
:isShowBalance="true"></item-qty> :isShowBalance="true"></item-qty>
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
@ -86,7 +87,19 @@
}, },
watch: { watch: {
dataContent: {
handler(newName, oldName) {
if (this.dataContent.subList.length > 0) {
if (this.$refs.collapse1 != undefined && this.$refs.collapse1 != null) {
this.$nextTick(res => {
this.$refs.collapse1.resize()
})
}
}
},
immediate: true,
deep: true
}
}, },
data() { data() {

8
pages/inventoryMove/job/inventoryMoveDetail.vue

@ -92,7 +92,6 @@
data() { data() {
return { return {
id: '', id: '',
received: false,
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
subList: [], //subList subList: [], //subList
@ -103,7 +102,8 @@
managementList: [], managementList: [],
businessTypeCode: '', businessTypeCode: '',
toLocationCode: '', toLocationCode: '',
toInventoryStatus: '' toInventoryStatus: '',
jobStatus:""
}; };
}, },
props: { props: {
@ -116,7 +116,6 @@
// // // //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -135,7 +134,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeInventoryMoveJob(this.id).then(res => { cancleTakeInventoryMoveJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -223,6 +222,7 @@
} else { } else {
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status
that.subList = res.data.subList; that.subList = res.data.subList;
that.detailSource = getDataSource(that.subList) that.detailSource = getDataSource(that.subList)
} else { } else {

2
pages/issue-按批次推荐/coms/comIssueJobCard.vue

@ -5,7 +5,7 @@
<view class="task_item"> <view class="task_item">
<view class="task_text"> <view class="task_text">
需求零件 : {{dataContent.itemCode}} 需求物料 : {{dataContent.itemCode}}
</view> </view>
<view class="task_text"> <view class="task_text">
需求库位 : {{dataContent.toLocationCode}} 需求库位 : {{dataContent.toLocationCode}}

2
pages/issue-按批次推荐/coms/comScanIssuePack.vue

@ -195,7 +195,7 @@
let item = that.requestLocation.Items.find(r => r.itemCode == itemCode); let item = that.requestLocation.Items.find(r => r.itemCode == itemCode);
if (item == undefined) { if (item == undefined) {
that.showErrorMessage('未查找到零件【' + itemCode + '】的发料明细', that.showErrorMessage('未查找到物料【' + itemCode + '】的发料明细',
res => { res => {
that.getfocus(); that.getfocus();
} }

12
pages/issue-按批次推荐/job/issueDetail.vue

@ -196,7 +196,7 @@
return list; return list;
}, },
//: -> Items -> Locations-> Batchs -> Records //: -> Items -> Locations-> Batchs -> Records
createDetailInfo(location, detail) { createDetailInfo(location, detail) {
let that = this; let that = this;
var item = location.Items.find(r => var item = location.Items.find(r =>
@ -206,7 +206,7 @@
location.Items.push(item) location.Items.push(item)
} else { } else {
item.qty += detail.qty item.qty += detail.qty
// //
let location = item.Locations.find(r => r.fromLocationCode == detail.fromLocationCode); let location = item.Locations.find(r => r.fromLocationCode == detail.fromLocationCode);
if (location == undefined) { if (location == undefined) {
location = that.createLocationInfo(detail); location = that.createLocationInfo(detail);
@ -353,7 +353,7 @@
} else { } else {
let item = location.Items.find(r => r.itemCode == result.label.itemCode); let item = location.Items.find(r => r.itemCode == result.label.itemCode);
if (item == undefined || item == null) { if (item == undefined || item == null) {
this.showErrorMessage('未查找到零件【' + result.label.itemCode + '】的发料需求', callback => { this.showErrorMessage('未查找到物料【' + result.label.itemCode + '】的发料需求', callback => {
}) })
} else { } else {
@ -365,7 +365,7 @@
let bacth = this.createBatchInfo(result); let bacth = this.createBatchInfo(result);
item.Batchs.push(bacth); item.Batchs.push(bacth);
} else { } else {
this.showErrorMessage('未查找到零件【' + result.label.itemCode + '】对应的批次【' + result.label.batch + this.showErrorMessage('未查找到物料【' + result.label.itemCode + '】对应的批次【' + result.label.batch +
'】需求', callback => { '】需求', callback => {
}) })
@ -399,7 +399,7 @@
mask: true mask: true
}) })
let that = this; let that = this;
// //
let params = { let params = {
pageSize: 100, pageSize: 100,
pageIndex: 1, pageIndex: 1,
@ -554,7 +554,7 @@
cancel() { cancel() {
let that = this; let that = this;
showConfirmMsg('是否要清空已扫描的零件和目标库位信息?', confirm => { showConfirmMsg('是否要清空已扫描的物料和目标库位信息?', confirm => {
if (confirm) { if (confirm) {
that.clearInfo(); that.clearInfo();
} }

25
pages/issue/coms/comIssueDetailCard.vue

@ -8,7 +8,12 @@
<uni-collapse-item :open="true"> <uni-collapse-item :open="true">
<template v-slot:title> <template v-slot:title>
<!-- 物品 --> <!-- 物品 -->
<item-qty :dataContent="item" :handleQty="item.handleQty"></item-qty> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="itemCoceClick($event,item,index)"
:right-options="removeOptions">
<item-qty :dataContent="item" :handleQty="item.handleQty"></item-qty>
</uni-swipe-action-item>
</uni-swipe-action>
<!-- <com-issue-request-info :workShopCode="dataContent.workShopCode" :dataContent="dataContent"> <!-- <com-issue-request-info :workShopCode="dataContent.workShopCode" :dataContent="dataContent">
</com-issue-request-info> --> </com-issue-request-info> -->
</template> </template>
@ -21,7 +26,7 @@
</location> </location>
</view> </view>
<view v-for="(batch,index) in loacation.Batchs"> <view v-for="(batch,index) in loacation.Batchs">
<recommend-balance style='margin-left: 20px;' :detail="batch" :isShowLocation="false" <recommend-balance style='margin-left: 0rpx;' :detail="batch" :isShowLocation="false"
:isShowPack="batch.packingNumber!=null && batch.packingNumber!=''"> :isShowPack="batch.packingNumber!=null && batch.packingNumber!=''">
</recommend-balance> </recommend-balance>
<view class="uni-flex uni-row " v-if='batch.Records.length>0'> <view class="uni-flex uni-row " v-if='batch.Records.length>0'>
@ -68,11 +73,12 @@
import comIssueRequestInfo from '@/pages/issue/coms/comIssueRequestInfo.vue' import comIssueRequestInfo from '@/pages/issue/coms/comIssueRequestInfo.vue'
import { import {
getDetailOption, getDetailOption,
getEditRemoveOption getEditRemoveOption,
getRemoveOption
} from '@/common/array.js'; } from '@/common/array.js';
export default { export default {
emits: ['updateData'], emits: ['updateData',"removeItemCode"],
components: { components: {
itemQty, itemQty,
recommend, recommend,
@ -107,13 +113,15 @@
editItem: {}, editItem: {},
batchItem: {}, batchItem: {},
detailOptions: [], detailOptions: [],
scanOptions: [] scanOptions: [],
removeOptions:[]
} }
}, },
mounted() { mounted() {
this.detailOptions = getDetailOption(); this.detailOptions = getDetailOption();
this.scanOptions = getEditRemoveOption(); this.scanOptions = getEditRemoveOption();
this.removeOptions = getRemoveOption()
}, },
methods: { methods: {
@ -135,6 +143,13 @@
this.remove(batch, record, index) this.remove(batch, record, index)
} }
}, },
itemCoceClick(e,item,index){
if (e.content.text == "移除") {
this.dataContent.Items.splice(index, 1);
this.$emit('removeItemCode')
}
},
edit(batch, item) { edit(batch, item) {
let that = this; let that = this;

37
pages/issue/coms/comIssueRequestCreator.vue

@ -3,12 +3,12 @@
<view class="uni-flex uni-column"> <view class="uni-flex uni-column">
<!-- <com-issue-request-info :workShopCode="dataContent.workshopCode" :dataContent="dataContent"> <!-- <com-issue-request-info :workShopCode="dataContent.workshopCode" :dataContent="dataContent">
</com-issue-request-info> --> </com-issue-request-info> -->
<work-station :workshopCode="dataContent.workShopCode" :productionLineCode="dataContent.productionLineCode" <work-station :fromWarehouseCode="dataContent.fromWarehouseCode" :workshopCode="dataContent.workshopCode" :productionLineCode="dataContent.productionLineCode"
:workStationCode="dataContent.workStationCode" :rawLocationCode="dataContent.toLocationCode"></work-station> :workStationCode="dataContent.workStationCode" :rawLocationCode="dataContent.toLocationCode"></work-station>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<view v-for="(item, index) in dataContent.subList" :key="index"> <view v-for="(item, index) in dataContent.subList" :key="index">
<uni-swipe-action-item @click="swipeClick($event,item)" :right-options="detailOptions"> <uni-swipe-action-item @click="swipeClick($event,item,index)" :right-options="options">
<item-qty :dataContent="item" :isShowStdPack="false"> <item-qty :dataContent="item" :isShowStdPack="false">
</item-qty> </item-qty>
<u-line /> <u-line />
@ -76,13 +76,6 @@
}, },
}, },
watch: { watch: {
dataContent: {
handler(newval, oldval) {
this.requestItem = this.dataContent.subList[0];
},
immediate: true,
deep: true
}
}, },
data() { data() {
@ -94,9 +87,9 @@
} }
}, },
requestItem: {},
detailOptions: [], detailOptions: [],
scanOptions: [] scanOptions: [],
options:[]
} }
}, },
@ -105,26 +98,27 @@
this.detailOptions = getDetailOption(); this.detailOptions = getDetailOption();
} }
if (this.scanOptions.length == 0) { if (this.scanOptions.length == 0) {
this.scanOptions = getDetailEditRemoveOption(); this.scanOptions = getDetailRemoveOption();
// if (this.dataContent.allowModifyQty == 1) { // if (this.dataContent.allowModifyQty == 1) {
// this.scanOptions = getDetailEditRemoveOption(); // this.scanOptions = getDetailEditRemoveOption();
// } else { // } else {
// this.scanOptions = getDetailRemoveOption(); // this.scanOptions = getDetailRemoveOption();
// } // }
} }
if(!this.isSwipe){ this.options =this.scanOptions
this.detailOptions=[] // if(!this.isSwipe){
} // this.detailOptions=[]
// }
}, },
methods: { methods: {
swipeClick(e, item) { swipeClick(e, item,index) {
if (e.content.text == "详情") { if (e.content.text == "详情") {
this.detail(item) this.detail(item)
} else if (e.content.text == "编辑") { } else if (e.content.text == "编辑") {
this.edit(item) this.edit(item)
} else if (e.content.text == "移除") { } else if (e.content.text == "移除") {
this.remove(item) this.remove(item,index)
} }
}, },
edit(item) { edit(item) {
@ -138,17 +132,12 @@
// // this.showItem = item; // // this.showItem = item;
// // this.$refs.jobDetailPopup.openPopup(item) // // this.$refs.jobDetailPopup.openPopup(item)
}, },
remove(item) { remove(item,index) {
this.$refs.message.showQuestionMessage("确定移除扫描信息?", this.$refs.message.showQuestionMessage("确定移除扫描信息?",
res => { res => {
if (res) { if (res) {
item.scaned = false this.dataContent.subList.splice(index, 1)
item.record = {}
item.balance = {}
item.inventoryStatus = item.RecommendInventoryStatus
// item.record.qty = 0;
this.$forceUpdate() this.$forceUpdate()
this.$emit('remove', item)
} }
}); });
}, },

271
pages/issue/coms/comIssueRequestPopup.vue

@ -13,6 +13,18 @@
<u-line /> <u-line />
<view class="uni-flex uni-column" style="background-color: white; "> <view class="uni-flex uni-column" style="background-color: white; ">
<view class="uni-flex uni-column "> <view class="uni-flex uni-column ">
<view class="uni-flex uni-row padding title u-col-center">
<text>从仓库代码</text>
<view class="uni-flex u-col-center uni-row" @click="showWarseHouseSelect">
<view class="" style="margin-left: 20rpx;width: 100% ">
{{fromWarehouseCode}}
</view>
<u-select v-model="showWareHouse" mode="single-column" :list="wareHouseList"
@confirm="confirmWareHouse"></u-select>
</view>
</view>
<u-line />
<view class="uni-flex uni-row padding title u-col-center"> <view class="uni-flex uni-row padding title u-col-center">
<text>位置</text> <text>位置</text>
<view class="uni-flex u-col-center uni-row" @click="showSelect"> <view class="uni-flex u-col-center uni-row" @click="showSelect">
@ -36,16 +48,22 @@
</image> </image>
</view> </view>
</view> </view>
<u-line />
<u-line />
<view class="uni-flex uni-row padding title u-col-center"> <view class="uni-flex uni-row padding title u-col-center">
<text>数量 </text> <text>数量 </text>
<view class="uni-flex uni-row uni-center" <view class="uni-flex uni-row uni-center"
style="align-items: center;margin-left: 20rpx;"> style="display: flex; align-items: center;margin-left: 20rpx;justify-content: center;">
<uni-number-box :value="counQty" @change="change" style='margin-left: 10rpx;'
:focus="numberFocus" @blur='numberFocus = false'> <input style="text-align: center;" class="qty_input" v-model="counQty" type="number"
</uni-number-box> @confirm="confirm()" :focus="numberFocus" @input="checkNum"
:maxlength="maxlength" />
<uom :uom="uom"></uom> <uom :uom="uom"></uom>
<view class="" v-if="stdPackInfo!=undefined"
style="display: flex;flex-direction: row;margin-left: 10rpx;">
(<stdPackQty :dataContent="stdPackInfo"></stdPackQty>)
</view>
</view> </view>
</view> </view>
<u-line /> <u-line />
@ -58,7 +76,8 @@
</view> </view>
</view> </view>
</uni-popup> </uni-popup>
<win-scan-item ref="scanPopup" title='物料代码' @getScanCode='getScanCode'> <win-scan-item ref="scanPopup" title='物料代码' @getScanResult='getItemScanResult'
:itemCodeTypeList="itemCodeTypeList">
</win-scan-item> </win-scan-item>
<comMessage ref="comMessage"></comMessage> <comMessage ref="comMessage"></comMessage>
</view> </view>
@ -69,7 +88,8 @@
getBasicLocationByCode, getBasicLocationByCode,
getBasicItemByCode, getBasicItemByCode,
getProductionlineItem, getProductionlineItem,
getWorkShopLineStation getWorkShopLineStation,
getWarehouseCodeList
} from '@/api/request2.js'; } from '@/api/request2.js';
import { import {
getLocationTypeName, getLocationTypeName,
@ -77,21 +97,21 @@
checkDirectoryItemExist checkDirectoryItemExist
} from '@/common/directory.js'; } from '@/common/directory.js';
import uom from '@/mycomponents/qty/uom.vue' import uom from '@/mycomponents/qty/uom.vue'
import stdPackQty from '@/mycomponents/qty/stdPackQty.vue'
import balanceStatus from '@/mycomponents/status/balanceStatus.vue' import balanceStatus from '@/mycomponents/status/balanceStatus.vue'
import comMessage from '@/mycomponents/common/comMessage.vue' import comMessage from '@/mycomponents/common/comMessage.vue'
import winScanItem from '@/mycomponents/scan/winScanItem.vue' import winScanItem from '@/mycomponents/scan/winScanItem.vue'
export default { export default {
components: { components: {
uom, uom,
balanceStatus, balanceStatus,
comMessage, comMessage,
winScanItem winScanItem,
stdPackQty,
}, },
data() { data() {
return { return {
// itemCode: 'CE115F11161AG',
workshopCode: "", // workshopCode: "", //
workShopName: "", workShopName: "",
productionLineCode: "", //线 productionLineCode: "", //线
@ -99,6 +119,7 @@
workStationCode: "", // workStationCode: "", //
workStationName: "", workStationName: "",
itemCode: '请扫描物料信息', itemCode: '请扫描物料信息',
fromWarehouseCode: "请选择仓库代码",
itemName: "", itemName: "",
qty: 0, qty: 0,
rawLocationCode: "", rawLocationCode: "",
@ -106,8 +127,7 @@
itemCodeFocus: false, itemCodeFocus: false,
requestInfo: null, requestInfo: null,
itemCodeList: [], itemCodeList: [],
isCheckItemCode: false, counQty: undefined,
counQty: 0,
editPosition: true, editPosition: true,
numberFocus: false, numberFocus: false,
uom: "", uom: "",
@ -115,70 +135,11 @@
show: false, show: false,
isModifiedPosition: true, isModifiedPosition: true,
positionList: [], positionList: [],
list: [{ stdQty: 0, //
value: 1, maxlength: 10,
label: '车间1', stdPackInfo: undefined,
children: [{ wareHouseList: [],
value: 2, showWareHouse: false
label: '生产线1',
children: [{
value: 3,
label: '工位1'
},
{
value: 4,
label: '工位2'
}
]
},
{
value: 5,
label: '生产线2',
children: [{
value: 6,
label: '工位1'
},
{
value: 7,
label: '工位2'
}
]
}
]
},
{
value: 8,
label: '车间2',
children: [{
value: 9,
label: '生产线1',
children: [{
value: 10,
label: '工位1'
},
{
value: 10,
label: '工位2'
}
]
}, {
value: 9,
label: '生产线2',
children: [{
value: 10,
label: '工位1'
},
{
value: 10,
label: '工位2'
}
]
},
]
}
]
} }
}, },
props: { props: {
@ -186,29 +147,82 @@
type: String, type: String,
default: '需求信息' default: '需求信息'
}, },
itemCodeTypeList: {
type: Array,
default: []
},
}, },
methods: { methods: {
checkNum(e) {
let value = e.detail.value;
let dot = value.indexOf('.'); //
let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
this.change(value)
},
openRequestPopup(editPosition) { openRequestPopup(editPosition) {
if (this.positionList.length == 0) { if (this.positionList.length == 0) {
getWorkShopLineStation().then(res => { getWorkShopLineStation().then(res => {
this.positionList = res.data if (res.data != null && res.data.length > 0) {
}).catch(error => { this.positionList = res.data
} else {
this.showErrorMessage('未查找到位置信息');
}
}).catch(error => {
this.showErrorMessage(error);
}) })
} }
this.editPosition = editPosition; this.editPosition = editPosition;
if (this.isModifiedPosition) { if (this.isModifiedPosition) {
this.isModifiedPosition = false this.isModifiedPosition = false
} else { } else {
this.itemCode = ""; this.itemCode = "请扫描物料信息";
this.show = false
this.showWareHouse = false
this.uom = "" this.uom = ""
this.qty = 0 this.qty = 0;
this.stdPackInfo = undefined;
this.counQty = undefined;
this.numberFocus = false
this.itemCodeGetFocus(); this.itemCodeGetFocus();
} }
this.$refs.popup.open('bottom') this.$refs.popup.open('bottom')
}, },
initData() {
this.positionList = [];
this.wareHouseList= [],
this.showWareHouse = false
this.editPosition =true;
this.itemCode = "请扫描物料信息";
this.rawLocationCode = ""
this.positionInfo = "请选择位置"
this.fromWarehouseCode = "请选择仓库代码"
this.workshopCode = "" //
this.workShopName = ""
this.productionLineCode = "" //线
this.productionLineName = ""
this.workStationCode = "" //
this.workStationName = ""
this.show = false
this.uom = ""
this.qty = 0;
this.stdPackInfo = undefined;
this.counQty = undefined;
this.numberFocus = false
},
closeRequestPopup() { closeRequestPopup() {
this.$refs.popup.close() this.$refs.popup.close()
}, },
@ -226,16 +240,28 @@
itemCodeLoseFocus() { itemCodeLoseFocus() {
this.itemCodeFocus = false; this.itemCodeFocus = false;
}, },
selectedItem(item) {
this.itemCode = item.itemCode;
this.checkItemCode();
},
confirm() { confirm() {
if (this.itemCode == "" || !this.isCheckItemCode) { if (this.positionInfo == "请选择位置") {
this.showErrorMessage("请选择位置")
return
}
if (this.fromWarehouseCode == "请选择仓库代码") {
this.showErrorMessage("请选择仓库代码")
return
}
if (this.itemCode == "请扫描物料信息") {
this.showErrorMessage("请输入物料", "itemCode") this.showErrorMessage("请输入物料", "itemCode")
return return
} }
if (this.counQty == undefined) {
this.showErrorMessage("请输入数量")
return
}
if (this.qty == 0) { if (this.qty == 0) {
this.showErrorMessage("数量必须大于0") this.showErrorMessage("数量必须大于0")
return return
@ -248,28 +274,6 @@
this.callback('add'); this.callback('add');
}, },
checkItemCode(itemCode) {
//
getBasicItemByCode(itemCode).then(res => {
uni.hideLoading();
this.$refs.scanPopup.closeScanPopup();
if (res.data != null && res.data.list.length > 0) {
this.itemCode = res.data.list[0].code;
this.itemName = res.data.list[0].name
this.isCheckItemCode = true;
this.numberFocus = true
this.uom = res.data.list[0].uom
} else {
this.showErrorMessage('未查找到物料【' + itemCode + '】', "itemCode");
}
}).catch(error => {
uni.hideLoading();
this.showErrorMessage(error, "itemCode");
})
},
callback(action) { callback(action) {
let item = { let item = {
positionInfo: this.positionInfo, positionInfo: this.positionInfo,
@ -281,6 +285,8 @@
workStationName: this.workStationName, workStationName: this.workStationName,
rawLocationCode: this.rawLocationCode, rawLocationCode: this.rawLocationCode,
fgLocationCode: this.fgLocationCode, fgLocationCode: this.fgLocationCode,
fromWarehouseCode: this.fromWarehouseCode,
toWarehouseCode: this.fromWarehouseCode,
itemCode: this.itemCode, itemCode: this.itemCode,
itemName: this.itemName, itemName: this.itemName,
uom: this.uom, uom: this.uom,
@ -300,8 +306,7 @@
} }
}) })
if (type == "itemCode") { if (type == "itemCode") {
this.itemCode = "" this.itemCode = "请扫描物料信息"
this.isCheckItemCode = false;
} }
}) })
}, },
@ -315,8 +320,14 @@
if (this.editPosition) { if (this.editPosition) {
this.show = true this.show = true
} }
},
showWarseHouseSelect() {
if (this.editPosition) {
this.wareHouseClick();
}
}, },
confirmSelect(e) { confirmSelect(e) {
this.positionInfo = e[0].label + "-" + e[1].label + "-" + e[2].label this.positionInfo = e[0].label + "-" + e[1].label + "-" + e[2].label
console.log("位置", this.positionInfo) console.log("位置", this.positionInfo)
@ -347,14 +358,42 @@
} }
}, },
getScanCode(code) { getItemScanResult(code, scanResult) {
if (code == "") { this.itemCode = code;
this.showErrorMessage('物料号不能为空') this.itemName = scanResult.name
return; this.uom = scanResult.uom
} this.stdPackInfo = scanResult.package;
this.itemCode = ""; this.numberFocus = true
this.checkItemCode(code)
}, },
wareHouseClick() {
uni.showLoading({
title: "查询中....",
mask: true
});
getWarehouseCodeList(1, 100).then(res => {
uni.hideLoading()
if (res.data != null && res.data.list.length > 0) {
res.data.list.forEach(item => {
item.value = item.code;
item.label = item.name;
})
this.wareHouseList = res.data.list
this.showWareHouse = true
} else {
this.showErrorMessage('未查找到仓库代码');
}
}).catch(error => {
uni.hideLoading()
this.showErrorMessage(error);
})
},
confirmWareHouse(e) {
this.fromWarehouseCode = e[0].value;
},
} }
} }

38
pages/issue/coms/comScanIssuePack.vue

@ -3,9 +3,16 @@
<uni-popup ref="popup" :maskClick='false'> <uni-popup ref="popup" :maskClick='false'>
<view class=""> <view class="">
<view class="popup_box"> <view class="popup_box">
<view class="pop_title">
扫描箱码 <view class="pop_title uni-flex space-between">
<text class="fr" @click="closeScanPopup()">关闭</text> <view class="" style="font-size: 35rpx;">
扫描箱码
</view>
<view class="">
<image class="fr icons_scan_close" src="/static/icons/icons_scan_close.svg"
@click="closeScanPopup()"></image>
</view>
</view> </view>
<!-- <view class="uni-flex uni-row" style="align-items: center; <!-- <view class="uni-flex uni-row" style="align-items: center;
background-color: #fff; background-color: #fff;
@ -45,8 +52,8 @@
<view class=""> <view class="">
<view class=""> <view class="">
<win-com-scan ref="comscan" placeholder="箱标签" @getResult="onScan" :clearResult="true" headerType ="HPQ,HMQ" <win-com-scan ref="comscan" placeholder="箱标签" @getResult="onScan" :clearResult="true"
:isShowHistory="false"> headerType="HPQ,HMQ" :isShowHistory="false">
</win-com-scan> </win-com-scan>
<view style="width: 100%;"> <view style="width: 100%;">
@ -106,6 +113,10 @@
getWorkShopLineStation getWorkShopLineStation
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import { import {
getBalanceByManagementPrecision getBalanceByManagementPrecision
} from '@/common/balance.js'; } from '@/common/balance.js';
@ -234,7 +245,7 @@
let lot = result.label.batch; let lot = result.label.batch;
let item = that.toLocation.Items.find(r => r.itemCode == itemCode); let item = that.toLocation.Items.find(r => r.itemCode == itemCode);
if (item == undefined) { if (item == undefined) {
that.showErrorMessage('未查找到零件【' + itemCode + '】的发料明细', that.showErrorMessage('未查找到物料【' + itemCode + '】的发料明细',
res => { res => {
that.getfocus(); that.getfocus();
} }
@ -325,9 +336,9 @@
this.showQuestionMessage('在【' + that.fromLocationCode + '】库位下,未查找到批次【' + lot + this.showQuestionMessage('在【' + that.fromLocationCode + '】库位下,未查找到批次【' + lot +
'】的发料明细,是否要继续发料?', res => { '】的发料明细,是否要继续发料?', res => {
if (res) { if (res) {
let batch = that.createBatchInfo(label, balance,packageInfo); let batch = that.createBatchInfo(label, balance, packageInfo);
//details //details
if(fromLocation.Batchs.length>0){ if (fromLocation.Batchs.length > 0) {
batch.detail = fromLocation.Batchs[0].detail; batch.detail = fromLocation.Batchs[0].detail;
} }
fromLocation.Batchs.unshift(batch); fromLocation.Batchs.unshift(batch);
@ -356,7 +367,7 @@
} }
}, },
createBatchInfo(data, balance,packageInfo) { createBatchInfo(data, balance, packageInfo) {
let batch = { let batch = {
batch: data.batch, batch: data.batch,
qty: 0, qty: 0,
@ -364,7 +375,7 @@
handleQty: Number(data.qty), handleQty: Number(data.qty),
Records: [] Records: []
} }
let record = this.creatRecord(data, balance,packageInfo); let record = this.creatRecord(data, balance, packageInfo);
batch.Records.push(record); batch.Records.push(record);
this.issueRecord.unshift(record) this.issueRecord.unshift(record)
return batch; return batch;
@ -374,11 +385,12 @@
balance.stdPackQty = packageInfo.stdPackQty balance.stdPackQty = packageInfo.stdPackQty
balance.stdPackUnit = packageInfo.stdPackUnit balance.stdPackUnit = packageInfo.stdPackUnit
let record = { let record = {
scaned:true, scaned: true,
itemCode: label.itemCode, itemCode: label.itemCode,
packingNumber: label.packingNumber, packingNumber: label.packingNumber,
batch: label.batch, batch: label.batch,
qty: Number(label.qty) > Number(balance.qty) ? Number(balance.qty) : Number(label.qty), qty: Number(balance.qty),
// qty: Number(label.qty) > Number(balance.qty) ? Number(balance.qty) : Number(label.qty),
uom: balance.uom, uom: balance.uom,
inventoryStatus: balance.inventoryStatus, inventoryStatus: balance.inventoryStatus,
balance: balance, balance: balance,
@ -391,7 +403,7 @@
calcBatchHandleQty(batch) { calcBatchHandleQty(batch) {
let handleQty = 0; let handleQty = 0;
batch.Records.forEach(res => { batch.Records.forEach(res => {
handleQty += Number(res.qty) handleQty = calc.add(handleQty,res.qty)
}) })
batch.handleQty = handleQty; batch.handleQty = handleQty;

100
pages/issue/job/issueDetail.vue

@ -10,23 +10,28 @@
</view> </view>
<view class="page-main"> <view class="page-main">
<scroll-view scroll-y="true" class="page-main-scroll"> <scroll-view scroll-y="true" class="page-main-scroll">
<view v-for="(toLocation, index) in detailSource"> <view v-for="(toLocation, index) in detailSource">
<work-station :workshopCode="jobContent.workShopCode" :productionLineCode="toLocation.productionLineCode" <work-station :workshopCode="jobContent.workShopCode"
:workStationCode="toLocation.workStationCode" :rawLocationCode="toLocation.toLocationCode"></work-station> :productionLineCode="toLocation.productionLineCode"
:workStationCode="toLocation.workStationCode" :rawLocationCode="toLocation.toLocationCode">
</work-station>
<com-issue-detail-card ref='comIssueDetailCard' :dataContent="toLocation" @updateData='updateData'> <com-issue-detail-card ref='comIssueDetailCard' :dataContent="toLocation" @updateData='updateData'>
</com-issue-detail-card> </com-issue-detail-card>
</view> </view>
</scroll-view> </scroll-view>
</view> </view>
<div class="btn_bottom"> <view class="page-footer">
<view class="" style="display: flex;flex-direction: row;"> <view class="uni-flex u-col-center space-between padding_10"
style="background-color:ghostwhite; width: 100%; ">
<view class=""> <view class="">
<!-- <button class="btn_commit" hover-class="btn_commit_after" @click="resizeCollapse()">刷新UI</button> --> </view>
<button class="btn_commit" hover-class="btn_commit_after" @click="submit()">提交</button> <view class=" uni-flex uni-row">
<button class="btn_single_commit" hover-class="btn_commit_after" @click="submit()">提交</button>
</view> </view>
</view> </view>
</div> </view>
<win-scan-button @goScan='openScanDetailPopup'></win-scan-button> <win-scan-button @goScan='openScanDetailPopup'></win-scan-button>
<com-scan-issue-pack ref="comScanIssuePack" @closeScan='closeScan' @updateData='updateData'> <com-scan-issue-pack ref="comScanIssuePack" @closeScan='closeScan' @updateData='updateData'>
</com-scan-issue-pack> </com-scan-issue-pack>
@ -59,6 +64,10 @@
import { import {
getManagementPrecisions getManagementPrecisions
} from '@/common/balance.js'; } from '@/common/balance.js';
import {
calc
} from '@/common/calc.js';
import jobDetailPopup from '@/mycomponents/job/jobDetailPopup.vue' import jobDetailPopup from '@/mycomponents/job/jobDetailPopup.vue'
import comIssueDetailCard from '@/pages/issue/coms/comIssueDetailCard.vue' import comIssueDetailCard from '@/pages/issue/coms/comIssueDetailCard.vue'
@ -88,7 +97,8 @@
subList: [], //subList subList: [], //subList
detailSource: [], // detailSource: [], //
detailOptions: [], detailOptions: [],
scanOptions: [] scanOptions: [],
jobStatus:""
}; };
}, },
@ -102,7 +112,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -120,12 +129,21 @@
// //
onBackPress(e) { onBackPress(e) {
// //
if (this.received) { if (e.from === 'backbutton') {
// if (this.jobStatus=="2") {
cancleTakeIssueJob(this.id).then(res => {}).catch(error => { //
this.showMessage(err); cancleTakeIssueJob(this.id).then(res => {
}) uni.navigateBack();
}).catch(error => {
uni.navigateBack();
})
} else {
uni.navigateBack();
}
return true;
} }
}, },
watch: { watch: {
@ -176,6 +194,7 @@
} else { } else {
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status
that.subList = res.data.subList; that.subList = res.data.subList;
that.detailSource = getDataSource(that.detailSource, that.subList) that.detailSource = getDataSource(that.detailSource, that.subList)
@ -266,9 +285,9 @@
issueJobSubmit(params).then(res => { issueJobSubmit(params).then(res => {
uni.hideLoading() uni.hideLoading()
if (res.data) { if (res.data) {
this.showCommitSuccessMessage("提交成功<br>生成发料记录" + res.data) this.showCommitSuccessMessage("提交成功<br>生成发料记录<br>" + res.data)
} else { } else {
this.showErrorMessage("提交失败" + res.msg) this.showErrorMessage("提交失败[" + res.msg+"]")
} }
}).catch(error => { }).catch(error => {
uni.hideLoading() uni.hideLoading()
@ -277,7 +296,7 @@
}, },
setParams() { setParams() {
var commitSubList = [] var subList = []
var createTime = getCurrDateTime(); var createTime = getCurrDateTime();
var creator = this.$store.state.user.id var creator = this.$store.state.user.id
this.detailSource.forEach(toLocationCode => { this.detailSource.forEach(toLocationCode => {
@ -285,19 +304,19 @@
item.Locations.forEach(fromLocation => { item.Locations.forEach(fromLocation => {
fromLocation.Batchs.forEach(batch => { fromLocation.Batchs.forEach(batch => {
let subItem = batch.detail; let subItem = batch.detail;
if(subItem!=undefined){ if (subItem != undefined) {
subItem.recordList = [];
if (batch.Records.length > 0) { if (batch.Records.length > 0) {
subItem.recordList = [];
batch.Records.forEach(r => { batch.Records.forEach(r => {
let record = {}; let record = {};
record.handleQty = r.qty; record.handleQty = r.qty;
record.fromPackingNumber = r record.fromPackingNumber = r
.packingNumber; .packingNumber;
record.fromBatch = r.batch; record.fromBatch = r.batch;
record.fromContainerNumber = r record.fromContainerNumber = r
.ContainerNumber; .ContainerNumber;
record.toContainerNumber = r record.toContainerNumber = r
.ContainerNumber; .ContainerNumber;
record.toInventoryStatus = r record.toInventoryStatus = r
@ -305,33 +324,44 @@
record.toLocationCode = subItem record.toLocationCode = subItem
.toLocationCode; .toLocationCode;
record.supplierCode = r.supplierCode; record.supplierCode = r.supplierCode;
let single_price = r.balance
.singlePrice == null ? 0 : r
.balance
.singlePrice;
record.singlePrice = single_price;
record.amount = single_price * r.qty;
//使 //使
if (this.jobContent.useOnTheWayLocation == if (this.jobContent
.useOnTheWayLocation ==
'TRUE') { 'TRUE') {
record.toPackingNumber = r record.toPackingNumber = r
.packingNumber; .packingNumber;
record.toBatch = r.batch; record.toBatch = r.batch;
} else { } else {
var info = getPackingNumberAndBatch( var info =
this.managementList, r getPackingNumberAndBatch(
.itemCode, this.managementList, r
r.packingNumber, r .itemCode,
.batch); r.packingNumber, r
.batch);
record.toPackingNumber = info record.toPackingNumber = info
.packingNumber; .packingNumber;
record.toBatch = info.batch; record.toBatch = info.batch;
} }
subItem.recordList.push(record); subItem.recordList.push(record);
}) })
commitSubList.push(subItem); subList.push(subItem);
} }
} }
}) })
}) })
}) })
}) })
this.jobContent.subList = commitSubList
this.jobContent.subList = subList
this.jobContent.createTime = createTime; this.jobContent.createTime = createTime;
this.jobContent.creator = creator; this.jobContent.creator = creator;
return this.jobContent; return this.jobContent;
@ -339,7 +369,7 @@
cancel() { cancel() {
let that = this; let that = this;
this.$refs.comMessage.showQuestionMessage('是否要清空已扫描的零件和目标库位信息?', res => { this.$refs.comMessage.showQuestionMessage('是否要清空已扫描的物料和目标库位信息?', res => {
if (res) { if (res) {
that.clearInfo(); that.clearInfo();
} }
@ -379,10 +409,10 @@
let handleQty = 0; let handleQty = 0;
if (batch != undefined) { if (batch != undefined) {
batch.Records.forEach(res => { batch.Records.forEach(res => {
handleQty += Number(res.qty) handleQty = calc.add(handleQty,res.qty)
}) })
batch.handleQty = handleQty; batch.handleQty = handleQty;
itemHandleQty += handleQty; itemHandleQty = calc.add(itemHandleQty,handleQty)
} }
}) })
} }

9
pages/issue/js/issue.js

@ -1,3 +1,6 @@
import {
calc
} from '@/common/calc.js';
export function getDataSource(list, subList) { export function getDataSource(list, subList) {
for (var i = 0; i < subList.length; i++) { for (var i = 0; i < subList.length; i++) {
let detail = subList[i]; let detail = subList[i];
@ -17,7 +20,7 @@ export function getDataSource(list, subList) {
return list; return list;
} }
//树形结构:需求库位 -> 零件Items -> 库位 Locations-> 批次Batchs -> 记录Records //树形结构:需求库位 -> 物料Items -> 库位 Locations-> 批次Batchs -> 记录Records
export function createDetailInfo(location, detail) { export function createDetailInfo(location, detail) {
var item = location.Items.find(r => var item = location.Items.find(r =>
r.itemCode == detail.itemCode) r.itemCode == detail.itemCode)
@ -25,8 +28,8 @@ export function createDetailInfo(location, detail) {
item = createItemInfo(detail); item = createItemInfo(detail);
location.Items.push(item) location.Items.push(item)
} else { } else {
item.qty += detail.qty item.qty = calc.add(item.qty,detail.qty)
//在零件下查找库位 //在物料下查找库位
let location = item.Locations.find(r => r.fromLocationCode == detail.fromLocationCode); let location = item.Locations.find(r => r.fromLocationCode == detail.fromLocationCode);
if (location == undefined) { if (location == undefined) {
location = createLocationInfo(detail); location = createLocationInfo(detail);

140
pages/issue/record/issueRecord.vue

@ -8,33 +8,44 @@
<scroll-view scroll-y="true" class=""> <scroll-view scroll-y="true" class="">
<view v-for="(toLocation, index) in detailSource"> <view v-for="(toLocation, index) in detailSource">
<view class="uni-row uni-flex"> <view class="uni-row uni-flex">
<!-- <com-issue-request-info :workShopCode="workShopCode" :dataContent="toLocation"> <!-- <com-issue-request-info :workShopCode="workShopCode" :dataContent="toLocation">
</com-issue-request-info> --> </com-issue-request-info> -->
<work-station :workshopCode="workShopCode" :productionLineCode="toLocation.productionLineCode" <work-station :workshopCode="workShopCode"
:workStationCode="toLocation.workStationCode" :rawLocationCode="toLocation.toLocationCode"></work-station> :productionLineCode="toLocation.productionLineCode"
:workStationCode="toLocation.workStationCode"
:rawLocationCode="toLocation.toLocationCode"></work-station>
</view> </view>
<com-issue-detail-card ref='comIssueDetailCard' :dataContent="toLocation" <com-issue-detail-card ref='comIssueDetailCard' :dataContent="toLocation"
@updateData='updateData'> @updateData='updateData'
@removeItemCode ="removeItemCode"
>
</com-issue-detail-card> </com-issue-detail-card>
</view> </view>
</scroll-view> </scroll-view>
<button class="btn_add" @click="goScan(true)">+去添加</button> <button class="btn_add" @click="goScan(false)">+去添加</button>
</view> </view>
<div class="btn_bottom"> <view class="page-footer">
<view class="" style="display: flex;flex-direction: row;"> <view class="uni-flex u-col-center space-between padding_10"
style="background-color:ghostwhite; width: 100%; ">
<view class=""> <view class="">
<button class="btn_commit" hover-class="btn_commit_after" @click="submit()">提交</button> </view>
<view class=" uni-flex uni-row">
<button class="btn_single_commit" hover-class="btn_commit_after" @click="submit()">提交</button>
</view> </view>
</view> </view>
</div> </view>
</view> </view>
</view> </view>
<com-message ref="comMessage"></com-message> <com-issue-request-popup ref="comIssueRequestPopup" @confirm='requestConfirm' :itemCodeTypeList="itemCodeTypeList"></com-issue-request-popup>
<com-issue-request-popup ref="comIssueRequestPopup" @confirm='requestConfirm'></com-issue-request-popup>
<win-scan-button v-if='detailSource.length>0' @goScan='openScanDetailPopup'></win-scan-button> <win-scan-button v-if='detailSource.length>0' @goScan='openScanDetailPopup'></win-scan-button>
<com-scan-issue-pack ref="comScanIssuePack" @closeScan='closeScan' @updateData='updateData'> <com-scan-issue-pack ref="comScanIssuePack" @closeScan='closeScan' @updateData='updateData'>
</com-scan-issue-pack> </com-scan-issue-pack>
<comMessage ref="comMessage"></comMessage>
</template> </template>
<script> <script>
@ -58,7 +69,10 @@
import { import {
getBusinessType, getBusinessType,
} from '@/common/record.js'; } from '@/common/record.js';
import {
calc
} from '@/common/calc.js';
import { import {
getManagementPrecisions getManagementPrecisions
} from '@/common/balance.js'; } from '@/common/balance.js';
@ -73,7 +87,7 @@
import winScanButton from '@/mycomponents/scan/winScanButton.vue' import winScanButton from '@/mycomponents/scan/winScanButton.vue'
import comScanIssuePack from '@/pages/issue/coms/comScanIssuePack.vue' import comScanIssuePack from '@/pages/issue/coms/comScanIssuePack.vue'
import workStation from '@/mycomponents/workStation/workStation.vue' import workStation from '@/mycomponents/workStation/workStation.vue'
export default { export default {
name: '', name: '',
components: { components: {
@ -98,19 +112,25 @@
fromInventoryStatuses: "", fromInventoryStatuses: "",
toInventoryStatuses: "", toInventoryStatuses: "",
requestList: [], requestList: [],
dataContent:{}, dataContent: {},
managementList:[] managementList: [],
itemCodeTypeList: []
} }
}, },
mounted() { mounted() {
},
onNavigationBarButtonTap(e) {
if (e.index === 0) {
goHome();
}
}, },
onLoad(option) { onLoad(option) {
var typeCode = "Issue" var typeCode = "Issue"
getBusinessType(typeCode, res => { getBusinessType(typeCode, res => {
if (res.success) { if (res.success) {
this.businessType = res.businessType; this.businessType = res.businessType;
this.fromlocationTypeList = res.fromlocationTypeList; this.itemCodeTypeList = res.itemCodeTypeList;
this.tolocationTypeList = res.tolocationTypeList; this.tolocationTypeList = res.tolocationTypeList;
this.fromInventoryStatuses = res.fromInventoryStatuses this.fromInventoryStatuses = res.fromInventoryStatuses
this.toInventoryStatuses = res.toInventoryStatuses this.toInventoryStatuses = res.toInventoryStatuses
@ -133,6 +153,7 @@
}); });
}, },
goScan(editPosition) { goScan(editPosition) {
this.$refs.comIssueRequestPopup.openRequestPopup(editPosition); this.$refs.comIssueRequestPopup.openRequestPopup(editPosition);
}, },
@ -147,7 +168,7 @@
this.getRecommendInfo(item); this.getRecommendInfo(item);
} else { } else {
this.$refs.comMessage.showQuestionMessage('已经存在零件[' + item.itemCode + ']的需求信息,是否要修改?', res => { this.$refs.comMessage.showQuestionMessage('已经存在物料[' + item.itemCode + ']的需求信息,是否要修改?', res => {
if (res) { if (res) {
request.qty = item.qty; request.qty = item.qty;
that.detailSource.forEach(detail => { that.detailSource.forEach(detail => {
@ -172,7 +193,6 @@
if (res.data == null) { if (res.data == null) {
that.showMessage('未获取到推荐信息'); that.showMessage('未获取到推荐信息');
} else { } else {
if (res.data.length > 0) { if (res.data.length > 0) {
that.workShopCode = item.workshopCode; that.workShopCode = item.workshopCode;
res.data.forEach(r => { res.data.forEach(r => {
@ -180,7 +200,8 @@
r.productionLineCode = item.productionLineCode; r.productionLineCode = item.productionLineCode;
r.workStationCode = item.workStationCode; r.workStationCode = item.workStationCode;
// r.itemCode = item.itemCode; // r.itemCode = item.itemCode;
// r.uom = item.uom; r.itemName = item.itemName
r.uom = item.uom;
that.subList.push(r); that.subList.push(r);
}) })
that.detailSource = getDataSource(that.detailSource, that.subList) that.detailSource = getDataSource(that.detailSource, that.subList)
@ -209,7 +230,7 @@
caclcQty() { caclcQty() {
var totalQty = 0; var totalQty = 0;
this.detailSource.subList.forEach(res => { this.detailSource.subList.forEach(res => {
totalQty += res.qty totalQty = calc.add(totalQty, res.qty);
}) })
this.detailSource.totalQty = totalQty; this.detailSource.totalQty = totalQty;
}, },
@ -241,10 +262,10 @@
let handleQty = 0; let handleQty = 0;
if (batch != undefined) { if (batch != undefined) {
batch.Records.forEach(res => { batch.Records.forEach(res => {
handleQty += Number(res.qty) handleQty = calc.add(handleQty, res.qty);
}) })
batch.handleQty = handleQty; batch.handleQty = handleQty;
itemHandleQty += handleQty; itemHandleQty = calc.add(itemHandleQty, handleQty)
} }
}) })
} }
@ -252,6 +273,14 @@
// item.handleQty=itemHandleQty; // item.handleQty=itemHandleQty;
// this.closeScan(); // this.closeScan();
}, },
removeItemCode(){
var isClear =this.detailSource[0].Items.length==0
if(isClear){
this.clearData();
this.$refs.comIssueRequestPopup.initData()
}
},
setParams() { setParams() {
var subList = [] var subList = []
@ -267,31 +296,39 @@
batch.Records.forEach(r => { batch.Records.forEach(r => {
let record = {}; let record = {};
record.handleQty = r.qty; record.handleQty = r.qty;
record.fromPackingNumber = r record.fromPackingNumber = r
.packingNumber; .packingNumber;
record.fromBatch = r.batch; record.fromBatch = r.batch;
record.fromContainerNumber = r record.fromContainerNumber = r
.ContainerNumber; .ContainerNumber;
record.toContainerNumber = r record.toContainerNumber = r
.ContainerNumber; .ContainerNumber;
record.toInventoryStatus = r record.toInventoryStatus = r
.inventoryStatus; .inventoryStatus;
record.toLocationCode = subItem record.toLocationCode = subItem
.toLocationCode; .toLocationCode;
record.fromLocationCode = fromLocation.fromLocationCode record.fromLocationCode = fromLocation
.fromLocationCode
record.supplierCode = r.supplierCode; record.supplierCode = r.supplierCode;
let single_price = r.singlePrice == null ?
0 : r.singlePrice;
record.singlePrice = single_price;
record.amount = single_price * r.qty;
//使 //使
var info = getPackingNumberAndBatch( var info = getPackingNumberAndBatch(
this.managementList, r this.managementList, r
.itemCode, .itemCode,
r.packingNumber, r r.packingNumber, r
.batch); .batch);
record.toPackingNumber = info record.toPackingNumber = info
.packingNumber; .packingNumber;
record.toBatch = info.batch; record.toBatch = info.batch;
subItem.recordList.push(record); subItem.recordList.push(record);
}) })
subList.push(subItem); subList.push(subItem);
@ -300,7 +337,7 @@
}) })
}) })
}) })
this.dataContent.subList = subList this.dataContent.subList = subList
this.dataContent.createTime = createTime; this.dataContent.createTime = createTime;
this.dataContent.creator = creator; this.dataContent.creator = creator;
@ -311,7 +348,7 @@
title: "提交中....", title: "提交中....",
mask: true mask: true
}); });
// //
var itemCodes = [] var itemCodes = []
let locationCode = this.detailSource[0].toLocationCode let locationCode = this.detailSource[0].toLocationCode
@ -320,7 +357,7 @@
itemCodes.push(item.itemCode) itemCodes.push(item.itemCode)
}) })
}) })
// //
getManagementPrecisions(itemCodes, locationCode, res => { getManagementPrecisions(itemCodes, locationCode, res => {
if (res.success) { if (res.success) {
@ -333,37 +370,42 @@
}); });
}, },
submitJob() { submitJob() {
var params = this.setParams() var params = this.setParams()
console.log("提交参数", JSON.stringify(params)); console.log("提交参数", JSON.stringify(params));
issueRecordSubmit(params).then(res => { issueRecordSubmit(params).then(res => {
uni.hideLoading() uni.hideLoading()
if (res.data) { if (res.data) {
this.showCommitSuccessMessage("提交成功<br>生成发料记录<br>" + res.data) this.showCommitSuccessMessage("提交成功<br>生成发料记录<br>" + res.data)
} else { } else {
this.showErrorMessage("提交失败:" + res.msg) this.showErrorMessage("提交失败:" + res.msg+"】")
} }
}).catch(error => { }).catch(error => {
uni.hideLoading() uni.hideLoading()
this.showErrorMessage(error) this.showErrorMessage(error)
}) })
}, },
showCommitSuccessMessage(hint) { showCommitSuccessMessage(hint) {
this.$refs.comMessage.showSuccessMessage(hint, res => { this.$refs.comMessage.showSuccessMessage(hint, res => {
this.clearData(); this.clearData();
this.$refs.comIssueRequestPopup.initData()
}) })
}, },
clearData(){ clearData() {
this.detailSource =[]; this.subList= [], //subList
this.requestList=[]; this.detailSource=[], //
this.dataContent ={} this.detailOptions=[],
this.managementList=[] this.scanOptions= [],
this.workShopCode="",
this.requestList= [],
this.dataContent= {},
this.managementList= []
}, },
showMessage(message) { showMessage(message) {
this.$refs.comMessage.showMessage(message, res => { this.$refs.comMessage.showMessage(message, res => {
if (res) { if (res) {
@ -380,7 +422,7 @@
}, },
// this.$refs.comMessage.showQuestionMessage('?', res => { // this.$refs.comMessage.showQuestionMessage('?', res => {
// if (res) { // if (res) {
// that.clearInfo(); // that.clearInfo();
// } // }

65
pages/issue/request/issueRequestCreate.vue

@ -5,25 +5,27 @@
</view> </view>
<view v-else class="page-wraper"> <view v-else class="page-wraper">
<view class="page-main"> <view class="page-main">
<comIssueRequestCreator ref="issueRequest" :dataContent="detailSource" :isSwipe ="false"> <comIssueRequestCreator ref="issueRequest" :dataContent="detailSource" :isSwipe="false">
</comIssueRequestCreator> </comIssueRequestCreator>
<button class="btn_add" @click="goScan(false)">+去添加</button> <button class="btn_add" @click="goScan(false)">+去添加</button>
</view> </view>
<view class="page-footer">
<div class="btn_bottom"> <view class="uni-flex u-col-center space-between padding_10"
<view class="" style="display: flex;flex-direction: row;"> style="background-color:ghostwhite; width: 100%; ">
<view class=""> <view class="">
<button class="btn_commit" hover-class="btn_commit_after" @click="submit()">提交</button> </view>
<view class=" uni-flex uni-row">
<button class="btn_single_commit" hover-class="btn_commit_after" @click="submit()">提交</button>
</view> </view>
</view> </view>
</div> </view>
<com-scan-issue-pack ref="comScanIssuePack"> <com-scan-issue-pack ref="comScanIssuePack">
</com-scan-issue-pack> </com-scan-issue-pack>
<comMessage ref="comMessage"></comMessage> <comMessage ref="comMessage"></comMessage>
</view> </view>
</view> </view>
<com-issue-request-popup ref="comIssueRequestPopup" @confirm='requestConfirm'></com-issue-request-popup> <com-issue-request-popup ref="comIssueRequestPopup" @confirm='requestConfirm' :itemCodeTypeList="itemCodeTypeList" ></com-issue-request-popup>
</template> </template>
<script> <script>
@ -31,10 +33,19 @@
issueRequestSubmit, issueRequestSubmit,
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import {
getBusinessType,
} from '@/common/record.js';
import { import {
goHome, goHome,
updateTitle, updateTitle,
getRemoveOption, getRemoveOption,
navigateBack,
getCurrDateOneMonthsTimes getCurrDateOneMonthsTimes
} from '@/common/basic.js'; } from '@/common/basic.js';
@ -69,14 +80,27 @@
detailOptions: [], detailOptions: [],
scanOptions: [], scanOptions: [],
requestList: [], // requestList: [], //
itemCodeTypeList:[],
useOnTheWay:"FALSE"
} }
}, },
mounted() { mounted() {
this.goScan(true)
}, },
onLoad(option) { onLoad(option) {
var typeCode = "Issue"
getBusinessType(typeCode, res => {
if (res.success) {
this.itemCodeTypeList = res.itemCodeTypeList;
this.tolocationTypeList = res.tolocationTypeList;
this.useOnTheWay = res.useOnTheWay;
this.fromInventoryStatuses = res.fromInventoryStatuses
this.toInventoryStatuses = res.toInventoryStatuses
this.goScan(true)
} else {
this.showErrorMessage(res.message)
}
});
}, },
methods: { methods: {
@ -89,22 +113,26 @@
if (this.detailSource.subList.length == 0) { if (this.detailSource.subList.length == 0) {
this.detailSource = { this.detailSource = {
workShopCode: item.workshopCode, workshopCode: item.workshopCode,
workShopName: item.workShopName, workShopName: item.workShopName,
productionLineCode: item.productionLineCode, productionLineCode: item.productionLineCode,
productionLineName: item.productionLineName, productionLineName: item.productionLineName,
workStationCode: item.workStationCode, workStationCode: item.workStationCode,
workStationName: item.workStationName, // workStationName: item.workStationName, //
toLocationCode:item.rawLocationCode, toLocationCode: item.rawLocationCode,
fromWarehouseCode:item.fromWarehouseCode,
useOnTheWay:this.useOnTheWay,
totalQty: 0, totalQty: 0,
subList: [] subList: []
} }
var subItem = { var subItem = {
productionLineCode: item.productionLineCode, productionLineCode: item.productionLineCode,
workStationCode: item.workStationCode, workStationCode: item.workStationCode,
itemCode: item.itemCode, itemCode: item.itemCode,
itemName: item.itemName, itemName: item.itemName,
toWarehouseCode:item.toWarehouseCode,
fromWarehouseCode:item.fromWarehouseCode,
qty: item.qty, qty: item.qty,
uom: item.uom uom: item.uom
} }
@ -123,6 +151,8 @@
workStationCode: item.workStationCode, workStationCode: item.workStationCode,
itemCode: item.itemCode, itemCode: item.itemCode,
itemName: item.itemName, itemName: item.itemName,
toWarehouseCode:item.toWarehouseCode,
fromWarehouseCode:item.fromWarehouseCode,
qty: item.qty, qty: item.qty,
uom: item.uom uom: item.uom
} }
@ -131,18 +161,17 @@
} else { } else {
// //
result[0].qty += item.qty result[0].qty = calc.add(result[0].qty,item.qty)
} }
} }
this.caclcQty(); this.caclcQty();
}, },
caclcQty() { caclcQty() {
var totalQty = 0; var totalQty = 0;
this.detailSource.subList.forEach(res => { this.detailSource.subList.forEach(res => {
totalQty += res.qty totalQty = calc.add(totalQty,res.qty)
}) })
this.detailSource.totalQty = totalQty; this.detailSource.totalQty = totalQty;
}, },
@ -173,9 +202,7 @@
}, },
showCommitSuccessMessage(hint) { showCommitSuccessMessage(hint) {
this.$refs.comMessage.showSuccessMessage(hint, res => { this.$refs.comMessage.showSuccessMessage(hint, res => {
uni.navigateTo({ navigateBack(1)
url: './issueRequest'
})
}) })
}, },
showErrorMessage(message) { showErrorMessage(message) {

2
pages/package/coms/comOverRecord.vue

@ -123,7 +123,7 @@
methods: { methods: {
removeItem(e, dataContent) { removeItem(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

2
pages/package/coms/comPackageRecord.vue

@ -124,7 +124,7 @@
methods: { methods: {
removeItem(e, dataContent) { removeItem(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

10
pages/package/record/mergePackageRecord.vue

@ -146,8 +146,8 @@
}) })
if (item == undefined) { if (item == undefined) {
if (this.currentItemCode != "" && this.currentItemCode != balance.itemCode) { if (this.currentItemCode != "" && this.currentItemCode != balance.itemCode) {
this.showErrorMessage("合包当前零件号[" + this.currentItemCode + "与扫描零件号[" + balance.itemCode + this.showErrorMessage("合包当前物料号[" + this.currentItemCode + "与扫描物料号[" + balance.itemCode +
"]不一致,请扫描相同零件号") "]不一致,请扫描相同物料号")
return; return;
} }
var itemp = createItemInfo(balance, pack); var itemp = createItemInfo(balance, pack);
@ -271,7 +271,7 @@
detail.fromInventoryStatus = detail.inventoryStatus; detail.fromInventoryStatus = detail.inventoryStatus;
detail.toInventoryStatus = detail.inventoryStatus; detail.toInventoryStatus = detail.inventoryStatus;
detail.fromQty = detail.qty detail.fromQty = detail.handleQty
detail.fromPackingNumber = detail.packingNumber; detail.fromPackingNumber = detail.packingNumber;
detail.toPackingNumber = this.toPackingNumber; detail.toPackingNumber = this.toPackingNumber;
@ -345,8 +345,8 @@
}, },
getToPackingNumber(result) { getToPackingNumber(result) {
if(this.currentItemCode!=result.label.itemCode){ if(this.currentItemCode!=result.label.itemCode){
this.showErrorMessage("合包当前零件号[" + this.currentItemCode + "与目标零件号[" + result.label.itemCode + this.showErrorMessage("合包当前物料号[" + this.currentItemCode + "与目标物料号[" + result.label.itemCode +
"]不一致,请扫描相同零件号") "]不一致,请扫描相同物料号")
return; return;
} }
this.toPackingNumber = result.label.packingNumber; this.toPackingNumber = result.label.packingNumber;

2
pages/package/record/overPackageRecord.vue

@ -262,7 +262,7 @@
subItem.itemDesc2 = detail.package.itemDesc2; subItem.itemDesc2 = detail.package.itemDesc2;
subItem.fromInventoryStatus = detail.inventoryStatus; subItem.fromInventoryStatus = detail.inventoryStatus;
subItem.fromQty = detail.qty subItem.fromQty = detail.handleQty
subItem.fromPackingNumber = detail.packingNumber; subItem.fromPackingNumber = detail.packingNumber;
subItem.fromBatch = detail.batch; subItem.fromBatch = detail.batch;
subItem.fromLocationCode = detail.locationCode; subItem.fromLocationCode = detail.locationCode;

20
pages/package/record/splitPackageRecord.vue

@ -48,6 +48,10 @@
splitPackageRecordSubmit splitPackageRecordSubmit
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import { import {
getInventoryStatusDesc, getInventoryStatusDesc,
getDirectoryItemArray getDirectoryItemArray
@ -180,9 +184,9 @@
var sumQty = 0; var sumQty = 0;
item.subList[0].Records.forEach(function(item1, index) { item.subList[0].Records.forEach(function(item1, index) {
sumQty += item1.qty; sumQty = calc.add(sumQty,item1.qty)
}); });
if ((Number(qty) + sumQty) > item.subList[0].qty) { if (calc.add(qty,sumQty)> item.subList[0].qty) {
this.showErrorMessage("扫描数量总和【" + (Number(qty) + sumQty) + "】(当前输入数量【" + qty + "】+已添加数量【" + this.showErrorMessage("扫描数量总和【" + (Number(qty) + sumQty) + "】(当前输入数量【" + qty + "】+已添加数量【" +
sumQty + sumQty +
"】)已超过拆包箱码的数量【" + Number(item.subList[0].qty) + "】!"); "】)已超过拆包箱码的数量【" + Number(item.subList[0].qty) + "】!");
@ -200,7 +204,7 @@
if (detail.Records.length > 0) { if (detail.Records.length > 0) {
detail.Records.forEach(r => { detail.Records.forEach(r => {
hQty += Number(r.qty) hQty = calc.add(hQty,r.qty)
}) })
} }
detail.handleQty = hQty; detail.handleQty = hQty;
@ -292,21 +296,21 @@
subItem.itemName = detail.package.itemName; subItem.itemName = detail.package.itemName;
subItem.itemDesc1 = detail.package.itemDesc1; subItem.itemDesc1 = detail.package.itemDesc1;
subItem.itemDesc2 = detail.package.itemDesc2; subItem.itemDesc2 = detail.package.itemDesc2;
subItem.fromInventoryStatus = subItem.inventoryStatus; subItem.fromInventoryStatus = subItem.inventoryStatus;
subItem.toInventoryStatus = subItem.inventoryStatus; subItem.toInventoryStatus = subItem.inventoryStatus;
subItem.fromQty = subItem.qty subItem.fromQty = subItem.qty
subItem.toQty = record.qty subItem.toQty = record.qty
subItem.fromPackingNumber = subItem.packingNumber; subItem.fromPackingNumber = subItem.packingNumber;
subItem.toPackingNumber = record.packingNumber; subItem.toPackingNumber = record.packingNumber;
subItem.fromBatch = subItem.batch; subItem.fromBatch = subItem.batch;
subItem.toBatch = record.batch; subItem.toBatch = record.batch;
subItem.fromLocationCode = subItem.fromLocationCode; subItem.fromLocationCode = subItem.fromLocationCode;
subItem.package = "" subItem.package = ""
subItem.Records="" subItem.Records = ""
subList.push(subItem) subList.push(subItem)
} }

2
pages/productDismantle/coms/comProductJobCard.vue

@ -9,7 +9,7 @@
<view class="task_text"> <view class="task_text">
<view class=""> <view class="">
零件 : {{dataContent.itemCode}} 物料 : {{dataContent.itemCode}}
</view> </view>
</view> </view>

2
pages/productDismantle/coms/comProductRecord.vue

@ -115,7 +115,7 @@
methods: { methods: {
removeItem(e, dataContent) { removeItem(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

198
pages/productPutaway/coms/comProductRecord.vue

@ -1,198 +0,0 @@
<template>
<view class="" style="background-color: #fff;">
<uni-collapse ref="collapse1" @change="">
<uni-collapse-item :open="true">
<template v-slot:title>
<uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeItem($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty"
:isShowBalance="true"></item-qty>
</uni-swipe-action-item>
</uni-swipe-action>
</template>
<u-line />
<view class="" v-for="(item,index) in dataContent.subList">
<uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="swipeClick($event,item,index)"
:right-options="item.scaned?scanOptions:detailOptions">
<!-- <balance :dataContent="item" :isShowStdPack="false" :isShowPack="true"
:isShowLocation="true"></balance> -->
<purchase-label :dataContent="item" :packageContent="item.package" :isShowStdPack="false">
</purchase-label>
</uni-swipe-action-item>
</uni-swipe-action>
<u-line color="#D8D8D8"></u-line>
</view>
</uni-collapse-item>
</uni-collapse>
<balanceQtyEdit ref="balanceQtyEdit" @confirm="confirm"></balanceQtyEdit>
<job-detail-popup ref="winHint" :dataContent="showItem"></job-detail-popup>
<com-message ref="comMessage"></com-message>
</view>
</template>
<script>
import itemQty from '@/mycomponents/item/itemQty.vue'
import recommend from '@/mycomponents/recommend/recommend.vue'
import jobDetailPopup from '@/mycomponents/job/jobDetailPopup.vue'
import purchaseLabel from '@/mycomponents/balance/purchaseLabel.vue'
import record from '@/mycomponents/record/record.vue'
import balanceQtyEdit from '@/mycomponents/qty/balanceQtyEdit.vue'
import comMessage from '@/mycomponents/common/comMessage.vue'
import {
getDetailOption,
getDetailEditRemoveOption,
getClearOption
} from '@/common/array.js';
export default {
components: {
itemQty,
recommend,
jobDetailPopup,
purchaseLabel,
balanceQtyEdit,
record,
comMessage
},
props: {
dataContent: {
type: Object,
default: {}
},
settingParam: {
type: Object,
default: {}
},
fromInventoryStatus: {
type: String,
default: ""
},
toInventoryStatus: {
type: String,
default: ""
},
isShowStatus: {
type: Boolean,
default: false
}
},
watch: {
dataContent: {
handler(newName, oldName) {
if (this.dataContent.subList.length > 0) {
if (this.$refs.collapse1 != undefined) {
this.$nextTick(res => {
this.$refs.collapse1.resize()
})
}
}
},
immediate: true,
deep: true
}
},
data() {
return {
option: [],
title: "推荐详情",
showItem: {},
editItem: {},
detailOptions: [],
scanOptions: [],
removeOptions: [],
dataList: []
}
},
mounted() {
this.detailOptions = getDetailOption();
this.scanOptions = getDetailEditRemoveOption();
this.removeOptions = getClearOption();
},
methods: {
removeItem(e, dataContent) {
if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?",
res => {
if (res) {
this.$emit('removeItem')
// this.$emit('removeItem', this.dataContent)
}
});
}
},
swipeClick(e, item, index) {
if (e.content.text == "详情") {
this.detail(item)
} else if (e.content.text == "编辑") {
this.edit(item)
} else if (e.content.text == "移除") {
this.remove(item, index)
}
},
edit(item) {
this.editItem = item;
this.$refs.balanceQtyEdit.openEditPopup(this.editItem, this.editItem.qty);
},
remove(item, index) {
this.$refs.comMessage.showQuestionMessage("确定移除扫描信息?",
res => {
if (res) {
this.dataContent.subList.splice(index, 1)
this.$emit('updateData')
}
});
},
confirm(qty) {
this.editItem.qty = qty;
this.$emit('updateData')
},
detail(item) {
this.showItem = item;
this.dataList = [{
title: "箱码",
content: item.packingNumber
},
{
title: "批次",
content: item.batch
},
{
title: "库位",
content: item.locationCode
},
{
title: "数量",
content: item.qty
},
{
title: "单位",
content: item.uom
}
]
this.$refs.winHint.openScanPopup()
},
remove(item, index) {
this.$refs.comMessage.showQuestionMessage("确定移除扫描信息?",
res => {
if (res) {
this.dataContent.subList.splice(index, 1)
this.$emit('removePack')
}
});
},
confirm(qty) {
this.editItem.qty = qty;
this.$emit('updateData')
}
}
}
</script>
<style>
</style>

4
pages/productPutaway/coms/comPutawayRequestCard.vue

@ -1,9 +1,9 @@
<template> <template>
<request-com-main-card :dataContent="dataContent"> <request-com-main-card :dataContent="dataContent">
<view class="task_item"> <view class="task_item">
<view class="task_text"> <!-- <view class="task_text">
供应商代码 : {{dataContent.supplierCode}} 供应商代码 : {{dataContent.supplierCode}}
</view> </view> -->
</view> </view>
</request-com-main-card> </request-com-main-card>
</template> </template>

6
pages/productPutaway/job/productPutawayDetail.vue

@ -102,7 +102,6 @@
data() { data() {
return { return {
id: '', id: '',
received: false,
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
subList: [], //subList subList: [], //subList
@ -112,6 +111,7 @@
toLocationCode: "", toLocationCode: "",
toLocationInfo: {}, toLocationInfo: {},
tolocationTypeList: [], tolocationTypeList: [],
jobStatus:""
}; };
}, },
onLoad(option) { onLoad(option) {
@ -120,7 +120,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -138,7 +137,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeProductPutawayJob(this.id).then(res => { cancleTakeProductPutawayJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -183,6 +182,7 @@
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.subList = res.data.subList; that.subList = res.data.subList;
that.jobStatus = res.data.status
that.fromLocationCode = that.subList[0].fromLocationCode that.fromLocationCode = that.subList[0].fromLocationCode
that.toLocationCode = that.subList[0].toLocationCode that.toLocationCode = that.subList[0].toLocationCode
that.tolocationTypeList = getLocationTypeArray(that.jobContent.toLocationTypes) that.tolocationTypeList = getLocationTypeArray(that.jobContent.toLocationTypes)

2
pages/productPutaway/record/productPutawayRecord.vue

@ -335,7 +335,7 @@
submitItem.fromLocationCode = detail.locationCode; submitItem.fromLocationCode = detail.locationCode;
submitItem.toLocationCode = detail.toLocationCode; submitItem.toLocationCode = detail.toLocationCode;
submitItem.qty = detail.handleQty!=0?detail.handleQty:detail.qty; submitItem.qty = detail.handleQty;
submitItem.package =""; submitItem.package ="";
subList.push(submitItem) subList.push(submitItem)
} }

2
pages/productPutaway/request/putawayRequest.vue

@ -88,7 +88,7 @@
this.addAgainOption = getAddAgainOption(); this.addAgainOption = getAddAgainOption();
this.detailAndApproveOptions = getDetailAndApproveOption() this.detailAndApproveOptions = getDetailAndApproveOption()
this.detailAndApprovePassAndApproveNoOption = getDetailAndApprovePassAndApproveNoOption(), this.detailAndApprovePassAndApproveNoOption = getDetailAndApprovePassAndApproveNoOption(),
this.detailAndHandleOption = getDetailAndHandleOption() this.detailAndHandleOption = getDetailAndHandleOption()
this.detailAndAddAndCloseOption = getDetailAndAddAndCloseOption() this.detailAndAddAndCloseOption = getDetailAndAddAndCloseOption()
}, },

30
pages/productPutaway/request/putawayRequestCreate.vue

@ -53,6 +53,7 @@
import { import {
goHome, goHome,
updateTitle, updateTitle,
deepCopyData,
getCurrDateTime, getCurrDateTime,
getPackingNumberAndBatchByList getPackingNumberAndBatchByList
} from '@/common/basic.js'; } from '@/common/basic.js';
@ -61,6 +62,10 @@
getDirectoryItemArray getDirectoryItemArray
} from '@/common/directory.js'; } from '@/common/directory.js';
import {
calc
} from '@/common/calc.js';
import { import {
getBusinessType, getBusinessType,
createItemInfo, createItemInfo,
@ -144,6 +149,17 @@
let balance = result.balance; let balance = result.balance;
let label = result.label; let label = result.label;
let pack = result.package; let pack = result.package;
if(label.batch==""){
this.showErrorMessage("扫描标签批次为空")
return;
}
if(label.packingNumber==""){
this.showErrorMessage("扫描标签箱码为空")
return;
}
if (this.supplierCode == '') { if (this.supplierCode == '') {
this.supplierCode = result.package.supplierCode this.supplierCode = result.package.supplierCode
} else { } else {
@ -206,14 +222,7 @@
}, },
calcHandleQty() { calcHandleQty() {
for (let item of this.detailSource) { calcHandleQty(this.detailSource)
item.qty = 0;
for (let detail of item.subList) {
if (detail != undefined) {
item.qty += Number(detail.qty)
}
}
}
this.$forceUpdate(); this.$forceUpdate();
}, },
@ -279,7 +288,7 @@
productPutawayRequestSubmit(params).then(res => { productPutawayRequestSubmit(params).then(res => {
uni.hideLoading() uni.hideLoading()
if (res.data) { if (res.data) {
this.showCommitSuccessMessage("提交成功<br>生成制品上架申请<br>" + res.data, ) this.showCommitSuccessMessage("提交成功<br>生成制品上架申请<br>" + res.data)
} else { } else {
this.showErrorMessage("提交失败[" + res.msg + "]") this.showErrorMessage("提交失败[" + res.msg + "]")
} }
@ -301,8 +310,7 @@
this.detailSource.forEach(item => { this.detailSource.forEach(item => {
item.subList.forEach(detail => { item.subList.forEach(detail => {
if (detail.scaned) { if (detail.scaned) {
var subItem = {}; var subItem = deepCopyData(detail)
Object.assign(subItem, detail)
subItem.fromLocationCode = detail.locationCode; subItem.fromLocationCode = detail.locationCode;
subItem.qty = detail.handleQty; subItem.qty = detail.handleQty;
subItem.package = null; subItem.package = null;

4
pages/productPutaway/request/putawayRequestDetail.vue

@ -4,9 +4,9 @@
<view class="header_job_top"> <view class="header_job_top">
<request-top :dataContent="requestContent"></request-top> <request-top :dataContent="requestContent"></request-top>
</view> </view>
<view class="header_item"> <!-- <view class="header_item">
供应商 : {{requestContent.supplierCode}} 供应商 : {{requestContent.supplierCode}}
</view> </view> -->
<u-line color="#D8D8D8" /> <u-line color="#D8D8D8" />
</view> </view>
<view class="page-main"> <view class="page-main">

2
pages/productReceipt/coms/comProductRecord.vue

@ -121,7 +121,7 @@
methods: { methods: {
removeData(e, dataContent) { removeData(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

8
pages/productReceipt/job/productReceiptDetail.vue

@ -97,7 +97,6 @@
return { return {
id: '', id: '',
receiptJob: {}, receiptJob: {},
received: false,
toLocationCode: '', toLocationCode: '',
isShowPackingCode: true, isShowPackingCode: true,
scanCount: 0, scanCount: 0,
@ -105,7 +104,8 @@
subList: [], //subList subList: [], //subList
detailSource: [], // detailSource: [], //
toLocationTypeList: [], toLocationTypeList: [],
managementList: [] managementList: [],
jobStatus:""
}; };
}, },
@ -115,7 +115,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -134,7 +133,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeProductReceiptJob(this.id).then(res => { cancleTakeProductReceiptJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -184,6 +183,7 @@
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.subList = res.data.subList; that.subList = res.data.subList;
that.jobStatus = res.data.status
that.toLocationCode = that.subList[0].toLocationCode that.toLocationCode = that.subList[0].toLocationCode
that.toLocationTypeList = getDirectoryItemArray(that.jobContent.toLocationTypes) that.toLocationTypeList = getDirectoryItemArray(that.jobContent.toLocationTypes)
that.detailSource = getDataSource(that.subList) that.detailSource = getDataSource(that.subList)

31
pages/productReceipt/record/productReceiptRecord.vue

@ -61,6 +61,12 @@
deepCopyData deepCopyData
} from '@/common/basic.js'; } from '@/common/basic.js';
import {
calc
} from '@/common/calc.js';
import { Decimal } from 'decimal.js';//
import { import {
getInventoryStatusDesc, getInventoryStatusDesc,
getDirectoryItemArray getDirectoryItemArray
@ -182,8 +188,8 @@
itemName: pack.itemName, itemName: pack.itemName,
stdPackQty: pack.stdPackQty, stdPackQty: pack.stdPackQty,
stdPackUnit: pack.stdPackUnit, stdPackUnit: pack.stdPackUnit,
qty: Number(label.qty), qty: new Decimal(label.qty).toNumber(),
handleQty: 0, handleQty: new Decimal(0).toNumber(),
uom: pack.uom, uom: pack.uom,
subList: [] subList: []
} }
@ -191,11 +197,10 @@
}, },
createDetailInfo(label, pack) { createDetailInfo(label, pack) {
let detail = {}; let detail = deepCopyData(label);
Object.assign(detail, label)
detail.scaned = true; detail.scaned = true;
detail.qty = Number(label.qty); detail.qty = new Decimal(label.qty).toNumber();
detail.handleQty = 0; detail.handleQty = new Decimal(label.qty).toNumber();
detail.inventoryStatus = "OK" detail.inventoryStatus = "OK"
detail.stdPackQty = pack.stdPackQty; detail.stdPackQty = pack.stdPackQty;
detail.stdPackUnit = pack.stdPackUnit; detail.stdPackUnit = pack.stdPackUnit;
@ -207,10 +212,10 @@
calcHandleQty() { calcHandleQty() {
for (let item of this.detailSource) { for (let item of this.detailSource) {
item.qty = 0; item.handleQty = new Decimal(0).toNumber();
for (let detail of item.subList) { for (let detail of item.subList) {
if (detail != undefined) { if (detail != undefined) {
item.qty += Number(detail.qty) item.handleQty = calc.add(item.handleQty,detail.handleQty)
} }
} }
} }
@ -326,10 +331,10 @@
submitItem.productionlineCode = this.productionLineCode; submitItem.productionlineCode = this.productionLineCode;
submitItem.workStationCode = this.workStationCode; submitItem.workStationCode = this.workStationCode;
submitItem.qty = detail.handleQty!=0?detail.handleQty:detail.qty; submitItem.qty = detail.handleQty;
submitItem.package =""; submitItem.package = "";
subList.push(submitItem) subList.push(submitItem)
} }
}) })
@ -392,7 +397,7 @@
this.clearData(); this.clearData();
}) })
}, },
clearData(){ clearData() {
this.subList = []; this.subList = [];
this.detailSource = []; this.detailSource = [];
this.toLocationCode = ''; this.toLocationCode = '';

2
pages/productionReceipt/coms/comProductionRecord.vue

@ -113,7 +113,7 @@
methods: { methods: {
removeItem(e,dataContent){ removeItem(e,dataContent){
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')

35
pages/productionReceipt/job/productionReceiptDetail.vue

@ -100,7 +100,6 @@
data() { data() {
return { return {
id: '', id: '',
received: false,
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
subList: [], //subList subList: [], //subList
@ -109,6 +108,7 @@
fromLocationCode: "", fromLocationCode: "",
toLocationCode: "", toLocationCode: "",
tolocationTypeList: [], tolocationTypeList: [],
jobStatus:""
}; };
}, },
onLoad(option) { onLoad(option) {
@ -117,7 +117,6 @@
// //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -135,7 +134,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeProductionReceiptJob(this.id).then(res => { cancleTakeProductionReceiptJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -179,6 +178,7 @@
} else { } else {
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status
that.subList = res.data.subList; that.subList = res.data.subList;
that.fromLocationCode = that.subList[0].fromLocationCode that.fromLocationCode = that.subList[0].fromLocationCode
that.toLocationCode = that.subList[0].toLocationCode that.toLocationCode = that.subList[0].toLocationCode
@ -247,7 +247,11 @@
getScanResult(result) { getScanResult(result) {
try { try {
var supplierCode = result.package.supplierCode var supplierCode = result.label.supplierCode;
if (supplierCode == '' || supplierCode == undefined) {
this.showErrorMessage("标签中未解析到供应商信息,请重新扫描")
return;
}
var packingNumber = result.balance.packingNumber; var packingNumber = result.balance.packingNumber;
var batch = result.balance.batch; var batch = result.balance.batch;
var qty = result.balance.qty; var qty = result.balance.qty;
@ -275,37 +279,39 @@
let balanceStatus = getInventoryStatusName(result.balance.inventoryStatus); let balanceStatus = getInventoryStatusName(result.balance.inventoryStatus);
let itemStatus = getInventoryStatusName(itemDetail.inventoryStatus); let itemStatus = getInventoryStatusName(itemDetail.inventoryStatus);
if (itemDetail.inventoryStatus != result.balance.inventoryStatus) { if (itemDetail.inventoryStatus != result.balance.inventoryStatus) {
if(this.jobContent.allowModifyInventoryStatus=="TRUE"){ if (this.jobContent.allowModifyInventoryStatus == "TRUE") {
this.showQuestionMessage('任务中允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' + itemStatus + this.showQuestionMessage('任务中允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' +
itemStatus +
']不一致,是否继续上架?', res => { ']不一致,是否继续上架?', res => {
if (res) { if (res) {
itemDetail.scaned = true; itemDetail.scaned = true;
itemDetail.supplierCode = supplierCode itemDetail.supplierCode = supplierCode
itemDetail.handleQty = Number(result.balance.qty) itemDetail.handleQty = Number(result.balance.qty)
itemDetail.toInventoryStatus = result.balance.inventoryStatus; itemDetail.toInventoryStatus = result.balance.inventoryStatus;
itemDetail.balance = result.balance; itemDetail.balance = result.balance;
itemDetail.balance.balanceQty = Number(result.balance.qty) itemDetail.balance.balanceQty = Number(result.balance.qty)
itemDetail.balance.stdPackQty = Number(result.package.stdPackQty) itemDetail.balance.stdPackQty = Number(result.package.stdPackQty)
itemDetail.balance.stdPackUnit = result.package.stdPackUnit itemDetail.balance.stdPackUnit = result.package.stdPackUnit
this.calcHandleQty(); this.calcHandleQty();
} else { } else {
this.scanPopupGetFocus(); this.scanPopupGetFocus();
} }
}); });
}else { } else {
this.showQuestionMessage('任务中不允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' + itemStatus + this.showQuestionMessage('任务中不允许修改库存状态,实际库存状态[' + balanceStatus + ']与推荐库存状态[' +
itemStatus +
']不一致,不允许转移!', res => { ']不一致,不允许转移!', res => {
this.scanPopupGetFocus(); this.scanPopupGetFocus();
}); });
} }
} else { } else {
itemDetail.scaned = true; itemDetail.scaned = true;
itemDetail.supplierCode = supplierCode itemDetail.supplierCode = supplierCode
itemDetail.handleQty = Number(result.balance.qty) itemDetail.handleQty = Number(result.balance.qty)
itemDetail.toInventoryStatus = result.balance.inventoryStatus; itemDetail.toInventoryStatus = result.balance.inventoryStatus;
itemDetail.balance = result.balance; itemDetail.balance = result.balance;
itemDetail.balance.balanceQty = Number(result.balance.qty) itemDetail.balance.balanceQty = Number(result.balance.qty)
itemDetail.balance.stdPackQty = Number(result.package.stdPackQty) itemDetail.balance.stdPackQty = Number(result.package.stdPackQty)
itemDetail.balance.stdPackUnit = result.package.stdPackUnit itemDetail.balance.stdPackUnit = result.package.stdPackUnit
this.calcHandleQty(); this.calcHandleQty();
@ -428,7 +434,6 @@
detail.toBatch = info.batch; detail.toBatch = info.batch;
detail.toContainerNumber = ""; detail.toContainerNumber = "";
detail.toLocationCode = this.toLocationCode; detail.toLocationCode = this.toLocationCode;
subList.push(detail) subList.push(detail)
} }
}) })

1
pages/productionReceipt/record/productionReceiptRecord.vue

@ -316,6 +316,7 @@
showCommitSuccessMessage(hint) { showCommitSuccessMessage(hint) {
this.$refs.comMessage.showSuccessMessage(hint, res => { this.$refs.comMessage.showSuccessMessage(hint, res => {
this.fromLocationCode = ''; this.fromLocationCode = '';
this.toLocationCode =""
}) })
}, },

8
pages/productionReturn/coms/comReturn.vue

@ -57,6 +57,10 @@
getPackingNumberAndBatchByList getPackingNumberAndBatchByList
} from '@/common/basic.js'; } from '@/common/basic.js';
import {
calc
} from '@/common/calc.js';
import { import {
getDirectoryItemArray getDirectoryItemArray
} from '@/common/directory.js'; } from '@/common/directory.js';
@ -237,7 +241,7 @@
item.qty = 0; item.qty = 0;
for (let detail of item.subList) { for (let detail of item.subList) {
if (detail != undefined) { if (detail != undefined) {
item.qty += Number(detail.qty) item.qty = calc.add(item.qty, detail.qty)
} }
} }
} }
@ -431,7 +435,7 @@
this.clearData(); this.clearData();
}) })
}, },
clearData(){ clearData() {
this.subList = []; this.subList = [];
this.detailSource = []; this.detailSource = [];
this.toLocationCode = ''; this.toLocationCode = '';

14
pages/productionReturn/coms/comReturnCommonRequest.vue

@ -109,7 +109,7 @@
this.addAgainOption = getAddAgainOption(); this.addAgainOption = getAddAgainOption();
this.detailAndApproveOptions = getDetailAndApproveOption() this.detailAndApproveOptions = getDetailAndApproveOption()
this.detailAndApprovePassAndApproveNoOption = getDetailAndApprovePassAndApproveNoOption(), this.detailAndApprovePassAndApproveNoOption = getDetailAndApprovePassAndApproveNoOption(),
this.detailAndHandleOption = getDetailAndHandleOption() this.detailAndHandleOption = getDetailAndHandleOption()
this.detailAndAddAndCloseOption = getDetailAndAddAndCloseOption() this.detailAndAddAndCloseOption = getDetailAndAddAndCloseOption()
this.updateTitle(); this.updateTitle();
this.getList('refresh'); this.getList('refresh');
@ -241,25 +241,25 @@
swipeClick(e, dataContent) { swipeClick(e, dataContent) {
var text = clearTirmAndWrap(e.content.text) var text = clearTirmAndWrap(e.content.text)
if (e.content.text == "详情") { if (text == "详情") {
this.openRequestInfoPopup(dataContent); this.openRequestInfoPopup(dataContent);
} else if (e.content.text == "处理") { } else if (text == "处理") {
this.showQuestionMessage("确定要处理当前申请吗?", res => { this.showQuestionMessage("确定要处理当前申请吗?", res => {
this.productionReturnRequestHandle(dataContent.id) this.productionReturnRequestHandle(dataContent.id)
}) })
} else if (e.content.text == "审批") { } else if (text == "提交审批") {
this.showQuestionMessage("确定要审批当前申请吗?", res => { this.showQuestionMessage("确定要审批当前申请吗?", res => {
this.productionReturnRequestSubmitApprove(dataContent.id) this.productionReturnRequestSubmitApprove(dataContent.id)
}) })
} else if (e.content.text == "审批通过") { } else if (text == "审批通过") {
this.showQuestionMessage("确定要审批通过当前申请吗?", res => { this.showQuestionMessage("确定要审批通过当前申请吗?", res => {
this.productionReturnRequestSubmitApproveAgree(dataContent.id) this.productionReturnRequestSubmitApproveAgree(dataContent.id)
}) })
} else if (e.content.text == "审批驳回") { } else if (text == "审批驳回") {
this.showQuestionMessage("确定要审批驳回当前申请吗?", res => { this.showQuestionMessage("确定要审批驳回当前申请吗?", res => {
this.productionReturnRequestSubmitApproveRefused(dataContent.id) this.productionReturnRequestSubmitApproveRefused(dataContent.id)
}) })
} else if (e.content.text == "关闭") { } else if (text == "关闭") {
this.showQuestionMessage("确定要关闭当前申请吗?", res => { this.showQuestionMessage("确定要关闭当前申请吗?", res => {
this.productionReturnRequestClose(dataContent.id) this.productionReturnRequestClose(dataContent.id)
}) })

15
pages/productionReturn/coms/comReturnRecord.vue

@ -5,8 +5,7 @@
<template v-slot:title> <template v-slot:title>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions"> <uni-swipe-action-item @click="removeData($event,dataContent)" :right-options="removeOptions">
<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty" <item-qty :dataContent="dataContent" :isShowBalanceQty="false" :isShowBalance="true"></item-qty>
:isShowBalance="true"></item-qty>
</uni-swipe-action-item> </uni-swipe-action-item>
</uni-swipe-action> </uni-swipe-action>
@ -17,7 +16,7 @@
<uni-swipe-action-item @click="swipeClick($event,item,index)" <uni-swipe-action-item @click="swipeClick($event,item,index)"
:right-options="item.scaned?scanOptions:detailOptions"> :right-options="item.scaned?scanOptions:detailOptions">
<balance :dataContent="item" :isShowStdPack="false" :isShowStatus="true" :isShowPack="true" <balance :dataContent="item" :isShowStdPack="false" :isShowStatus="true" :isShowPack="true"
:isShowFromLocation="true" :isShowToLocation="isShowToLocation"></balance> :isShowFromLocation="isShowFromLocation" :isShowToLocation="isShowToLocation"></balance>
<!-- <production-label :dataContent="item" :packageContent="item.package" <!-- <production-label :dataContent="item" :packageContent="item.package"
:isShowLocation="false"> :isShowLocation="false">
</production-label> --> </production-label> -->
@ -86,6 +85,10 @@
isShowToLocation: { isShowToLocation: {
type: Boolean, type: Boolean,
default: true default: true
},
isShowFromLocation: {
type: Boolean,
default: true
} }
}, },
watch: { watch: {
@ -126,7 +129,7 @@
methods: { methods: {
removeData(e, dataContent) { removeData(e, dataContent) {
if (e.content.text == "清空") { if (e.content.text == "清空") {
this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?", this.$refs.comMessage.showQuestionMessage("确定清空物料及箱码信息?",
res => { res => {
if (res) { if (res) {
this.$emit('removeItem') this.$emit('removeItem')
@ -147,7 +150,7 @@
edit(item) { edit(item) {
this.editItem = item; this.editItem = item;
this.$refs.recommendQtyEdit.openRecordEditPopup(item.qty); this.$refs.recommendQtyEdit.openRecordEditPopup(item.handleQty);
// this.$refs.recommendQtyEdit.openEditPopup(item.qty); // this.$refs.recommendQtyEdit.openEditPopup(item.qty);
}, },
@ -165,7 +168,7 @@
}); });
}, },
confirm(qty) { confirm(qty) {
this.editItem.qty = qty; this.editItem.handleQty = qty;
this.$emit('updateData') this.$emit('updateData')
} }
} }

35
pages/productionReturn/coms/comReturnRequestCreator.vue

@ -5,7 +5,7 @@
</comReturnRequestInfo> </comReturnRequestInfo>
<uni-swipe-action ref="swipeAction"> <uni-swipe-action ref="swipeAction">
<view v-for="(item, index) in dataContent.subList" :key="index"> <view v-for="(item, index) in dataContent.subList" :key="index">
<uni-swipe-action-item @click="swipeClick($event,item)" :right-options="detailOptions"> <uni-swipe-action-item @click="swipeClick($event,item,index)" :right-options="options">
<item-qty :dataContent="item" :isShowStdPack="false"> <item-qty :dataContent="item" :isShowStdPack="false">
</item-qty> </item-qty>
<!-- <view v-if="item.batch!=''" style="margin-left: 10rpx;"> <!-- <view v-if="item.batch!=''" style="margin-left: 10rpx;">
@ -36,7 +36,7 @@
import { import {
getDetailOption, getDetailOption,
getDetailEditRemoveOption, getDetailEditRemoveOption,
getDetailRemoveOption getDetailRemoveOption,
} from '@/common/array.js'; } from '@/common/array.js';
export default { export default {
@ -79,7 +79,6 @@
}, },
watch: { watch: {
dataContent(newVal) { dataContent(newVal) {
this.requestItem = newVal.subList[0];
}, },
}, },
@ -92,9 +91,9 @@
} }
}, },
requestItem: {},
detailOptions: [], detailOptions: [],
scanOptions: [] scanOptions: [],
options:[]
} }
}, },
@ -103,26 +102,30 @@
this.detailOptions = getDetailOption(); this.detailOptions = getDetailOption();
} }
if (this.scanOptions.length == 0) { if (this.scanOptions.length == 0) {
this.scanOptions = getDetailEditRemoveOption(); this.scanOptions = getDetailRemoveOption();
// if (this.dataContent.allowModifyQty == 1) { // if (this.dataContent.allowModifyQty == 1) {
// this.scanOptions = getDetailEditRemoveOption(); // this.scanOptions = getDetailEditRemoveOption();
// } else { // } else {
// this.scanOptions = getDetailRemoveOption(); // this.scanOptions = getDetailRemoveOption();
// } // }
} }
if(!this.isSwipe){
this.detailOptions=[] this.options =this.scanOptions
} // if(!this.isSwipe){
// this.options=[]
// }else {
// this.options =this.scanOptions
// }
}, },
methods: { methods: {
swipeClick(e, item) { swipeClick(e, item,index) {
if (e.content.text == "详情") { if (e.content.text == "详情") {
this.detail(item) this.detail(item)
} else if (e.content.text == "编辑") { } else if (e.content.text == "编辑") {
this.edit(item) this.edit(item)
} else if (e.content.text == "移除") { } else if (e.content.text == "移除") {
this.remove(item) this.remove(item,index)
} }
}, },
edit(item) { edit(item) {
@ -136,17 +139,13 @@
// // this.showItem = item; // // this.showItem = item;
// // this.$refs.jobDetailPopup.openPopup(item) // // this.$refs.jobDetailPopup.openPopup(item)
}, },
remove(item) { remove(item,index) {
this.$refs.message.showQuestionMessage("确定移除扫描信息?", this.$refs.message.showQuestionMessage("确定移除扫描信息?",
res => { res => {
if (res) { if (res) {
item.scaned = false this.dataContent.subList.splice(index, 1)
item.record = {}
item.balance = {}
item.inventoryStatus = item.RecommendInventoryStatus
// item.record.qty = 0;
this.$forceUpdate() this.$forceUpdate()
this.$emit('remove', item) // this.$emit('remove', item)
} }
}); });
}, },

95
pages/productionReturn/coms/comReturnRequestPopup.vue

@ -28,7 +28,7 @@
<view class="title padding" style="display: flex;"> <view class="title padding" style="display: flex;">
<text style=" flex-shrink: 0;">箱码</text> <text style=" flex-shrink: 0;">物料</text>
<view class="" style="width: 100% ;"> <view class="" style="width: 100% ;">
{{itemCode}} {{itemCode}}
</view> </view>
@ -46,10 +46,13 @@
<text>数量 : </text> <text>数量 : </text>
<view class="uni-flex uni-row uni-center" <view class="uni-flex uni-row uni-center"
style="align-items: center;margin-left: 20rpx;"> style="align-items: center;margin-left: 20rpx;">
<uni-number-box :value="counQty" @change="change" style='margin-left: 10rpx;' <input style="text-align: center;" class="qty_input" v-model="counQty" type="number"
:focus="numberFocus" @blur='numberFocus = false'> @confirm="confirm()" :focus="numberFocus" @input="checkNum" :maxlength="maxlength" />
</uni-number-box>
<uom :uom="uom"></uom> <uom :uom="uom"></uom>
<view class="" v-if="stdPackInfo!=undefined" style="display: flex;flex-direction: row;margin-left: 10rpx;">
(<stdPackQty :dataContent="stdPackInfo"></stdPackQty>)
</view>
</view> </view>
</view> </view>
@ -63,7 +66,7 @@
</view> </view>
</view> </view>
</uni-popup> </uni-popup>
<win-scan-item ref="scanPopup" title='物料代码' @getScanCode='getScanCode'> <win-scan-item ref="scanPopup" title='物料代码' @getScanResult='getItemScanResult' :itemCodeTypeList="itemCodeTypeList">
</win-scan-item> </win-scan-item>
<comMessage ref="comMessage"></comMessage> <comMessage ref="comMessage"></comMessage>
</view> </view>
@ -82,6 +85,7 @@
checkDirectoryItemExist checkDirectoryItemExist
} from '@/common/directory.js'; } from '@/common/directory.js';
import uom from '@/mycomponents/qty/uom.vue' import uom from '@/mycomponents/qty/uom.vue'
import stdPackQty from '@/mycomponents/qty/stdPackQty.vue'
import balanceStatus from '@/mycomponents/status/balanceStatus.vue' import balanceStatus from '@/mycomponents/status/balanceStatus.vue'
import comMessage from '@/mycomponents/common/comMessage.vue' import comMessage from '@/mycomponents/common/comMessage.vue'
import winScanItem from '@/mycomponents/scan/winScanItem.vue' import winScanItem from '@/mycomponents/scan/winScanItem.vue'
@ -90,6 +94,7 @@
export default { export default {
components: { components: {
uom, uom,
stdPackQty,
balanceStatus, balanceStatus,
comMessage, comMessage,
winScanItem winScanItem
@ -111,8 +116,7 @@
itemCodeFocus: false, itemCodeFocus: false,
requestInfo: null, requestInfo: null,
itemCodeList: [], itemCodeList: [],
isCheckItemCode: false, counQty: undefined,
counQty: 0,
editPosition: true, editPosition: true,
numberFocus: false, numberFocus: false,
uom: "", uom: "",
@ -120,6 +124,8 @@
show: false, show: false,
isModifiedPosition: true, isModifiedPosition: true,
positionList: [], positionList: [],
maxlength:10,
stdPackInfo:undefined,
list: [{ list: [{
value: 1, value: 1,
label: '车间1', label: '车间1',
@ -191,8 +197,27 @@
type: String, type: String,
default: '需求信息' default: '需求信息'
}, },
itemCodeTypeList: {
type: Array,
default: []
},
}, },
methods: { methods: {
checkNum(e) {
let value = e.detail.value;
let dot = value.indexOf('.'); //
let reg = /^[0-9]+$/; //
if (dot > -1) {
this.maxlength = dot + 7; //
if (value.length > dot + 7) {
}
}
if (reg.test(value)) { //
this.maxlength = 10;
}
this.change(value)
},
openRequestPopup(editPosition) { openRequestPopup(editPosition) {
if (this.positionList.length == 0) { if (this.positionList.length == 0) {
getWorkShopLineStation().then(res => { getWorkShopLineStation().then(res => {
@ -206,9 +231,11 @@
if (this.isModifiedPosition) { if (this.isModifiedPosition) {
this.isModifiedPosition = false this.isModifiedPosition = false
} else { } else {
this.itemCode = ""; this.itemCode = "请扫描物料信息";
this.uom = "" this.uom = ""
this.qty = 0 this.qty = 0;
this.counQty = undefined
this.numberFocus = false
this.itemCodeGetFocus(); this.itemCodeGetFocus();
} }
@ -231,16 +258,18 @@
itemCodeLoseFocus() { itemCodeLoseFocus() {
this.itemCodeFocus = false; this.itemCodeFocus = false;
}, },
selectedItem(item) {
this.itemCode = item.itemCode;
this.checkItemCode();
},
confirm() { confirm() {
if (this.itemCode == "" || !this.isCheckItemCode) { if (this.itemCode == "请扫描物料信息" ) {
this.showErrorMessage("请输入物料", "itemCode") this.showErrorMessage("请输入物料", "itemCode")
return return
} }
if (this.counQty == undefined) {
this.showErrorMessage("请输入数量")
return
}
if (this.qty == 0) { if (this.qty == 0) {
this.showErrorMessage("数量必须大于0") this.showErrorMessage("数量必须大于0")
return return
@ -253,28 +282,6 @@
this.callback('add'); this.callback('add');
}, },
checkItemCode(itemCode) {
//
getBasicItemByCode(itemCode).then(res => {
uni.hideLoading();
this.$refs.scanPopup.closeScanPopup();
if (res.data != null && res.data.list.length > 0) {
this.itemCode = res.data.list[0].code;
this.itemName = res.data.list[0].name
this.isCheckItemCode = true;
this.numberFocus = true
this.uom = res.data.list[0].uom
} else {
this.showErrorMessage('未查找到物料【' + this.itemCode + '】', "itemCode");
}
}).catch(error => {
uni.hideLoading();
this.showErrorMessage(error, "itemCode");
})
},
callback(action) { callback(action) {
let item = { let item = {
positionInfo: this.positionInfo, positionInfo: this.positionInfo,
@ -305,8 +312,7 @@
} }
}) })
if (type == "itemCode") { if (type == "itemCode") {
this.itemCode = "" this.itemCode = "请扫描物料信息"
this.isCheckItemCode = false;
} }
}) })
}, },
@ -352,13 +358,12 @@
} }
}, },
getScanCode(code) { getItemScanResult(code, scanResult) {
if (code == "") { this.itemCode = code;
this.showErrorMessage('物料号不能为空') this.itemName = scanResult.name
return; this.uom =scanResult.uom
} this.stdPackInfo = scanResult.package;
this.itemCode = ""; this.numberFocus = true
this.checkItemCode(code)
}, },
} }

65
pages/productionReturn/coms/comScanReturnPack.vue

@ -7,7 +7,7 @@
扫描箱码 扫描箱码
<text class="fr" @click="closeScanPopup()">关闭</text> <text class="fr" @click="closeScanPopup()">关闭</text>
</view> </view>
<!-- <view class="uni-flex uni-row" style="align-items: center; <!-- <view class="uni-flex uni-row" style="align-items: center;
background-color: #fff; background-color: #fff;
margin-left: 20rpx; margin-left: 20rpx;
margin-right: 20rpx; margin-right: 20rpx;
@ -106,6 +106,10 @@
getWorkShopLineStation getWorkShopLineStation
} from '@/api/request2.js'; } from '@/api/request2.js';
import {
calc
} from '@/common/calc.js';
import { import {
getBalanceByManagementPrecision getBalanceByManagementPrecision
} from '@/common/balance.js'; } from '@/common/balance.js';
@ -145,7 +149,7 @@
positionInfo: "请选择位置", positionInfo: "请选择位置",
positionList: [], positionList: [],
defaultValueList: [], defaultValueList: [],
fromInventoryStatuses :"", fromInventoryStatuses: "",
} }
}, },
created() { created() {
@ -157,8 +161,8 @@
this.scanOptions = getDetailEditRemoveOption(); this.scanOptions = getDetailEditRemoveOption();
}, },
methods: { methods: {
openScanPopup(content, jobcontent) { openScanPopup(content, jobcontent) {
this.issueRecord = []; this.issueRecord = [];
this.dataContent = content; this.dataContent = content;
@ -231,7 +235,7 @@
let lot = result.label.batch; let lot = result.label.batch;
let item = that.toLocation.Items.find(r => r.itemCode == itemCode); let item = that.toLocation.Items.find(r => r.itemCode == itemCode);
if (item == undefined) { if (item == undefined) {
that.showErrorMessage('未查找到零件【' + itemCode + '】的发料明细', that.showErrorMessage('未查找到物料【' + itemCode + '】的发料明细',
res => { res => {
that.getfocus(); that.getfocus();
} }
@ -243,24 +247,25 @@
title: '加载中', title: '加载中',
mask: true mask: true
}) })
getBalanceByManagementPrecision(result.label, that.fromLocationCode, that.fromInventoryStatuses, balanceRes => { getBalanceByManagementPrecision(result.label, that.fromLocationCode, that.fromInventoryStatuses,
if (balanceRes.success) { balanceRes => {
if (balanceRes.data.list.length == 0) { if (balanceRes.success) {
this.showErrorMessage('在来源库位[' + this.fromLocationCode + '],未查找到该包装的库存记录', if (balanceRes.data.list.length == 0) {
res => { this.showErrorMessage('在来源库位[' + this.fromLocationCode + '],未查找到该包装的库存记录',
this.packGetFocus(); res => {
}) this.packGetFocus();
} else if (balanceRes.data.list.length == 1) { })
let balance = balanceRes.data.list[0]; } else if (balanceRes.data.list.length == 1) {
this.afterGetBalance(result.label, balance,packageInfo); let balance = balanceRes.data.list[0];
this.afterGetBalance(result.label, balance, packageInfo);
} else {
this.showBalanceSelect(balanceRes.data.list);
}
} else { } else {
this.showBalanceSelect(balanceRes.data.list); this.showErrorMessage(balanceRes.message.message);
} }
} else { uni.hideLoading();
this.showErrorMessage(balanceRes.message.message); });
}
uni.hideLoading();
});
} }
} catch (e) { } catch (e) {
this.showErrorMessage(e.stack) this.showErrorMessage(e.stack)
@ -271,7 +276,7 @@
this.afterGetBalance(this.label, balance); this.afterGetBalance(this.label, balance);
}, },
afterGetBalance(label, balance,packageInfo) { afterGetBalance(label, balance, packageInfo) {
try { try {
let that = this; let that = this;
let itemCode = label.itemCode; let itemCode = label.itemCode;
@ -292,11 +297,11 @@
if (batch.Recommends.length > 0) { if (batch.Recommends.length > 0) {
let recommend = batch.Recommends.find(r => r.packingNumber == packingCode); let recommend = batch.Recommends.find(r => r.packingNumber == packingCode);
if (recommend != undefined) { if (recommend != undefined) {
that.addRecord(batch, label, balance,packageInfo) that.addRecord(batch, label, balance, packageInfo)
} else { } else {
// //
if (this.jobContent.allowModifyPackingNumber == 'TRUE') { if (this.jobContent.allowModifyPackingNumber == 'TRUE') {
that.addRecord(batch, label, balance,packageInfo); that.addRecord(batch, label, balance, packageInfo);
} else { } else {
that.showErrorMessage('未查找到该箱码【' + packingCode + '】的明细', that.showErrorMessage('未查找到该箱码【' + packingCode + '】的明细',
res => { res => {
@ -306,7 +311,7 @@
} }
} }
} else { } else {
that.addRecord(batch, label, balance,packageInfo) that.addRecord(batch, label, balance, packageInfo)
} }
} else { } else {
that.showErrorMessage('箱码【' + packingCode + '】已经扫描,请继续扫描下一箱', that.showErrorMessage('箱码【' + packingCode + '】已经扫描,请继续扫描下一箱',
@ -361,14 +366,14 @@
return batch; return batch;
}, },
creatRecord(label, balance,packageInfo) { creatRecord(label, balance, packageInfo) {
balance.stdPackQty = packageInfo.stdPackQty balance.stdPackQty = packageInfo.stdPackQty
balance.stdPackUnit = packageInfo.stdPackUnit balance.stdPackUnit = packageInfo.stdPackUnit
let record = { let record = {
itemCode: label.itemCode, itemCode: label.itemCode,
packingNumber: label.packingNumber, packingNumber: label.packingNumber,
batch: label.batch, batch: label.batch,
qty: Number(label.qty)>Number(balance.qty)?Number(balance.qty):Number(label.qty), qty: Number(label.qty) > Number(balance.qty) ? Number(balance.qty) : Number(label.qty),
uom: balance.uom, uom: balance.uom,
inventoryStatus: balance.inventoryStatus, inventoryStatus: balance.inventoryStatus,
balance: balance, balance: balance,
@ -381,13 +386,13 @@
calcBatchHandleQty(batch) { calcBatchHandleQty(batch) {
let handleQty = 0; let handleQty = 0;
batch.Records.forEach(res => { batch.Records.forEach(res => {
handleQty += Number(res.qty) handleQty = calc.add(handleQty,res.qty)
}) })
batch.handleQty = handleQty; batch.handleQty = handleQty;
}, },
addRecord(batch, label, balance,packageInfo) { addRecord(batch, label, balance, packageInfo) {
let record = this.creatRecord(label, balance,packageInfo); let record = this.creatRecord(label, balance, packageInfo);
batch.Records.push(record); batch.Records.push(record);
this.issueRecord.unshift(record) this.issueRecord.unshift(record)
this.calcBatchHandleQty(batch); this.calcBatchHandleQty(batch);

8
pages/productionReturn/job/returnDetail.vue

@ -104,7 +104,6 @@
return { return {
id: '', id: '',
jobContent: {}, jobContent: {},
received: false,
toLocationCode: '', toLocationCode: '',
scanCount: 0, scanCount: 0,
jobContent: {}, // jobContent: {}, //
@ -115,7 +114,8 @@
toLocationTypeList: [], toLocationTypeList: [],
toLocationInfo: {}, toLocationInfo: {},
businessTypeInfo: {}, businessTypeInfo: {},
titleInfo: "" titleInfo: "",
jobStatus:""
}; };
}, },
onLoad(option) { onLoad(option) {
@ -124,7 +124,6 @@
// // // //
if (option.status == "1") { if (option.status == "1") {
this.receive((callback => { this.receive((callback => {
this.received = true;
this.getDetail(); this.getDetail();
})); }));
} else { } else {
@ -142,7 +141,7 @@
onBackPress(e) { onBackPress(e) {
// //
if (e.from == 'backbutton') { if (e.from == 'backbutton') {
if (this.received) { if (this.jobStatus=="2") {
// //
cancleTakeProductionReturnJob(this.id).then(res => { cancleTakeProductionReturnJob(this.id).then(res => {
uni.navigateBack(); uni.navigateBack();
@ -190,6 +189,7 @@
} else { } else {
if (res.data.subList.length > 0) { if (res.data.subList.length > 0) {
that.jobContent = res.data; that.jobContent = res.data;
that.jobStatus = res.data.status
that.subList = res.data.subList; that.subList = res.data.subList;
that.detailSource = getDataSource(that.subList) that.detailSource = getDataSource(that.subList)

Some files were not shown because too many files changed in this diff

Loading…
Cancel
Save