| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | <template> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |     <view class="app-container"> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         <view class="nav-hidden hidden-animation" :class="{ 'hidden-height': isScrollingDown }"> | 
					
						
							|  |  |  |  |             <view class="container-search"> | 
					
						
							|  |  |  |  |                 <view class="search-input button-click" @click="navTo('/pages/search/search')"> | 
					
						
							|  |  |  |  |                     <uni-icons class="iconsearch" color="#666666" type="search" size="18"></uni-icons> | 
					
						
							|  |  |  |  |                     <text class="inpute">职位名称、薪资要求等</text> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <view class="chart button-click">职业图谱</view> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             <view class="cards"> | 
					
						
							|  |  |  |  |                 <view class="card btn-feel" @click="navTo('/pages/nearby/nearby')"> | 
					
						
							|  |  |  |  |                     <view class="card-title">附近工作</view> | 
					
						
							|  |  |  |  |                     <view class="card-text">好岗职等你来</view> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <view class="card btn-feel" @click="navTo('/packageA/pages/choiceness/choiceness')"> | 
					
						
							|  |  |  |  |                     <view class="card-title">精选企业</view> | 
					
						
							|  |  |  |  |                     <view class="card-text">优选职得信赖</view> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |             </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         <view class="nav-filter"> | 
					
						
							|  |  |  |  |             <view class="filter-top"> | 
					
						
							|  |  |  |  |                 <scroll-view :scroll-x="true" :show-scrollbar="false" class="tab-scroll"> | 
					
						
							|  |  |  |  |                     <view class="jobs-left"> | 
					
						
							|  |  |  |  |                         <view | 
					
						
							|  |  |  |  |                             class="job button-click" | 
					
						
							|  |  |  |  |                             :class="{ active: state.tabIndex === 'all' }" | 
					
						
							|  |  |  |  |                             @click="choosePosition('all')" | 
					
						
							|  |  |  |  |                         > | 
					
						
							|  |  |  |  |                             全部 | 
					
						
							|  |  |  |  |                         </view> | 
					
						
							|  |  |  |  |                         <view | 
					
						
							|  |  |  |  |                             class="job button-click" | 
					
						
							|  |  |  |  |                             :class="{ active: state.tabIndex === index }" | 
					
						
							|  |  |  |  |                             v-for="(item, index) in userInfo.jobTitle" | 
					
						
							|  |  |  |  |                             :key="index" | 
					
						
							|  |  |  |  |                             @click="choosePosition(index)" | 
					
						
							|  |  |  |  |                         > | 
					
						
							|  |  |  |  |                             {{ item }} | 
					
						
							|  |  |  |  |                         </view> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 </scroll-view> | 
					
						
							|  |  |  |  |                 <view class="jobs-add button-click" @click="navTo('/packageA/pages/addPosition/addPosition')"> | 
					
						
							|  |  |  |  |                     <uni-icons class="iconsearch" color="#666D7F" type="plusempty" size="18"></uni-icons> | 
					
						
							|  |  |  |  |                     <text>添加</text> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |             <view class="filter-bottom"> | 
					
						
							|  |  |  |  |                 <view class="btm-left"> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                     <view | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                         class="button-click filterbtm" | 
					
						
							|  |  |  |  |                         :class="{ active: pageState.search.order === item.value }" | 
					
						
							|  |  |  |  |                         v-for="item in rangeOptions" | 
					
						
							|  |  |  |  |                         @click="handelHostestSearch(item)" | 
					
						
							|  |  |  |  |                         :key="item.value" | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                     > | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                         {{ item.text }} | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                     </view> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                 </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 <view class="btm-right button-click" @click="openFilter"> | 
					
						
							|  |  |  |  |                     筛选 | 
					
						
							|  |  |  |  |                     <image class="right-sx" :class="{ active: showFilter }" src="@/static/icon/shaixun.png"></image> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                 </view> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         <view class="table-list"> | 
					
						
							|  |  |  |  |             <scroll-view :scroll-y="true" class="falls-scroll" @scroll="handleScroll" @scrolltolower="scrollBottom"> | 
					
						
							|  |  |  |  |                 <view class="falls" v-if="list.length"> | 
					
						
							| 
									
										
										
										
											2025-05-16 09:28:44 +08:00
										 |  |  |  |                     <custom-waterfalls-flow | 
					
						
							|  |  |  |  |                         :column="columnCount" | 
					
						
							|  |  |  |  |                         :columnSpace="columnSpace" | 
					
						
							|  |  |  |  |                         ref="waterfallsFlowRef" | 
					
						
							|  |  |  |  |                         :value="list" | 
					
						
							|  |  |  |  |                     > | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                         <template v-slot:default="job"> | 
					
						
							|  |  |  |  |                             <view class="item btn-feel" v-if="!job.recommend"> | 
					
						
							|  |  |  |  |                                 <view class="falls-card" @click="nextDetail(job)"> | 
					
						
							|  |  |  |  |                                     <view class="falls-card-pay"> | 
					
						
							|  |  |  |  |                                         <view class="pay-text"> | 
					
						
							|  |  |  |  |                                             <Salary-Expectation | 
					
						
							|  |  |  |  |                                                 :max-salary="job.maxSalary" | 
					
						
							|  |  |  |  |                                                 :min-salary="job.minSalary" | 
					
						
							|  |  |  |  |                                                 :is-month="true" | 
					
						
							|  |  |  |  |                                             ></Salary-Expectation> | 
					
						
							|  |  |  |  |                                         </view> | 
					
						
							|  |  |  |  |                                         <image v-if="job.isHot" class="flame" src="/static/icon/flame.png"></image> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                                     </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                                     <view class="falls-card-title">{{ job.jobTitle }}</view> | 
					
						
							|  |  |  |  |                                     <view class="fl_box fl_warp"> | 
					
						
							|  |  |  |  |                                         <view class="falls-card-education mar_ri10" v-if="job.education"> | 
					
						
							|  |  |  |  |                                             <dict-Label dictType="education" :value="job.education"></dict-Label> | 
					
						
							|  |  |  |  |                                         </view> | 
					
						
							|  |  |  |  |                                         <view class="falls-card-experience" v-if="job.experience"> | 
					
						
							|  |  |  |  |                                             <dict-Label dictType="experience" :value="job.experience"></dict-Label> | 
					
						
							|  |  |  |  |                                         </view> | 
					
						
							|  |  |  |  |                                     </view> | 
					
						
							|  |  |  |  |                                     <view class="falls-card-company">{{ job.companyName }}</view> | 
					
						
							|  |  |  |  |                                     <view class="falls-card-company"> | 
					
						
							|  |  |  |  |                                         青岛 | 
					
						
							|  |  |  |  |                                         <dict-Label dictType="area" :value="job.jobLocationAreaCode"></dict-Label> | 
					
						
							|  |  |  |  |                                     </view> | 
					
						
							|  |  |  |  |                                     <view class="falls-card-pepleNumber"> | 
					
						
							|  |  |  |  |                                         <view>{{ job.postingDate || '发布日期' }}</view> | 
					
						
							|  |  |  |  |                                         <view>{{ vacanciesTo(job.vacancies) }}</view> | 
					
						
							|  |  |  |  |                                     </view> | 
					
						
							|  |  |  |  |                                     <!--  <view class="falls-card-matchingrate"> | 
					
						
							|  |  |  |  |                                         <view class=""><matchingDegree :job="job"></matchingDegree></view> | 
					
						
							|  |  |  |  |                                         <uni-icons type="star" size="30"></uni-icons> | 
					
						
							|  |  |  |  |                                     </view> --> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                                 </view> | 
					
						
							|  |  |  |  |                             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                             <view class="item" :class="{ isBut: job.isBut }" v-else> | 
					
						
							|  |  |  |  |                                 <view class="recommend-card"> | 
					
						
							|  |  |  |  |                                     <view class="card-content"> | 
					
						
							|  |  |  |  |                                         <view class="recommend-card-title">在找「{{ job.jobCategory }}」工作吗?</view> | 
					
						
							|  |  |  |  |                                         <view class="recommend-card-tip">{{ job.tip }}</view> | 
					
						
							|  |  |  |  |                                         <view class="recommend-card-line"></view> | 
					
						
							|  |  |  |  |                                         <view class="recommend-card-controll"> | 
					
						
							|  |  |  |  |                                             <view class="controll-no" @click="clearfindJob(job)">不是</view> | 
					
						
							|  |  |  |  |                                             <view class="controll-yes" @click="findJob(job)">是的</view> | 
					
						
							|  |  |  |  |                                         </view> | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                                     </view> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |                                 </view> | 
					
						
							|  |  |  |  |                             </view> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                         </template> | 
					
						
							|  |  |  |  |                     </custom-waterfalls-flow> | 
					
						
							|  |  |  |  |                     <loadmore ref="loadmoreRef"></loadmore> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <empty v-else pdTop="200"></empty> | 
					
						
							|  |  |  |  |             </scroll-view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  |         <!-- 筛选 --> | 
					
						
							|  |  |  |  |         <select-filter ref="selectFilterModel"></select-filter> | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  |     </view> | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script setup> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | import { reactive, inject, watch, ref, onMounted, watchEffect, nextTick } from 'vue'; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | import img from '@/static/icon/filter.png'; | 
					
						
							|  |  |  |  | import dictLabel from '@/components/dict-Label/dict-Label.vue'; | 
					
						
							|  |  |  |  | const { $api, navTo, vacanciesTo, formatTotal } = inject('globalFunction'); | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | import { onLoad, onShow } from '@dcloudio/uni-app'; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | import { storeToRefs } from 'pinia'; | 
					
						
							|  |  |  |  | import useUserStore from '@/stores/useUserStore'; | 
					
						
							|  |  |  |  | const { userInfo } = storeToRefs(useUserStore()); | 
					
						
							|  |  |  |  | import useDictStore from '@/stores/useDictStore'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | const { getTransformChildren, oneDictData } = useDictStore(); | 
					
						
							|  |  |  |  | import useLocationStore from '@/stores/useLocationStore'; | 
					
						
							|  |  |  |  | import selectFilter from '@/components/selectFilter/selectFilter.vue'; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | import { useRecommedIndexedDBStore, jobRecommender } from '@/stores/useRecommedIndexedDBStore.js'; | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | import { useScrollDirection } from '@/hook/useScrollDirection'; | 
					
						
							|  |  |  |  | import { useColumnCount } from '@/hook/useColumnCount'; | 
					
						
							|  |  |  |  | const { isScrollingDown, handleScroll } = useScrollDirection(); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | const recommedIndexDb = useRecommedIndexedDBStore(); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 16:33:37 +08:00
										 |  |  |  | const waterfallsFlowRef = ref(null); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | const loadmoreRef = ref(null); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | const conditionSearch = ref({}); | 
					
						
							|  |  |  |  | const waterfallcolumn = ref(2); | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | const state = reactive({ | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |     tabIndex: 'all', | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | const list = ref([]); | 
					
						
							|  |  |  |  | const pageState = reactive({ | 
					
						
							|  |  |  |  |     page: 0, | 
					
						
							|  |  |  |  |     total: 0, | 
					
						
							|  |  |  |  |     maxPage: 2, | 
					
						
							|  |  |  |  |     pageSize: 10, | 
					
						
							|  |  |  |  |     search: { | 
					
						
							|  |  |  |  |         order: 0, | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | }); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | const inputText = ref(''); | 
					
						
							|  |  |  |  | const showFilter = ref(false); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | const selectFilterModel = ref(null); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | const showModel = ref(false); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | const rangeOptions = ref([ | 
					
						
							|  |  |  |  |     { value: 0, text: '推荐' }, | 
					
						
							|  |  |  |  |     { value: 1, text: '最热' }, | 
					
						
							|  |  |  |  |     { value: 2, text: '最新发布' }, | 
					
						
							|  |  |  |  | ]); | 
					
						
							| 
									
										
										
										
											2025-05-15 14:27:34 +08:00
										 |  |  |  | // const jobList = ref([
 | 
					
						
							|  |  |  |  | //     { name: '销售顾问', highlight: true },
 | 
					
						
							|  |  |  |  | //     { name: '销售管理', highlight: true },
 | 
					
						
							|  |  |  |  | //     { name: '销售工程师', highlight: true },
 | 
					
						
							|  |  |  |  | //     { name: '算法工程师', highlight: false },
 | 
					
						
							|  |  |  |  | //     { name: '生产经理', highlight: false },
 | 
					
						
							|  |  |  |  | //     { name: '市场策划', highlight: false },
 | 
					
						
							|  |  |  |  | //     { name: '商务服务', highlight: false },
 | 
					
						
							|  |  |  |  | //     { name: '客服', highlight: false },
 | 
					
						
							|  |  |  |  | //     { name: '创意总监', highlight: false },
 | 
					
						
							|  |  |  |  | // ]);
 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-16 09:28:44 +08:00
										 |  |  |  | const { columnCount, columnSpace } = useColumnCount(() => { | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     pageState.pageSize = 10 * (columnCount.value - 1); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |     getJobRecommend('refresh'); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     nextTick(() => { | 
					
						
							|  |  |  |  |         waterfallsFlowRef.value?.refresh?.(); | 
					
						
							|  |  |  |  |         useLocationStore().getLocation(); | 
					
						
							|  |  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | // onLoad(() => {
 | 
					
						
							|  |  |  |  | //     getJobRecommend('refresh');
 | 
					
						
							|  |  |  |  | // });
 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function scrollBottom() { | 
					
						
							|  |  |  |  |     loadmoreRef.value.change('loading'); | 
					
						
							|  |  |  |  |     if (state.tabIndex === 'all') { | 
					
						
							|  |  |  |  |         getJobRecommend(); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							|  |  |  |  |         getJobList(); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function findJob(job) { | 
					
						
							|  |  |  |  |     if (job.isBut) { | 
					
						
							|  |  |  |  |         $api.msg('已确认'); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							|  |  |  |  |         list.value = list.value.map((item) => { | 
					
						
							|  |  |  |  |             if (item.recommend && item.jobCategory === job.jobCategory) { | 
					
						
							|  |  |  |  |                 return { | 
					
						
							|  |  |  |  |                     ...item, | 
					
						
							|  |  |  |  |                     isBut: true, | 
					
						
							|  |  |  |  |                 }; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return item; | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         const jobstr = job.jobCategory; | 
					
						
							|  |  |  |  |         const jobsObj = { | 
					
						
							|  |  |  |  |             地区: 'area', | 
					
						
							|  |  |  |  |             岗位: 'jobTitle', | 
					
						
							|  |  |  |  |             经验: 'experience', | 
					
						
							|  |  |  |  |         }; | 
					
						
							|  |  |  |  |         const [name, value] = jobstr.split(':'); | 
					
						
							|  |  |  |  |         const nameAttr = jobsObj[name]; | 
					
						
							|  |  |  |  |         if (name === '岗位') { | 
					
						
							|  |  |  |  |             conditionSearch.value[nameAttr] = value; | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |             const valueAttr = oneDictData(nameAttr).filter((item) => item.label === value); | 
					
						
							|  |  |  |  |             if (valueAttr.length) { | 
					
						
							|  |  |  |  |                 const val = valueAttr[0].value; | 
					
						
							|  |  |  |  |                 conditionSearch.value[nameAttr] = val; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function clearfindJob(job) { | 
					
						
							|  |  |  |  |     if (job.isBut) { | 
					
						
							|  |  |  |  |         $api.msg('已确认'); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							|  |  |  |  |         list.value = list.value.map((item) => { | 
					
						
							|  |  |  |  |             if (item.recommend && item.jobCategory === job.jobCategory) { | 
					
						
							|  |  |  |  |                 return { | 
					
						
							|  |  |  |  |                     ...item, | 
					
						
							|  |  |  |  |                     isBut: true, | 
					
						
							|  |  |  |  |                 }; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return item; | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         recommedIndexDb.deleteRecords(job); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function nextDetail(job) { | 
					
						
							|  |  |  |  |     // 记录岗位类型,用作数据分析
 | 
					
						
							|  |  |  |  |     if (job.jobCategory) { | 
					
						
							|  |  |  |  |         const recordData = recommedIndexDb.JobParameter(job); | 
					
						
							|  |  |  |  |         recommedIndexDb.addRecord(recordData); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     navTo(`/packageA/pages/post/post?jobId=${btoa(job.jobId)}`); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function openFilter() { | 
					
						
							|  |  |  |  |     showFilter.value = true; | 
					
						
							|  |  |  |  |     selectFilterModel.value?.open({ | 
					
						
							|  |  |  |  |         title: '筛选', | 
					
						
							|  |  |  |  |         maskClick: true, | 
					
						
							|  |  |  |  |         success: (values) => { | 
					
						
							|  |  |  |  |             pageState.search = { | 
					
						
							|  |  |  |  |                 ...pageState.search, | 
					
						
							|  |  |  |  |             }; | 
					
						
							|  |  |  |  |             for (const [key, value] of Object.entries(values)) { | 
					
						
							|  |  |  |  |                 pageState.search[key] = value.join(','); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             showFilter.value = false; | 
					
						
							|  |  |  |  |             getJobList('refresh'); | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         cancel: () => { | 
					
						
							|  |  |  |  |             showFilter.value = false; | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function handleFilterConfirm(e) { | 
					
						
							|  |  |  |  |     console.log(e); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function choosePosition(index) { | 
					
						
							|  |  |  |  |     state.tabIndex = index; | 
					
						
							|  |  |  |  |     list.value = []; | 
					
						
							|  |  |  |  |     if (index === 'all') { | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         pageState.search = { | 
					
						
							|  |  |  |  |             order: pageState.search.order, | 
					
						
							|  |  |  |  |         }; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |         inputText.value = ''; | 
					
						
							|  |  |  |  |         getJobRecommend('refresh'); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							|  |  |  |  |         // const id = useUserStore().userInfo.jobTitleId.split(',')[index];
 | 
					
						
							| 
									
										
										
										
											2025-05-15 14:17:51 +08:00
										 |  |  |  |         pageState.search.jobTitle = userInfo.value.jobTitle[index]; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |         inputText.value = ''; | 
					
						
							|  |  |  |  |         getJobList('refresh'); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | function handelHostestSearch(val) { | 
					
						
							|  |  |  |  |     pageState.search.order = val.value; | 
					
						
							|  |  |  |  |     if (state.tabIndex === 'all') { | 
					
						
							|  |  |  |  |         getJobRecommend('refresh'); | 
					
						
							|  |  |  |  |     } else { | 
					
						
							|  |  |  |  |         getJobList('refresh'); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function getJobRecommend(type = 'add') { | 
					
						
							|  |  |  |  |     if (type === 'refresh') { | 
					
						
							|  |  |  |  |         list.value = []; | 
					
						
							|  |  |  |  |         if (waterfallsFlowRef.value) waterfallsFlowRef.value.refresh(); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     let params = { | 
					
						
							|  |  |  |  |         pageSize: pageState.pageSize, | 
					
						
							|  |  |  |  |         sessionId: useUserStore().seesionId, | 
					
						
							|  |  |  |  |         ...pageState.search, | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |         ...conditionSearch.value, | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |     }; | 
					
						
							|  |  |  |  |     let comd = { recommend: true, jobCategory: '', tip: '确认你的兴趣,为您推荐更多合适的岗位' }; | 
					
						
							|  |  |  |  |     $api.createRequest('/app/job/recommend', params).then((resData) => { | 
					
						
							|  |  |  |  |         const { data, total } = resData; | 
					
						
							|  |  |  |  |         pageState.total = 0; | 
					
						
							|  |  |  |  |         if (type === 'add') { | 
					
						
							|  |  |  |  |             // 记录系统
 | 
					
						
							|  |  |  |  |             recommedIndexDb.getRecord().then((res) => { | 
					
						
							|  |  |  |  |                 if (res.length) { | 
					
						
							|  |  |  |  |                     // 数据分析系统
 | 
					
						
							|  |  |  |  |                     const resultData = recommedIndexDb.analyzer(res); | 
					
						
							|  |  |  |  |                     const { sort, result } = resultData; | 
					
						
							|  |  |  |  |                     // 岗位询问系统
 | 
					
						
							|  |  |  |  |                     const conditionCounts = Object.fromEntries( | 
					
						
							|  |  |  |  |                         sort.filter((item) => item[1] > 1) // 过滤掉次数为 1 的项
 | 
					
						
							|  |  |  |  |                     ); | 
					
						
							|  |  |  |  |                     jobRecommender.updateConditions(conditionCounts); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     const question = jobRecommender.getNextQuestion(); | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                     if (question) { | 
					
						
							|  |  |  |  |                         comd.jobCategory = question; | 
					
						
							|  |  |  |  |                         data.unshift(comd); | 
					
						
							|  |  |  |  |                     } | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 const reslist = dataToImg(data); | 
					
						
							|  |  |  |  |                 list.value.push(...reslist); | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |             list.value = dataToImg(data); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         // 切换状态
 | 
					
						
							|  |  |  |  |         if (data.length < pageState.pageSize) { | 
					
						
							|  |  |  |  |             loadmoreRef.value.change('noMore'); | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |             loadmoreRef.value.change('more'); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         // 当没有岗位,刷新sessionId重新啦
 | 
					
						
							|  |  |  |  |         if (!data.length) { | 
					
						
							|  |  |  |  |             useUserStore().initSeesionId(); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     }); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function getJobList(type = 'add') { | 
					
						
							|  |  |  |  |     if (type === 'add' && pageState.page < pageState.maxPage) { | 
					
						
							|  |  |  |  |         pageState.page += 1; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     if (type === 'refresh') { | 
					
						
							|  |  |  |  |         list.value = []; | 
					
						
							|  |  |  |  |         pageState.page = 1; | 
					
						
							|  |  |  |  |         pageState.maxPage = 2; | 
					
						
							|  |  |  |  |         waterfallsFlowRef.value.refresh(); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |     let params = { | 
					
						
							|  |  |  |  |         current: pageState.page, | 
					
						
							|  |  |  |  |         pageSize: pageState.pageSize, | 
					
						
							|  |  |  |  |         ...pageState.search, | 
					
						
							|  |  |  |  |     }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     $api.createRequest('/app/job/list', params).then((resData) => { | 
					
						
							|  |  |  |  |         const { rows, total } = resData; | 
					
						
							|  |  |  |  |         if (type === 'add') { | 
					
						
							|  |  |  |  |             const str = pageState.pageSize * (pageState.page - 1); | 
					
						
							|  |  |  |  |             const end = list.value.length; | 
					
						
							|  |  |  |  |             const reslist = dataToImg(rows); | 
					
						
							|  |  |  |  |             list.value.splice(str, end, ...reslist); | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |             list.value = dataToImg(rows); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         pageState.total = resData.total; | 
					
						
							|  |  |  |  |         pageState.maxPage = Math.ceil(pageState.total / pageState.pageSize); | 
					
						
							|  |  |  |  |         if (rows.length < pageState.pageSize) { | 
					
						
							| 
									
										
										
										
											2025-04-07 09:10:55 +08:00
										 |  |  |  |             loadmoreRef.value?.change('noMore'); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2025-04-07 09:10:55 +08:00
										 |  |  |  |             loadmoreRef.value?.change('more'); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |     }); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | function dataToImg(data) { | 
					
						
							|  |  |  |  |     return data.map((item) => ({ | 
					
						
							|  |  |  |  |         ...item, | 
					
						
							|  |  |  |  |         image: img, | 
					
						
							|  |  |  |  |         hide: true, | 
					
						
							|  |  |  |  |     })); | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-08 11:55:23 +08:00
										 |  |  |  | </script> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <style lang="stylus" scoped> | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | .app-container | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							|  |  |  |  |     height: calc(100vh - var(--window-top) - var(--status-bar-height) - var(--window-bottom)); | 
					
						
							|  |  |  |  |     background: url('@/static/icon/background2.png') 0 0 no-repeat; | 
					
						
							|  |  |  |  |     background-size: 100% 728rpx; | 
					
						
							|  |  |  |  |     background-color: #FFFFFF; | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     flex-direction: column | 
					
						
							|  |  |  |  |     .hidden-animation | 
					
						
							|  |  |  |  |         max-height: 1000px; | 
					
						
							|  |  |  |  |         transition: all 0.3s ease; | 
					
						
							|  |  |  |  |         overflow: hidden; | 
					
						
							|  |  |  |  |     .hidden-height | 
					
						
							|  |  |  |  |         max-height: 0; | 
					
						
							|  |  |  |  |         padding-top: 0; | 
					
						
							|  |  |  |  |         padding-bottom: 0; | 
					
						
							|  |  |  |  | .container-search | 
					
						
							|  |  |  |  |     padding: 16rpx 24rpx | 
					
						
							|  |  |  |  |     display: flex | 
					
						
							|  |  |  |  |     justify-content: space-between | 
					
						
							|  |  |  |  |     .search-input | 
					
						
							|  |  |  |  |         display: flex | 
					
						
							|  |  |  |  |         align-items: center; | 
					
						
							|  |  |  |  |         width: 100% | 
					
						
							|  |  |  |  |         height: 80rpx; | 
					
						
							|  |  |  |  |         line-height: 80rpx | 
					
						
							|  |  |  |  |         margin-right: 24rpx | 
					
						
							|  |  |  |  |         background: #FFFFFF; | 
					
						
							|  |  |  |  |         border-radius: 75rpx 75rpx 75rpx 75rpx; | 
					
						
							|  |  |  |  |         .iconsearch | 
					
						
							|  |  |  |  |             padding-left: 36rpx | 
					
						
							|  |  |  |  |         .inpute | 
					
						
							|  |  |  |  |             margin-left: 20rpx | 
					
						
							|  |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |  |             color: #B5B5B5; | 
					
						
							|  |  |  |  |             width: 100% | 
					
						
							|  |  |  |  |     .chart | 
					
						
							|  |  |  |  |         width: 170rpx; | 
					
						
							|  |  |  |  |         background: radial-gradient( 0% 56% at 87% 61%, rgba(255,255,255,0.82) 0%, rgba(255,255,255,0.47) 100%); | 
					
						
							|  |  |  |  |         box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(210,210,210,0.14); | 
					
						
							|  |  |  |  |         border-radius: 80rpx 80rpx 80rpx 80rpx; | 
					
						
							|  |  |  |  |         border: 2rpx solid #FFFFFF; | 
					
						
							|  |  |  |  |         text-align: center | 
					
						
							|  |  |  |  |         font-weight: 500; | 
					
						
							|  |  |  |  |         font-size: 28rpx; | 
					
						
							|  |  |  |  |         height: 36rpx; | 
					
						
							|  |  |  |  |         color: #000000; | 
					
						
							|  |  |  |  |         padding: 20rpx 30rpx | 
					
						
							|  |  |  |  | .cards | 
					
						
							|  |  |  |  |     padding: 10rpx 28rpx | 
					
						
							|  |  |  |  |     display: grid | 
					
						
							|  |  |  |  |     grid-gap: 38rpx; | 
					
						
							|  |  |  |  |     grid-template-columns: 1fr 1fr; | 
					
						
							|  |  |  |  |     .card | 
					
						
							|  |  |  |  |         height: calc(158rpx - 40rpx); | 
					
						
							|  |  |  |  |         padding: 22rpx 26rpx | 
					
						
							|  |  |  |  |         box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(210,210,210,0.14); | 
					
						
							|  |  |  |  |         border-radius: 16rpx 16rpx 16rpx 16rpx; | 
					
						
							|  |  |  |  |         border: 2rpx solid #FFFFFF; | 
					
						
							|  |  |  |  |         .card-title | 
					
						
							|  |  |  |  |             font-weight: 600; | 
					
						
							|  |  |  |  |             font-size: 32rpx; | 
					
						
							|  |  |  |  |             color: #000000; | 
					
						
							|  |  |  |  |         .card-text | 
					
						
							|  |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 24rpx; | 
					
						
							|  |  |  |  |             color: #9E9E9E; | 
					
						
							|  |  |  |  |             margin-top: 4rpx | 
					
						
							|  |  |  |  |     .card:first-child | 
					
						
							|  |  |  |  |         background: radial-gradient( 0% 56% at 87% 61%, rgba(255,255,255,0.82) 0%, rgba(255,255,255,0.47) 100%), | 
					
						
							|  |  |  |  |             url('@/static/icon/fujin.png'); | 
					
						
							|  |  |  |  |         background-size: 100%, 100% | 
					
						
							|  |  |  |  |     .card:last-child | 
					
						
							|  |  |  |  |         background: radial-gradient( 0% 56% at 87% 61%, rgba(255,255,255,0.82) 0%, rgba(255,255,255,0.47) 100%), | 
					
						
							|  |  |  |  |             url('@/static/icon/jinxuan.png'); | 
					
						
							|  |  |  |  |         background-size: 100%, 100% | 
					
						
							|  |  |  |  |         background-size: cover; | 
					
						
							|  |  |  |  |         background-position: center; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .nav-filter | 
					
						
							|  |  |  |  |     padding: 16rpx 28rpx 0 28rpx | 
					
						
							|  |  |  |  |     .filter-top | 
					
						
							|  |  |  |  |         display: flex | 
					
						
							|  |  |  |  |         justify-content: space-between; | 
					
						
							|  |  |  |  |         .tab-scroll | 
					
						
							|  |  |  |  |             flex: 1; | 
					
						
							|  |  |  |  |             overflow: hidden; | 
					
						
							|  |  |  |  |             margin-right: 20rpx | 
					
						
							|  |  |  |  |             white-space: nowrap; | 
					
						
							|  |  |  |  |             overflow: hidden; | 
					
						
							|  |  |  |  |             text-overflow: clip; | 
					
						
							|  |  |  |  |             -webkit-mask-image: linear-gradient(to right, black 60%, transparent); | 
					
						
							|  |  |  |  |             mask-image: linear-gradient(to right, black 60%, transparent); | 
					
						
							|  |  |  |  |             .jobs-left | 
					
						
							|  |  |  |  |                 display: flex | 
					
						
							|  |  |  |  |                 flex-wrap: nowrap | 
					
						
							|  |  |  |  |                 .job | 
					
						
							|  |  |  |  |                     font-weight: 400; | 
					
						
							|  |  |  |  |                     font-size: 36rpx; | 
					
						
							|  |  |  |  |                     color: #666D7F; | 
					
						
							|  |  |  |  |                     margin-right: 32rpx; | 
					
						
							|  |  |  |  |                     white-space: nowrap | 
					
						
							|  |  |  |  |                 .active | 
					
						
							|  |  |  |  |                     font-weight: 500; | 
					
						
							|  |  |  |  |                     font-size: 36rpx; | 
					
						
							|  |  |  |  |                     color: #000000; | 
					
						
							|  |  |  |  |         .jobs-add | 
					
						
							|  |  |  |  |             display: flex | 
					
						
							|  |  |  |  |             align-items: center; | 
					
						
							|  |  |  |  |             justify-content: center; | 
					
						
							|  |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 32rpx; | 
					
						
							|  |  |  |  |             color: #666D7F; | 
					
						
							|  |  |  |  |             line-height: 38rpx; | 
					
						
							|  |  |  |  |     .filter-bottom | 
					
						
							|  |  |  |  |         display: flex | 
					
						
							|  |  |  |  |         justify-content: space-between | 
					
						
							|  |  |  |  |         padding: 24rpx 0 | 
					
						
							|  |  |  |  |         .btm-left | 
					
						
							|  |  |  |  |             display: flex | 
					
						
							|  |  |  |  |             .filterbtm | 
					
						
							|  |  |  |  |                 font-weight: 400; | 
					
						
							|  |  |  |  |                 font-size: 32rpx; | 
					
						
							|  |  |  |  |                 color: #666D7F; | 
					
						
							|  |  |  |  |                 margin-right: 24rpx | 
					
						
							|  |  |  |  |                 padding: 0rpx 16rpx | 
					
						
							|  |  |  |  |             .active | 
					
						
							|  |  |  |  |                 font-weight: 500; | 
					
						
							|  |  |  |  |                 font-size: 32rpx; | 
					
						
							|  |  |  |  |                 color: #256BFA; | 
					
						
							|  |  |  |  |         .btm-right | 
					
						
							|  |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 32rpx; | 
					
						
							|  |  |  |  |             color: #6C7282; | 
					
						
							|  |  |  |  |             .right-sx | 
					
						
							|  |  |  |  |                 width: 26rpx; | 
					
						
							|  |  |  |  |                 height: 26rpx; | 
					
						
							|  |  |  |  |             .active | 
					
						
							|  |  |  |  |                 transform: rotate(180deg) | 
					
						
							|  |  |  |  | .table-list | 
					
						
							|  |  |  |  |     background: #F4F4F4 | 
					
						
							|  |  |  |  |     flex: 1 | 
					
						
							|  |  |  |  |     overflow: hidden | 
					
						
							|  |  |  |  |     .falls-scroll | 
					
						
							|  |  |  |  |         width: 100% | 
					
						
							|  |  |  |  |         height: 100% | 
					
						
							|  |  |  |  |         .falls | 
					
						
							|  |  |  |  |             padding: 28rpx 28rpx; | 
					
						
							|  |  |  |  |             .item | 
					
						
							|  |  |  |  |                 position: relative; | 
					
						
							|  |  |  |  |                 // background: linear-gradient( 180deg, rgba(19, 197, 124, 0.4) 0%, rgba(255, 255, 255, 0) 30%), rgba(255, 255, 255, 0);
 | 
					
						
							|  |  |  |  |                 .falls-card | 
					
						
							|  |  |  |  |                     padding: 30rpx; | 
					
						
							|  |  |  |  |                     .falls-card-title | 
					
						
							|  |  |  |  |                         color: #606060; | 
					
						
							|  |  |  |  |                         line-height: 49rpx; | 
					
						
							|  |  |  |  |                         text-align: left; | 
					
						
							|  |  |  |  |                         word-break:break-all | 
					
						
							|  |  |  |  |                         font-weight: 500; | 
					
						
							|  |  |  |  |                         font-size: 32rpx; | 
					
						
							|  |  |  |  |                         color: #333333; | 
					
						
							|  |  |  |  |                     .falls-card-pay | 
					
						
							|  |  |  |  |                         // height: 50rpx;
 | 
					
						
							|  |  |  |  |                         word-break:break-all | 
					
						
							|  |  |  |  |                         color: #002979; | 
					
						
							|  |  |  |  |                         text-align: left; | 
					
						
							|  |  |  |  |                         display: flex; | 
					
						
							|  |  |  |  |                         align-items: end; | 
					
						
							|  |  |  |  |                         position: relative | 
					
						
							|  |  |  |  |                         .pay-text | 
					
						
							|  |  |  |  |                             color: #4C6EFB; | 
					
						
							|  |  |  |  |                             padding-right: 10rpx | 
					
						
							|  |  |  |  |                             font-weight: 500; | 
					
						
							|  |  |  |  |                             font-size: 28rpx; | 
					
						
							|  |  |  |  |                             color: #4C6EFB; | 
					
						
							|  |  |  |  |                             line-height: 45rpx; | 
					
						
							|  |  |  |  |                             text-align: left; | 
					
						
							|  |  |  |  |                         .flame | 
					
						
							|  |  |  |  |                             position: absolute | 
					
						
							|  |  |  |  |                             bottom: 0 | 
					
						
							|  |  |  |  |                             right: -10rpx | 
					
						
							|  |  |  |  |                             transform: translate(0, -30%) | 
					
						
							|  |  |  |  |                             width: 24rpx | 
					
						
							|  |  |  |  |                             height: 31rpx | 
					
						
							|  |  |  |  |                     .falls-card-education,.falls-card-experience | 
					
						
							|  |  |  |  |                         width: fit-content; | 
					
						
							|  |  |  |  |                         height: 30rpx; | 
					
						
							|  |  |  |  |                         background: #F4F4F4; | 
					
						
							|  |  |  |  |                         border-radius: 4rpx; | 
					
						
							|  |  |  |  |                         padding: 6rpx 20rpx; | 
					
						
							|  |  |  |  |                         line-height: 30rpx; | 
					
						
							|  |  |  |  |                         font-weight: 400; | 
					
						
							|  |  |  |  |                         font-size: 24rpx; | 
					
						
							|  |  |  |  |                         color: #6C7282; | 
					
						
							|  |  |  |  |                         text-align: center; | 
					
						
							|  |  |  |  |                         margin-top: 14rpx; | 
					
						
							|  |  |  |  |                         white-space: nowrap | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     .falls-card-company,.falls-card-pepleNumber | 
					
						
							|  |  |  |  |                         margin-top: 20rpx; | 
					
						
							|  |  |  |  |                         font-size: 24rpx; | 
					
						
							|  |  |  |  |                         color: #606060; | 
					
						
							|  |  |  |  |                         line-height: 25rpx; | 
					
						
							|  |  |  |  |                         text-align: left; | 
					
						
							|  |  |  |  |                     .falls-card-pepleNumber | 
					
						
							|  |  |  |  |                         display: flex; | 
					
						
							|  |  |  |  |                         justify-content: space-between; | 
					
						
							|  |  |  |  |                         align-items: center; | 
					
						
							|  |  |  |  |                         margin-top: 38rpx; | 
					
						
							|  |  |  |  |                         font-weight: 400; | 
					
						
							|  |  |  |  |                         font-size: 28rpx; | 
					
						
							|  |  |  |  |                         color: #6C7282; | 
					
						
							|  |  |  |  |                     .falls-card-matchingrate | 
					
						
							|  |  |  |  |                         margin-top: 10rpx; | 
					
						
							|  |  |  |  |                         display: flex; | 
					
						
							|  |  |  |  |                         justify-content: space-between; | 
					
						
							|  |  |  |  |                         align-items: center; | 
					
						
							|  |  |  |  |                         font-size: 21rpx; | 
					
						
							|  |  |  |  |                         color: #4778EC; | 
					
						
							|  |  |  |  |                         text-align: left; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | // 推荐卡片
 | 
					
						
							|  |  |  |  | .recommend-card::before | 
					
						
							|  |  |  |  |     position: absolute | 
					
						
							|  |  |  |  |     left: 0 | 
					
						
							|  |  |  |  |     top: 0 | 
					
						
							|  |  |  |  |     content: '' | 
					
						
							|  |  |  |  |     height: 60rpx | 
					
						
							|  |  |  |  |     width: 100% | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     height: 8rpx; | 
					
						
							|  |  |  |  |     background: linear-gradient( to left, #9E74FD 0%, #256BFA 100%); | 
					
						
							|  |  |  |  |     box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(0,54,170,0.15); | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  | .recommend-card | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |     padding: 24rpx | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |     .card-content | 
					
						
							|  |  |  |  |         position: relative; | 
					
						
							|  |  |  |  |         z-index: 2; | 
					
						
							|  |  |  |  |         .recommend-card-title | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             font-weight: 500; | 
					
						
							|  |  |  |  |             font-size: 32rpx; | 
					
						
							|  |  |  |  |             color: #333333; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |         .recommend-card-tip | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             font-weight: 400; | 
					
						
							|  |  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |  |             color: #6C7282; | 
					
						
							|  |  |  |  |             margin-top: 20rpx | 
					
						
							|  |  |  |  |         .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: 50rpx | 
					
						
							|  |  |  |  |             position: relative | 
					
						
							|  |  |  |  |         .recommend-card-line::before | 
					
						
							|  |  |  |  |             position: absolute | 
					
						
							|  |  |  |  |             content: '' | 
					
						
							|  |  |  |  |             left: 0 | 
					
						
							|  |  |  |  |             top: 0 | 
					
						
							|  |  |  |  |             transform: translate(-50% - 90rpx, -50%) | 
					
						
							|  |  |  |  |             width: 28rpx; | 
					
						
							|  |  |  |  |             height: 28rpx; | 
					
						
							|  |  |  |  |             background: #F4F4F4; | 
					
						
							|  |  |  |  |             border-radius: 50%; | 
					
						
							|  |  |  |  |         .recommend-card-line::after | 
					
						
							|  |  |  |  |             position: absolute | 
					
						
							|  |  |  |  |             content: '' | 
					
						
							|  |  |  |  |             right: 0 | 
					
						
							|  |  |  |  |             top: 0 | 
					
						
							|  |  |  |  |             transform: translate(50% + 90rpx, -50%) | 
					
						
							|  |  |  |  |             width: 28rpx; | 
					
						
							|  |  |  |  |             height: 28rpx; | 
					
						
							|  |  |  |  |             background: #F4F4F4; | 
					
						
							|  |  |  |  |             border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |         .recommend-card-controll | 
					
						
							|  |  |  |  |             display: flex | 
					
						
							|  |  |  |  |             align-items: center | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             justify-content: space-between | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |             margin-top: 40rpx | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |             padding: 0 6rpx; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |             .controll-yes | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 width: 124rpx; | 
					
						
							|  |  |  |  |                 height: 70rpx; | 
					
						
							|  |  |  |  |                 background: rgba(37,107,250,0.1); | 
					
						
							|  |  |  |  |                 border-radius: 12rpx 12rpx 12rpx 12rpx; | 
					
						
							|  |  |  |  |                 text-align: center; | 
					
						
							|  |  |  |  |                 line-height:70rpx | 
					
						
							|  |  |  |  |                 color: #256BFA | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |             .controll-no | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 width: 124rpx; | 
					
						
							|  |  |  |  |                 height: 66rpx; | 
					
						
							|  |  |  |  |                 line-height: 66rpx | 
					
						
							|  |  |  |  |                 border-radius: 12rpx 12rpx 12rpx 12rpx; | 
					
						
							|  |  |  |  |                 border: 2rpx solid #DEDEDE; | 
					
						
							|  |  |  |  |                 font-weight: 400; | 
					
						
							|  |  |  |  |                 font-size: 28rpx; | 
					
						
							|  |  |  |  |                 color: #333333; | 
					
						
							|  |  |  |  |                 text-align: center; | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |             .controll-yes:active, .controll-no:active | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  |                 width: 120rpx; | 
					
						
							|  |  |  |  |                 height: 66rpx; | 
					
						
							|  |  |  |  |                 line-height: 66rpx | 
					
						
							| 
									
										
										
										
											2025-03-28 15:19:42 +08:00
										 |  |  |  |                 background: #e8e8e8 | 
					
						
							|  |  |  |  |                 border: 2rpx solid #e8e8e8 | 
					
						
							| 
									
										
										
										
											2025-05-13 11:10:38 +08:00
										 |  |  |  | .isBut{ | 
					
						
							|  |  |  |  |     filter: grayscale(100%); | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2025-05-16 09:28:44 +08:00
										 |  |  |  | </style> |