| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  | <template> | 
					
						
							|  |  |  |  |     <view class="tabbar_container"> | 
					
						
							|  |  |  |  |         <view class="tabbar_item" v-for="(item, index) in tabbarList" :key="index" @click="changeItem(item)"> | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  |  |             <view | 
					
						
							|  |  |  |  |                 class="item-top" | 
					
						
							|  |  |  |  |                 :class="[ | 
					
						
							|  |  |  |  |                     item.centerItem ? 'center-item-img ' : '', | 
					
						
							|  |  |  |  |                     item.centerItem && currentItem === item.id ? 'rubberBand animated' : '', | 
					
						
							|  |  |  |  |                 ]" | 
					
						
							|  |  |  |  |             > | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  |                 <image :src="currentItem == item.id ? item.selectedIconPath : item.iconPath"></image> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             <view class="badge" v-if="item.badge && item.badge > 0">{{ item.badge }}</view> | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  |             <view class="item-bottom" :class="[currentItem == item.id ? 'item-active' : '']"> | 
					
						
							|  |  |  |  |                 <text>{{ item.text }}</text> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |     </view> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | <script setup> | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  | import { ref, onMounted, computed, watch, nextTick } from 'vue'; | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | import { useReadMsg } from '@/stores/useReadMsg'; | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							|  |  |  |  | import useUserStore from '@/stores/useUserStore'; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | const props = defineProps({ | 
					
						
							|  |  |  |  |     currentpage: { | 
					
						
							|  |  |  |  |         type: Number, | 
					
						
							|  |  |  |  |         required: true, | 
					
						
							|  |  |  |  |         default: 0, | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | const readMsg = useReadMsg(); | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  | const { userInfo } = storeToRefs(useUserStore()); | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | const currentItem = ref(0); | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  | // 监听用户类型变化,重新生成tabbar配置
 | 
					
						
							|  |  |  |  | watch(() => userInfo.value?.isCompanyUser, (newIsCompanyUser, oldIsCompanyUser) => { | 
					
						
							|  |  |  |  |     console.log('midell-box用户类型变化监听:', { newIsCompanyUser, oldIsCompanyUser, userInfo: userInfo.value }); | 
					
						
							|  |  |  |  |     if (newIsCompanyUser !== oldIsCompanyUser) { | 
					
						
							|  |  |  |  |         console.log('用户类型发生变化,重新生成tabbar:', newIsCompanyUser); | 
					
						
							|  |  |  |  |         // tabbarList是computed,会自动重新计算
 | 
					
						
							|  |  |  |  |         // 强制触发响应式更新
 | 
					
						
							|  |  |  |  |         nextTick(() => { | 
					
						
							|  |  |  |  |             console.log('tabbar配置已更新:', tabbarList.value); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | }, { immediate: true }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 监听用户信息变化(包括登录状态)
 | 
					
						
							|  |  |  |  | watch(() => userInfo.value, (newUserInfo, oldUserInfo) => { | 
					
						
							|  |  |  |  |     console.log('midell-box用户信息变化监听:', { newUserInfo, oldUserInfo }); | 
					
						
							|  |  |  |  |     if (newUserInfo !== oldUserInfo) { | 
					
						
							|  |  |  |  |         console.log('用户信息发生变化,重新生成tabbar'); | 
					
						
							|  |  |  |  |         // 强制触发响应式更新
 | 
					
						
							|  |  |  |  |         nextTick(() => { | 
					
						
							|  |  |  |  |             console.log('tabbar配置已更新:', tabbarList.value); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | }, { immediate: true, deep: true }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 生成tabbar配置的函数
 | 
					
						
							|  |  |  |  | const generateTabbarList = () => { | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |     const baseItems = [ | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             id: 0, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             text: '职位2', | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |             path: '/pages/index/index', | 
					
						
							|  |  |  |  |             iconPath: '../../static/tabbar/calendar.png', | 
					
						
							|  |  |  |  |             selectedIconPath: '../../static/tabbar/calendared.png', | 
					
						
							|  |  |  |  |             centerItem: false, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             badge: readMsg.badges[0]?.count || 0, | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             id: 2, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             text: 'AI+', | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |             path: '/pages/chat/chat', | 
					
						
							|  |  |  |  |             iconPath: '../../static/tabbar/logo3.png', | 
					
						
							|  |  |  |  |             selectedIconPath: '../../static/tabbar/logo3.png', | 
					
						
							|  |  |  |  |             centerItem: true, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             badge: readMsg.badges[2]?.count || 0, | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             id: 3, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             text: '消息2', | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |             path: '/pages/msglog/msglog', | 
					
						
							|  |  |  |  |             iconPath: '../../static/tabbar/chat4.png', | 
					
						
							|  |  |  |  |             selectedIconPath: '../../static/tabbar/chat4ed.png', | 
					
						
							|  |  |  |  |             centerItem: false, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             badge: readMsg.badges[3]?.count || 0, | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             id: 4, | 
					
						
							|  |  |  |  |             text: '我的', | 
					
						
							|  |  |  |  |             path: '/pages/mine/mine', | 
					
						
							|  |  |  |  |             iconPath: '../../static/tabbar/mine.png', | 
					
						
							|  |  |  |  |             selectedIconPath: '../../static/tabbar/mined.png', | 
					
						
							|  |  |  |  |             centerItem: false, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             badge: readMsg.badges[4]?.count || 0, | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         }, | 
					
						
							|  |  |  |  |     ]; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |     // 根据用户类型添加不同的导航项,未登录时默认为求职者
 | 
					
						
							|  |  |  |  |     const userType = userInfo.value?.isCompanyUser !== undefined ? userInfo.value.isCompanyUser : 1; | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |      | 
					
						
							|  |  |  |  |     if (userType === 0) { | 
					
						
							|  |  |  |  |         // 企业用户:显示发布岗位,隐藏招聘会
 | 
					
						
							|  |  |  |  |         baseItems.splice(1, 0, { | 
					
						
							|  |  |  |  |             id: 1, | 
					
						
							|  |  |  |  |             text: '发布岗位', | 
					
						
							|  |  |  |  |             path: '/pages/job/publishJob', | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             iconPath: '../../static/tabbar/post.png', | 
					
						
							|  |  |  |  |             selectedIconPath: '../../static/tabbar/posted.png', | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |             centerItem: false, | 
					
						
							|  |  |  |  |             badge: 0, | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |         // 求职者用户(包括未登录状态):显示招聘会
 | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         baseItems.splice(1, 0, { | 
					
						
							|  |  |  |  |             id: 1, | 
					
						
							|  |  |  |  |             text: '招聘会', | 
					
						
							|  |  |  |  |             path: '/pages/careerfair/careerfair', | 
					
						
							|  |  |  |  |             iconPath: '../../static/tabbar/post.png', | 
					
						
							|  |  |  |  |             selectedIconPath: '../../static/tabbar/posted.png', | 
					
						
							|  |  |  |  |             centerItem: false, | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             badge: readMsg.badges[1]?.count || 0, | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         }); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     return baseItems; | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 根据用户类型生成不同的导航栏配置
 | 
					
						
							|  |  |  |  | const tabbarList = computed(() => { | 
					
						
							|  |  |  |  |     return generateTabbarList(); | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | onMounted(() => { | 
					
						
							| 
									
										
										
										
											2025-10-20 11:05:11 +08:00
										 |  |  |  |     // 自定义TabBar不需要调用hideTabBar,因为已经在pages.json中设置了custom: true
 | 
					
						
							|  |  |  |  |     // uni.hideTabBar(); // 移除这行,避免在自定义TabBar模式下调用
 | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  |     currentItem.value = props.currentpage; | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | const changeItem = (item) => { | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  |     // 判断是否为 TabBar 页面
 | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |     const tabBarPages = [ | 
					
						
							|  |  |  |  |         '/pages/index/index', | 
					
						
							|  |  |  |  |         '/pages/careerfair/careerfair',  | 
					
						
							|  |  |  |  |         '/pages/chat/chat', | 
					
						
							|  |  |  |  |         '/pages/msglog/msglog', | 
					
						
							|  |  |  |  |         '/pages/mine/mine' | 
					
						
							|  |  |  |  |     ]; | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     if (tabBarPages.includes(item.path)) { | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  |         // TabBar 页面使用 redirectTo 避免页面栈溢出
 | 
					
						
							|  |  |  |  |         uni.redirectTo({ | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |             url: item.path, | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  |         // 非 TabBar 页面使用 navigateTo
 | 
					
						
							| 
									
										
										
										
											2025-10-16 16:44:30 +08:00
										 |  |  |  |         uni.navigateTo({ | 
					
						
							|  |  |  |  |             url: item.path, | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  | }; | 
					
						
							|  |  |  |  | </script> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <style lang="scss" scoped> | 
					
						
							| 
									
										
										
										
											2025-07-21 14:49:45 +08:00
										 |  |  |  | .badge { | 
					
						
							|  |  |  |  |     position: absolute; | 
					
						
							|  |  |  |  |     top: 4rpx; | 
					
						
							|  |  |  |  |     right: 20rpx; | 
					
						
							|  |  |  |  |     min-width: 30rpx; | 
					
						
							|  |  |  |  |     height: 30rpx; | 
					
						
							|  |  |  |  |     background-color: red; | 
					
						
							|  |  |  |  |     color: #fff; | 
					
						
							|  |  |  |  |     font-size: 18rpx; | 
					
						
							|  |  |  |  |     border-radius: 15rpx; | 
					
						
							|  |  |  |  |     text-align: center; | 
					
						
							|  |  |  |  |     line-height: 30rpx; | 
					
						
							|  |  |  |  |     padding: 0 10rpx; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  | .tabbar_container { | 
					
						
							|  |  |  |  |     background-color: #ffffff; | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  |  |     height: 88rpx; | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     align-items: center; | 
					
						
							|  |  |  |  |     padding: 5rpx 0; | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |  |     // position: fixed;
 | 
					
						
							|  |  |  |  |     // bottom: 0rpx;
 | 
					
						
							|  |  |  |  |     // left: 0rpx;
 | 
					
						
							|  |  |  |  |     // box-shadow: 0 0 5px #999;
 | 
					
						
							|  |  |  |  |     // padding-bottom: env(safe-area-inset-bottom);
 | 
					
						
							|  |  |  |  |     // z-index: 998;
 | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  |     .tabbar_item { | 
					
						
							|  |  |  |  |         width: 33.33%; | 
					
						
							|  |  |  |  |         height: 100rpx; | 
					
						
							|  |  |  |  |         display: flex; | 
					
						
							|  |  |  |  |         flex-direction: column; | 
					
						
							|  |  |  |  |         justify-content: center; | 
					
						
							|  |  |  |  |         align-items: center; | 
					
						
							|  |  |  |  |         text-align: center; | 
					
						
							|  |  |  |  |         position: relative; | 
					
						
							|  |  |  |  |         color: #5e5f60; | 
					
						
							|  |  |  |  |         .item-top { | 
					
						
							|  |  |  |  |             width: 44.44rpx; | 
					
						
							|  |  |  |  |             height: 44.44rpx; | 
					
						
							|  |  |  |  |             image { | 
					
						
							|  |  |  |  |                 width: 100%; | 
					
						
							|  |  |  |  |                 height: 100%; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .item-bottom { | 
					
						
							|  |  |  |  |             font-weight: 500; | 
					
						
							|  |  |  |  |             font-size: 22rpx; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | .center-item-img { | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  |  |     // position: absolute;
 | 
					
						
							|  |  |  |  |     // top: 0rpx;
 | 
					
						
							|  |  |  |  |     // left: 50%;
 | 
					
						
							|  |  |  |  |     // transform: translate(-50%, 0);
 | 
					
						
							|  |  |  |  |     width: 108rpx !important; | 
					
						
							|  |  |  |  |     height: 98rpx !important; | 
					
						
							| 
									
										
										
										
											2025-04-10 10:59:25 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | .item-active { | 
					
						
							|  |  |  |  |     color: #256bfa; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | </style> |