| 
									
										
										
										
											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-top"> | 
					
						
							|  |  |  |  |                     <view class="header-btnLf button-click" @click="seemsg(0)" :class="{ active: state.current === 0 }"> | 
					
						
							|  |  |  |  |                         现场招聘 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                     <view class="header-btnLf button-click" @click="seemsg(1)" :class="{ active: state.current === 1 }"> | 
					
						
							|  |  |  |  |                         VR虚拟招聘会 | 
					
						
							|  |  |  |  |                     </view> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <view class="header-input btn-feel"> | 
					
						
							|  |  |  |  |                     <uni-icons class="iconsearch" color="#666666" type="search" size="18"></uni-icons> | 
					
						
							|  |  |  |  |                     <input class="input" placeholder="招聘会" placeholder-class="inputplace" /> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <view class="header-date"> | 
					
						
							|  |  |  |  |                     <view class="data-week"> | 
					
						
							|  |  |  |  |                         <view | 
					
						
							|  |  |  |  |                             class="weel-days button-click" | 
					
						
							|  |  |  |  |                             :class="{ active: currentDay.fullDate === item.fullDate }" | 
					
						
							|  |  |  |  |                             v-for="(item, index) in weekList" | 
					
						
							|  |  |  |  |                             :key="index" | 
					
						
							|  |  |  |  |                             @click="selectDate(item)" | 
					
						
							|  |  |  |  |                         > | 
					
						
							|  |  |  |  |                             <view class="label">{{ item.day }}</view> | 
					
						
							|  |  |  |  |                             <view class="day">{{ item.date }}</view> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                         </view> | 
					
						
							|  |  |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                     <view class="data-all"> | 
					
						
							|  |  |  |  |                         <image class="allimg button-click" @click="toSelectDate" src="/static/icon/date1.png"></image> | 
					
						
							|  |  |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                 </view> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |             <!-- 主体内容区域 --> | 
					
						
							|  |  |  |  |             <view class="container-main"> | 
					
						
							|  |  |  |  |                 <scroll-view scroll-y class="main-scroll" @scrolltolower="handleScrollToLower"> | 
					
						
							|  |  |  |  |                     <view class="cards" v-if="fairList.length"> | 
					
						
							|  |  |  |  |                         <view | 
					
						
							| 
									
										
										
										
											2025-06-26 08:56:42 +08:00
										 |  |  |  |                             class="card press-button" | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                             v-for="(item, index) in fairList" | 
					
						
							|  |  |  |  |                             :key="index" | 
					
						
							|  |  |  |  |                             @click="navTo('/packageA/pages/exhibitors/exhibitors?jobFairId=' + item.jobFairId)" | 
					
						
							|  |  |  |  |                         > | 
					
						
							|  |  |  |  |                             <view class="card-title">{{ item.name }}</view> | 
					
						
							|  |  |  |  |                             <view class="card-row"> | 
					
						
							|  |  |  |  |                                 <text class="">{{ item.location }}</text> | 
					
						
							|  |  |  |  |                                 <text class=""> | 
					
						
							|  |  |  |  |                                     <convert-distance | 
					
						
							|  |  |  |  |                                         :alat="item.latitude" | 
					
						
							|  |  |  |  |                                         :along="item.longitude" | 
					
						
							|  |  |  |  |                                         :blat="latitudeVal" | 
					
						
							|  |  |  |  |                                         :blong="longitudeVal" | 
					
						
							|  |  |  |  |                                     ></convert-distance> | 
					
						
							|  |  |  |  |                                 </text> | 
					
						
							|  |  |  |  |                             </view> | 
					
						
							|  |  |  |  |                             <view class="card-times"> | 
					
						
							|  |  |  |  |                                 <view class="time-left"> | 
					
						
							|  |  |  |  |                                     <view class="left-date">{{ parseDateTime(item.startTime).time }}</view> | 
					
						
							|  |  |  |  |                                     <view class="left-dateDay">{{ parseDateTime(item.startTime).date }}</view> | 
					
						
							|  |  |  |  |                                 </view> | 
					
						
							|  |  |  |  |                                 <view class="line"></view> | 
					
						
							|  |  |  |  |                                 <view class="time-center"> | 
					
						
							|  |  |  |  |                                     <view class="center-date"> | 
					
						
							|  |  |  |  |                                         {{ getTimeStatus(item.startTime, item.endTime).statusText }} | 
					
						
							|  |  |  |  |                                     </view> | 
					
						
							|  |  |  |  |                                     <view class="center-dateDay"> | 
					
						
							|  |  |  |  |                                         {{ getHoursBetween(item.startTime, item.endTime) }}小时 | 
					
						
							|  |  |  |  |                                     </view> | 
					
						
							|  |  |  |  |                                 </view> | 
					
						
							|  |  |  |  |                                 <view class="line"></view> | 
					
						
							|  |  |  |  |                                 <view class="time-right"> | 
					
						
							|  |  |  |  |                                     <view class="left-date">{{ parseDateTime(item.endTime).time }}</view> | 
					
						
							|  |  |  |  |                                     <view class="left-dateDay">{{ parseDateTime(item.endTime).date }}</view> | 
					
						
							|  |  |  |  |                                 </view> | 
					
						
							|  |  |  |  |                             </view> | 
					
						
							|  |  |  |  |                             <view class="recommend-card-line"></view> | 
					
						
							|  |  |  |  |                             <view class="card-footer">内容简介:{{ item.description }}</view> | 
					
						
							|  |  |  |  |                         </view> | 
					
						
							|  |  |  |  |                     </view> | 
					
						
							|  |  |  |  |                     <empty v-else pdTop="200"></empty> | 
					
						
							|  |  |  |  |                 </scroll-view> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  |             <!-- 自定义tabbar --> | 
					
						
							|  |  |  |  |             <CustomTabBar :currentPage="1" /> | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  |              | 
					
						
							|  |  |  |  |             <!-- 微信授权登录弹窗 --> | 
					
						
							|  |  |  |  |             <WxAuthLogin ref="wxAuthLoginRef" @success="handleLoginSuccess"></WxAuthLogin> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  |     </view> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | <script setup> | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  | import { reactive, inject, watch, ref, onMounted, onUnmounted } from 'vue'; | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | import { onLoad, onShow } from '@dcloudio/uni-app'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | import useLocationStore from '@/stores/useLocationStore'; | 
					
						
							|  |  |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  | import { tabbarManager } from '@/utils/tabbarManager'; | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  | import WxAuthLogin from '@/components/WxAuthLogin/WxAuthLogin.vue'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | const { longitudeVal, latitudeVal } = storeToRefs(useLocationStore()); | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  | const wxAuthLoginRef = ref(null); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | const { $api, navTo, cloneDeep } = inject('globalFunction'); | 
					
						
							|  |  |  |  | const weekList = ref([]); | 
					
						
							|  |  |  |  | const fairList = ref([]); | 
					
						
							|  |  |  |  | const currentDay = ref({}); | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | const state = reactive({ | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     current: 0, | 
					
						
							|  |  |  |  |     all: [{}], | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | const pageState = reactive({ | 
					
						
							|  |  |  |  |     page: 0, | 
					
						
							|  |  |  |  |     total: 0, | 
					
						
							|  |  |  |  |     maxPage: 2, | 
					
						
							|  |  |  |  |     pageSize: 10, | 
					
						
							|  |  |  |  |     search: {}, | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | onLoad(() => { | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |  |     const today = new Date(); | 
					
						
							|  |  |  |  |     const year = today.getFullYear(); | 
					
						
							|  |  |  |  |     const month = String(today.getMonth() + 1).padStart(2, '0'); | 
					
						
							|  |  |  |  |     const day = String(today.getDate()).padStart(2, '0'); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     const currentDate = `${year}-${month}-${day}`; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     const result = getNextDates({ | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |  |         startDate: currentDate, | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     }); | 
					
						
							|  |  |  |  |     weekList.value = result; | 
					
						
							|  |  |  |  |     getFair('refresh'); | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-03-29 12:06:35 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-23 17:16:16 +08:00
										 |  |  |  | onShow(() => { | 
					
						
							|  |  |  |  |     // 更新自定义tabbar选中状态
 | 
					
						
							|  |  |  |  |     tabbarManager.updateSelected(1); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-24 16:54:52 +08:00
										 |  |  |  | onMounted(() => { | 
					
						
							|  |  |  |  |     // 监听退出登录事件,显示微信登录弹窗
 | 
					
						
							|  |  |  |  |     uni.$on('showLoginModal', () => { | 
					
						
							|  |  |  |  |         wxAuthLoginRef.value?.open(); | 
					
						
							|  |  |  |  |     }); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | onUnmounted(() => { | 
					
						
							|  |  |  |  |     uni.$off('showLoginModal'); | 
					
						
							|  |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 登录成功回调
 | 
					
						
							|  |  |  |  | const handleLoginSuccess = () => { | 
					
						
							|  |  |  |  |     console.log('登录成功'); | 
					
						
							|  |  |  |  |     // 可以在这里添加登录成功后的处理逻辑
 | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function toSelectDate() { | 
					
						
							|  |  |  |  |     navTo('/packageA/pages/selectDate/selectDate', { | 
					
						
							|  |  |  |  |         query: { | 
					
						
							|  |  |  |  |             date: currentDay.value.fullDate, | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         onBack: (res) => { | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |  |             console.log(res); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             const result = getNextDates({ | 
					
						
							|  |  |  |  |                 startDate: res.date, | 
					
						
							|  |  |  |  |             }); | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |  |             const formattedDate = res.date.slice(5); // MM-DD
 | 
					
						
							|  |  |  |  |             const dateFull = { | 
					
						
							|  |  |  |  |                 date: res.date.slice(5), | 
					
						
							|  |  |  |  |                 day: '周' + res.week, | 
					
						
							|  |  |  |  |                 fullDate: res.date, | 
					
						
							|  |  |  |  |             }; | 
					
						
							|  |  |  |  |             currentDay.value = dateFull; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             weekList.value = result; | 
					
						
							|  |  |  |  |             getFair('refresh'); | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |     }); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | // 查看消息类型
 | 
					
						
							|  |  |  |  | function changeSwiperMsgType(e) { | 
					
						
							|  |  |  |  |     const currented = e.detail.current; | 
					
						
							|  |  |  |  |     state.current = currented; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function seemsg(index) { | 
					
						
							|  |  |  |  |     if (index === 1) { | 
					
						
							|  |  |  |  |         return $api.msg('功能确定中'); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     state.current = index; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | const handleScrollToLower = () => { | 
					
						
							|  |  |  |  |     getFair(); | 
					
						
							|  |  |  |  |     console.log('触底'); | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function getFair(type = 'add') { | 
					
						
							|  |  |  |  |     if (type === 'refresh') { | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |  |         pageState.page = 1; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         pageState.maxPage = 1; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     if (type === 'add' && pageState.page < pageState.maxPage) { | 
					
						
							|  |  |  |  |         pageState.page += 1; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     let params = { | 
					
						
							|  |  |  |  |         ...pageState.search, | 
					
						
							|  |  |  |  |         current: pageState.page, | 
					
						
							|  |  |  |  |         pageSize: pageState.pageSize, | 
					
						
							|  |  |  |  |     }; | 
					
						
							|  |  |  |  |     if (currentDay.value?.fullDate) { | 
					
						
							|  |  |  |  |         params.queryDate = currentDay.value.fullDate; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     $api.createRequest('/app/fair', params).then((resData) => { | 
					
						
							|  |  |  |  |         const { rows, total } = resData; | 
					
						
							|  |  |  |  |         console.log(rows); | 
					
						
							|  |  |  |  |         if (type === 'add') { | 
					
						
							|  |  |  |  |             const str = pageState.pageSize * (pageState.page - 1); | 
					
						
							|  |  |  |  |             const end = fairList.value.length; | 
					
						
							|  |  |  |  |             const reslist = rows; | 
					
						
							|  |  |  |  |             fairList.value.splice(str, end, ...reslist); | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |             fairList.value = rows; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         // pageState.list = resData.rows;
 | 
					
						
							|  |  |  |  |         pageState.total = resData.total; | 
					
						
							|  |  |  |  |         pageState.maxPage = Math.ceil(pageState.total / pageState.pageSize); | 
					
						
							|  |  |  |  |     }); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function parseDateTime(datetimeStr) { | 
					
						
							|  |  |  |  |     if (!datetimeStr) return { time: '', date: '' }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     const dateObj = new Date(datetimeStr); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     if (isNaN(dateObj.getTime())) return { time: '', date: '' }; // 无效时间
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     const year = dateObj.getFullYear(); | 
					
						
							|  |  |  |  |     const month = String(dateObj.getMonth() + 1).padStart(2, '0'); | 
					
						
							|  |  |  |  |     const day = String(dateObj.getDate()).padStart(2, '0'); | 
					
						
							|  |  |  |  |     const hours = String(dateObj.getHours()).padStart(2, '0'); | 
					
						
							|  |  |  |  |     const minutes = String(dateObj.getMinutes()).padStart(2, '0'); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     return { | 
					
						
							|  |  |  |  |         time: `${hours}:${minutes}`, | 
					
						
							|  |  |  |  |         date: `${year}年${month}月${day}日`, | 
					
						
							|  |  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2025-03-29 11:51:48 +08:00
										 |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function getTimeStatus(startTimeStr, endTimeStr) { | 
					
						
							|  |  |  |  |     const now = new Date(); | 
					
						
							|  |  |  |  |     const startTime = new Date(startTimeStr); | 
					
						
							|  |  |  |  |     const endTime = new Date(endTimeStr); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     // 判断状态:0 开始中,1 过期,2 待开始
 | 
					
						
							|  |  |  |  |     let status = 0; | 
					
						
							|  |  |  |  |     let statusText = '开始中'; | 
					
						
							|  |  |  |  |     if (now < startTime) { | 
					
						
							|  |  |  |  |         status = 2; // 待开始
 | 
					
						
							|  |  |  |  |         statusText = '待开始'; | 
					
						
							|  |  |  |  |     } else if (now > endTime) { | 
					
						
							|  |  |  |  |         status = 1; // 已过期
 | 
					
						
							|  |  |  |  |         statusText = '已过期'; | 
					
						
							|  |  |  |  |     } else { | 
					
						
							|  |  |  |  |         status = 0; // 进行中
 | 
					
						
							|  |  |  |  |         statusText = '进行中'; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     return { | 
					
						
							|  |  |  |  |         status, // 0: 进行中,1: 已过期,2: 待开始
 | 
					
						
							|  |  |  |  |         statusText, | 
					
						
							|  |  |  |  |     }; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function getHoursBetween(startTimeStr, endTimeStr) { | 
					
						
							|  |  |  |  |     const start = new Date(startTimeStr); | 
					
						
							|  |  |  |  |     const end = new Date(endTimeStr); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     const diffMs = end - start; | 
					
						
							|  |  |  |  |     const diffHours = diffMs / (1000 * 60 * 60); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     return +diffHours.toFixed(2); // 保留 2 位小数
 | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | const selectDate = (item) => { | 
					
						
							|  |  |  |  |     if (currentDay.value?.fullDate === item.fullDate) { | 
					
						
							|  |  |  |  |         currentDay.value = {}; | 
					
						
							|  |  |  |  |         getFair('refresh'); | 
					
						
							|  |  |  |  |         return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     currentDay.value = item; | 
					
						
							|  |  |  |  |     getFair('refresh'); | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function getNextDates({ startDate = '', count = 6 }) { | 
					
						
							|  |  |  |  |     const baseDate = startDate ? new Date(startDate) : new Date(); // 指定起点或今天
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |     const dates = []; | 
					
						
							|  |  |  |  |     const dayNames = ['日', '一', '二', '三', '四', '五', '六']; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     for (let i = 0; i < count; i++) { | 
					
						
							|  |  |  |  |         const date = new Date(baseDate); | 
					
						
							|  |  |  |  |         date.setDate(baseDate.getDate() + i); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         const fullDate = date.toISOString().slice(0, 10); // YYYY-MM-DD
 | 
					
						
							|  |  |  |  |         const formattedDate = fullDate.slice(5); // MM-DD
 | 
					
						
							|  |  |  |  |         const dayOfWeek = dayNames[date.getDay()]; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |         dates.push({ | 
					
						
							|  |  |  |  |             date: formattedDate, | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             fullDate, | 
					
						
							|  |  |  |  |             day: '周' + dayOfWeek, | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     // 可选设置默认选中项
 | 
					
						
							|  |  |  |  |     // currentDay.value = dates[0];
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |     return dates; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											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 { | 
					
						
							|  |  |  |  |         background: url('@/static/icon/background2.png') 0 0 no-repeat; | 
					
						
							|  |  |  |  |         background-size: 100% 400rpx; | 
					
						
							|  |  |  |  |         .header-top{ | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |             display: flex; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             line-height: calc(88rpx - 14rpx); | 
					
						
							|  |  |  |  |             padding: 16rpx 44rpx 14rpx 44rpx; | 
					
						
							|  |  |  |  |             .header-btnLf { | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                 display: flex; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 width: fit-content; | 
					
						
							|  |  |  |  |                 white-space: nowrap | 
					
						
							|  |  |  |  |                 justify-content: flex-start; | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                 align-items: center; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 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; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .header-input{ | 
					
						
							|  |  |  |  |             padding: 0 24rpx | 
					
						
							|  |  |  |  |             width: calc(100% - 48rpx); | 
					
						
							|  |  |  |  |             position: relative | 
					
						
							|  |  |  |  |             .iconsearch{ | 
					
						
							|  |  |  |  |                 position: absolute | 
					
						
							|  |  |  |  |                 left: 50rpx; | 
					
						
							|  |  |  |  |                 top: 50% | 
					
						
							|  |  |  |  |                 transform: translate(0, -50%) | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             .input{ | 
					
						
							|  |  |  |  |                 padding: 0 30rpx 0 80rpx | 
					
						
							|  |  |  |  |                 height: 80rpx; | 
					
						
							|  |  |  |  |                 background: #FFFFFF; | 
					
						
							|  |  |  |  |                 border-radius: 75rpx 75rpx 75rpx 75rpx; | 
					
						
							|  |  |  |  |                 font-size: 28rpx; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             .inputplace{ | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                 font-weight: 400; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 font-size: 28rpx; | 
					
						
							|  |  |  |  |                 color: #B5B5B5; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .header-date{ | 
					
						
							|  |  |  |  |             padding: 28rpx | 
					
						
							|  |  |  |  |             display: flex | 
					
						
							|  |  |  |  |             justify-content: space-between | 
					
						
							|  |  |  |  |             align-items: center | 
					
						
							|  |  |  |  |             .data-week{ | 
					
						
							|  |  |  |  |                 flex: 1 | 
					
						
							|  |  |  |  |                 display: flex | 
					
						
							|  |  |  |  |                 justify-content: space-between | 
					
						
							|  |  |  |  |                 flex-wrap: nowrap | 
					
						
							|  |  |  |  |                 overflow: hidden | 
					
						
							|  |  |  |  |                 .weel-days{ | 
					
						
							| 
									
										
										
										
											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: center | 
					
						
							|  |  |  |  |                     flex-direction: column | 
					
						
							|  |  |  |  |                     text-align: center | 
					
						
							|  |  |  |  |                     font-weight: 400; | 
					
						
							|  |  |  |  |                     font-size: 24rpx; | 
					
						
							|  |  |  |  |                     color: #333333; | 
					
						
							|  |  |  |  |                     width: 96rpx; | 
					
						
							|  |  |  |  |                     height: 88rpx; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     .label{} | 
					
						
							|  |  |  |  |                     .day{ | 
					
						
							|  |  |  |  |                         font-weight: 500; | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 .active{ | 
					
						
							|  |  |  |  |                     background: rgba(37,107,250,0.1); | 
					
						
							|  |  |  |  |                     border-radius: 12rpx 12rpx 12rpx 12rpx; | 
					
						
							|  |  |  |  |                     color: #256BFA; | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             .data-all{ | 
					
						
							|  |  |  |  |                 width: 66rpx; | 
					
						
							|  |  |  |  |                 height: 66rpx; | 
					
						
							|  |  |  |  |                 margin-left: 18rpx | 
					
						
							|  |  |  |  |                 .allimg{ | 
					
						
							|  |  |  |  |                     width: 100%; | 
					
						
							|  |  |  |  |                     height: 100% | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .container-main { | 
					
						
							|  |  |  |  |     flex: 1; | 
					
						
							|  |  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |  |     background-color: #f4f4f4; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | .main-scroll { | 
					
						
							|  |  |  |  |     width: 100% | 
					
						
							|  |  |  |  |     height: 100%; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | .cards{ | 
					
						
							|  |  |  |  |     padding: 28rpx 28rpx 28rpx 28rpx; | 
					
						
							|  |  |  |  |     .card{ | 
					
						
							|  |  |  |  |         margin-top: 28rpx | 
					
						
							|  |  |  |  |         padding: 32rpx; | 
					
						
							|  |  |  |  |         background: #FFFFFF | 
					
						
							|  |  |  |  |         background: #FFFFFF; | 
					
						
							|  |  |  |  |         box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0,0,0,0.04); | 
					
						
							|  |  |  |  |         border-radius: 20rpx 20rpx 20rpx 20rpx; | 
					
						
							|  |  |  |  |         .card-title{ | 
					
						
							| 
									
										
										
										
											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
										 |  |  |  |             font-weight: 500; | 
					
						
							|  |  |  |  |             font-size: 32rpx; | 
					
						
							|  |  |  |  |             color: #333333; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .card-row{ | 
					
						
							|  |  |  |  |             display: flex | 
					
						
							|  |  |  |  |             justify-content: space-between | 
					
						
							|  |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |  |             color: #495265; | 
					
						
							|  |  |  |  |             margin-top: 4rpx | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .card-times{ | 
					
						
							|  |  |  |  |             display: flex; | 
					
						
							|  |  |  |  |             justify-content: space-between | 
					
						
							|  |  |  |  |             align-items: center | 
					
						
							|  |  |  |  |             margin-top: 24rpx | 
					
						
							|  |  |  |  |             .time-left, | 
					
						
							|  |  |  |  |             .time-right{ | 
					
						
							|  |  |  |  |                 text-align: center | 
					
						
							|  |  |  |  |                 .left-date{ | 
					
						
							|  |  |  |  |                     font-weight: 500; | 
					
						
							|  |  |  |  |                     font-size: 48rpx; | 
					
						
							|  |  |  |  |                     color: #333333; | 
					
						
							| 
									
										
										
										
											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
										 |  |  |  |                 } | 
					
						
							|  |  |  |  |                 .left-dateDay{ | 
					
						
							|  |  |  |  |                     font-weight: 400; | 
					
						
							|  |  |  |  |                     font-size: 24rpx; | 
					
						
							|  |  |  |  |                     color: #333333; | 
					
						
							|  |  |  |  |                     margin-top: 12rpx | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             .line{ | 
					
						
							|  |  |  |  |                 width: 40rpx; | 
					
						
							|  |  |  |  |                 height: 0rpx; | 
					
						
							|  |  |  |  |                 border: 2rpx solid #D4D4D4; | 
					
						
							|  |  |  |  |                 margin-top: 64rpx | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             .time-center{ | 
					
						
							|  |  |  |  |                 text-align: center; | 
					
						
							|  |  |  |  |                 display: flex | 
					
						
							|  |  |  |  |                 flex-direction: column | 
					
						
							|  |  |  |  |                 justify-content: center | 
					
						
							|  |  |  |  |                 align-items: center | 
					
						
							|  |  |  |  |                 .center-date{ | 
					
						
							|  |  |  |  |                     font-weight: 400; | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                     font-size: 28rpx; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                     color: #FF881A; | 
					
						
							|  |  |  |  |                     padding-top: 10rpx | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 .center-dateDay{ | 
					
						
							|  |  |  |  |                     font-weight: 400; | 
					
						
							|  |  |  |  |                     font-size: 24rpx; | 
					
						
							|  |  |  |  |                     color: #333333; | 
					
						
							|  |  |  |  |                     margin-top: 6rpx | 
					
						
							|  |  |  |  |                     line-height: 48rpx; | 
					
						
							|  |  |  |  |                     width: 104rpx; | 
					
						
							|  |  |  |  |                     height: 48rpx; | 
					
						
							|  |  |  |  |                     background: #F9F9F9; | 
					
						
							|  |  |  |  |                     border-radius: 8rpx 8rpx 8rpx 8rpx; | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .recommend-card-line{ | 
					
						
							|  |  |  |  |             width: calc(100%); | 
					
						
							|  |  |  |  |             height: 0rpx; | 
					
						
							|  |  |  |  |             border-radius: 0rpx 0rpx 0rpx 0rpx; | 
					
						
							|  |  |  |  |             border: 2rpx dashed rgba(0,0,0,0.14); | 
					
						
							|  |  |  |  |             margin-top: 32rpx | 
					
						
							|  |  |  |  |             position: relative | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .recommend-card-line::before{ | 
					
						
							|  |  |  |  |             position: absolute | 
					
						
							|  |  |  |  |             content: '' | 
					
						
							|  |  |  |  |             left: 0 | 
					
						
							|  |  |  |  |             top: 0 | 
					
						
							|  |  |  |  |             transform: translate(-50% - 110rpx, -50%) | 
					
						
							|  |  |  |  |             width: 28rpx; | 
					
						
							|  |  |  |  |             height: 28rpx; | 
					
						
							|  |  |  |  |             background: #F4F4F4; | 
					
						
							|  |  |  |  |             border-radius: 50%; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .recommend-card-line::after{ | 
					
						
							|  |  |  |  |             position: absolute | 
					
						
							|  |  |  |  |             content: '' | 
					
						
							|  |  |  |  |             right: 0 | 
					
						
							|  |  |  |  |             top: 0 | 
					
						
							|  |  |  |  |             transform: translate(50% + 100rpx, -50%) | 
					
						
							|  |  |  |  |             width: 28rpx; | 
					
						
							|  |  |  |  |             height: 28rpx; | 
					
						
							|  |  |  |  |             background: #F4F4F4; | 
					
						
							|  |  |  |  |             border-radius: 50%; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         .card-footer{ | 
					
						
							|  |  |  |  |             margin-top: 32rpx | 
					
						
							|  |  |  |  |             min-height: 50rpx; | 
					
						
							|  |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |  |             color: #6C7282; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     .card:first-child{ | 
					
						
							|  |  |  |  |         margin-top: 0 | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | </style> |