| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |     <scroll-view scroll-y class="main-scroll"> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         <view class="scrollmain"> | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |             <!-- 消息列表 --> | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |             <view | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  |                 class="list-card press-button" | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |                 v-for="(item, index) in msgList" | 
					
						
							|  |  |  |                 :key="index" | 
					
						
							|  |  |  |                 @click="seeDetail(item, index)" | 
					
						
							|  |  |  |             > | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 <view class="card-img"> | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |                     <image | 
					
						
							|  |  |  |                         class="card-img-flame" | 
					
						
							|  |  |  |                         v-if="item.title === '招聘会预约提醒'" | 
					
						
							|  |  |  |                         src="/static/icon/msgtype.png" | 
					
						
							|  |  |  |                     ></image> | 
					
						
							|  |  |  |                     <image | 
					
						
							|  |  |  |                         class="card-img-flame" | 
					
						
							|  |  |  |                         v-if="item.title === '职位上新'" | 
					
						
							|  |  |  |                         src="/static/icon/msgtype2.png" | 
					
						
							|  |  |  |                     ></image> | 
					
						
							|  |  |  |                     <image | 
					
						
							|  |  |  |                         class="card-img-flame" | 
					
						
							|  |  |  |                         v-if="item.title === '系统通知'" | 
					
						
							|  |  |  |                         src="/static/icon/msgtype3.png" | 
					
						
							|  |  |  |                     ></image> | 
					
						
							|  |  |  |                     <view class="subscript" v-if="item.notReadCount || !item.isRead"> | 
					
						
							|  |  |  |                         {{ item.notReadCount || '' }} | 
					
						
							|  |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 </view> | 
					
						
							|  |  |  |                 <view class="card-info"> | 
					
						
							|  |  |  |                     <view class="info-title"> | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |                         <text>{{ item.title }}</text> | 
					
						
							|  |  |  |                         <view class="card-time">{{ item.date }}</view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |                     <view class="info-text line_2">{{ item.subTitle || '消息' }}</view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 </view> | 
					
						
							|  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |              | 
					
						
							|  |  |  |             <!-- 暂无消息提示 --> | 
					
						
							|  |  |  |             <view class="empty-state" v-if="msgList.length === 0"> | 
					
						
							|  |  |  |                 <image class="empty-icon" src="/static/icon/empty.png" mode="aspectFit"></image> | 
					
						
							|  |  |  |                 <text class="empty-text">暂无消息</text> | 
					
						
							|  |  |  |                 <text class="empty-desc">您还没有收到任何消息</text> | 
					
						
							|  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         </view> | 
					
						
							|  |  |  |     </scroll-view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script setup> | 
					
						
							|  |  |  | import { reactive, inject, ref } from 'vue'; | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | const { $api, navTo, debounce } = inject('globalFunction'); | 
					
						
							|  |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							|  |  |  | import { useReadMsg } from '@/stores/useReadMsg'; | 
					
						
							|  |  |  | const { msgList } = storeToRefs(useReadMsg()); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | const isLoaded = ref(false); | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | async function loadData() { | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |         if (isLoaded.value) return; | 
					
						
							|  |  |  |         isLoaded.value = true; | 
					
						
							|  |  |  |     } catch (err) { | 
					
						
							|  |  |  |         isLoaded.value = false; // 重置状态允许重试
 | 
					
						
							|  |  |  |         throw err; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | function seeDetail(item, index) { | 
					
						
							|  |  |  |     switch (item.title) { | 
					
						
							|  |  |  |         case '职位上新': | 
					
						
							|  |  |  |             useReadMsg().markAsRead(item, index); | 
					
						
							|  |  |  |             navTo('/packageA/pages/newJobPosition/newJobPosition'); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case '招聘会预约提醒': | 
					
						
							|  |  |  |             useReadMsg().markAsRead(item, index); | 
					
						
							|  |  |  |             navTo('/packageA/pages/reservation/reservation'); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case '系统通知': | 
					
						
							|  |  |  |             navTo('/packageA/pages/systemNotification/systemNotification'); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | defineExpose({ loadData }); | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="stylus" scoped> | 
					
						
							|  |  |  | .main-scroll { | 
					
						
							|  |  |  |     width: 100% | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .scrollmain{ | 
					
						
							|  |  |  |     padding: 28rpx | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | } | 
					
						
							|  |  |  | .read{ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | } | 
					
						
							|  |  |  | .list-card | 
					
						
							|  |  |  |     background: #FFFFFF; | 
					
						
							|  |  |  |     border-radius: 17rpx; | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: flex-start; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     padding: 26rpx 36rpx; | 
					
						
							|  |  |  |     margin: 0 0 28rpx 0 | 
					
						
							|  |  |  |     .card-img | 
					
						
							|  |  |  |         width: 96rpx; | 
					
						
							|  |  |  |         height: 96rpx; | 
					
						
							|  |  |  |         border-radius: 50% | 
					
						
							|  |  |  |         display: grid; | 
					
						
							|  |  |  |         place-items: center; | 
					
						
							|  |  |  |         margin-right: 30rpx; | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |         position: relative; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         .card-img-flame | 
					
						
							|  |  |  |             width: 100%; | 
					
						
							|  |  |  |             height: 100% | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |         .subscript | 
					
						
							|  |  |  |             position: absolute; | 
					
						
							|  |  |  |             right: 0; | 
					
						
							|  |  |  |             top: 0; | 
					
						
							|  |  |  |             min-width: 26rpx; | 
					
						
							|  |  |  |             height: 26rpx; | 
					
						
							|  |  |  |             padding: 0 8rpx; /* 横向内边距控制宽度自适应 */ | 
					
						
							|  |  |  |             border-radius: 1000rpx; /* 实现椭圆形/圆角 */ | 
					
						
							|  |  |  |             text-align: center; | 
					
						
							|  |  |  |             line-height: 26rpx; | 
					
						
							|  |  |  |             background: #F73636; | 
					
						
							|  |  |  |             font-weight: 600; | 
					
						
							|  |  |  |             font-size: 20rpx; | 
					
						
							|  |  |  |             color: #FFFFFF; | 
					
						
							|  |  |  |             box-sizing: border-box; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     .card-info | 
					
						
							|  |  |  |         flex: 1; | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         align-items: flex-start; | 
					
						
							|  |  |  |         flex-direction: column; | 
					
						
							|  |  |  |         .info-title | 
					
						
							|  |  |  |             font-weight: 500; | 
					
						
							|  |  |  |             font-size: 32rpx; | 
					
						
							|  |  |  |             color: #333333; | 
					
						
							|  |  |  |             display: flex; | 
					
						
							|  |  |  |             justify-content: space-between; | 
					
						
							|  |  |  |             width: 100% | 
					
						
							| 
									
										
										
										
											2025-07-09 15:15:37 +08:00
										 |  |  |             text | 
					
						
							|  |  |  |                 font-family: 'PingFangSC-Medium', 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, 'Microsoft YaHei', sans-serif; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             .card-time | 
					
						
							|  |  |  |                 font-weight: 400; | 
					
						
							|  |  |  |                 font-size: 28rpx; | 
					
						
							|  |  |  |                 color: #AAAAAA; | 
					
						
							|  |  |  |                 height: 100% | 
					
						
							|  |  |  |                 margin: 4rpx; | 
					
						
							|  |  |  |         .info-text | 
					
						
							|  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |             color: #6C7282; | 
					
						
							|  |  |  |             margin-top: 4rpx; | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // 空状态样式
 | 
					
						
							|  |  |  | .empty-state | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							|  |  |  |     padding: 120rpx 40rpx; | 
					
						
							|  |  |  |     .empty-icon | 
					
						
							|  |  |  |         width: 200rpx; | 
					
						
							|  |  |  |         height: 200rpx; | 
					
						
							|  |  |  |         margin-bottom: 40rpx; | 
					
						
							|  |  |  |         opacity: 0.6; | 
					
						
							|  |  |  |     .empty-text | 
					
						
							|  |  |  |         font-size: 32rpx; | 
					
						
							|  |  |  |         color: #999999; | 
					
						
							|  |  |  |         font-weight: 500; | 
					
						
							|  |  |  |         margin-bottom: 16rpx; | 
					
						
							|  |  |  |     .empty-desc | 
					
						
							|  |  |  |         font-size: 28rpx; | 
					
						
							|  |  |  |         color: #CCCCCC; | 
					
						
							|  |  |  |         font-weight: 400; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | </style> |