jy-safe-app/pages/apply/subPages/SCCM/materialLibraryIndex.vue

288 lines
7.6 KiB
Vue
Raw Permalink Normal View History

2025-10-14 15:17:30 +08:00
<template>
<!-- 操作记录 列表 CM042 -->
<view class="risk-record-page">
<u-sticky>
<view class="filter-bar">
<!-- <view class="filter filter-date-range" @click="handleShowPicker({title: '时间区间', name: 'dateRange'})">
<text>{{dateFilterTxt}}</text>
<u-icon size="14" style="margin-left: 4px;" name="arrow-down"></u-icon>
</view> -->
<uni-search-bar class="search-bar" radius="100" v-model="keyword" @confirm="handleSearch"
@cancel="handleCancelSearch" @clear="handleCancelSearch" placeholder="搜索" cancel-button="none">
<uni-icons slot="searchIcon" color="#999999" size="16" type="search" class="search-slot" />
</uni-search-bar>
<!-- <view class="filter filter-status" @click="handleShowPicker({title: '状态', name: 'status'})">
<text>{{statusFilterTxt}}</text>
<u-icon size="14" style="margin-left: 4px;" name="arrow-down"></u-icon>
</view> -->
</view>
</u-sticky>
<view class="main">
<view class="content-list">
<common-card :dataSource="item" v-for="item in lists" @click="showDetail(item.ID)">
<view class="content">
<view class="field">
<text class="left">物资编号</text>
<text class="value">{{item.CODE}}</text>
</view>
<view class="field">
<text class="left">类型</text>
<text class="value">{{item.Nav_MaterialType.NAME}}</text>
</view>
<view class="field">
<text class="left">规格/型号</text>
<text class="value">{{item.SPECIFICATION}}</text>
</view>
<view class="field">
<text class="left">数量</text>
<text class="value">{{item.COUNT +(item.UNIT?(""+item.UNIT+""):"" )}}</text>
</view>
<view class="field">
<text class="left">存放位置</text>
<text class="value">{{item.LOCATION}}</text>
</view>
<view class="field">
<text class="left">管理部门</text>
<text class="value">{{item.Nav_Department.NAME}}</text>
</view>
<view class="field">
<text class="left">管理责任人</text>
<text class="value">{{item.Nav_User.NAME}}</text>
</view>
</view>
</common-card>
</view>
<view v-if="!lists.length" class="empty-wrap">
<u-empty text="暂无数据" icon="/static/empty@2x.png">
</u-empty>
</view>
</view>
<u-picker :show="comPickerInfo.showPicker" :columns="comPickerInfo.columns" @confirm="onConfirmPicker"
@cancel="closePicker"></u-picker>
</view>
</template>
<script>
import {
initFilter,
extendRule,
extendInclude
} from '../../../../utils/common'
import {
OrderPagedMaterialLibrary
} from '../../../../services/apply/subPages/SCCM/emergency'
import {
getEnum
} from '../../../../services/common'
export default {
data() {
return {
pageIndex: 0,
lists: [{
Nav_User: {
NAME: ''
},
Nav_MaterialType: {
NAME: ''
},
Nav_Department: {
NAME: ''
},
OPERATETYPE_SHOW: '',
COUNT:'',
UNIT:'',
}],
enums: [{
ID: '',
NAME: ''
}],
currentTab: 0,
text: '',
total: '',
keyword: '',
searchStartTime: '',
filterStatus: null,
dateFilterTxt: '时间区间',
statusFilterTxt: '类型筛选',
comPickerInfo: {
showPicker: false,
columns: [],
title: '',
name: ''
}
}
},
onLoad() {
this.loadData()
// this.ini()
},
methods: {
// handleTab(t) {
// this.currentTab = t
// },
handleSearch() {
this.pageIndex = 0
this.loadData(false)
},
ini() {
getEnum({
name: 'CMOperation'
}).then(res => {
var listEnums = res
this.enums = listEnums
this.loadData()
})
},
loadData(paginate) {
this.pageIndex++
const orgId = uni.getStorageSync('orgId')
let json = initFilter(orgId, "", "CREATE_TIME", 1, this.pageIndex);
extendInclude(json, 'Nav_User')
extendInclude(json, 'Nav_MaterialType')
extendInclude(json, 'Nav_Department')
if (this.keyword) {
extendRule(json, 'NAME', 9, this.keyword);
}
if (this.searchStartTime && this.searchStartTime.length > 0) {
extendRule(json, 'CREATE_TIME', 6, this.searchStartTime)
}
if (this.filterStatus !== null) {
extendRule(json, 'OPERATETYPE', 1, this.filterStatus)
}
OrderPagedMaterialLibrary(json).then(res => {
this.total = res.TotalCount
const newRes = (res.Data || []).map(i => {
return {
...i,
title: i.NAME,
// OPERATETYPE_SHOW: (this.enums && this.enums.length > 0) ? (this.enums.find(e =>
// e.ID == i.OPERATETYPE).NAME) : i.OPERATETYPE
}
})
if (paginate) {
this.lists = this.lists.concat(newRes)
} else {
this.lists = newRes
}
})
},
showDetail(id) {
uni.navigateTo({
url: 'materialInfo?ID=' + id
})
},
handleShowPicker(p) {
let column = []
if (p.name === 'dateRange') {
column = ['全部', '当天', '最近三天', '最近一周', '最近一月']
}
if (p.name === 'status') {
// column = ['全部', '草稿', '确认中', '签到中', '审批中', '归档', '审批驳回']
if (this.enums && this.enums.length > 0) {
// column.push({'name':'类型筛选','ID':0} )
column.push('类型筛选')
this.enums.forEach(e => {
column.push(e.NAME)
// column.push({'name':e.NAME,'ID':e.ID} )
})
}
}
this.comPickerInfo = {
showPicker: true,
title: p.title,
name: p.name,
columns: [column]
}
},
onConfirmPicker(e) {
if (this.comPickerInfo.name === 'dateRange') {
let currentDate = new Date();
if (e.indexs[0] === 2) {
currentDate.setDate(currentDate.getDate() - 3);
} else if (e.indexs[0] === 3) {
currentDate.setDate(currentDate.getDate() - 7);
} else if (e.indexs[0] === 4) {
currentDate.setMonth(currentDate.getMonth() - 1);
}
if (e.indexs[0] === 0) {
this.searchStartTime = ''
this.dateFilterTxt = '时间区间'
} else {
this.dateFilterTxt = e.value[0]
this.searchStartTime = uni.$u.timeFormat(currentDate, 'yyyy-mm-dd 00:00:00');
}
}
if (this.comPickerInfo.name === 'status') {
// 草稿 = 0, 确认中5 签到中 = 6, 审批中 = 10, 归档 = 20, 审批驳回 = 30,
// if (e.indexs[0] === 1) {
// this.filterStatus = 0
// } else if (e.indexs[0] === 2) {
// this.filterStatus = 5
// } else if (e.indexs[0] === 3) {
// this.filterStatus = 6
// } else if (e.indexs[0] === 4) {
// this.filterStatus = 10
// } else if (e.indexs[0] === 5) {
// this.filterStatus = 20
// } else if (e.indexs[0] === 6) {
// this.filterStatus = 30
// }
if (e.indexs[0] === 0) {
// 全部
this.filterStatus = null
this.statusFilterTxt = '类型筛选'
} else {
this.filterStatus = this.enums[e.indexs[0] - 1].ID
this.statusFilterTxt = e.value[0]
}
}
this.closePicker()
},
closePicker() {
this.comPickerInfo = {
showPicker: false,
columns: [],
title: '',
name: ''
}
},
},
computed: {
},
onReachBottom() {
if (this.total > 10 * this.pageIndex)
this.loadData(true)
},
watch: {
keyword(n, o) {
this.pageIndex = 0
this.keyword = n
this.loadData()
},
searchStartTime(n, o) {
this.pageIndex = 0
this.searchStartTime = n
this.loadData()
},
filterStatus(n, o) {
this.pageIndex = 0
this.filterStatus = n
this.loadData()
}
}
}
</script>
<style>
@import url("../../../../style/css/listTemplate.css");
</style>