288 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			288 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<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> |