Browse Source

page/package/job 文件迁移 8/8-10/25

pull/1/head
test 4 months ago
parent
commit
cd3690cf4d
  1. 282
      src/pages/package/job/overPackageJob.vue
  2. 76
      src/pages/package/job/overPackageJobDetail.vue

282
src/pages/package/job/overPackageJob.vue

@ -1,7 +1,9 @@
<template> <template>
<view class=""> <view class="">
<com-empty-view v-if="jobList.length == 0"></com-empty-view> <com-empty-view v-if="jobList.length == 0"></com-empty-view>
<job-filter ref="filter" otherTitle="" @switchChangeToday="switchChangeToday" @switchChangeWait="switchChangeWait" @onScanNumber="getScanNumber" :checkedToday="checkedToday" :checkedWaitTask="checkedWaitTask"> </job-filter> <job-filter ref="filter" otherTitle=""
@onQuery="getListByFilter" :isShowQurery='true'>
</job-filter>
<view v-if="jobList.length > 0" class="u-m-20"> <view v-if="jobList.length > 0" class="u-m-20">
<u-swipe-action :show="item.show" :index="index" v-for="(item, index) in jobList" :key="index" :options="item.status == '2' ? detailGiveupOptions : detailOptions" bg-color="rgba(255,255,255,0)" class="u-m-b-20" @click="swipeClick"> <u-swipe-action :show="item.show" :index="index" v-for="(item, index) in jobList" :key="index" :options="item.status == '2' ? detailGiveupOptions : detailOptions" bg-color="rgba(255,255,255,0)" class="u-m-b-20" @click="swipeClick">
<comOverPackJobCard :dataContent="item" @click="openJobDetail(item)"></comOverPackJobCard> <comOverPackJobCard :dataContent="item" @click="openJobDetail(item)"></comOverPackJobCard>
@ -10,21 +12,32 @@
<uni-load-more :status="loadingType" v-if="jobList.length > 0" /> <uni-load-more :status="loadingType" v-if="jobList.length > 0" />
</view> </view>
<win-scan-button @goScan='openScanPopup' v-if="jobList.length>0"></win-scan-button>
<winComScanBalance ref="scanPopup" @getBalance='getScanResult'
:isCheckLocationBalance="false"
:bussinessCode="businessTypeCode">
</winComScanBalance>
<!-- <winScanPackJob ref="scanPopup" @getResult='getScanResult'></winScanPackJob>-->
<jobList ref="jobList" @selectItem="selectItem"></jobList>
<com-message ref="comMessageRef" /> <com-message ref="comMessageRef" />
</view> </view>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { ref, getCurrentInstance, nextTick } from 'vue' import { ref, getCurrentInstance, nextTick } from 'vue'
import { onLoad, onShow, onNavigationBarButtonTap, onReady, onBackPress, onReachBottom, onPullDownRefresh } from '@dcloudio/uni-app' import { onLoad, onShow, onNavigationBarButtonTap, onReady, onBackPress, onReachBottom, onPullDownRefresh } from '@dcloudio/uni-app'
import { cancleTakeOverPageJob, getOverPageJobList } from '@/api/request2.js' import { cancleTakeOverPageJob, getOverPageJobList, packageoverRequestClose } from '@/api/request2.js'
import { goHome, updateTitle } from '@/common/basic.js' import { goHome, updateTitle } from '@/common/basic.js'
import {getBusinessType} from '@/common/record.js';
import {planRefreshTime, overPackageJobFilter} from '@/common/config.js';
import { getDetailOption, getDetailGiveupOption } from '@/common/array.js' import { getDetailOption, getDetailGiveupOption } from '@/common/array.js'
import comEmptyView from '@/mycomponents/common/comEmptyView.vue' import comEmptyView from '@/mycomponents/common/comEmptyView.vue'
import jobFilter from '@/mycomponents/job/jobFilter.vue' import jobFilter from '@/mycomponents/job/jobFilter.vue'
import comOverPackJobCard from '@/pages/package/coms/comOverPackJobCard.vue' import comOverPackJobCard from '@/pages/package/coms/comOverPackJobCard.vue'
import jobInfoPopup from '@/pages/issue/coms/jobInfoPopup.vue' import jobInfoPopup from '@/pages/issue/coms/jobInfoPopup.vue'
import winScanButton from '@/mycomponents/scan/winScanButton.vue'
import winComScanBalance from '@/mycomponents/scan/winComScanBalance.vue'
import jobList from '@/mycomponents/jobList/jobList.vue'
const { proxy } = getCurrentInstance() const { proxy } = getCurrentInstance()
const jobList = ref([]) const jobList = ref([])
@ -42,6 +55,11 @@ const filter = ref()
const title = ref('') const title = ref('')
const comMessageRef = ref() const comMessageRef = ref()
const jobInfoPopupRef = ref() const jobInfoPopupRef = ref()
const businessTypeCode = ref('OverPackage')
const businessType = ref(null)
const timer = ref(null)
const scanMessage = ref('')
const scanPopup = ref(null)
onShow(() => { onShow(() => {
nextTick(() => { nextTick(() => {
getList('refresh') getList('refresh')
@ -53,6 +71,12 @@ onLoad((option) => {
onReady(() => { onReady(() => {
detailOptions.value = getDetailOption() detailOptions.value = getDetailOption()
detailGiveupOptions.value = getDetailGiveupOption() detailGiveupOptions.value = getDetailGiveupOption()
detailOptions.value = [...detailOptions.value,{
text:"关闭",
style:{
backgroundColor:"#F56C6C"
}
}]
}) })
onReachBottom(() => { onReachBottom(() => {
// //
@ -78,9 +102,61 @@ onNavigationBarButtonTap((e) => {
if (e.index === 0) { if (e.index === 0) {
goHome() goHome()
} else if (e.index == 1) { } else if (e.index == 1) {
filter.value.openFilter() filter.value.openFilterParams(uni.getStorageSync(overPackageJobFilter));
} }
}) })
const getBusinessTypeFunc = ()=> {
getBusinessType(this.businessTypeCode, res => {
if (res.success) {
businessType.value = res.businessType;
openScanPopup();
} else {
showMessage(res.message)
}
});
}
const timerRefresh = ()=> {
getList('refresh')
stopRefresh();
timer.value = setInterval(function() {
getList('refresh')
}, planRefreshTime)
}
const stopRefresh = ()=> {
if (timer.value) {
clearInterval(timer.value);
timer.value = null;
}
}
const setQueryParam = ()=> {
let filterParams = []
let queryParams = uni.getStorageSync(overPackageJobFilter)
//
if (queryParams.creationTime ) {
filterParams.push({
column: "create_time",
action: "betweeen",
value: queryParams.creationTime
})
}
//
if (queryParams.status) {
filterParams.push({
column: "status",
action: "in",
value: queryParams.status
})
}else {
filterParams.push({
column: "status",
action: "in",
value: "1,2"
})
}
return filterParams;
}
const getList = (type) => { const getList = (type) => {
proxy.$modal.loading('加载中­....') proxy.$modal.loading('加载中­....')
loadingType.value = 'loading' loadingType.value = 'loading'
@ -88,28 +164,9 @@ const getList = (type) => {
pageNo.value = 1 pageNo.value = 1
jobList.value = [] jobList.value = []
} }
let queryFiltersParams = setQueryParam()
const filters = []
if (checkedToday.value) {
filters.push({
column: 'create_time',
action: 'betweeen',
value: todayTime.value
})
}
filters.push({
column: 'status',
action: 'in',
value: status.value
})
filters.push({
column: 'accept_user_id',
action: '==',
value: store.id
})
const params = { const params = {
filters, filters:queryFiltersParams,
pageNo: pageNo.value, pageNo: pageNo.value,
pageSize: pageSize.value pageSize: pageSize.value
} }
@ -118,8 +175,8 @@ const getList = (type) => {
uni.hideLoading() uni.hideLoading()
if (type === 'refresh') { if (type === 'refresh') {
uni.stopPullDownRefresh() uni.stopPullDownRefresh()
openScanPopup()
} }
const { list } = res.data const { list } = res.data
totalCount.value = res.data.total totalCount.value = res.data.total
updateTitle(`${title.value}(${totalCount.value})`) updateTitle(`${title.value}(${totalCount.value})`)
@ -129,6 +186,12 @@ const getList = (type) => {
loadingType.value = 'nomore' loadingType.value = 'nomore'
return return
} }
if (list && list.length > 0) {
list.forEach(item => {
item.fromPackCount = Math.ceil(item.qty / item.fromPackQty)
item.toPackCount = Math.ceil(item.qty / item.toPackQty)
})
}
jobList.value = type === 'refresh' ? list : jobList.value.concat(list) jobList.value = type === 'refresh' ? list : jobList.value.concat(list)
pageNo.value++ pageNo.value++
}) })
@ -139,39 +202,20 @@ const getList = (type) => {
loadingType.value = '' loadingType.value = ''
updateTitle(title.value) updateTitle(title.value)
uni.hideLoading() uni.hideLoading()
showErrorMessage(error) showMessage(error)
}) })
} }
const getByAsnNumber = (code) => { const getListByFilter = (params)=> {
proxy.$modal.loading('加载中­....') uni.setStorageSync(overPackageJobFilter,params)
getPurchasereceiptByAsnNumber(code) getList('refresh')
.then((res) => {
uni.hideLoading()
if (res.data.total == 0) {
showMessage('未查找到' + `${code}】的收货任务`)
} else if (res.data.total == 1) {
scanAsnNumber.value.closeScanPopup()
openJobDetail(res.data.list[0])
} else {
scanAsnNumber.value.closeScanPopup()
showItemList(res.data.list)
}
})
.catch((error) => {
uni.hideLoading()
showErrorMessage(error)
})
} }
const openJobDetail = (item) => { const openJobDetail = (item,scanMessage = '') => {
proxy.$tab.navigateTo(`./overPackageJobDetail?id=${item.masterId}&status=${item.status}`) getJobInfoByNumber(item.number,scanMessage)
} }
const selectedItem = (item) => { const selectedItem = (item) => {
openJobDetail(item) openJobDetail(item.number)
} }
const showItemList = (itemList) => {
scanList.value.openPopup(itemList)
}
const swipeClick = (index, index1) => { const swipeClick = (index, index1) => {
// var text = clearTirmAndWrap(requestList.value[index].options[index].text) // var text = clearTirmAndWrap(requestList.value[index].options[index].text)
let text = '' let text = ''
@ -189,8 +233,29 @@ const swipeClick = (index, index1) => {
cancleJob(dataContent.masterId) cancleJob(dataContent.masterId)
} }
}) })
}else if (e.content.text == "关闭") {
comMessageRef.value.showQuestionMessage("确定要关闭当前任务?",
res => {
if (res) {
closeJob(dataContent.masterId);
}
});
} }
} }
const closeJob = (id)=>{
packageoverRequestClose(id).then(res => {
if(res.data){
getList("refresh")
uni.showToast({
title:"关闭任务成功"
})
}else {
showMessage("关闭任务失败")
}
}).catch(error => {
showMessage(error)
})
}
const openjobInfoPopup = (item) => { const openjobInfoPopup = (item) => {
jobInfoPopupRef.value.openPopup(item) jobInfoPopupRef.value.openPopup(item)
} }
@ -210,6 +275,19 @@ const cancleJob = (id) => {
showMessage(error) showMessage(error)
}) })
} }
const showMessage = (message)=> {
comMessageRef.value.showErrorMessage(message, res => {
if (res) {
}
});
}
const openScanPopup = ()=> {
if (businessType.value == null) {
getBusinessTypeFunc()
} else {
scanPopup.value.openScanPopup(businessType.value);
}
}
const switchChangeToday = (state, creationTime) => { const switchChangeToday = (state, creationTime) => {
checkedToday.value = state checkedToday.value = state
todayTime.value = creationTime todayTime.value = creationTime
@ -223,7 +301,7 @@ const switchChangeWait = (state, jobStatus) => {
const getScanNumber = (code) => { const getScanNumber = (code) => {
getDataListByType(code) getDataListByType(code)
} }
const getDataListByType = (code) => { const getJobInfoByNumber = (number,scanMessage) => {
proxy.$modal.loading('加载中­....') proxy.$modal.loading('加载中­....')
const filters = [] const filters = []
filters.push({ filters.push({
@ -234,7 +312,7 @@ const getDataListByType = (code) => {
filters.push({ filters.push({
column: 'number', column: 'number',
action: '==', action: '==',
value: code value: number
}) })
const params = { const params = {
filters, filters,
@ -245,9 +323,22 @@ const getDataListByType = (code) => {
.then((res) => { .then((res) => {
uni.hideLoading() uni.hideLoading()
if (res.data.list.length == 0) { if (res.data.list.length == 0) {
showMessage('未查找到' + `${code}】的收货任务`) showMessage(`未查找到【${number}】的发料任务`)
} else if (res.data.list.length == 1) { } else {
openJobDetail(res.data.list[0]) let result = res.data.list[0];
if (result.acceptUserId && result.acceptUserId != store.id) {
comMessageRef.value.showErrorMessage("任务号[" + result.number + "]已经被[" + result.acceptUserName + "]承接,无法执行", res => {
if (res) {
getList('refresh')
}
});
return;
}
uni.navigateTo({
url: './overPackageJobDetail?id=' + result.masterId + '&status=' + result.status + '&title=' + title.value + '&scanMessage=' +
scanMessage + '&fromLocationCode=' + result.fromLocationCode
});
scanMessage.value = ""
} }
}) })
.catch((error) => { .catch((error) => {
@ -255,11 +346,80 @@ const getDataListByType = (code) => {
showMessage(error) showMessage(error)
}) })
} }
const showMessage = (message) => { const selectItem = (item)=> {
comMessageRef.value.showErrorMessage(message, (res) => { scanPopup.value.closeScanPopup();
if (res) { openJobDetail(item, this.scanMessage);
}
const getScanResult = (result)=> {
let balance = result.balance;
if (balance != null) {
scanMessage.value = ""
if (!result.label.batch) {
showMessage("批次为空")
return;
} }
}) if (!result.label.itemCode) {
showMessage("物料号为空")
return;
}
try {
let filters = [{
column: "status",
action: "in",
value: '1,2'
},
{
column: "batch",
action: "==",
value: result.label.batch
},
{
column: "itemCode",
action: "==",
value: result.label.itemCode
},
{
column: "fromLocationCode",
action: "==",
value: balance.locationCode
}
]
getOverPageJobList({
filters: filters,
pageNo: 1,
pageSize: 1000,
sort: 'createTime',
by: 'asc'
}).then(res => {
scanMessage.value = result.scanMessage
let resultList = res.data.list;
if (resultList.length > 0) {
resultList.forEach(item => {
item.title = item.number;
item.selected = false
})
let list = []
resultList.forEach(item => {
if (!list.find(subItem => subItem.title == item.title)) {
list.push(item)
}
})
if (list.length > 0) {
selectItem(list[0])
}
} else {
showMessage("按来源库位[" + balance.locationCode + "]批次[" + result.label.batch +
"]物料号[" + result.label.itemCode + "]未查找到任务\n" + "扫描[" + result
.scanMessage + "]")
}
}).catch(error => {
showMessage(error + "\n扫描[" + result.scanMessage + "]")
})
} catch (e) {
showMessage(e.message)
}
}
} }
</script> </script>

76
src/pages/package/job/overPackageJobDetail.vue

@ -22,7 +22,7 @@
<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" :key="index"> <view v-for="(toLocation, index) in detailSource" :key="index">
<comOverPackJobDetailCard ref="comOverPackJobDetailCard" :dataContent="toLocation" @updateData="updateData"> </comOverPackJobDetailCard> <comOverPackJobDetailCard ref="comOverPackJobDetailCard" :dataContent="toLocation" @updateData="updateData" :settingParam="jobContent"> </comOverPackJobDetailCard>
</view> </view>
</scroll-view> </scroll-view>
</view> </view>
@ -100,11 +100,15 @@ const comMessageRef = ref()
const comOverPackJobDetailCardRef = ref() const comOverPackJobDetailCardRef = ref()
const managementList = ref([]) const managementList = ref([])
const printService = ref() const printService = ref()
const scanMessage = ref('')
const fromLocationCode = ref('')
onLoad((option) => { onLoad((option) => {
uni.setNavigationBarTitle({ uni.setNavigationBarTitle({
title: `${option.title}详情` title: `${option.title}详情`
}) })
id.value = option.id id.value = option.id
fromLocationCode.value = option.fromLocationCode;
scanMessage.value = option.scanMessage || '';
if (id.value != undefined) { if (id.value != undefined) {
// //
if (option.status == '1') { if (option.status == '1') {
@ -173,6 +177,11 @@ const getDetail = () => {
jobStatus.value = res.data.status jobStatus.value = res.data.status
subList.value = res.data.subList subList.value = res.data.subList
detailSource.value = getDataSource(detailSource.value, subList.value) detailSource.value = getDataSource(detailSource.value, subList.value)
if (scanMessage.value) {
openScanPopupSimulate(scanMessage.value);
}else {
openScanDetailPopup()
}
nextTick(() => { nextTick(() => {
// if (uni.getStorageSync('overPackageJobDetailPointParams')) { // if (uni.getStorageSync('overPackageJobDetailPointParams')) {
// const overPackageJobDetailPointParams = uni.getStorageSync('overPackageJobDetailPointParams') // const overPackageJobDetailPointParams = uni.getStorageSync('overPackageJobDetailPointParams')
@ -195,6 +204,9 @@ const getDetail = () => {
showErrorMessage(error) showErrorMessage(error)
}) })
} }
const openScanPopupSimulate = (scanMessage)=> {
comScanPackagePackRef.value.openScanPopupForJobSimulate(detailSource.value, jobContent.value, scanMessage);
}
const closeScan = () => { const closeScan = () => {
resizeCollapse() resizeCollapse()
} }
@ -233,20 +245,43 @@ const submit = () => {
// } // }
} }
const checkSubmit = () => { const checkSubmit = () => {
const tempHandleQty = detailSource.value[0].Items[0].Locations[0].Batchs[0].handleQty let str=""
const tempQty = detailSource.value[0].Items[0].Locations[0].Batchs[0].qty detailSource.value.forEach(detail => {
const { toPackQty } = detailSource.value[0].Items[0].Locations[0].Batchs[0] detail.Items.forEach(item => {
if (tempHandleQty == 0) { let taskQty = 0;
showErrorMessage("实际数量为0,请先扫描数据") item.taskQty = calc.add(taskQty,item.qty)
return let totalQty = 0;
} item.Locations.forEach(lco => {
if (tempHandleQty > tempQty) { lco.Batchs.forEach(batch => {
// batch.Records.forEach(record => {
showCommitMessage(`实际数量【${tempHandleQty}】大于需求数量` + `${tempQty}】, 是否提交?`, tempHandleQty, toPackQty) if(record){
} else if (tempHandleQty < tempQty) { let hanleQty =record.qty?record.qty:0
showCommitMessage(`实际数量【${tempHandleQty}】小于需求数量` + `${tempQty}】, 是否提交?`, tempHandleQty, toPackQty) totalQty = calc.add(totalQty,hanleQty)
} else { }
packageHint(tempHandleQty, toPackQty)
})
})
})
//
item.totalQty =totalQty
})
})
//
detailSource.value.forEach(detail=>{
detail.Items.forEach(item=>{
if(item.taskQty!=item.totalQty){
str += `物料号【${item.itemCode}】实际提交数量【${item.totalQty}】与任务数量【${item.taskQty}】与不一致\n`
}
})
})
let toPackQty = detailSource.value[0].Items[0].qty
let commitHandleQty = detailSource.value[0].Items[0].totalQty
if(str){
str ="是否提交\n"+str
showCommitMessage(str,commitHandleQty,toPackQty)
}else {
packageHint(commitHandleQty, toPackQty)
} }
} }
const packageHint = (tempHandleQty, toPackQty) => { const packageHint = (tempHandleQty, toPackQty) => {
@ -299,7 +334,7 @@ const submitJob = () => {
barcodeBase64: '', barcodeBase64: '',
}) })
}) })
showCommitSuccessMessage("提交成功<br>生成翻包记录<br>", list) showCommitSuccessMessage("提交成功\n生成翻包记录\n", list)
} else { } else {
showErrorMessage("提交失败[" + res.msg + "]") showErrorMessage("提交失败[" + res.msg + "]")
@ -354,6 +389,12 @@ const setParams = () => {
}) })
subList.push(deepCopyData(subItem)) subList.push(deepCopyData(subItem))
} }
let itemInfo = subList.find(r => r.itemCode == subItem.itemCode&& r.fromLocationCode == subItem.fromLocationCode);
if(itemInfo){
itemInfo.recordList.push(...subItem.recordList)
}else {
subList.push(deepCopyData(subItem));
}
} }
}) })
}) })
@ -452,6 +493,9 @@ const showCommitSuccess = () => {
const showCommitSuccessMessage = (hint, pointData) => { const showCommitSuccessMessage = (hint, pointData) => {
comMessageRef.value.showSuccessMessage(hint, (res) => { comMessageRef.value.showSuccessMessage(hint, (res) => {
if (pointData.length > 0) { if (pointData.length > 0) {
pointData.forEach(item=>{
item.fromLocationCode = fromLocationCode.value
})
uni.redirectTo({ uni.redirectTo({
url: `/pages/point/index?points=${JSON.stringify(pointData)}` url: `/pages/point/index?points=${JSON.stringify(pointData)}`
}) })

Loading…
Cancel
Save