| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     <view class="app-custom-root"> | 
					
						
							|  |  |  |         <view class="app-container"> | 
					
						
							|  |  |  |             <!-- 顶部头部区域 --> | 
					
						
							|  |  |  |             <view class="container-header"> | 
					
						
							|  |  |  |                 <view class="header-btnLf button-click" @click="changeType(0)" :class="{ active: state.current === 0 }"> | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |                     全部消息 | 
					
						
							|  |  |  |                     <!-- <view class="btns-wd"></view> --> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 </view> | 
					
						
							|  |  |  |                 <view class="header-btnLf button-click" @click="changeType(1)" :class="{ active: state.current === 1 }"> | 
					
						
							|  |  |  |                     未读消息 | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |                     <view class="btns-wd" v-if="unreadCount"></view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 </view> | 
					
						
							|  |  |  |             </view> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <!-- 主体内容区域 --> | 
					
						
							|  |  |  |             <view class="container-main"> | 
					
						
							|  |  |  |                 <swiper class="swiper" :current="state.current" @change="changeSwiperType"> | 
					
						
							|  |  |  |                     <swiper-item class="swiper-item" v-for="(_, index) in 2" :key="index"> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:42:17 +08:00
										 |  |  |                         <!-- #ifndef MP-WEIXIN --> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                         <component :is="components[index]" :ref="(el) => handelComponentsRef(el, index)" /> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:42:17 +08:00
										 |  |  |                         <!-- #endif --> | 
					
						
							|  |  |  |                         <!-- #ifdef MP-WEIXIN --> | 
					
						
							|  |  |  |                         <ReadComponent v-show="currentIndex === 0" :ref="(el) => handelComponentsRef(el, index)" /> | 
					
						
							|  |  |  |                         <UnreadComponent v-show="currentIndex === 1" :ref="(el) => handelComponentsRef(el, index)" /> | 
					
						
							|  |  |  |                         <!-- #endif --> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                     </swiper-item> | 
					
						
							|  |  |  |                 </swiper> | 
					
						
							|  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |             <Tabbar :currentpage="3"></Tabbar> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |     </view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  | <script setup> | 
					
						
							|  |  |  | import { reactive, inject, watch, ref, onMounted } from 'vue'; | 
					
						
							|  |  |  | import { onLoad, onShow } from '@dcloudio/uni-app'; | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  | import Tabbar from '@/components/tabbar/midell-box.vue'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:42:17 +08:00
										 |  |  | import ReadComponent from './read.vue'; | 
					
						
							|  |  |  | import UnreadComponent from './unread.vue'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | const loadedMap = reactive([false, false]); | 
					
						
							|  |  |  | const swiperRefs = [ref(null), ref(null)]; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:42:17 +08:00
										 |  |  | const components = [ReadComponent, UnreadComponent]; | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							|  |  |  | import { useReadMsg } from '@/stores/useReadMsg'; | 
					
						
							|  |  |  | const { unreadCount } = storeToRefs(useReadMsg()); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | onShow(() => { | 
					
						
							|  |  |  |     // 获取消息列表
 | 
					
						
							|  |  |  |     useReadMsg().fetchMessages(); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  | const state = reactive({ | 
					
						
							|  |  |  |     current: 0, | 
					
						
							|  |  |  |     all: [{}], | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | onMounted(() => { | 
					
						
							|  |  |  |     handleTabChange(state.current); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const handelComponentsRef = (el, index) => { | 
					
						
							|  |  |  |     if (el) { | 
					
						
							|  |  |  |         swiperRefs[index].value = el; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | // 查看消息类型
 | 
					
						
							|  |  |  | function changeSwiperType(e) { | 
					
						
							|  |  |  |     const index = e.detail.current; | 
					
						
							|  |  |  |     state.current = index; | 
					
						
							|  |  |  |     handleTabChange(index); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | function changeType(index) { | 
					
						
							|  |  |  |     state.current = index; | 
					
						
							|  |  |  |     handleTabChange(index); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function handleTabChange(index) { | 
					
						
							|  |  |  |     if (!loadedMap[index]) { | 
					
						
							|  |  |  |         swiperRefs[index].value?.loadData(); | 
					
						
							|  |  |  |         loadedMap[index] = true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // 查看消息类型
 | 
					
						
							|  |  |  | function changeSwiperMsgType(e) { | 
					
						
							|  |  |  |     const currented = e.detail.current; | 
					
						
							|  |  |  |     state.current = currented; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  | <style lang="stylus" scoped> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | .app-custom-root { | 
					
						
							|  |  |  |     position: fixed; | 
					
						
							|  |  |  |     z-index: 10; | 
					
						
							|  |  |  |     width: 100vw; | 
					
						
							|  |  |  |     height: calc(100% - var(--window-bottom)); | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .app-container { | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     height: 100%; | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |     .container-header { | 
					
						
							|  |  |  |         height: calc(88rpx - 14rpx); | 
					
						
							|  |  |  |         text-align: center; | 
					
						
							|  |  |  |         line-height: calc(88rpx - 14rpx); | 
					
						
							|  |  |  |         font-size: 32rpx; | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |         display: flex; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         flex-direction: row; | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |         align-items: center; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         padding: 16rpx 44rpx 36rpx 44rpx; | 
					
						
							|  |  |  |         background: url('@/static/icon/msgTopbg.png') 0 0 no-repeat; | 
					
						
							|  |  |  |         background-size: 100% 100%; | 
					
						
							|  |  |  |         .header-title { | 
					
						
							|  |  |  |             color: #000000; | 
					
						
							|  |  |  |             font-weight: bold; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         .header-btnLf { | 
					
						
							| 
									
										
										
										
											2025-07-09 15:15:37 +08:00
										 |  |  |             font-family: 'PingFangSC-Medium', 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, 'Microsoft YaHei', sans-serif; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             display: flex; | 
					
						
							|  |  |  |             justify-content: flex-start; | 
					
						
							|  |  |  |             align-items: center; | 
					
						
							|  |  |  |             width: calc(60rpx * 3); | 
					
						
							|  |  |  |             font-weight: 500; | 
					
						
							|  |  |  |             font-size: 40rpx; | 
					
						
							|  |  |  |             color: #696969; | 
					
						
							|  |  |  |             margin-right: 44rpx; | 
					
						
							|  |  |  |             position: relative; | 
					
						
							|  |  |  |             .btns-wd{ | 
					
						
							|  |  |  |                 position: absolute | 
					
						
							|  |  |  |                 top: 2rpx; | 
					
						
							|  |  |  |                 right: 2rpx | 
					
						
							|  |  |  |                 width: 16rpx; | 
					
						
							|  |  |  |                 height: 16rpx; | 
					
						
							|  |  |  |                 background: #F73636; | 
					
						
							|  |  |  |                 border-radius: 50%; | 
					
						
							|  |  |  |                 border: 4rpx solid #EEEEFF; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         .active { | 
					
						
							|  |  |  |             font-weight: 600; | 
					
						
							|  |  |  |             font-size: 40rpx; | 
					
						
							|  |  |  |             color: #000000; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .container-main { | 
					
						
							|  |  |  |     flex: 1; | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |     background-color: #f4f4f4; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .main-scroll { | 
					
						
							|  |  |  |     width: 100% | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .scrollmain{ | 
					
						
							|  |  |  |     padding: 28rpx | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .swiper | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  |     width: 100% | 
					
						
							|  |  |  |     .list | 
					
						
							|  |  |  |         width: 100% | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         flex-direction: column; | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | </style> |