348 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			348 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						||
	<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" class="content" @click="showDetail(item.ID)">
 | 
						||
					<view>
 | 
						||
						<view class="field">
 | 
						||
							<text class="label">发起人:</text>
 | 
						||
							<text class="value">{{item.Nav_LaunchUser?item.Nav_LaunchUser.NAME:''}}</text>
 | 
						||
						</view>
 | 
						||
						<view class="field">
 | 
						||
							<text class="label">培训类型:</text>
 | 
						||
							<text class="value">{{item.Nav_TrainType?item.Nav_TrainType.NAME:''}}</text>
 | 
						||
						</view>
 | 
						||
						<view class="field">
 | 
						||
							<text class="label">培训开始时间:</text>
 | 
						||
							<text class="value">{{item.TRAIN_START_TIME}}</text>
 | 
						||
						</view>
 | 
						||
						<view class="field">
 | 
						||
							<text class="label">培训结束时间:</text>
 | 
						||
							<text class="value">{{item.TRAIN_END_TIME}}</text>
 | 
						||
						</view>
 | 
						||
						<view class="field">
 | 
						||
							<text class="label">考核方式:</text>
 | 
						||
							<text class="value">{{item.Nav_TrainCheckType?item.Nav_TrainCheckType.NAME:''}}</text>
 | 
						||
						</view>
 | 
						||
						<view class="field">
 | 
						||
							<text class="label">状态:</text>
 | 
						||
							<text class="value">{{item.STATUS}}</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" :defaultIndex="[0]" @cancel="closePicker"></u-picker>
 | 
						||
	</view>
 | 
						||
</template>
 | 
						||
 | 
						||
<script>
 | 
						||
	import {
 | 
						||
		getRequestOrderPage
 | 
						||
	} from '../../../../services/apply/FOServices/FOServices.js'
 | 
						||
	import {
 | 
						||
		extendInclude,
 | 
						||
		extendRule,
 | 
						||
		initFilter
 | 
						||
	} from '../../../../utils/common'
 | 
						||
	import {
 | 
						||
		getEnum
 | 
						||
	} from '../../../../services/common';
 | 
						||
 | 
						||
	export default {
 | 
						||
		data() {
 | 
						||
			return {
 | 
						||
				pageIndex: 1,
 | 
						||
				total: 0,
 | 
						||
				lists: [],
 | 
						||
				keyword: '',
 | 
						||
				searchStartTime: '',
 | 
						||
				filterStatus: null,
 | 
						||
				dateFilterTxt: '时间区间',
 | 
						||
				statusFilterTxt: '状态筛选',
 | 
						||
				comPickerInfo: {
 | 
						||
					showPicker: false,
 | 
						||
					columns: [],
 | 
						||
					title: '',
 | 
						||
					name: ''
 | 
						||
				},
 | 
						||
				enumsData: {}, // 存储所有枚举数据(键:枚举名称,值:处理后的枚举列表)
 | 
						||
				enumsText: {} // 存储枚举文本列表(用于下拉选择等场景)
 | 
						||
			}
 | 
						||
		},
 | 
						||
		onLoad() {
 | 
						||
			this.fetchEnums(['SETrainNotifyStatus']);
 | 
						||
		},
 | 
						||
		methods: {
 | 
						||
			async fetchEnums(enumNames) {
 | 
						||
				try {
 | 
						||
					// 存储所有枚举请求的Promise
 | 
						||
					const enumPromises = enumNames.map(name => {
 | 
						||
						return getEnum({
 | 
						||
							name
 | 
						||
						}).then(res => {
 | 
						||
							// 统一处理枚举格式:添加name/code字段,便于后续映射
 | 
						||
							return {
 | 
						||
								enumName: name,
 | 
						||
								data: res.map(item => ({
 | 
						||
									...item,
 | 
						||
									name: item.NAME, // 统一显示名称字段
 | 
						||
									code: item.ID // 统一值字段
 | 
						||
								}))
 | 
						||
							};
 | 
						||
						});
 | 
						||
					});
 | 
						||
 | 
						||
					// 等待所有枚举请求完成
 | 
						||
					const results = await Promise.all(enumPromises);
 | 
						||
					// 存储枚举结果到data中(键为枚举名称,值为处理后的数据)
 | 
						||
					results.forEach(({
 | 
						||
						enumName,
 | 
						||
						data
 | 
						||
					}) => {
 | 
						||
						this.enumsData[enumName] = data;
 | 
						||
						// 生成文本列表(如需要)
 | 
						||
						this.enumsText[enumName] = data.map(item => item.name);
 | 
						||
					});
 | 
						||
					// 所有枚举获取完成后,执行loadData
 | 
						||
					this.loadData();
 | 
						||
				} catch (error) {
 | 
						||
					console.error('枚举请求失败:', error);
 | 
						||
					uni.showToast({
 | 
						||
						title: '枚举数据加载失败',
 | 
						||
						icon: 'none'
 | 
						||
					});
 | 
						||
				}
 | 
						||
			},
 | 
						||
			handleSearch(obj) {
 | 
						||
				this.keyword = obj.value
 | 
						||
			},
 | 
						||
			handleCancelSearch() {
 | 
						||
				this.keyword = ''
 | 
						||
			},
 | 
						||
			loadData() {
 | 
						||
				const orgId = uni.getStorageSync('orgId')
 | 
						||
				const json = initFilter(orgId, "", "CREATE_TIME", 1, this.pageIndex)
 | 
						||
				extendInclude(json, "Nav_LaunchDepartment")
 | 
						||
				extendInclude(json, "Nav_LaunchUser")
 | 
						||
				extendInclude(json, "Nav_TrainType")
 | 
						||
				extendInclude(json, "Nav_TrainCheckType")
 | 
						||
				if (this.keyword) {
 | 
						||
					extendRule(json, 'NAME', 9, this.keyword)
 | 
						||
				}
 | 
						||
				if (this.searchStartTime) {
 | 
						||
					extendRule(json, 'TRAIN_START_TIME', 6, this.searchStartTime)
 | 
						||
				}
 | 
						||
				if (this.filterStatus !== null) {
 | 
						||
					extendRule(json, 'STATUS', 1, this.filterStatus)
 | 
						||
				}
 | 
						||
				getRequestOrderPage(json, "/SE/TrainNotify/OrderPaged").then(res => {
 | 
						||
					this.total = res.TotalCount;
 | 
						||
					let newRes = (res.Data || []).map(i => {
 | 
						||
						return {
 | 
						||
							...i,
 | 
						||
							title: i.NAME,
 | 
						||
							STATUS: i.STATUS !== undefined ? this.enumsData['SETrainNotifyStatus'].find(item => item.code === i.STATUS).name : ''
 | 
						||
						}
 | 
						||
					})
 | 
						||
 | 
						||
					if (this.pageIndex !== 1) {
 | 
						||
						this.lists = this.lists.concat(newRes)
 | 
						||
					} else {
 | 
						||
						this.lists = newRes
 | 
						||
					}
 | 
						||
				})
 | 
						||
			},
 | 
						||
			showDetail(id) {
 | 
						||
				uni.navigateTo({
 | 
						||
					url: '/pages/apply/subPages/SE/1trainNotifyShow?ID=' + id
 | 
						||
				})
 | 
						||
			},
 | 
						||
			handleShowPicker(p) {
 | 
						||
				let column = []
 | 
						||
				if (p.name === 'dateRange') {
 | 
						||
					column = ['全部', '当天', '最近三天', '最近一周', '最近一月']
 | 
						||
				}
 | 
						||
				if (p.name === 'status') {
 | 
						||
					column = this.enumsText['SETrainNotifyStatus']
 | 
						||
				}
 | 
						||
				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.setDate(currentDate.getMonth());
 | 
						||
					}
 | 
						||
					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') {
 | 
						||
					this.filterStatus = this.enumsData['SETrainNotifyStatus'][e.indexs[0]].code
 | 
						||
					this.statusFilterTxt = e.value[0]
 | 
						||
				}
 | 
						||
				this.closePicker()
 | 
						||
			},
 | 
						||
			closePicker() {
 | 
						||
				this.comPickerInfo = {
 | 
						||
					showPicker: false,
 | 
						||
					columns: [],
 | 
						||
					title: '',
 | 
						||
					name: ''
 | 
						||
				}
 | 
						||
			},
 | 
						||
		},
 | 
						||
		onReachBottom() {
 | 
						||
			// 页码 +1
 | 
						||
			if (this.total > 10 * this.pageIndex)
 | 
						||
				this.pageIndex++
 | 
						||
		},
 | 
						||
		watch: {
 | 
						||
			pageIndex(n, o) {
 | 
						||
				this.loadData()
 | 
						||
			},
 | 
						||
			keyword(n, o) {
 | 
						||
				this.pageIndex = 1
 | 
						||
				this.keyword = n
 | 
						||
				this.loadData()
 | 
						||
			},
 | 
						||
			searchStartTime(n, o) {
 | 
						||
				this.pageIndex = 1
 | 
						||
				this.searchStartTime = n
 | 
						||
				this.loadData()
 | 
						||
			},
 | 
						||
			filterStatus(n, o) {
 | 
						||
				this.pageIndex = 1
 | 
						||
				this.filterStatus = n
 | 
						||
				this.loadData()
 | 
						||
			}
 | 
						||
		}
 | 
						||
	}
 | 
						||
</script>
 | 
						||
 | 
						||
<style>
 | 
						||
	.risk-record-page {
 | 
						||
		position: relative;
 | 
						||
	}
 | 
						||
 | 
						||
	.risk-record-page .main {
 | 
						||
		padding: 0px 16px;
 | 
						||
		position: relative;
 | 
						||
	}
 | 
						||
 | 
						||
	.risk-record-page>>>.uni-searchbar {
 | 
						||
		padding: 0px;
 | 
						||
		display: flex;
 | 
						||
		align-items: center;
 | 
						||
		font-size: 12px;
 | 
						||
 | 
						||
		.uni-searchbar__box {
 | 
						||
			height: 30px;
 | 
						||
		}
 | 
						||
 | 
						||
		.uni-searchbar__box-icon-clear {
 | 
						||
			display: flex;
 | 
						||
			align-items: center;
 | 
						||
		}
 | 
						||
 | 
						||
		.uni-input-placeholder {}
 | 
						||
 | 
						||
		.uni-searchbar__box-search-input {
 | 
						||
			font-size: 12px;
 | 
						||
		}
 | 
						||
 | 
						||
		.uni-searchbar__text-placeholder {
 | 
						||
			font-size: 12px;
 | 
						||
			margin-left: 0px;
 | 
						||
		}
 | 
						||
 | 
						||
		.uni-text {
 | 
						||
			font-size: 12px;
 | 
						||
		}
 | 
						||
	}
 | 
						||
 | 
						||
	.filter-bar .search-bar {
 | 
						||
		margin-left: 20px;
 | 
						||
		margin-right: 20px;
 | 
						||
		width: 100%;
 | 
						||
		display: flex;
 | 
						||
		flex: 1;
 | 
						||
		align-items: center;
 | 
						||
		font-size: 12px;
 | 
						||
	}
 | 
						||
 | 
						||
	.filter-bar {
 | 
						||
		display: flex;
 | 
						||
		justify-content: space-between;
 | 
						||
		align-items: center;
 | 
						||
		background-color: #ffffff;
 | 
						||
		padding: 10px 16px 10px 16px;
 | 
						||
		box-shadow: 0px 0px 5px 0px #eaedf4;
 | 
						||
	}
 | 
						||
 | 
						||
	.filter-bar .filter {
 | 
						||
		display: flex;
 | 
						||
		align-items: center;
 | 
						||
		font-size: 12px;
 | 
						||
		line-height: 18px;
 | 
						||
		color: #333;
 | 
						||
	}
 | 
						||
 | 
						||
	.content-list {
 | 
						||
		padding: 10px 0;
 | 
						||
	}
 | 
						||
 | 
						||
	.content .field {
 | 
						||
		font-size: 12px;
 | 
						||
		line-height: 18px;
 | 
						||
		margin-bottom: 4px;
 | 
						||
	}
 | 
						||
 | 
						||
	.content .field .label {
 | 
						||
		color: #666;
 | 
						||
	}
 | 
						||
 | 
						||
	.content .field .value {
 | 
						||
		color: #333333;
 | 
						||
	}
 | 
						||
 | 
						||
	.status {
 | 
						||
		background-color: rgba(5, 109, 232, 0.1);
 | 
						||
		color: #056DE8;
 | 
						||
		padding: 0px 5px 0px 5px;
 | 
						||
		border-radius: 5px;
 | 
						||
	}
 | 
						||
</style> |