| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  |     <view class="app-custom-root"> | 
					
						
							|  |  |  |         <view class="app-container"> | 
					
						
							|  |  |  |             <!-- 主体内容区域 --> | 
					
						
							|  |  |  |             <view class="container-main"> | 
					
						
							| 
									
										
										
										
											2025-09-29 11:53:10 +08:00
										 |  |  |                 <IndexOne @onShowTabbar="changeShowTabbar" /> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-07-09 15:15:37 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |             <!-- 自定义tabbar --> | 
					
						
							|  |  |  |             <CustomTabBar :currentPage="0" /> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |         </view> | 
					
						
							|  |  |  |     </view> | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script setup> | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | import { reactive, inject, watch, ref, onMounted } from 'vue'; | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | import { onLoad, onShow } from '@dcloudio/uni-app'; | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | import IndexOne from './components/index-one.vue'; | 
					
						
							| 
									
										
										
										
											2025-09-29 11:53:10 +08:00
										 |  |  | // import IndexTwo from './components/index-two.vue';
 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | import { useReadMsg } from '@/stores/useReadMsg'; | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  | import { tabbarManager } from '@/utils/tabbarManager'; | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | const { unreadCount } = storeToRefs(useReadMsg()); | 
					
						
							| 
									
										
										
										
											2025-07-09 15:15:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | onLoad(() => { | 
					
						
							| 
									
										
										
										
											2025-10-17 13:15:14 +08:00
										 |  |  |     // useReadMsg().fetchMessages();
 | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | onShow(() => { | 
					
						
							|  |  |  |     // 更新自定义tabbar选中状态
 | 
					
						
							|  |  |  |     tabbarManager.updateSelected(0); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | </script> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | <style lang="stylus" scoped> | 
					
						
							|  |  |  | .app-custom-root { | 
					
						
							|  |  |  |     position: fixed; | 
					
						
							|  |  |  |     z-index: 10; | 
					
						
							|  |  |  |     width: 100vw; | 
					
						
							|  |  |  |     height: calc(100% - var(--window-bottom)); | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | .app-container { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |     .container-header { | 
					
						
							|  |  |  |         height: calc(88rpx - 14rpx); | 
					
						
							|  |  |  |         text-align: center; | 
					
						
							|  |  |  |         line-height: calc(88rpx - 14rpx); | 
					
						
							|  |  |  |         font-size: 32rpx; | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         flex-direction: row; | 
					
						
							|  |  |  |         align-items: center; | 
					
						
							|  |  |  |         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; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  |         .header-btnLf { | 
					
						
							|  |  |  |             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; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  |         .active { | 
					
						
							|  |  |  |             font-weight: 600; | 
					
						
							|  |  |  |             font-size: 40rpx; | 
					
						
							|  |  |  |             color: #000000; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | .container-main { | 
					
						
							|  |  |  |     flex: 1; | 
					
						
							|  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |     background-color: #f4f4f4; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | .main-scroll { | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |     width: 100% | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  |     height: 100%; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2025-06-20 22:03:24 +08:00
										 |  |  | .scrollmain{ | 
					
						
							|  |  |  |     padding: 28rpx | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .swiper | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  |     width: 100% | 
					
						
							|  |  |  |     .list | 
					
						
							|  |  |  |         width: 100% | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         flex-direction: column; | 
					
						
							| 
									
										
										
										
											2025-07-09 15:15:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // mask:
 | 
					
						
							|  |  |  | .maskFristEntry | 
					
						
							|  |  |  |     position: fixed; | 
					
						
							|  |  |  |     // right: 20rpx;
 | 
					
						
							|  |  |  |     // bottom: calc(50% - 200rpx);
 | 
					
						
							|  |  |  |     height: 100vh | 
					
						
							|  |  |  |     width: 100vw | 
					
						
							|  |  |  |     background: rgba(0,0,0,0.3) | 
					
						
							|  |  |  |     .entry-content | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         align-items: center | 
					
						
							|  |  |  |         position: absolute | 
					
						
							|  |  |  |         left: 50% | 
					
						
							|  |  |  |         top: 35% | 
					
						
							|  |  |  |         transform: translate(-50%, -50%) | 
					
						
							|  |  |  |         flex-direction: column | 
					
						
							|  |  |  |         background: url('@/static/imgs/fristEntry.png') 0 0 no-repeat; | 
					
						
							|  |  |  |         background-size: 100% 100%; | 
					
						
							|  |  |  |         width: 480rpx | 
					
						
							|  |  |  |         height: 584rpx | 
					
						
							|  |  |  |         // padding-left: 80rpx
 | 
					
						
							|  |  |  |         .text1 | 
					
						
							|  |  |  |             font-family: 'PingFangSC-Medium', 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, 'Microsoft YaHei', sans-serif; | 
					
						
							|  |  |  |             margin-top: 370rpx | 
					
						
							|  |  |  |             font-size: 36rpx | 
					
						
							|  |  |  |             background: linear-gradient(273.34deg, #356CFA 3.58%, #A47FFD 85.84%); | 
					
						
							|  |  |  |             -webkit-background-clip: text; | 
					
						
							|  |  |  |             -webkit-text-fill-color: transparent; | 
					
						
							|  |  |  |             background-clip: text; /* 有些浏览器兼容用 */ | 
					
						
							|  |  |  |             text-fill-color: transparent; | 
					
						
							|  |  |  |             padding-left: 28rpx | 
					
						
							|  |  |  |         .text2 | 
					
						
							|  |  |  |             padding-left: 28rpx | 
					
						
							|  |  |  |             margin-top: 8rpx | 
					
						
							|  |  |  |             font-size: 20rpx; | 
					
						
							|  |  |  |             color: #666666; | 
					
						
							|  |  |  |             text-align: center; | 
					
						
							|  |  |  |         .indicateArrow | 
					
						
							|  |  |  |             height: 76rpx | 
					
						
							|  |  |  |             width: 68rpx | 
					
						
							|  |  |  |         .indicatefristEntry | 
					
						
							|  |  |  |             width: 244rpx | 
					
						
							|  |  |  |             height: 244rpx | 
					
						
							|  |  |  |         .goExperience | 
					
						
							|  |  |  |             font-family: 'PingFangSC-Medium', 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, 'Microsoft YaHei', sans-serif; | 
					
						
							|  |  |  |             margin-left: 28rpx | 
					
						
							|  |  |  |             margin-top: 28rpx | 
					
						
							|  |  |  |             width: 160rpx; | 
					
						
							|  |  |  |             height: 60rpx; | 
					
						
							|  |  |  |             background: linear-gradient( 180deg, #9974FD 0%, #286BFA 100%); | 
					
						
							|  |  |  |             border-radius: 12rpx 12rpx 12rpx 12rpx; | 
					
						
							|  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |             color: #FFFFFF; | 
					
						
							|  |  |  |             text-align: center; | 
					
						
							|  |  |  |             line-height: 60rpx | 
					
						
							|  |  |  |         .maskFristEntry-Close | 
					
						
							|  |  |  |             position: absolute; | 
					
						
							|  |  |  |             left: calc(50% - 10rpx); | 
					
						
							|  |  |  |             bottom: -130rpx | 
					
						
							|  |  |  |             width: 42rpx | 
					
						
							|  |  |  |             height: 42rpx | 
					
						
							|  |  |  |             background: linear-gradient(273.34deg, #356CFA 3.58%, #A47FFD 85.84%); | 
					
						
							|  |  |  |             border-radius: 50%; | 
					
						
							|  |  |  |         .maskFristEntry-Close::before | 
					
						
							|  |  |  |             position: absolute; | 
					
						
							|  |  |  |             left: calc( 50% - 2rpx) | 
					
						
							|  |  |  |             top: calc( 50% - 10rpx) | 
					
						
							|  |  |  |             transform: rotate(45deg); | 
					
						
							|  |  |  |             content: '' | 
					
						
							|  |  |  |             background: #FFFFFF | 
					
						
							|  |  |  |             width: 4rpx | 
					
						
							|  |  |  |             height: 20rpx | 
					
						
							|  |  |  |         .maskFristEntry-Close::after | 
					
						
							|  |  |  |             position: absolute; | 
					
						
							|  |  |  |             left: calc( 50% - 2rpx) | 
					
						
							|  |  |  |             top: calc( 50% - 10rpx) | 
					
						
							|  |  |  |             transform: rotate(-45deg); | 
					
						
							|  |  |  |             content: '' | 
					
						
							|  |  |  |             background: #FFFFFF | 
					
						
							|  |  |  |             width: 4rpx | 
					
						
							|  |  |  |             height: 20rpx | 
					
						
							| 
									
										
										
										
											2025-05-16 09:28:44 +08:00
										 |  |  | </style> |