flat: 暂存
This commit is contained in:
		
							
								
								
									
										748
									
								
								pages/index/components/index-one.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										748
									
								
								pages/index/components/index-one.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,748 @@ | |||||||
|  | <template> | ||||||
|  |     <view class="app-container"> | ||||||
|  |         <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> | ||||||
|  |             </view> | ||||||
|  |             <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> | ||||||
|  |             </view> | ||||||
|  |         </view> | ||||||
|  |         <view class="nav-filter"> | ||||||
|  |             <view class="filter-top" @touchmove.stop.prevent> | ||||||
|  |                 <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> | ||||||
|  |                     </view> | ||||||
|  |                 </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"> | ||||||
|  |                     <view | ||||||
|  |                         class="button-click filterbtm" | ||||||
|  |                         :class="{ active: pageState.search.order === item.value }" | ||||||
|  |                         v-for="item in rangeOptions" | ||||||
|  |                         @click="handelHostestSearch(item)" | ||||||
|  |                         :key="item.value" | ||||||
|  |                     > | ||||||
|  |                         {{ item.text }} | ||||||
|  |                     </view> | ||||||
|  |                 </view> | ||||||
|  |                 <view class="btm-right button-click" @click="openFilter"> | ||||||
|  |                     筛选 | ||||||
|  |                     <image class="right-sx" :class="{ active: showFilter }" src="@/static/icon/shaixun.png"></image> | ||||||
|  |                 </view> | ||||||
|  |             </view> | ||||||
|  |         </view> | ||||||
|  |         <view class="table-list"> | ||||||
|  |             <scroll-view :scroll-y="true" class="falls-scroll" @scroll="handleScroll" @scrolltolower="scrollBottom"> | ||||||
|  |                 <view class="falls" v-if="list.length"> | ||||||
|  |                     <custom-waterfalls-flow | ||||||
|  |                         :column="columnCount" | ||||||
|  |                         :columnSpace="columnSpace" | ||||||
|  |                         ref="waterfallsFlowRef" | ||||||
|  |                         :value="list" | ||||||
|  |                     > | ||||||
|  |                         <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> | ||||||
|  |                                     </view> | ||||||
|  |                                     <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> --> | ||||||
|  |                                 </view> | ||||||
|  |                             </view> | ||||||
|  |                             <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> | ||||||
|  |                                     </view> | ||||||
|  |                                 </view> | ||||||
|  |                             </view> | ||||||
|  |                         </template> | ||||||
|  |                     </custom-waterfalls-flow> | ||||||
|  |                     <loadmore ref="loadmoreRef"></loadmore> | ||||||
|  |                 </view> | ||||||
|  |                 <empty v-else pdTop="200"></empty> | ||||||
|  |             </scroll-view> | ||||||
|  |         </view> | ||||||
|  |         <!-- 筛选 --> | ||||||
|  |         <select-filter ref="selectFilterModel"></select-filter> | ||||||
|  |     </view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script setup> | ||||||
|  | import { reactive, inject, watch, ref, onMounted, watchEffect, nextTick } from 'vue'; | ||||||
|  | import img from '@/static/icon/filter.png'; | ||||||
|  | import dictLabel from '@/components/dict-Label/dict-Label.vue'; | ||||||
|  | const { $api, navTo, vacanciesTo, formatTotal } = inject('globalFunction'); | ||||||
|  | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
|  | import { storeToRefs } from 'pinia'; | ||||||
|  | import useUserStore from '@/stores/useUserStore'; | ||||||
|  | const { userInfo } = storeToRefs(useUserStore()); | ||||||
|  | import useDictStore from '@/stores/useDictStore'; | ||||||
|  | const { getTransformChildren, oneDictData } = useDictStore(); | ||||||
|  | import useLocationStore from '@/stores/useLocationStore'; | ||||||
|  | import selectFilter from '@/components/selectFilter/selectFilter.vue'; | ||||||
|  | import { useRecommedIndexedDBStore, jobRecommender } from '@/stores/useRecommedIndexedDBStore.js'; | ||||||
|  | import { useScrollDirection } from '@/hook/useScrollDirection'; | ||||||
|  | import { useColumnCount } from '@/hook/useColumnCount'; | ||||||
|  | const { isScrollingDown, handleScroll } = useScrollDirection(); | ||||||
|  | const recommedIndexDb = useRecommedIndexedDBStore(); | ||||||
|  |  | ||||||
|  | const waterfallsFlowRef = ref(null); | ||||||
|  | const loadmoreRef = ref(null); | ||||||
|  | const conditionSearch = ref({}); | ||||||
|  | const waterfallcolumn = ref(2); | ||||||
|  | const state = reactive({ | ||||||
|  |     tabIndex: 'all', | ||||||
|  | }); | ||||||
|  | const list = ref([]); | ||||||
|  | const pageState = reactive({ | ||||||
|  |     page: 0, | ||||||
|  |     total: 0, | ||||||
|  |     maxPage: 2, | ||||||
|  |     pageSize: 10, | ||||||
|  |     search: { | ||||||
|  |         order: 0, | ||||||
|  |     }, | ||||||
|  | }); | ||||||
|  | const inputText = ref(''); | ||||||
|  | const showFilter = ref(false); | ||||||
|  | const selectFilterModel = ref(null); | ||||||
|  | const showModel = ref(false); | ||||||
|  | const rangeOptions = ref([ | ||||||
|  |     { value: 0, text: '推荐' }, | ||||||
|  |     { value: 1, text: '最热' }, | ||||||
|  |     { value: 2, text: '最新发布' }, | ||||||
|  | ]); | ||||||
|  | const isLoaded = ref(false); | ||||||
|  | // 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 }, | ||||||
|  | // ]); | ||||||
|  |  | ||||||
|  | const { columnCount, columnSpace } = useColumnCount(() => { | ||||||
|  |     pageState.pageSize = 10 * (columnCount.value - 1); | ||||||
|  |     getJobRecommend('refresh'); | ||||||
|  |     nextTick(() => { | ||||||
|  |         waterfallsFlowRef.value?.refresh?.(); | ||||||
|  |         useLocationStore().getLocation(); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // onLoad(() => { | ||||||
|  | //     getJobRecommend('refresh'); | ||||||
|  | // }); | ||||||
|  |  | ||||||
|  | async function loadData() { | ||||||
|  |     try { | ||||||
|  |         if (isLoaded.value) return; | ||||||
|  |         isLoaded.value = true; | ||||||
|  |     } catch (err) { | ||||||
|  |         isLoaded.value = false; // 重置状态允许重试 | ||||||
|  |         throw err; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function scrollBottom() { | ||||||
|  |     loadmoreRef.value.change('loading'); | ||||||
|  |     if (state.tabIndex === 'all') { | ||||||
|  |         getJobRecommend(); | ||||||
|  |     } else { | ||||||
|  |         getJobList(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 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; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 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); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function nextDetail(job) { | ||||||
|  |     // 记录岗位类型,用作数据分析 | ||||||
|  |     if (job.jobCategory) { | ||||||
|  |         const recordData = recommedIndexDb.JobParameter(job); | ||||||
|  |         recommedIndexDb.addRecord(recordData); | ||||||
|  |     } | ||||||
|  |     navTo(`/packageA/pages/post/post?jobId=${btoa(job.jobId)}`); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 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; | ||||||
|  |         }, | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function handleFilterConfirm(e) { | ||||||
|  |     console.log(e); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function choosePosition(index) { | ||||||
|  |     state.tabIndex = index; | ||||||
|  |     list.value = []; | ||||||
|  |     if (index === 'all') { | ||||||
|  |         pageState.search = { | ||||||
|  |             order: pageState.search.order, | ||||||
|  |         }; | ||||||
|  |         inputText.value = ''; | ||||||
|  |         getJobRecommend('refresh'); | ||||||
|  |     } else { | ||||||
|  |         // const id = useUserStore().userInfo.jobTitleId.split(',')[index]; | ||||||
|  |         pageState.search.jobTitle = userInfo.value.jobTitle[index]; | ||||||
|  |         inputText.value = ''; | ||||||
|  |         getJobList('refresh'); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function handelHostestSearch(val) { | ||||||
|  |     pageState.search.order = val.value; | ||||||
|  |     if (state.tabIndex === 'all') { | ||||||
|  |         getJobRecommend('refresh'); | ||||||
|  |     } else { | ||||||
|  |         getJobList('refresh'); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 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, | ||||||
|  |         ...conditionSearch.value, | ||||||
|  |     }; | ||||||
|  |     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(); | ||||||
|  |  | ||||||
|  |                     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, | ||||||
|  |         // ...conditionSearch.value, | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     $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) { | ||||||
|  |             loadmoreRef.value?.change('noMore'); | ||||||
|  |         } else { | ||||||
|  |             loadmoreRef.value?.change('more'); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function dataToImg(data) { | ||||||
|  |     return data.map((item) => ({ | ||||||
|  |         ...item, | ||||||
|  |         image: img, | ||||||
|  |         hide: true, | ||||||
|  |     })); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | defineExpose({ loadData }); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="stylus" scoped> | ||||||
|  |  | ||||||
|  | .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; | ||||||
|  | // 推荐卡片 | ||||||
|  | .recommend-card::before | ||||||
|  |     position: absolute | ||||||
|  |     left: 0 | ||||||
|  |     top: 0 | ||||||
|  |     content: '' | ||||||
|  |     height: 60rpx | ||||||
|  |     width: 100% | ||||||
|  |     height: 8rpx; | ||||||
|  |     background: linear-gradient( to left, #9E74FD 0%, #256BFA 100%); | ||||||
|  |     box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(0,54,170,0.15); | ||||||
|  | .recommend-card | ||||||
|  |     padding: 24rpx | ||||||
|  |     .card-content | ||||||
|  |         position: relative; | ||||||
|  |         z-index: 2; | ||||||
|  |         .recommend-card-title | ||||||
|  |             font-weight: 500; | ||||||
|  |             font-size: 32rpx; | ||||||
|  |             color: #333333; | ||||||
|  |         .recommend-card-tip | ||||||
|  |             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%; | ||||||
|  |         .recommend-card-controll | ||||||
|  |             display: flex | ||||||
|  |             align-items: center | ||||||
|  |             justify-content: space-between | ||||||
|  |             margin-top: 40rpx | ||||||
|  |             padding: 0 6rpx; | ||||||
|  |             .controll-yes | ||||||
|  |                 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 | ||||||
|  |             .controll-no | ||||||
|  |                 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; | ||||||
|  |             .controll-yes:active, .controll-no:active | ||||||
|  |                 width: 120rpx; | ||||||
|  |                 height: 66rpx; | ||||||
|  |                 line-height: 66rpx | ||||||
|  |                 background: #e8e8e8 | ||||||
|  |                 border: 2rpx solid #e8e8e8 | ||||||
|  | .isBut{ | ||||||
|  |     filter: grayscale(100%); | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										205
									
								
								pages/index/components/index-two.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										205
									
								
								pages/index/components/index-two.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,205 @@ | |||||||
|  | <template> | ||||||
|  |     <view class="app-container"> | ||||||
|  |         <view class="nav-filter"> | ||||||
|  |             <view class="filter-top" @touchmove.stop.prevent> | ||||||
|  |                 <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> | ||||||
|  |                     </view> | ||||||
|  |                 </scroll-view> | ||||||
|  |                 <view class="jobs-add button-click" @click="navTo('/pages/search/search')"> | ||||||
|  |                     <uni-icons class="iconsearch" color="#666D7F" type="search" size="18"></uni-icons> | ||||||
|  |                     <text>搜索</text> | ||||||
|  |                 </view> | ||||||
|  |             </view> | ||||||
|  |         </view> | ||||||
|  |         <view class="cards"> | ||||||
|  |             <scroll-view :scroll-y="true" class="tab-scroll"> | ||||||
|  |                 <view class="scroll-content"> | ||||||
|  |                     <custom-waterfalls-flow ref="waterfallsFlowRef" :value="data.list"> | ||||||
|  |                         <template v-slot:default="item"> | ||||||
|  |                             <view class="item"> | ||||||
|  |                                 <view class="title">{{ item.title }}</view> | ||||||
|  |                                 <view class="desc">{{ item.desc }}</view> | ||||||
|  |                             </view> | ||||||
|  |                         </template> | ||||||
|  |                     </custom-waterfalls-flow> | ||||||
|  |                 </view> | ||||||
|  |             </scroll-view> | ||||||
|  |         </view> | ||||||
|  |     </view> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script setup> | ||||||
|  | import { reactive, inject, watch, ref, onMounted, watchEffect, nextTick } from 'vue'; | ||||||
|  | const { $api, navTo } = inject('globalFunction'); | ||||||
|  | import { storeToRefs } from 'pinia'; | ||||||
|  | import useUserStore from '@/stores/useUserStore'; | ||||||
|  |  | ||||||
|  | const { userInfo } = storeToRefs(useUserStore()); | ||||||
|  | const isLoaded = ref(false); | ||||||
|  | const waterfallsFlowRef = ref(null); | ||||||
|  | const state = reactive({ | ||||||
|  |     tabIndex: 'all', | ||||||
|  | }); | ||||||
|  | const data = reactive({ | ||||||
|  |     list: [ | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/200x500.png/ff0000', | ||||||
|  |             title: '我是标题1', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述1', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/200x200.png/2878ff', | ||||||
|  |             title: '我是标题2', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述2', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/200x100.png/FFB6C1', | ||||||
|  |             title: '我是标题3', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述3', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/200x300.png/9400D3', | ||||||
|  |             title: '我是标题4', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述4', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/100x240.png/B0E0E6', | ||||||
|  |             title: '我是标题5', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述5', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/140x280.png/7FFFAA', | ||||||
|  |             title: '我是标题6', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述6', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/40x60.png/EEE8AA', | ||||||
|  |             title: '我是标题7', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述7', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/140x280.png/7FFFAA', | ||||||
|  |             title: '我是标题6', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述6', | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             image: 'https://via.placeholder.com/40x60.png/EEE8AA', | ||||||
|  |             title: '我是标题7', | ||||||
|  |             desc: '描述描述描述描述描述描述描述描述7', | ||||||
|  |         }, | ||||||
|  |     ], | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | async function loadData() { | ||||||
|  |     try { | ||||||
|  |         if (isLoaded.value) return; | ||||||
|  |         isLoaded.value = true; | ||||||
|  |     } catch (err) { | ||||||
|  |         isLoaded.value = false; // 重置状态允许重试 | ||||||
|  |         throw err; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | async function choosePosition() {} | ||||||
|  |  | ||||||
|  | defineExpose({ loadData }); | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style lang="stylus" scoped> | ||||||
|  | .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 | ||||||
|  |     .cards | ||||||
|  |         flex: 1; | ||||||
|  |         overflow: hidden; | ||||||
|  |         .tab-scroll | ||||||
|  |             height: 100%; | ||||||
|  |             white-space: nowrap; | ||||||
|  |             text-overflow: clip; | ||||||
|  |             .scroll-content{ | ||||||
|  |                 padding: 24rpx | ||||||
|  |             } | ||||||
|  |  | ||||||
|  | .nav-filter | ||||||
|  |     padding: 16rpx 28rpx 30rpx 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) | ||||||
|  | </style> | ||||||
| @@ -1,735 +1,153 @@ | |||||||
| <template> | <template> | ||||||
|     <view class="app-container"> |     <view class="app-custom-root"> | ||||||
|         <view class="nav-hidden hidden-animation" :class="{ 'hidden-height': isScrollingDown }"> |         <view class="app-container"> | ||||||
|             <view class="container-search"> |             <!-- 主体内容区域 --> | ||||||
|                 <view class="search-input button-click" @click="navTo('/pages/search/search')"> |             <view class="container-main"> | ||||||
|                     <uni-icons class="iconsearch" color="#666666" type="search" size="18"></uni-icons> |                 <swiper class="swiper" :current="state.current" @change="changeSwiperType"> | ||||||
|                     <text class="inpute">职位名称、薪资要求等</text> |                     <swiper-item class="swiper-item" v-for="(_, index) in 2" :key="index"> | ||||||
|                 </view> |                         <!-- #ifndef MP-WEIXIN --> | ||||||
|                 <view class="chart button-click">职业图谱</view> |                         <component :is="components[index]" :ref="(el) => handelComponentsRef(el, index)" /> | ||||||
|             </view> |                         <!-- #endif --> | ||||||
|             <view class="cards"> |                         <!-- #ifdef MP-WEIXIN --> | ||||||
|                 <view class="card btn-feel" @click="navTo('/pages/nearby/nearby')"> |                         <IndexOne v-show="currentIndex === 0" :ref="(el) => handelComponentsRef(el, index)" /> | ||||||
|                     <view class="card-title">附近工作</view> |                         <IndexTwo v-show="currentIndex === 1" :ref="(el) => handelComponentsRef(el, index)" /> | ||||||
|                     <view class="card-text">好岗职等你来</view> |                         <!-- #endif --> | ||||||
|                 </view> |                     </swiper-item> | ||||||
|                 <view class="card btn-feel" @click="navTo('/packageA/pages/choiceness/choiceness')"> |                 </swiper> | ||||||
|                     <view class="card-title">精选企业</view> |  | ||||||
|                     <view class="card-text">优选职得信赖</view> |  | ||||||
|                 </view> |  | ||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> | ||||||
|         <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> |  | ||||||
|                     </view> |  | ||||||
|                 </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"> |  | ||||||
|                     <view |  | ||||||
|                         class="button-click filterbtm" |  | ||||||
|                         :class="{ active: pageState.search.order === item.value }" |  | ||||||
|                         v-for="item in rangeOptions" |  | ||||||
|                         @click="handelHostestSearch(item)" |  | ||||||
|                         :key="item.value" |  | ||||||
|                     > |  | ||||||
|                         {{ item.text }} |  | ||||||
|                     </view> |  | ||||||
|                 </view> |  | ||||||
|                 <view class="btm-right button-click" @click="openFilter"> |  | ||||||
|                     筛选 |  | ||||||
|                     <image class="right-sx" :class="{ active: showFilter }" src="@/static/icon/shaixun.png"></image> |  | ||||||
|                 </view> |  | ||||||
|             </view> |  | ||||||
|         </view> |  | ||||||
|         <view class="table-list"> |  | ||||||
|             <scroll-view :scroll-y="true" class="falls-scroll" @scroll="handleScroll" @scrolltolower="scrollBottom"> |  | ||||||
|                 <view class="falls" v-if="list.length"> |  | ||||||
|                     <custom-waterfalls-flow |  | ||||||
|                         :column="columnCount" |  | ||||||
|                         :columnSpace="columnSpace" |  | ||||||
|                         ref="waterfallsFlowRef" |  | ||||||
|                         :value="list" |  | ||||||
|                     > |  | ||||||
|                         <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> |  | ||||||
|                                     </view> |  | ||||||
|                                     <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> --> |  | ||||||
|                                 </view> |  | ||||||
|                             </view> |  | ||||||
|                             <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> |  | ||||||
|                                     </view> |  | ||||||
|                                 </view> |  | ||||||
|                             </view> |  | ||||||
|                         </template> |  | ||||||
|                     </custom-waterfalls-flow> |  | ||||||
|                     <loadmore ref="loadmoreRef"></loadmore> |  | ||||||
|                 </view> |  | ||||||
|                 <empty v-else pdTop="200"></empty> |  | ||||||
|             </scroll-view> |  | ||||||
|         </view> |  | ||||||
|         <!-- 筛选 --> |  | ||||||
|         <select-filter ref="selectFilterModel"></select-filter> |  | ||||||
|     </view> |     </view> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, inject, watch, ref, onMounted, watchEffect, nextTick } from 'vue'; | import { reactive, inject, watch, ref, onMounted } from 'vue'; | ||||||
| import img from '@/static/icon/filter.png'; |  | ||||||
| import dictLabel from '@/components/dict-Label/dict-Label.vue'; |  | ||||||
| const { $api, navTo, vacanciesTo, formatTotal } = inject('globalFunction'); |  | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
|  | import IndexOne from './components/index-one.vue'; | ||||||
|  | import IndexTwo from './components/index-two.vue'; | ||||||
|  | const loadedMap = reactive([false, false]); | ||||||
|  | const swiperRefs = [ref(null), ref(null)]; | ||||||
|  | const components = [IndexOne, IndexTwo]; | ||||||
| import { storeToRefs } from 'pinia'; | import { storeToRefs } from 'pinia'; | ||||||
| import useUserStore from '@/stores/useUserStore'; | import { useReadMsg } from '@/stores/useReadMsg'; | ||||||
| const { userInfo } = storeToRefs(useUserStore()); | const { unreadCount } = storeToRefs(useReadMsg()); | ||||||
| import useDictStore from '@/stores/useDictStore'; |  | ||||||
| const { getTransformChildren, oneDictData } = useDictStore(); |  | ||||||
| import useLocationStore from '@/stores/useLocationStore'; |  | ||||||
| import selectFilter from '@/components/selectFilter/selectFilter.vue'; |  | ||||||
| import { useRecommedIndexedDBStore, jobRecommender } from '@/stores/useRecommedIndexedDBStore.js'; |  | ||||||
| import { useScrollDirection } from '@/hook/useScrollDirection'; |  | ||||||
| import { useColumnCount } from '@/hook/useColumnCount'; |  | ||||||
| const { isScrollingDown, handleScroll } = useScrollDirection(); |  | ||||||
| const recommedIndexDb = useRecommedIndexedDBStore(); |  | ||||||
|  |  | ||||||
| const waterfallsFlowRef = ref(null); | onShow(() => { | ||||||
| const loadmoreRef = ref(null); |     // 获取消息列表 | ||||||
| const conditionSearch = ref({}); |     useReadMsg().fetchMessages(); | ||||||
| const waterfallcolumn = ref(2); | }); | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
|     tabIndex: 'all', |     current: 0, | ||||||
| }); |     all: [{}], | ||||||
| const list = ref([]); |  | ||||||
| const pageState = reactive({ |  | ||||||
|     page: 0, |  | ||||||
|     total: 0, |  | ||||||
|     maxPage: 2, |  | ||||||
|     pageSize: 10, |  | ||||||
|     search: { |  | ||||||
|         order: 0, |  | ||||||
|     }, |  | ||||||
| }); |  | ||||||
| const inputText = ref(''); |  | ||||||
| const showFilter = ref(false); |  | ||||||
| const selectFilterModel = ref(null); |  | ||||||
| const showModel = ref(false); |  | ||||||
| const rangeOptions = ref([ |  | ||||||
|     { value: 0, text: '推荐' }, |  | ||||||
|     { value: 1, text: '最热' }, |  | ||||||
|     { value: 2, text: '最新发布' }, |  | ||||||
| ]); |  | ||||||
| // 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 }, |  | ||||||
| // ]); |  | ||||||
|  |  | ||||||
| const { columnCount, columnSpace } = useColumnCount(() => { |  | ||||||
|     pageState.pageSize = 10 * (columnCount.value - 1); |  | ||||||
|     getJobRecommend('refresh'); |  | ||||||
|     nextTick(() => { |  | ||||||
|         waterfallsFlowRef.value?.refresh?.(); |  | ||||||
|         useLocationStore().getLocation(); |  | ||||||
|     }); |  | ||||||
| }); | }); | ||||||
|  |  | ||||||
| // onLoad(() => { | onMounted(() => { | ||||||
| //     getJobRecommend('refresh'); |     handleTabChange(state.current); | ||||||
| // }); | }); | ||||||
|  |  | ||||||
| function scrollBottom() { | const handelComponentsRef = (el, index) => { | ||||||
|     loadmoreRef.value.change('loading'); |     if (el) { | ||||||
|     if (state.tabIndex === 'all') { |         swiperRefs[index].value = el; | ||||||
|         getJobRecommend(); |     } | ||||||
|     } else { | }; | ||||||
|         getJobList(); | // 查看消息类型 | ||||||
|  | function changeSwiperType(e) { | ||||||
|  |     const index = e.detail.current; | ||||||
|  |     state.current = index; | ||||||
|  |     handleTabChange(index); | ||||||
|  | } | ||||||
|  | function changeType(index) { | ||||||
|  |     state.current = index; | ||||||
|  |     handleTabChange(index); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function handleTabChange(index) { | ||||||
|  |     if (!loadedMap[index]) { | ||||||
|  |         swiperRefs[index].value?.loadData(); | ||||||
|  |         loadedMap[index] = true; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function findJob(job) { | // 查看消息类型 | ||||||
|     if (job.isBut) { | function changeSwiperMsgType(e) { | ||||||
|         $api.msg('已确认'); |     const currented = e.detail.current; | ||||||
|     } else { |     state.current = currented; | ||||||
|         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; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function nextDetail(job) { |  | ||||||
|     // 记录岗位类型,用作数据分析 |  | ||||||
|     if (job.jobCategory) { |  | ||||||
|         const recordData = recommedIndexDb.JobParameter(job); |  | ||||||
|         recommedIndexDb.addRecord(recordData); |  | ||||||
|     } |  | ||||||
|     navTo(`/packageA/pages/post/post?jobId=${btoa(job.jobId)}`); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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; |  | ||||||
|         }, |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function handleFilterConfirm(e) { |  | ||||||
|     console.log(e); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function choosePosition(index) { |  | ||||||
|     state.tabIndex = index; |  | ||||||
|     list.value = []; |  | ||||||
|     if (index === 'all') { |  | ||||||
|         pageState.search = { |  | ||||||
|             order: pageState.search.order, |  | ||||||
|         }; |  | ||||||
|         inputText.value = ''; |  | ||||||
|         getJobRecommend('refresh'); |  | ||||||
|     } else { |  | ||||||
|         // const id = useUserStore().userInfo.jobTitleId.split(',')[index]; |  | ||||||
|         pageState.search.jobTitle = userInfo.value.jobTitle[index]; |  | ||||||
|         inputText.value = ''; |  | ||||||
|         getJobList('refresh'); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function handelHostestSearch(val) { |  | ||||||
|     pageState.search.order = val.value; |  | ||||||
|     if (state.tabIndex === 'all') { |  | ||||||
|         getJobRecommend('refresh'); |  | ||||||
|     } else { |  | ||||||
|         getJobList('refresh'); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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, |  | ||||||
|         ...conditionSearch.value, |  | ||||||
|     }; |  | ||||||
|     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(); |  | ||||||
|  |  | ||||||
|                     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, |  | ||||||
|         // ...conditionSearch.value, |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     $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) { |  | ||||||
|             loadmoreRef.value?.change('noMore'); |  | ||||||
|         } else { |  | ||||||
|             loadmoreRef.value?.change('more'); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function dataToImg(data) { |  | ||||||
|     return data.map((item) => ({ |  | ||||||
|         ...item, |  | ||||||
|         image: img, |  | ||||||
|         hide: true, |  | ||||||
|     })); |  | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
|  | .app-custom-root { | ||||||
| .app-container |     position: fixed; | ||||||
|     width: 100%; |     z-index: 10; | ||||||
|     height: calc(100vh - var(--window-top) - var(--status-bar-height) - var(--window-bottom)); |     width: 100vw; | ||||||
|     background: url('@/static/icon/background2.png') 0 0 no-repeat; |     height: calc(100% - var(--window-bottom)); | ||||||
|     background-size: 100% 728rpx; |     overflow: hidden; | ||||||
|     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; |  | ||||||
| // 推荐卡片 |  | ||||||
| .recommend-card::before |  | ||||||
|     position: absolute |  | ||||||
|     left: 0 |  | ||||||
|     top: 0 |  | ||||||
|     content: '' |  | ||||||
|     height: 60rpx |  | ||||||
|     width: 100% |  | ||||||
|     height: 8rpx; |  | ||||||
|     background: linear-gradient( to left, #9E74FD 0%, #256BFA 100%); |  | ||||||
|     box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(0,54,170,0.15); |  | ||||||
| .recommend-card |  | ||||||
|     padding: 24rpx |  | ||||||
|     .card-content |  | ||||||
|         position: relative; |  | ||||||
|         z-index: 2; |  | ||||||
|         .recommend-card-title |  | ||||||
|             font-weight: 500; |  | ||||||
|             font-size: 32rpx; |  | ||||||
|             color: #333333; |  | ||||||
|         .recommend-card-tip |  | ||||||
|             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%; |  | ||||||
|         .recommend-card-controll |  | ||||||
|             display: flex |  | ||||||
|             align-items: center |  | ||||||
|             justify-content: space-between |  | ||||||
|             margin-top: 40rpx |  | ||||||
|             padding: 0 6rpx; |  | ||||||
|             .controll-yes |  | ||||||
|                 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 |  | ||||||
|             .controll-no |  | ||||||
|                 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; |  | ||||||
|             .controll-yes:active, .controll-no:active |  | ||||||
|                 width: 120rpx; |  | ||||||
|                 height: 66rpx; |  | ||||||
|                 line-height: 66rpx |  | ||||||
|                 background: #e8e8e8 |  | ||||||
|                 border: 2rpx solid #e8e8e8 |  | ||||||
| .isBut{ |  | ||||||
|     filter: grayscale(100%); |  | ||||||
| } | } | ||||||
|  | .app-container { | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     height: 100%; | ||||||
|  |     width: 100%; | ||||||
|  |     .container-header { | ||||||
|  |         height: calc(88rpx - 14rpx); | ||||||
|  |         text-align: center; | ||||||
|  |         line-height: calc(88rpx - 14rpx); | ||||||
|  |         font-size: 32rpx; | ||||||
|  |         display: flex; | ||||||
|  |         flex-direction: row; | ||||||
|  |         align-items: center; | ||||||
|  |         padding: 16rpx 44rpx 36rpx 44rpx; | ||||||
|  |         background: url('@/static/icon/msgTopbg.png') 0 0 no-repeat; | ||||||
|  |         background-size: 100% 100%; | ||||||
|  |         .header-title { | ||||||
|  |             color: #000000; | ||||||
|  |             font-weight: bold; | ||||||
|  |         } | ||||||
|  |         .header-btnLf { | ||||||
|  |             display: flex; | ||||||
|  |             justify-content: flex-start; | ||||||
|  |             align-items: center; | ||||||
|  |             width: calc(60rpx * 3); | ||||||
|  |             font-weight: 500; | ||||||
|  |             font-size: 40rpx; | ||||||
|  |             color: #696969; | ||||||
|  |             margin-right: 44rpx; | ||||||
|  |             position: relative; | ||||||
|  |             .btns-wd{ | ||||||
|  |                 position: absolute | ||||||
|  |                 top: 2rpx; | ||||||
|  |                 right: 2rpx | ||||||
|  |                 width: 16rpx; | ||||||
|  |                 height: 16rpx; | ||||||
|  |                 background: #F73636; | ||||||
|  |                 border-radius: 50%; | ||||||
|  |                 border: 4rpx solid #EEEEFF; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         .active { | ||||||
|  |             font-weight: 600; | ||||||
|  |             font-size: 40rpx; | ||||||
|  |             color: #000000; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .container-main { | ||||||
|  |     flex: 1; | ||||||
|  |     overflow: hidden; | ||||||
|  |     background-color: #f4f4f4; | ||||||
|  | } | ||||||
|  | .main-scroll { | ||||||
|  |     width: 100% | ||||||
|  |     height: 100%; | ||||||
|  | } | ||||||
|  | .scrollmain{ | ||||||
|  |     padding: 28rpx | ||||||
|  | } | ||||||
|  | .swiper | ||||||
|  |     height: 100%; | ||||||
|  |     width: 100% | ||||||
|  |     .list | ||||||
|  |         width: 100% | ||||||
|  |         display: flex; | ||||||
|  |         flex-direction: column; | ||||||
| </style> | </style> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 史典卓
					史典卓