422 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			422 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
|   | <template> | |||
|  | 	<view class="container"> | |||
|  | 		<!-- 顶部导航栏 --> | |||
|  | 		<view class="top-heder"> | |||
|  | 			<view class="t-left" @click="getback()"> | |||
|  | 				<uni-icons type="left" size="18"></uni-icons> | |||
|  | 			</view> | |||
|  | 			<view class="t-title"> | |||
|  | 				<text>汇报列表</text> | |||
|  | 			</view> | |||
|  | 			<view class="t-you" @click="showFilterPopup"> | |||
|  | 				<text>筛选</text> | |||
|  | 			</view> | |||
|  | 		</view> | |||
|  | 
 | |||
|  | 		<!-- 搜索栏 --> | |||
|  | 		<view class="searchContent"> | |||
|  | 			<view class="t-input"> | |||
|  | 				<uni-icons type="search" color="#BCBCBC" size="22"></uni-icons> | |||
|  | 				<input type="text" v-model="queryParams.topicOrUserName" placeholder="请输入汇报主题或汇报人"> | |||
|  | 			</view> | |||
|  | 			<view class="sou" @click="search()">搜索</view> | |||
|  | 		</view> | |||
|  | 
 | |||
|  | 
 | |||
|  | 		<!-- 汇报列表 --> | |||
|  | 		<view class="report-list"> | |||
|  | 			<view class="report-item" v-for="(item, index) in reportList" :key="index" | |||
|  | 				@click="goToEditWriteReport(item.id)"> | |||
|  | 				<image class="avatar" :src="baseImageUrl + '/' + item.avatar"></image> | |||
|  | 				<view class="content"> | |||
|  | 					<view class="top"> | |||
|  | 						<view class="name">{{ item.userName }}</view> | |||
|  | 						<u-tag :text="item.reportTopic" type="primary" size="mini" class="tag"></u-tag> | |||
|  | 					</view> | |||
|  | 					<view class="report-time">汇报时间:{{ formatDateTimeToMinute(item.reportTime) }}</view> | |||
|  | 				</view> | |||
|  | 			</view> | |||
|  | 		</view> | |||
|  | 
 | |||
|  | 		<!-- 筛选弹窗 --> | |||
|  | 		<u-popup :show="showPopup" @close="closeFilterPopup" mode="right" closeable="true"> | |||
|  | 			<view class="filter-popup"> | |||
|  | 				<view class="popup-header"> | |||
|  | 					<text>时间筛选</text> | |||
|  | 				</view> | |||
|  | 				<view style="width: 95%; margin: 5px auto;"> | |||
|  | 					<uni-datetime-picker v-model="queryParams.reportTime" type="daterange" /> | |||
|  | 				</view> | |||
|  | 				<view class="popup-footer"> | |||
|  | 					<u-button type="primary" @click="applyFilter">应用筛选</u-button> | |||
|  | 					<u-button type="default" @click="clearTime">清除时间</u-button> | |||
|  | 				</view> | |||
|  | 			</view> | |||
|  | 		</u-popup> | |||
|  | 
 | |||
|  | 		<u-datetime-picker :show="showStarTime" v-model="queryParams.reportTime[0]" mode="date" | |||
|  | 			@cancel="showStarTime = false" @confirm="selectStartTime"></u-datetime-picker> | |||
|  | 
 | |||
|  | 		<u-datetime-picker :show="showEndTime" v-model="queryParams.reportTime[1]" mode="date" | |||
|  | 			@cancel="showEndTime = false" @confirm="selectEndTime"></u-datetime-picker> | |||
|  | 
 | |||
|  | 		<!-- 底部按钮 --> | |||
|  | 		<view class="bottom-btn"> | |||
|  | 			<u-button type="primary" shape="circle" class="report-btn" @click="goToWriteReport">填写汇报</u-button> | |||
|  | 		</view> | |||
|  | 	</view> | |||
|  | </template> | |||
|  | 
 | |||
|  | <script> | |||
|  | 	import request from "@/utils/request"; | |||
|  | 	import { | |||
|  | 		formatDate, | |||
|  | 		formatDateTimeToMinute | |||
|  | 	} from "@/utils/utils"; | |||
|  | 	import config from "@/config"; | |||
|  | 
 | |||
|  | 	export default { | |||
|  | 		data() { | |||
|  | 			return { | |||
|  | 				reportList: [], | |||
|  | 				showPopup: false, // 控制筛选弹窗显示
 | |||
|  | 				// 查询参数
 | |||
|  | 				queryParams: { | |||
|  | 					pageNo: 1, | |||
|  | 					pageSize: 10, | |||
|  | 					reportTopic: null, | |||
|  | 					reportTime: [], | |||
|  | 					createTime: [], | |||
|  | 					userName: null, | |||
|  | 					servicePackageId: "jiance", | |||
|  | 					dictType: 'ins_high_rise', | |||
|  | 					topicOrUserName: '', | |||
|  | 				}, | |||
|  | 				showStarTime: false, | |||
|  | 				showEndTime: false, | |||
|  | 				baseImageUrl: config.baseImageUrl, | |||
|  | 				totalPages: 0, | |||
|  | 				reportTimeStr: [], | |||
|  | 			}; | |||
|  | 		}, | |||
|  | 		onLoad() { | |||
|  | 			this.getReportList(); | |||
|  | 		}, | |||
|  | 		onReachBottom() { | |||
|  | 			if (this.queryParams.pageNo >= this.totalPages) { | |||
|  | 				uni.showToast({ | |||
|  | 					title: '没有下一页数据', | |||
|  | 					icon: 'none' | |||
|  | 				}); | |||
|  | 			} else { | |||
|  | 				this.queryParams.pageNo++; | |||
|  | 				this.getReportList(); | |||
|  | 			} | |||
|  | 		}, | |||
|  | 		methods: { | |||
|  | 			// 打开筛选弹窗
 | |||
|  | 			showFilterPopup() { | |||
|  | 				this.showPopup = true; | |||
|  | 			}, | |||
|  | 			// 关闭筛选弹窗
 | |||
|  | 			closeFilterPopup() { | |||
|  | 				this.showPopup = false; | |||
|  | 			}, | |||
|  | 			// 应用筛选
 | |||
|  | 			applyFilter() { | |||
|  | 				this.closeFilterPopup(); | |||
|  | 				this.search(); | |||
|  | 			}, | |||
|  | 			// 清除时间
 | |||
|  | 			clearTime() { | |||
|  | 				this.showPopup = false; | |||
|  | 				this.queryParams.reportTime = ['', '']; | |||
|  | 				this.reportTimeStr = []; | |||
|  | 				this.search(); | |||
|  | 			}, | |||
|  | 			formatDateTimeToMinute, | |||
|  | 			formatDate, | |||
|  | 			// 搜索
 | |||
|  | 			search() { | |||
|  | 				this.reportList = []; | |||
|  | 				this.queryParams.pageNo = 1; | |||
|  | 				this.getReportList(); | |||
|  | 			}, | |||
|  | 			// 获取汇报列表
 | |||
|  | 			getReportList() { | |||
|  | 				request({ | |||
|  | 					url: "/work/report/page", | |||
|  | 					method: "GET", | |||
|  | 					params: this.queryParams, | |||
|  | 				}).then((res) => { | |||
|  | 					if (this.queryParams.pageNo != 1) { | |||
|  | 						this.reportList = this.reportList.concat(res.data.records); | |||
|  | 					} else { | |||
|  | 						this.reportList = res.data.records; | |||
|  | 					} | |||
|  | 					let total = res.total; | |||
|  | 					this.totalPages = Math.ceil(total / this.queryParams.pageSize); | |||
|  | 				}); | |||
|  | 			}, | |||
|  | 			// 返回上一页
 | |||
|  | 			getback() { | |||
|  | 				uni.navigateBack({ | |||
|  | 					delta: 1 | |||
|  | 				}); | |||
|  | 			}, | |||
|  | 			// 跳转到填写汇报页面
 | |||
|  | 			goToWriteReport() { | |||
|  | 				uni.navigateTo({ | |||
|  | 					url: "/pages/manage/workReport/workReportAdd?type=add" | |||
|  | 				}); | |||
|  | 			}, | |||
|  | 			// 跳转到编辑汇报页面
 | |||
|  | 			goToEditWriteReport(id) { | |||
|  | 				uni.navigateTo({ | |||
|  | 					url: "/pages/manage/workReport/workReportAdd?type=edit&id=" + id | |||
|  | 				}); | |||
|  | 			}, | |||
|  | 			selectStartTime() { | |||
|  | 				//加延时器
 | |||
|  | 				this.$nextTick(() => { | |||
|  | 					this.queryParams.reportTime[0] = formatDate(this.queryParams.reportTime[0]); | |||
|  | 					this.reportTimeStr[0] = this.queryParams.reportTime[0] | |||
|  | 					this.showStarTime = false; | |||
|  | 				}); | |||
|  | 
 | |||
|  | 			}, | |||
|  | 			selectEndTime() { | |||
|  | 				this.$nextTick(() => { | |||
|  | 					this.queryParams.reportTime[1] = formatDate(this.queryParams.reportTime[1]); | |||
|  | 					this.reportTimeStr[1] = this.queryParams.reportTime[1] | |||
|  | 					this.showEndTime = false; | |||
|  | 				}); | |||
|  | 			}, | |||
|  | 		}, | |||
|  | 	}; | |||
|  | </script> | |||
|  | 
 | |||
|  | <style scoped> | |||
|  | 	.container { | |||
|  | 		background-color: #f5f6fa; | |||
|  | 		min-height: 100vh; | |||
|  | 		padding-bottom: 120rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 筛选弹窗样式 */ | |||
|  | 	.filter-popup { | |||
|  | 		padding: 20rpx; | |||
|  | 		width: 450rpx; | |||
|  | 		/* 或者设置更大的固定宽度,如 600px */ | |||
|  | 		max-width: 90%; | |||
|  | 		/* 最大宽度,防止屏幕过窄时弹窗过大 */ | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.popup-header { | |||
|  | 		display: flex; | |||
|  | 		justify-content: space-between; | |||
|  | 		align-items: center; | |||
|  | 		padding-bottom: 20rpx; | |||
|  | 		border-bottom: 1rpx solid #eee; | |||
|  | 		margin-top: 70rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.popup-footer { | |||
|  | 		display: flex; | |||
|  | 		justify-content: space-between; | |||
|  | 		margin-top: 20rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 列表样式 */ | |||
|  | 	.report-list { | |||
|  | 		padding: 20rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.report-item { | |||
|  | 		display: flex; | |||
|  | 		align-items: center; | |||
|  | 		background: #fff; | |||
|  | 		padding: 10rpx; | |||
|  | 		/* 减少上、下内边距 */ | |||
|  | 		margin-bottom: 16rpx; | |||
|  | 		height: 180rpx; | |||
|  | 		/* 调整高度,使整体紧凑 */ | |||
|  | 		box-shadow: 0 4rpx 8rpx rgba(0, 0, 0, 0.05); | |||
|  | 		border: 1px solid #eaeaea; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 头像 */ | |||
|  | 	.avatar { | |||
|  | 		width: 90rpx; | |||
|  | 		height: 90rpx; | |||
|  | 		//border-radius: 50%; margin-right: 20rpx; border: 2rpx solid #ddd;
 | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 内容区 */ | |||
|  | 	.content { | |||
|  | 		flex: 1; | |||
|  | 		display: flex; | |||
|  | 		flex-direction: column; | |||
|  | 		/* 改为垂直排列 */ | |||
|  | 		justify-content: space-between; | |||
|  | 		/* 保证内容上下分布 */ | |||
|  | 		margin-left: 20rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 姓名 + 主题 */ | |||
|  | 	.top { | |||
|  | 		display: flex; | |||
|  | 		align-items: center; | |||
|  | 		justify-content: space-between; | |||
|  | 		margin-top: 0; | |||
|  | 		/* 调整顶部间距为0 */ | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.name { | |||
|  | 		font-size: 30rpx; | |||
|  | 		font-weight: bold; | |||
|  | 		color: #333; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 主题标签 */ | |||
|  | 	.tag { | |||
|  | 		padding: 4rpx 12rpx; | |||
|  | 		font-size: 24rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 汇报时间 */ | |||
|  | 	.report-time { | |||
|  | 		font-size: 26rpx; | |||
|  | 		color: #999; | |||
|  | 		margin-top: 8rpx; | |||
|  | 		/* 保证汇报时间在下面 */ | |||
|  | 	} | |||
|  | 
 | |||
|  | 	/* 底部按钮 */ | |||
|  | 	.bottom-btn { | |||
|  | 		position: fixed; | |||
|  | 		bottom: 30rpx; | |||
|  | 		left: 50%; | |||
|  | 		transform: translateX(-50%); | |||
|  | 		width: 90%; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.report-btn { | |||
|  | 		font-size: 32rpx; | |||
|  | 		height: 80rpx; | |||
|  | 		line-height: 80rpx; | |||
|  | 		border-radius: 40rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 
 | |||
|  | 	.top-heder { | |||
|  | 		width: 100%; | |||
|  | 		height: 68px; | |||
|  | 		background: white; | |||
|  | 		display: flex; | |||
|  | 		align-items: center; | |||
|  | 		justify-content: space-between; | |||
|  | 		box-sizing: border-box; | |||
|  | 		padding: 5px 15px; | |||
|  | 		margin-top: 2rem; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.t-title { | |||
|  | 		font-size: 17px; | |||
|  | 		font-weight: bold; | |||
|  | 		color: #333333; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.t-left { | |||
|  | 		width: 20%; | |||
|  | 		height: 20px; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.t-you { | |||
|  | 		width: 20%; | |||
|  | 		height: 20px; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.t-input { | |||
|  | 		width: 75%; | |||
|  | 		height: 36px; | |||
|  | 		background: #F0F0F0; | |||
|  | 		border-radius: 50px; | |||
|  | 		box-sizing: border-box; | |||
|  | 		padding: 0 15px; | |||
|  | 		display: flex; | |||
|  | 		align-items: center; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.sou { | |||
|  | 		width: 10%; | |||
|  | 		margin-left: 5px; | |||
|  | 		display: flex; | |||
|  | 		justify-content: center; | |||
|  | 		align-items: center; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.searchContent { | |||
|  | 		display: flex; | |||
|  | 		justify-content: center; | |||
|  | 		margin-top: 20rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 
 | |||
|  | 	.time-picker { | |||
|  | 		display: flex; | |||
|  | 		flex-direction: column; | |||
|  | 		/* 添加:使子元素垂直排列 */ | |||
|  | 		align-items: center; | |||
|  | 		padding: 20rpx; | |||
|  | 		background: #fff; | |||
|  | 		margin: 20rpx 0; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.picker-item { | |||
|  | 		flex: 1; | |||
|  | 		display: block; | |||
|  | 		/* 修改:改为块级元素 */ | |||
|  | 		padding: 20rpx; | |||
|  | 		background: #f8f8f8; | |||
|  | 		border-radius: 12rpx; | |||
|  | 		margin: 10rpx 0; | |||
|  | 		/* 添加:增加上下间距 */ | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.split-line { | |||
|  | 		padding: 0 10rpx; | |||
|  | 		color: #999; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.label { | |||
|  | 		font-size: 26rpx; | |||
|  | 		color: #666; | |||
|  | 		margin-right: 15rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.time-text { | |||
|  | 		flex: 1; | |||
|  | 		font-size: 28rpx; | |||
|  | 		color: #333; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	.placeholder { | |||
|  | 		color: #999; | |||
|  | 	} | |||
|  | 
 | |||
|  | 	uni-icons { | |||
|  | 		margin-left: 10rpx; | |||
|  | 	} | |||
|  | 
 | |||
|  | 
 | |||
|  | 	/* 添加清除按钮样式 */ | |||
|  | 	.clear-btn { | |||
|  | 		color: #007AFF; | |||
|  | 		font-size: 26rpx; | |||
|  | 		margin-left: 20rpx; | |||
|  | 		padding: 10rpx 20rpx; | |||
|  | 		border: 1rpx solid #007AFF; | |||
|  | 		border-radius: 8rpx; | |||
|  | 	} | |||
|  | </style> |