You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

284 lines
7.2 KiB

<template>
<view class="">
<com-empty-view v-if="jobList.length == 0"></com-empty-view>
<job-filter ref="filter" otherTitle="ASN" @switchChangeToday="switchChangeToday" @switchChangeWait="switchChangeWait" @onScanNumber="getScanNumber" :checkedToday="checkedToday" :checkedWaitTask="checkedWaitTask"> </job-filter>
<view v-if="jobList.length > 0">
<uni-swipe-action ref="swipeAction">
<view v-for="(item, index) in jobList" :key="index">
<uni-swipe-action-item :right-options="item.status == '2' ? detailGiveupOptions : detailOptions" @click="swipeClick($event, item)">
<com-inspect-job-card :dataContent="item" @click="openJobDetail(item)"></com-inspect-job-card>
</uni-swipe-action-item>
</view>
</uni-swipe-action>
<uni-load-more :status="loadingType" v-if="jobList.length > 0" />
<inspectInfoPopup ref="jobInfoPopup"></inspectInfoPopup>
<com-inspect-job-list ref="comReceiptJobList" @selectedItem="selectedItem"></com-inspect-job-list>
</view>
<comMessage ref="comMessage"></comMessage>
</view>
</template>
<script>
import { cancleTakeInspectJob, getInspectJobList } from '@/api/request2.js'
import { goHome, updateTitle } from '@/common/basic.js'
import { getDetailOption, getDetailGiveupOption } from '@/common/array.js'
import comEmptyView from '@/mycomponents/common/comEmptyView.vue'
import jobFilter from '@/mycomponents/job/jobFilter.vue'
import inspectInfoPopup from '@/pages/inspect/coms/inspectInfoPopup.vue'
import comInspectJobCard from '@/pages/inspect/coms/comInspectJobCard.vue'
import comInspectJobList from '@/pages/inspect/coms/comInspectJobList.vue'
export default {
name: 'receipt',
components: {
comEmptyView,
jobFilter,
comInspectJobCard,
inspectInfoPopup,
comInspectJobList
},
data() {
return {
jobList: [],
pageNo: 1,
pageSize: 10,
totalCount: 0,
loadingType: 'nomore',
checkedToday: false,
checkedWaitTask: false,
todayTime: '',
status: '1,2', // 待处理 、进行中
detailOptions: [],
detailGiveupOptions: []
}
},
onShow() {
this.getList('refresh')
},
onReady() {
this.detailOptions = getDetailOption()
this.detailGiveupOptions = getDetailGiveupOption()
},
onReachBottom() {
// 避免多次触发
if (this.loadingType == 'loading' || this.loadingType == 'nomore') {
return
}
this.getList('more')
},
onPullDownRefresh() {
this.getList('refresh')
},
// 后退按钮
onBackPress(options) {
if (options.from === 'navigateBack') {
uni.navigateBack({
delta: 1
})
return false
}
},
// 返回首页
onNavigationBarButtonTap(e) {
if (e.index === 0) {
goHome()
} else if (e.index == 1) {
this.$refs.filter.openFilter()
}
},
methods: {
getList(type) {
const that = this
uni.showLoading({
title: '加载中­....',
mask: true
})
this.loadingType = 'loading'
if (type === 'refresh') {
this.pageNo = 1
this.jobList = []
}
const filters = []
if (this.checkedToday) {
filters.push({
column: 'create_time',
action: 'betweeen',
value: this.todayTime
})
}
filters.push({
column: 'status',
action: 'in',
value: this.status
})
filters.push({
column: 'accept_user_id',
action: '==',
value: this.$store.state.user.id
})
const params = {
filters,
pageNo: this.pageNo,
pageSize: this.pageSize
}
getInspectJobList(params)
.then((res) => {
uni.hideLoading()
if (type === 'refresh') {
uni.stopPullDownRefresh()
}
const { list } = res.data
this.totalCount = res.data.total
updateTitle(`到货检验(${this.totalCount})`)
this.loadingType = 'loadmore'
if (list == null || list.length == 0) {
this.loadingType = 'nomore'
return
}
this.jobList = type === 'refresh' ? list : this.jobList.concat(list)
this.pageNo++
})
.catch((error) => {
if (type === 'refresh') {
uni.stopPullDownRefresh()
}
updateTitle('到货检验')
this.loadingType = ''
uni.hideLoading()
that.showMessage(error)
})
},
openJobDetail(item) {
// uni.navigateTo({
// url: './inspectDetail?id=' + item.id + '&status=' + item.status
// });
if (item.inspectType == 'FULL') {
uni.navigateTo({
url: `./inspectFullDetail?id=${item.id}&status=${item.status}`
})
} else {
uni.navigateTo({
url: `./inspectResult?id=${item.id}&status=${item.status}`
})
}
},
showItemList(itemList) {
this.$refs.comReceiptJobList.openPopup(itemList)
},
selectedItem(item) {
this.openJobDetail(item)
},
swipeClick(e, dataContent) {
if (e.content.text == '详情') {
this.openjobInfoPopup(dataContent)
} else if (e.content.text == '放弃') {
this.$refs.comMessage.showQuestionMessage('确定要放弃当前任务?', (res) => {
if (res) {
this.cancleJob(dataContent.id)
}
})
}
},
openjobInfoPopup(item) {
this.$refs.jobInfoPopup.openPopup(item)
},
cancleJob(id) {
cancleTakeInspectJob(id)
.then((res) => {
if (res.data) {
this.getList('refresh')
uni.showToast({
title: '放弃任务成功'
})
} else {
this.showMessage('放弃任务失败')
}
})
.catch((error) => {
this.showMessage(error)
})
},
switchChangeToday(state, creationTime) {
this.checkedToday = state
this.todayTime = creationTime
this.getList('refresh')
},
switchChangeWait(state, jobStatus) {
this.checkedWaitTask = state
this.status = jobStatus
this.getList('refresh')
},
getScanNumber(code) {
this.getDataListByType(code)
},
getDataListByType(code) {
const that = this
uni.showLoading({
title: '加载中....',
mask: true
})
const filters = []
filters.push({
column: 'status',
action: 'in',
value: '1,2'
})
filters.push({
column: 'number',
action: '==',
value: code
})
const params = {
filters,
pageNo: 1,
pageSize: 100
}
getInspectJobList(params)
.then((res) => {
uni.hideLoading()
if (res.data.list.length == 0) {
that.showMessage('未查找到' + `【${code}】的收货任务`)
} else if (res.data.list.length == 1) {
that.openJobDetail(res.data.list[0])
}
})
.catch((error) => {
uni.hideLoading()
that.showMessage(error)
})
},
showMessage(message) {
this.$refs.comMessage.showErrorMessage(message, (res) => {
if (res) {
}
})
}
}
}
</script>
<style scoped lang="scss"></style>