| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     <AppLayout title="我的浏览" :show-bg-image="false" :use-scroll-view="false"> | 
					
						
							|  |  |  |         <template #headerleft> | 
					
						
							| 
									
										
										
										
											2025-07-14 15:38:39 +08:00
										 |  |  |             <view class="btnback"> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 <image src="@/static/icon/back.png" @click="navBack"></image> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         </template> | 
					
						
							|  |  |  |         <view class="collection-content"> | 
					
						
							|  |  |  |             <view class="collection-search"> | 
					
						
							|  |  |  |                 <view class="search-content"> | 
					
						
							|  |  |  |                     <view class="header-input button-click"> | 
					
						
							|  |  |  |                         <uni-icons class="iconsearch" color="#6A6A6A" type="search" size="22"></uni-icons> | 
					
						
							|  |  |  |                         <input | 
					
						
							|  |  |  |                             class="input" | 
					
						
							|  |  |  |                             @confirm="searchCollection" | 
					
						
							|  |  |  |                             placeholder="招聘会" | 
					
						
							|  |  |  |                             placeholder-class="inputplace" | 
					
						
							|  |  |  |                         /> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |                     </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> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |                     </view> | 
					
						
							|  |  |  |                 </view> | 
					
						
							|  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             <scroll-view scroll-y class="main-scroll" @scrolltolower="getJobList('add')"> | 
					
						
							|  |  |  |                 <view class="one-cards"> | 
					
						
							|  |  |  |                     <view class="mian"> | 
					
						
							|  |  |  |                         <renderJobs | 
					
						
							|  |  |  |                             :list="pageState.list" | 
					
						
							|  |  |  |                             v-if="pageState.list.length" | 
					
						
							|  |  |  |                             :longitude="longitudeVal" | 
					
						
							|  |  |  |                             :latitude="latitudeVal" | 
					
						
							|  |  |  |                         ></renderJobs> | 
					
						
							|  |  |  |                         <empty v-else pdTop="200"></empty> | 
					
						
							|  |  |  |                         <!-- <loadmore ref="loadmoreRef"></loadmore> --> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |                     </view> | 
					
						
							|  |  |  |                 </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             </scroll-view> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     </AppLayout> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script setup> | 
					
						
							|  |  |  | import dictLabel from '@/components/dict-Label/dict-Label.vue'; | 
					
						
							|  |  |  | import { reactive, inject, watch, ref, onMounted } from 'vue'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | import { onLoad, onShow } from '@dcloudio/uni-app'; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | import useUserStore from '@/stores/useUserStore'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | const { $api, navTo, navBack } = inject('globalFunction'); | 
					
						
							|  |  |  | import useLocationStore from '@/stores/useLocationStore'; | 
					
						
							|  |  |  | const { userInfo } = storeToRefs(useUserStore()); | 
					
						
							|  |  |  | const { longitudeVal, latitudeVal } = storeToRefs(useLocationStore()); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | const userStore = useUserStore(); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | const browseDate = ref(''); | 
					
						
							|  |  |  | const weekday = ref([]); | 
					
						
							|  |  |  | const monthDay = ref([]); | 
					
						
							|  |  |  | const currentDay = ref(''); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | const pageState = reactive({ | 
					
						
							|  |  |  |     page: 0, | 
					
						
							|  |  |  |     list: [], | 
					
						
							|  |  |  |     total: 0, | 
					
						
							|  |  |  |     maxPage: 1, | 
					
						
							|  |  |  |     pageSize: 10, | 
					
						
							|  |  |  |     search: {}, | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     lastDate: '', | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | const currentDate = ref(''); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | onLoad(() => { | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     getBrowseDate(); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |     getJobList('refresh'); | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |     // const today = new Date().toISOString().split('T')[0];
 | 
					
						
							|  |  |  |     // currentDate.value = today;
 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | function toSelectDate() { | 
					
						
							|  |  |  |     navTo('/packageA/pages/selectDate/selectDate', { | 
					
						
							|  |  |  |         query: { | 
					
						
							|  |  |  |             date: currentDate.value, | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |             record: true, | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         }, | 
					
						
							|  |  |  |         onBack: (res) => { | 
					
						
							|  |  |  |             currentDate.value = res.date; | 
					
						
							|  |  |  |             pageState.search.startDate = getPreviousDay(res.date); | 
					
						
							|  |  |  |             pageState.search.endDate = res.date; | 
					
						
							|  |  |  |             getJobList('refresh'); | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | function navToPost(jobId) { | 
					
						
							| 
									
										
										
										
											2025-10-22 13:22:06 +08:00
										 |  |  |     navTo(`/packageA/pages/post/post?jobId=${encodeURIComponent(jobId)}`); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function searchCollection(e) { | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     const value = e.detail.value; | 
					
						
							|  |  |  |     pageState.search.jobTitle = value; | 
					
						
							|  |  |  |     getJobList('refresh'); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function getBrowseDate() { | 
					
						
							|  |  |  |     $api.createRequest('/app/user/review/array').then((res) => { | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         browseDate.value = res.data.join(','); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function getJobList(type = 'add', loading = true) { | 
					
						
							|  |  |  |     if (type === 'refresh') { | 
					
						
							|  |  |  |         pageState.page = 1; | 
					
						
							|  |  |  |         pageState.maxPage = 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (type === 'add' && pageState.page < pageState.maxPage) { | 
					
						
							|  |  |  |         pageState.page += 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     let params = { | 
					
						
							|  |  |  |         current: pageState.page, | 
					
						
							|  |  |  |         pageSize: pageState.pageSize, | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         ...pageState.search, | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |     }; | 
					
						
							|  |  |  |     $api.createRequest('/app/user/review', params, 'GET', loading).then((resData) => { | 
					
						
							|  |  |  |         const { rows, total } = resData; | 
					
						
							|  |  |  |         if (type === 'add') { | 
					
						
							|  |  |  |             const str = pageState.pageSize * (pageState.page - 1); | 
					
						
							|  |  |  |             const end = pageState.list.length; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             const [reslist, lastDate] = $api.insertSortData(rows, 'reviewDate'); | 
					
						
							|  |  |  |             if (reslist.length) { | 
					
						
							|  |  |  |                 // 日期监测是否一致
 | 
					
						
							|  |  |  |                 if (reslist[0].title === pageState.lastDate) { | 
					
						
							|  |  |  |                     reslist.shift(); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             pageState.list.splice(str, end, ...reslist); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             pageState.lastDate = lastDate; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |             const [reslist, lastDate] = $api.insertSortData(rows, 'reviewDate'); | 
					
						
							|  |  |  |             pageState.list = reslist; | 
					
						
							|  |  |  |             pageState.lastDate = lastDate; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |         // pageState.list = resData.rows;
 | 
					
						
							|  |  |  |         pageState.total = resData.total; | 
					
						
							|  |  |  |         pageState.maxPage = Math.ceil(pageState.total / pageState.pageSize); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function getPreviousDay(dateStr) { | 
					
						
							|  |  |  |     const date = new Date(dateStr); | 
					
						
							|  |  |  |     date.setDate(date.getDate() - 1); // 减去一天
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // 格式化成 YYYY-MM-DD
 | 
					
						
							|  |  |  |     return date.toISOString().split('T')[0]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | <style lang="stylus" scoped> | 
					
						
							| 
									
										
										
										
											2025-07-14 15:38:39 +08:00
										 |  |  | .btnback{ | 
					
						
							|  |  |  |     width: 64rpx; | 
					
						
							|  |  |  |     height: 64rpx; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | .btn { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: space-between; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							| 
									
										
										
										
											2025-07-14 15:38:39 +08:00
										 |  |  |     width: 52rpx; | 
					
						
							|  |  |  |     height: 52rpx; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | } | 
					
						
							|  |  |  | image { | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | .collection-content | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |     height: 100% | 
					
						
							|  |  |  |     display: flex | 
					
						
							|  |  |  |     flex-direction: column | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | .collection-search | 
					
						
							|  |  |  |     padding: 10rpx 20rpx; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |     .search-content | 
					
						
							|  |  |  |         position: relative | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |         display: flex | 
					
						
							|  |  |  |         align-items: center | 
					
						
							|  |  |  |         padding: 14rpx 0 | 
					
						
							|  |  |  |         .header-input{ | 
					
						
							|  |  |  |             padding: 0 | 
					
						
							|  |  |  |             width: calc(100% - 48rpx); | 
					
						
							|  |  |  |             position: relative | 
					
						
							|  |  |  |             .iconsearch{ | 
					
						
							|  |  |  |                 position: absolute | 
					
						
							|  |  |  |                 left: 30rpx; | 
					
						
							|  |  |  |                 top: 50% | 
					
						
							|  |  |  |                 transform: translate(0, -50%) | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             .input{ | 
					
						
							|  |  |  |                 padding: 0 30rpx 0 80rpx | 
					
						
							|  |  |  |                 height: 80rpx; | 
					
						
							|  |  |  |                 background: #FFFFFF; | 
					
						
							|  |  |  |                 border-radius: 75rpx 75rpx 75rpx 75rpx; | 
					
						
							|  |  |  |                 border: 2rpx solid #ECECEC | 
					
						
							|  |  |  |                 font-size: 28rpx; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             .inputplace{ | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |                 font-weight: 400; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |                 font-size: 28rpx; | 
					
						
							|  |  |  |                 color: #B5B5B5; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         .data-all{ | 
					
						
							|  |  |  |             width: 66rpx; | 
					
						
							|  |  |  |             height: 66rpx; | 
					
						
							|  |  |  |             margin-left: 18rpx | 
					
						
							|  |  |  |             .allimg{ | 
					
						
							|  |  |  |                 width: 100%; | 
					
						
							|  |  |  |                 height: 100% | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | .main-scroll{ | 
					
						
							|  |  |  |     flex: 1 | 
					
						
							|  |  |  |     overflow: hidden | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .one-cards{ | 
					
						
							|  |  |  |     padding: 0 20rpx 20rpx 20rpx; | 
					
						
							|  |  |  |     background: #f4f4f4 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  | </style> |