首页卡片开发
This commit is contained in:
		| @@ -6,6 +6,7 @@ | |||||||
|         > |         > | ||||||
|             <!-- 顶部头部区域 --> |             <!-- 顶部头部区域 --> | ||||||
|             <view |             <view | ||||||
|  |                 v-if="title" | ||||||
|                 class="container-header" |                 class="container-header" | ||||||
|                 :style="border ? { borderBottom: `2rpx solid ${borderColor}` } : { borderBottom: 'none' }" |                 :style="border ? { borderBottom: `2rpx solid ${borderColor}` } : { borderBottom: 'none' }" | ||||||
|             > |             > | ||||||
| @@ -49,7 +50,7 @@ const emit = defineEmits(['onScrollBottom']); | |||||||
| defineProps({ | defineProps({ | ||||||
|     title: { |     title: { | ||||||
|         type: String, |         type: String, | ||||||
|         default: '标题', |         default: '', | ||||||
|     }, |     }, | ||||||
|     border: { |     border: { | ||||||
|         type: Boolean, |         type: Boolean, | ||||||
|   | |||||||
| @@ -154,6 +154,79 @@ watch(() => userInfo.value, (newUserInfo, oldUserInfo) => { | |||||||
|  |  | ||||||
| // 切换tab | // 切换tab | ||||||
| const switchTab = (item, index) => { | const switchTab = (item, index) => { | ||||||
|  |     // 检查是否为"发布岗位"页面,需要判断企业信息是否完整 | ||||||
|  |     if (item.path === '/pages/job/publishJob') { | ||||||
|  |         // 检查用户是否已登录 | ||||||
|  |         const token = uni.getStorageSync('token') || ''; | ||||||
|  |         const hasLogin = userStore.hasLogin; | ||||||
|  |          | ||||||
|  |         if (!token || !hasLogin) { | ||||||
|  |             // 未登录,发送事件显示登录弹窗 | ||||||
|  |             uni.$emit('showLoginModal'); | ||||||
|  |             return; // 不进行页面跳转 | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         // 已登录,检查企业信息是否完整 | ||||||
|  |         const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|  |         const storeUserInfo = userInfo.value || {}; | ||||||
|  |         const currentUserInfo = storeUserInfo.id ? storeUserInfo : cachedUserInfo; | ||||||
|  |          | ||||||
|  |         // 判断企业信息字段company是否为null或undefined | ||||||
|  |         if (!currentUserInfo.company || currentUserInfo.company === null) { | ||||||
|  |             // 企业信息为空,跳转到企业信息补全页面 | ||||||
|  |             uni.navigateTo({ | ||||||
|  |                 url: '/pages/complete-info/company-info', | ||||||
|  |             }); | ||||||
|  |         } else { | ||||||
|  |             // 企业信息完整,跳转到发布岗位页面 | ||||||
|  |             uni.navigateTo({ | ||||||
|  |                 url: '/pages/job/publishJob', | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         currentItem.value = item.id; | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // 检查是否为"我的"页面,需要登录验证和用户类型判断 | ||||||
|  |     if (item.path === '/pages/mine/mine') { | ||||||
|  |         // 检查用户是否已登录 | ||||||
|  |         const token = uni.getStorageSync('token') || ''; | ||||||
|  |         const hasLogin = userStore.hasLogin; | ||||||
|  |          | ||||||
|  |         if (!token || !hasLogin) { | ||||||
|  |             // 未登录,发送事件显示登录弹窗 | ||||||
|  |             uni.$emit('showLoginModal'); | ||||||
|  |             return; // 不进行页面跳转 | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         // 已登录,根据用户类型跳转到不同的"我的"页面 | ||||||
|  |         const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|  |         const storeIsCompanyUser = userInfo.value?.isCompanyUser; | ||||||
|  |         const cachedIsCompanyUser = cachedUserInfo.isCompanyUser; | ||||||
|  |          | ||||||
|  |         // 获取用户类型 | ||||||
|  |         const userType = Number(storeIsCompanyUser !== undefined ? storeIsCompanyUser : (cachedIsCompanyUser !== undefined ? cachedIsCompanyUser : 1)); | ||||||
|  |          | ||||||
|  |         let targetPath = '/pages/mine/mine'; // 默认求职者页面 | ||||||
|  |          | ||||||
|  |         if (userType === 0) { | ||||||
|  |             // 企业用户,跳转到企业我的页面 | ||||||
|  |             targetPath = '/pages/mine/company-mine'; | ||||||
|  |         } else { | ||||||
|  |             // 求职者或其他用户类型,跳转到普通我的页面 | ||||||
|  |             targetPath = '/pages/mine/mine'; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         // 跳转到对应的页面 | ||||||
|  |         uni.navigateTo({ | ||||||
|  |             url: targetPath, | ||||||
|  |         }); | ||||||
|  |          | ||||||
|  |         currentItem.value = item.id; | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  |      | ||||||
|     // 判断是否为 tabBar 页面 |     // 判断是否为 tabBar 页面 | ||||||
|     const tabBarPages = [ |     const tabBarPages = [ | ||||||
|         '/pages/index/index', |         '/pages/index/index', | ||||||
| @@ -164,12 +237,12 @@ const switchTab = (item, index) => { | |||||||
|     ]; |     ]; | ||||||
|      |      | ||||||
|     if (tabBarPages.includes(item.path)) { |     if (tabBarPages.includes(item.path)) { | ||||||
|         // tabBar 页面使用 switchTab |         // TabBar 页面使用 redirectTo 避免页面栈溢出 | ||||||
|         uni.navigateTo({ |         uni.redirectTo({ | ||||||
|             url: item.path, |             url: item.path, | ||||||
|         }); |         }); | ||||||
|     } else { |     } else { | ||||||
|         // 非 tabBar 页面使用 navigateTo |         // 非 TabBar 页面使用 navigateTo | ||||||
|         uni.navigateTo({ |         uni.navigateTo({ | ||||||
|             url: item.path, |             url: item.path, | ||||||
|         }); |         }); | ||||||
|   | |||||||
| @@ -144,7 +144,7 @@ onMounted(() => { | |||||||
| }); | }); | ||||||
|  |  | ||||||
| const changeItem = (item) => { | const changeItem = (item) => { | ||||||
|     // 判断是否为 tabBar 页面 |     // 判断是否为 TabBar 页面 | ||||||
|     const tabBarPages = [ |     const tabBarPages = [ | ||||||
|         '/pages/index/index', |         '/pages/index/index', | ||||||
|         '/pages/careerfair/careerfair',  |         '/pages/careerfair/careerfair',  | ||||||
| @@ -154,12 +154,12 @@ const changeItem = (item) => { | |||||||
|     ]; |     ]; | ||||||
|      |      | ||||||
|     if (tabBarPages.includes(item.path)) { |     if (tabBarPages.includes(item.path)) { | ||||||
|         // tabBar 页面使用 switchTab |         // TabBar 页面使用 redirectTo 避免页面栈溢出 | ||||||
|         uni.switchTab({ |         uni.redirectTo({ | ||||||
|             url: item.path, |             url: item.path, | ||||||
|         }); |         }); | ||||||
|     } else { |     } else { | ||||||
|         // 非 tabBar 页面使用 navigateTo |         // 非 TabBar 页面使用 navigateTo | ||||||
|         uni.navigateTo({ |         uni.navigateTo({ | ||||||
|             url: item.path, |             url: item.path, | ||||||
|         }); |         }); | ||||||
|   | |||||||
| @@ -1,16 +1,5 @@ | |||||||
| <template> | <template> | ||||||
| 	<AppLayout | 	<view class="page-container"> | ||||||
| 	    title="添加工作经历" |  | ||||||
| 	    border |  | ||||||
| 	    back-gorund-color="#ffffff" |  | ||||||
| 	    :show-bg-image="false" |  | ||||||
| 	> |  | ||||||
| 	    <template #headerleft> |  | ||||||
| 	        <view class="btn mar_le20 button-click" @click="navBack">取消</view> |  | ||||||
| 	    </template> |  | ||||||
| 	    <template #headerright> |  | ||||||
| 	        <view class="btn mar_ri20 button-click" @click="handleConfirm">确认</view> |  | ||||||
| 	    </template> |  | ||||||
| 		<view class="content"> | 		<view class="content"> | ||||||
| 			<view class="content-input"> | 			<view class="content-input"> | ||||||
| 			    <view class="input-titile">公司名称</view> | 			    <view class="input-titile">公司名称</view> | ||||||
| @@ -44,8 +33,12 @@ | |||||||
| 				<textarea class="textarea-con" v-model="formData.description" placeholder-style="font-size: 16px" maxlength="500" placeholder="请输入工作描述"/> | 				<textarea class="textarea-con" v-model="formData.description" placeholder-style="font-size: 16px" maxlength="500" placeholder="请输入工作描述"/> | ||||||
| 			</view> | 			</view> | ||||||
| 		</view> | 		</view> | ||||||
| 	</AppLayout> |  | ||||||
| 		 | 		 | ||||||
|  | 		<!-- 底部确认按钮 --> | ||||||
|  | 		<view class="bottom-confirm-btn"> | ||||||
|  | 			<view class="confirm-btn" @click="handleConfirm">确认</view> | ||||||
|  | 		</view> | ||||||
|  | 	</view> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| @@ -206,7 +199,6 @@ | |||||||
| 			console.log('页面类型:', pageType.value); | 			console.log('页面类型:', pageType.value); | ||||||
| 			 | 			 | ||||||
| 			let resData; | 			let resData; | ||||||
| 			alert(editData.value.id) |  | ||||||
| 			// 根据页面类型调用不同的接口 | 			// 根据页面类型调用不同的接口 | ||||||
| 			if (pageType.value === 'edit' && editData.value?.id) { | 			if (pageType.value === 'edit' && editData.value?.id) { | ||||||
| 				// 编辑模式:调用更新接口 | 				// 编辑模式:调用更新接口 | ||||||
| @@ -234,12 +226,18 @@ | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
|  | .page-container { | ||||||
|  |     min-height: 100vh; | ||||||
|  |     background-color: #ffffff; | ||||||
|  |     position: relative; | ||||||
|  | } | ||||||
|  |  | ||||||
| .content{ | .content{ | ||||||
|     padding: 28rpx; |     padding: 28rpx; | ||||||
|     display: flex; |     display: flex; | ||||||
|     flex-direction: column; |     flex-direction: column; | ||||||
|     justify-content: flex-start |     justify-content: flex-start; | ||||||
|     height: calc(100% - 120rpx) |     padding-bottom: 120rpx; | ||||||
| } | } | ||||||
| .content-input | .content-input | ||||||
|     margin-bottom: 52rpx |     margin-bottom: 52rpx | ||||||
| @@ -328,6 +326,30 @@ | |||||||
| 			line-height: 20rpx | 			line-height: 20rpx | ||||||
| 			display: flex | 			display: flex | ||||||
| 			align-items: center | 			align-items: center | ||||||
|  |  | ||||||
|  | // 底部确认按钮样式 | ||||||
|  | .bottom-confirm-btn | ||||||
|  | 	position: fixed | ||||||
|  | 	bottom: 0 | ||||||
|  | 	left: 0 | ||||||
|  | 	right: 0 | ||||||
|  | 	background-color: #ffffff | ||||||
|  | 	padding: 20rpx 28rpx | ||||||
|  | 	border-top: 2rpx solid #EBEBEB | ||||||
|  | 	z-index: 999 | ||||||
|  | 	 | ||||||
|  | 	.confirm-btn | ||||||
|  | 		width: 100% | ||||||
|  | 		height: 90rpx | ||||||
|  | 		background: #256BFA | ||||||
|  | 		border-radius: 12rpx | ||||||
|  | 		font-weight: 500 | ||||||
|  | 		font-size: 32rpx | ||||||
|  | 		color: #FFFFFF | ||||||
|  | 		text-align: center | ||||||
|  | 		line-height: 90rpx | ||||||
|  | 		button-click: true | ||||||
|  |  | ||||||
| // .content-sex | // .content-sex | ||||||
| //     height: 110rpx; | //     height: 110rpx; | ||||||
| //     display: flex | //     display: flex | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ | |||||||
|                 <input |                 <input | ||||||
|                     class="input-con triangle" |                     class="input-con triangle" | ||||||
|                     disabled |                     disabled | ||||||
|                     v-if="!state.jobsText.length" |                     v-if="!state.jobsText || !state.jobsText.length" | ||||||
|                     placeholder="请选择您的求职岗位" |                     placeholder="请选择您的求职岗位" | ||||||
|                 /> |                 /> | ||||||
|                 <view class="input-nx" @click="changeJobs" v-else> |                 <view class="input-nx" @click="changeJobs" v-else> | ||||||
| @@ -40,6 +40,7 @@ | |||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> | ||||||
|         <SelectJobs ref="selectJobsModel"></SelectJobs> |         <SelectJobs ref="selectJobsModel"></SelectJobs> | ||||||
|  |         <SelectPopup ref="selectPopupRef"></SelectPopup> | ||||||
|     </AppLayout> |     </AppLayout> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| @@ -47,16 +48,24 @@ | |||||||
| import { reactive, inject, watch, ref, onMounted, computed } from 'vue'; | import { reactive, inject, watch, ref, onMounted, computed } from 'vue'; | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
| import SelectJobs from '@/components/selectJobs/selectJobs.vue'; | import SelectJobs from '@/components/selectJobs/selectJobs.vue'; | ||||||
|  | import SelectPopup from '@/components/selectPopup/selectPopup.vue'; | ||||||
| const { $api, navTo, navBack, config } = inject('globalFunction'); | const { $api, navTo, navBack, config } = inject('globalFunction'); | ||||||
| const openSelectPopup = inject('openSelectPopup'); |  | ||||||
|  | // 创建本地的 openSelectPopup 函数 | ||||||
|  | const openSelectPopup = (config) => { | ||||||
|  |     if (selectPopupRef.value) { | ||||||
|  |         selectPopupRef.value.open(config); | ||||||
|  |     } | ||||||
|  | }; | ||||||
| import { storeToRefs } from 'pinia'; | import { storeToRefs } from 'pinia'; | ||||||
| import useUserStore from '@/stores/useUserStore'; | import useUserStore from '@/stores/useUserStore'; | ||||||
| import useDictStore from '@/stores/useDictStore'; | import useDictStore from '@/stores/useDictStore'; | ||||||
| const { userInfo } = storeToRefs(useUserStore()); | const { userInfo } = storeToRefs(useUserStore()); | ||||||
| const { getUserResume } = useUserStore(); | const { getUserResume } = useUserStore(); | ||||||
| const { dictLabel, oneDictData } = useDictStore(); | const { dictLabel, oneDictData, getDictData } = useDictStore(); | ||||||
|  |  | ||||||
| const selectJobsModel = ref(); | const selectJobsModel = ref(); | ||||||
|  | const selectPopupRef = ref(); | ||||||
| const percent = ref('0%'); | const percent = ref('0%'); | ||||||
| const salay = [2, 5, 10, 15, 20, 25, 30, 50, 80, 100]; | const salay = [2, 5, 10, 15, 20, 25, 30, 50, 80, 100]; | ||||||
| const state = reactive({ | const state = reactive({ | ||||||
| @@ -72,7 +81,9 @@ const fromValue = reactive({ | |||||||
|     area: '', |     area: '', | ||||||
|     jobTitleId: [], |     jobTitleId: [], | ||||||
| }); | }); | ||||||
| onLoad(() => { | onLoad(async () => { | ||||||
|  |     // 初始化字典数据 | ||||||
|  |     await getDictData(); | ||||||
|     initLoad(); |     initLoad(); | ||||||
| }); | }); | ||||||
| const confirm = () => { | const confirm = () => { | ||||||
| @@ -99,8 +110,12 @@ function initLoad() { | |||||||
|     fromValue.jobTitleId = userInfo.value.jobTitleId; |     fromValue.jobTitleId = userInfo.value.jobTitleId; | ||||||
|     // 回显 |     // 回显 | ||||||
|     state.areaText = dictLabel('area', Number(userInfo.value.area)); |     state.areaText = dictLabel('area', Number(userInfo.value.area)); | ||||||
|  |     if (userInfo.value.salaryMin && userInfo.value.salaryMax) { | ||||||
|         state.salayText = `${userInfo.value.salaryMin}-${userInfo.value.salaryMax}`; |         state.salayText = `${userInfo.value.salaryMin}-${userInfo.value.salaryMax}`; | ||||||
|     state.jobsText = userInfo.value.jobTitle; |     } else { | ||||||
|  |         state.salayText = ''; | ||||||
|  |     } | ||||||
|  |     state.jobsText = userInfo.value.jobTitle || []; | ||||||
|     const result = getFormCompletionPercent(fromValue); |     const result = getFormCompletionPercent(fromValue); | ||||||
|     percent.value = result; |     percent.value = result; | ||||||
| } | } | ||||||
| @@ -123,7 +138,8 @@ const changeSalary = () => { | |||||||
|                 const copyri = JSON.parse(JSON.stringify(salay)); |                 const copyri = JSON.parse(JSON.stringify(salay)); | ||||||
|                 const [lf, ri] = e.detail.value; |                 const [lf, ri] = e.detail.value; | ||||||
|                 const risalay = copyri.slice(lf, copyri.length); |                 const risalay = copyri.slice(lf, copyri.length); | ||||||
|                 this.setColunm(1, risalay); |                 // 更新右侧选项 | ||||||
|  |                 state.risalay = risalay; | ||||||
|                 leftIndex = salayData[0]; |                 leftIndex = salayData[0]; | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|   | |||||||
| @@ -122,28 +122,23 @@ | |||||||
|         </view> |         </view> | ||||||
|  |  | ||||||
|         <!-- 4. 新增:简历上传区域(固定在页面底部) --> |         <!-- 4. 新增:简历上传区域(固定在页面底部) --> | ||||||
|         <view class="resume-upload-section"> |         <!-- <view class="resume-upload-section"> | ||||||
|             <!-- 上传按钮 --> |  | ||||||
|             <button class="upload-btn" @click="handleResumeUpload" :loading="isUploading" :disabled="isUploading"> |             <button class="upload-btn" @click="handleResumeUpload" :loading="isUploading" :disabled="isUploading"> | ||||||
|                 <uni-icons type="cloud-upload" size="20"></uni-icons> |                 <uni-icons type="cloud-upload" size="20"></uni-icons> | ||||||
|                 <!-- <image class="upload-icon" src="/static/icons/upload-file.png" mode="widthFix"></image> --> |  | ||||||
|                 <text class="upload-text"> |                 <text class="upload-text"> | ||||||
|                     {{ uploadedResumeName || '上传简历' }} |                     {{ uploadedResumeName || '上传简历' }} | ||||||
|                 </text> |                 </text> | ||||||
|                 <!-- 已上传时显示“重新上传”文字 --> |  | ||||||
|                 <text class="reupload-text" v-if="uploadedResumeName">(重新上传)</text> |                 <text class="reupload-text" v-if="uploadedResumeName">(重新上传)</text> | ||||||
|             </button> |             </button> | ||||||
|  |  | ||||||
|             <!-- 上传说明 --> |  | ||||||
|             <text class="upload-tip">支持 PDF、Word 格式,文件大小不超过 20MB</text> |             <text class="upload-tip">支持 PDF、Word 格式,文件大小不超过 20MB</text> | ||||||
|  |  | ||||||
|             <!-- 已上传文件信息(可选) --> |  | ||||||
|             <view class="uploaded-file-info" v-if="uploadedResumeName"> |             <view class="uploaded-file-info" v-if="uploadedResumeName"> | ||||||
|                 <image class="file-icon" src="/static/icons/file-icon.png" mode="widthFix"></image> |                 <image class="file-icon" src="/static/icons/file-icon.png" mode="widthFix"></image> | ||||||
|                 <text class="file-name">{{ uploadedResumeName }}</text> |                 <text class="file-name">{{ uploadedResumeName }}</text> | ||||||
|                 <button class="delete-file-btn" size="mini" @click.stop="handleDeleteResume">删除</button> |                 <button class="delete-file-btn" size="mini" @click.stop="handleDeleteResume">删除</button> | ||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> --> | ||||||
|     </view> |     </view> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										41
									
								
								pages.json
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								pages.json
									
									
									
									
									
								
							| @@ -19,9 +19,9 @@ | |||||||
|         { |         { | ||||||
|             "path": "pages/msglog/msglog", |             "path": "pages/msglog/msglog", | ||||||
|             "style": { |             "style": { | ||||||
|                 "navigationBarTitleText": "消息", |                 "navigationBarTitleText": "消息" | ||||||
|                 "navigationStyle": "custom", |                 // "navigationStyle": "custom", | ||||||
|                 "enablePullDownRefresh": false |                 // "enablePullDownRefresh": false | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
| @@ -106,12 +106,12 @@ | |||||||
|         { |         { | ||||||
|             "path": "pages/job/publishJob", |             "path": "pages/job/publishJob", | ||||||
|             "style": { |             "style": { | ||||||
|                 "navigationBarTitleText": "发布岗位", |                 "navigationBarTitleText": "发布岗位" | ||||||
|                 "navigationStyle": "custom", |                 // "navigationStyle": "custom", | ||||||
|                 "disableScroll": false, |                 // "disableScroll": false, | ||||||
|                 "enablePullDownRefresh": false, |                 // "enablePullDownRefresh": false, | ||||||
|                 "onReachBottomDistance": 50, |                 // "onReachBottomDistance": 50, | ||||||
|                 "backgroundColor": "#f5f5f5" |                 // "backgroundColor": "#f5f5f5" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
| @@ -130,31 +130,30 @@ | |||||||
|                 "navigationBarTitleText": "AI+", |                 "navigationBarTitleText": "AI+", | ||||||
|                 "navigationBarBackgroundColor": "#4778EC", |                 "navigationBarBackgroundColor": "#4778EC", | ||||||
|                 "navigationBarTextStyle": "white", |                 "navigationBarTextStyle": "white", | ||||||
|                 "enablePullDownRefresh": false, |                 "enablePullDownRefresh": false | ||||||
|                 // #ifdef H5 |                 // #ifdef H5 | ||||||
|                 "navigationStyle": "custom" |                 // "navigationStyle": "custom" | ||||||
|                 //#endif |                 //#endif | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "path": "pages/search/search", |             "path": "pages/search/search", | ||||||
|             "style": { |             "style": { | ||||||
|                 "navigationBarTitleText": "", |                 "navigationBarTitleText": "" | ||||||
|                 "navigationStyle": "custom" |                 // "navigationStyle": "custom" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "path": "pages/mine/company-mine", |             "path": "pages/mine/company-mine", | ||||||
|             "style": { |             "style": { | ||||||
|                 "navigationBarTitleText": "我的", |                 "navigationBarTitleText": "我的" | ||||||
|                 "navigationStyle": "custom" |                 // "navigationStyle": "custom" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "path": "pages/mine/company-info", |             "path": "pages/mine/company-info", | ||||||
|             "style": { |             "style": { | ||||||
|                 "navigationBarTitleText": "企业信息", |                 "navigationBarTitleText": "企业信息" | ||||||
|                 "navigationStyle": "custom" |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -166,8 +165,8 @@ | |||||||
|                 "path" : "pages/addWorkExperience/addWorkExperience", |                 "path" : "pages/addWorkExperience/addWorkExperience", | ||||||
|                 "style" :  |                 "style" :  | ||||||
|                 { |                 { | ||||||
|                     "navigationBarTitleText" : "添加工作经历", |                     "navigationBarTitleText" : "添加工作经历" | ||||||
|                     "navigationStyle": "custom" |                     // "navigationStyle": "custom" | ||||||
|                 } |                 } | ||||||
|             },{ |             },{ | ||||||
|                 "path": "pages/choiceness/choiceness", |                 "path": "pages/choiceness/choiceness", | ||||||
| @@ -252,8 +251,8 @@ | |||||||
|             { |             { | ||||||
|                 "path": "pages/jobExpect/jobExpect", |                 "path": "pages/jobExpect/jobExpect", | ||||||
|                 "style": { |                 "style": { | ||||||
|                     "navigationBarTitleText": "求职期望", |                     "navigationBarTitleText": "求职期望" | ||||||
|                     "navigationStyle": "custom" |                     // "navigationStyle": "custom" | ||||||
|                 } |                 } | ||||||
|             }, |             }, | ||||||
|             { |             { | ||||||
|   | |||||||
| @@ -85,17 +85,22 @@ | |||||||
|             </view> |             </view> | ||||||
|             <!-- 自定义tabbar --> |             <!-- 自定义tabbar --> | ||||||
|             <CustomTabBar :currentPage="1" /> |             <CustomTabBar :currentPage="1" /> | ||||||
|  |              | ||||||
|  |             <!-- 微信授权登录弹窗 --> | ||||||
|  |             <WxAuthLogin ref="wxAuthLoginRef" @success="handleLoginSuccess"></WxAuthLogin> | ||||||
|         </view> |         </view> | ||||||
|     </view> |     </view> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, inject, watch, ref, onMounted } from 'vue'; | import { reactive, inject, watch, ref, onMounted, onUnmounted } from 'vue'; | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
| import useLocationStore from '@/stores/useLocationStore'; | import useLocationStore from '@/stores/useLocationStore'; | ||||||
| import { storeToRefs } from 'pinia'; | import { storeToRefs } from 'pinia'; | ||||||
| import { tabbarManager } from '@/utils/tabbarManager'; | import { tabbarManager } from '@/utils/tabbarManager'; | ||||||
|  | import WxAuthLogin from '@/components/WxAuthLogin/WxAuthLogin.vue'; | ||||||
| const { longitudeVal, latitudeVal } = storeToRefs(useLocationStore()); | const { longitudeVal, latitudeVal } = storeToRefs(useLocationStore()); | ||||||
|  | const wxAuthLoginRef = ref(null); | ||||||
| const { $api, navTo, cloneDeep } = inject('globalFunction'); | const { $api, navTo, cloneDeep } = inject('globalFunction'); | ||||||
| const weekList = ref([]); | const weekList = ref([]); | ||||||
| const fairList = ref([]); | const fairList = ref([]); | ||||||
| @@ -131,6 +136,23 @@ onShow(() => { | |||||||
|     tabbarManager.updateSelected(1); |     tabbarManager.updateSelected(1); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | onMounted(() => { | ||||||
|  |     // 监听退出登录事件,显示微信登录弹窗 | ||||||
|  |     uni.$on('showLoginModal', () => { | ||||||
|  |         wxAuthLoginRef.value?.open(); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | onUnmounted(() => { | ||||||
|  |     uni.$off('showLoginModal'); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // 登录成功回调 | ||||||
|  | const handleLoginSuccess = () => { | ||||||
|  |     console.log('登录成功'); | ||||||
|  |     // 可以在这里添加登录成功后的处理逻辑 | ||||||
|  | }; | ||||||
|  |  | ||||||
| function toSelectDate() { | function toSelectDate() { | ||||||
|     navTo('/packageA/pages/selectDate/selectDate', { |     navTo('/packageA/pages/selectDate/selectDate', { | ||||||
|         query: { |         query: { | ||||||
|   | |||||||
| @@ -2,6 +2,9 @@ | |||||||
|     <view class="container"> |     <view class="container"> | ||||||
|         <!-- 自定义tabbar --> |         <!-- 自定义tabbar --> | ||||||
|         <CustomTabBar :currentPage="2" /> |         <CustomTabBar :currentPage="2" /> | ||||||
|  |          | ||||||
|  |         <!-- 微信授权登录弹窗 --> | ||||||
|  |         <WxAuthLogin ref="wxAuthLoginRef" @success="handleLoginSuccess"></WxAuthLogin> | ||||||
|         <!-- 抽屉遮罩层 --> |         <!-- 抽屉遮罩层 --> | ||||||
|         <view v-if="isDrawerOpen" class="overlay" @click="toggleDrawer"></view> |         <view v-if="isDrawerOpen" class="overlay" @click="toggleDrawer"></view> | ||||||
|  |  | ||||||
| @@ -73,7 +76,7 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { ref, inject, nextTick, computed } from 'vue'; | import { ref, inject, nextTick, computed, onMounted, onUnmounted } from 'vue'; | ||||||
| const { $api, navTo, insertSortData, config } = inject('globalFunction'); | const { $api, navTo, insertSortData, config } = inject('globalFunction'); | ||||||
| import { onLoad, onShow, onHide } from '@dcloudio/uni-app'; | import { onLoad, onShow, onHide } from '@dcloudio/uni-app'; | ||||||
| import useChatGroupDBStore from '@/stores/userChatGroupStore'; | import useChatGroupDBStore from '@/stores/userChatGroupStore'; | ||||||
| @@ -81,6 +84,7 @@ import useUserStore from '@/stores/useUserStore'; | |||||||
| import { tabbarManager } from '@/utils/tabbarManager'; | import { tabbarManager } from '@/utils/tabbarManager'; | ||||||
| import aiPaging from './components/ai-paging.vue'; | import aiPaging from './components/ai-paging.vue'; | ||||||
| import { storeToRefs } from 'pinia'; | import { storeToRefs } from 'pinia'; | ||||||
|  | import WxAuthLogin from '@/components/WxAuthLogin/WxAuthLogin.vue'; | ||||||
| const { isTyping, tabeList, chatSessionID } = storeToRefs(useChatGroupDBStore()); | const { isTyping, tabeList, chatSessionID } = storeToRefs(useChatGroupDBStore()); | ||||||
| const { userInfo } = storeToRefs(useUserStore()); | const { userInfo } = storeToRefs(useUserStore()); | ||||||
| const isDrawerOpen = ref(false); | const isDrawerOpen = ref(false); | ||||||
| @@ -88,6 +92,7 @@ const scrollIntoView = ref(false); | |||||||
|  |  | ||||||
| const searchText = ref(''); | const searchText = ref(''); | ||||||
| const paging = ref(null); | const paging = ref(null); | ||||||
|  | const wxAuthLoginRef = ref(null); | ||||||
|  |  | ||||||
| // 实时过滤 | // 实时过滤 | ||||||
| const filteredList = computed(() => { | const filteredList = computed(() => { | ||||||
| @@ -110,6 +115,23 @@ onShow(() => { | |||||||
|     tabbarManager.updateSelected(2); |     tabbarManager.updateSelected(2); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | onMounted(() => { | ||||||
|  |     // 监听退出登录事件,显示微信登录弹窗 | ||||||
|  |     uni.$on('showLoginModal', () => { | ||||||
|  |         wxAuthLoginRef.value?.open(); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | onUnmounted(() => { | ||||||
|  |     uni.$off('showLoginModal'); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // 登录成功回调 | ||||||
|  | const handleLoginSuccess = () => { | ||||||
|  |     console.log('登录成功'); | ||||||
|  |     // 可以在这里添加登录成功后的处理逻辑 | ||||||
|  | }; | ||||||
|  |  | ||||||
| onHide(() => { | onHide(() => { | ||||||
|     paging.value?.handleTouchCancel(); |     paging.value?.handleTouchCancel(); | ||||||
|     if (isDrawerOpen.value) { |     if (isDrawerOpen.value) { | ||||||
|   | |||||||
| @@ -1,11 +1,7 @@ | |||||||
| <template> | <template> | ||||||
|     <view class="chat-container"> |     <view class="chat-container"> | ||||||
|         <!-- #ifdef MP-WEIXIN --> |         <!-- #ifdef MP-WEIXIN --> | ||||||
|          <view class="chat-background"> |          <view class="chat-background" v-if="!messages.length"> | ||||||
|         <!-- #endif --> |  | ||||||
|         <!-- #ifndef MP-WEIXIN --> |  | ||||||
|         <view class="chat-background" v-fade:600="!messages.length"> |  | ||||||
|         <!-- #endif --> |  | ||||||
|             <image class="backlogo" src="/static/icon/backAI.png"></image> |             <image class="backlogo" src="/static/icon/backAI.png"></image> | ||||||
|             <view class="back-rowTitle">嗨!欢迎使用{{ config.appInfo.areaName }}AI智能求职</view> |             <view class="back-rowTitle">嗨!欢迎使用{{ config.appInfo.areaName }}AI智能求职</view> | ||||||
|             <view class="back-rowText"> |             <view class="back-rowText"> | ||||||
| @@ -24,6 +20,28 @@ | |||||||
|                 <view class="message">{{ recognizedText }} {{ lastFinalText }}</view> |                 <view class="message">{{ recognizedText }} {{ lastFinalText }}</view> | ||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> | ||||||
|  |         <!-- #endif --> | ||||||
|  |         <!-- #ifndef MP-WEIXIN --> | ||||||
|  |         <view class="chat-background" v-if="!messages.length"> | ||||||
|  |             <image class="backlogo" src="/static/icon/backAI.png"></image> | ||||||
|  |             <view class="back-rowTitle">嗨!欢迎使用{{ config.appInfo.areaName }}AI智能求职</view> | ||||||
|  |             <view class="back-rowText"> | ||||||
|  |                 我可以根据您的简历和求职需求,帮你精准匹配{{ config.appInfo.areaName }}互联网招聘信息,对比招聘信息的优缺点,提供面试指导等,请把你的任务交给我吧~ | ||||||
|  |             </view> | ||||||
|  |             <view class="back-rowh3">猜你所想</view> | ||||||
|  |             <view | ||||||
|  |                 class="back-rowmsg button-click" | ||||||
|  |                 v-for="(item, index) in queries" | ||||||
|  |                 :key="index" | ||||||
|  |                 @click="sendMessageGuess(item)" | ||||||
|  |             > | ||||||
|  |                 {{ item }} | ||||||
|  |             </view> | ||||||
|  |             <view class="chat-item self" v-if="isRecording"> | ||||||
|  |                 <view class="message">{{ recognizedText }} {{ lastFinalText }}</view> | ||||||
|  |             </view> | ||||||
|  |         </view> | ||||||
|  |         <!-- #endif --> | ||||||
|         <scroll-view class="chat-list scrollView" :scroll-top="scrollTop" :scroll-y="true" scroll-with-animation> |         <scroll-view class="chat-list scrollView" :scroll-top="scrollTop" :scroll-y="true" scroll-with-animation> | ||||||
|             <!-- #ifdef MP-WEIXIN --> |             <!-- #ifdef MP-WEIXIN --> | ||||||
|             <view class="chat-list list-content"> |             <view class="chat-list list-content"> | ||||||
| @@ -946,19 +964,19 @@ image-margin-top = 40rpx | |||||||
|     white-space: pre-wrap; |     white-space: pre-wrap; | ||||||
| } | } | ||||||
| .list-content { | .list-content { | ||||||
|     padding: 0 44rpx 44rpx 44rpx; |     padding: 0 44rpx 10rpx 44rpx; | ||||||
| } | } | ||||||
| .chat-item { | .chat-item { | ||||||
|     display: flex; |     display: flex; | ||||||
|     align-items: flex-start; |     align-items: flex-start; | ||||||
|     margin-bottom: 20rpx; |     margin-bottom: 10rpx; | ||||||
|     width: 100%; |     width: 100%; | ||||||
| } | } | ||||||
| .chat-item.self { | .chat-item.self { | ||||||
|     justify-content: flex-end; |     justify-content: flex-end; | ||||||
| } | } | ||||||
| .message | .message | ||||||
|     margin-top: 40rpx |     margin-top: 0rpx | ||||||
|     // max-width: 80%; |     // max-width: 80%; | ||||||
|     width: 100%; |     width: 100%; | ||||||
|     word-break: break-word; |     word-break: break-word; | ||||||
| @@ -1003,10 +1021,12 @@ image-margin-top = 40rpx | |||||||
| } | } | ||||||
| .input-area { | .input-area { | ||||||
|     padding: 32rpx 28rpx 24rpx 28rpx; |     padding: 32rpx 28rpx 24rpx 28rpx; | ||||||
|  |     padding-bottom: calc(24rpx + env(safe-area-inset-bottom) + 40rpx - 40rpx); | ||||||
|     position: relative; |     position: relative; | ||||||
|     background: #FFFFFF; |     background: #FFFFFF; | ||||||
|     box-shadow: 0rpx -4rpx 10rpx 0rpx rgba(11,44,112,0.06); |     box-shadow: 0rpx -4rpx 10rpx 0rpx rgba(11,44,112,0.06); | ||||||
|     transition: height 2s ease-in-out; |     transition: height 2s ease-in-out; | ||||||
|  |     z-index: 1001; | ||||||
| } | } | ||||||
| .input-area::after | .input-area::after | ||||||
|     position: absolute |     position: absolute | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
|     <AppLayout title="企业信息"> |     <AppLayout> | ||||||
|         <view class="company-info-container"> |         <view class="company-info-container"> | ||||||
|             <!-- 头部信息 --> |             <!-- 头部信息 --> | ||||||
|             <view class="header-info"> |             <view class="header-info"> | ||||||
| @@ -131,6 +131,15 @@ | |||||||
|                     </view> |                     </view> | ||||||
|                 </view> |                 </view> | ||||||
|                  |                  | ||||||
|  |                 <!-- 企业规模 --> | ||||||
|  |                 <view class="form-item clickable" @click="selectScale"> | ||||||
|  |                     <view class="label">企业规模</view> | ||||||
|  |                     <view class="input-content"> | ||||||
|  |                         <input class="input-con" v-model="formData.scaleText" disabled placeholder="请选择企业规模" /> | ||||||
|  |                         <uni-icons type="arrowright" size="16" color="#999"></uni-icons> | ||||||
|  |                     </view> | ||||||
|  |                 </view> | ||||||
|  |                  | ||||||
|                 <!-- 联系人信息列表 --> |                 <!-- 联系人信息列表 --> | ||||||
|                 <view class="contact-section"> |                 <view class="contact-section"> | ||||||
|                     <view class="section-title">联系人信息</view> |                     <view class="section-title">联系人信息</view> | ||||||
| @@ -225,9 +234,11 @@ import { onLoad } from '@dcloudio/uni-app' | |||||||
| import AreaCascadePicker from '@/components/area-cascade-picker/area-cascade-picker.vue' | import AreaCascadePicker from '@/components/area-cascade-picker/area-cascade-picker.vue' | ||||||
| import SelectPopup from '@/components/selectPopup/selectPopup.vue' | import SelectPopup from '@/components/selectPopup/selectPopup.vue' | ||||||
| import useDictStore from '@/stores/useDictStore' | import useDictStore from '@/stores/useDictStore' | ||||||
|  | import useUserStore from '@/stores/useUserStore' | ||||||
|  |  | ||||||
| const { $api } = inject('globalFunction') | const { $api } = inject('globalFunction') | ||||||
| const dictStore = useDictStore() | const dictStore = useDictStore() | ||||||
|  | const userStore = useUserStore() | ||||||
|  |  | ||||||
| // 表单数据 | // 表单数据 | ||||||
| const formData = reactive({ | const formData = reactive({ | ||||||
| @@ -246,6 +257,8 @@ const formData = reactive({ | |||||||
|     legalPhone: '', // 法人联系方式 |     legalPhone: '', // 法人联系方式 | ||||||
|     industryType: '', // 是否是本地重点发展产业 |     industryType: '', // 是否是本地重点发展产业 | ||||||
|     isLocalCompany: null, // 是否是本地企业 (true/false/null) |     isLocalCompany: null, // 是否是本地企业 (true/false/null) | ||||||
|  |     scale: '', // 企业规模 | ||||||
|  |     scaleText: '', // 企业规模显示文本 | ||||||
|     companyContactList: [ |     companyContactList: [ | ||||||
|         { contactPerson: '', contactPersonPhone: '' } |         { contactPerson: '', contactPersonPhone: '' } | ||||||
|     ] |     ] | ||||||
| @@ -311,7 +324,8 @@ const completionPercentage = computed(() => { | |||||||
|         formData.legalIdCard, |         formData.legalIdCard, | ||||||
|         formData.legalPhone, |         formData.legalPhone, | ||||||
|         formData.industryType, |         formData.industryType, | ||||||
|         formData.isLocalCompany !== null ? 'filled' : '' |         formData.isLocalCompany !== null ? 'filled' : '', | ||||||
|  |         formData.scale | ||||||
|     ] |     ] | ||||||
|      |      | ||||||
|     // 检查联系人信息 |     // 检查联系人信息 | ||||||
| @@ -464,6 +478,73 @@ const selectLocalCompany = () => { | |||||||
|     }) |     }) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // 企业规模选项数据从字典中获取 | ||||||
|  | const scaleOptions = computed(() => { | ||||||
|  |     const scaleData = dictStore.state?.scale || [] | ||||||
|  |     console.log('企业规模选项数据:', scaleData) | ||||||
|  |     return scaleData | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | // 选择企业规模 | ||||||
|  | const selectScale = () => { | ||||||
|  |     console.log('点击企业规模,当前数据:', scaleOptions.value) | ||||||
|  |     console.log('字典store状态:', dictStore.state.scale) | ||||||
|  |      | ||||||
|  |     // 获取企业规模选项,优先使用字典数据,失败时使用备用数据 | ||||||
|  |     let options = scaleOptions.value | ||||||
|  |      | ||||||
|  |     if (!options || !options.length) { | ||||||
|  |         console.log('企业规模数据为空,尝试重新加载') | ||||||
|  |         // 尝试重新加载字典数据 | ||||||
|  |         dictStore.getDictData().then(() => { | ||||||
|  |             if (dictStore.state.scale && dictStore.state.scale.length > 0) { | ||||||
|  |                 selectScale() // 递归调用 | ||||||
|  |             } else { | ||||||
|  |                 // 使用备用数据 | ||||||
|  |                 console.log('使用备用企业规模数据') | ||||||
|  |                 options = fallbackScaleOptions | ||||||
|  |                 showScaleSelector(options) | ||||||
|  |             } | ||||||
|  |         }).catch(() => { | ||||||
|  |             // 使用备用数据 | ||||||
|  |             console.log('字典加载失败,使用备用企业规模数据') | ||||||
|  |             options = fallbackScaleOptions | ||||||
|  |             showScaleSelector(options) | ||||||
|  |         }) | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     showScaleSelector(options) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // 备用企业规模选项(当字典数据加载失败时使用) | ||||||
|  | const fallbackScaleOptions = [ | ||||||
|  |     { label: '1-10人', value: '1' }, | ||||||
|  |     { label: '11-50人', value: '2' }, | ||||||
|  |     { label: '51-100人', value: '3' }, | ||||||
|  |     { label: '101-500人', value: '4' }, | ||||||
|  |     { label: '501-1000人', value: '5' }, | ||||||
|  |     { label: '1000人以上', value: '6' } | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | // 显示企业规模选择器 | ||||||
|  | const showScaleSelector = (options) => { | ||||||
|  |     console.log('企业规模选项列表:', options) | ||||||
|  |      | ||||||
|  |     openSelectPopup({ | ||||||
|  |         title: '企业规模', | ||||||
|  |         maskClick: true, | ||||||
|  |         data: [options], | ||||||
|  |         success: (_, [value]) => { | ||||||
|  |             console.log('选择的企业规模:', value) | ||||||
|  |             formData.scale = value.value | ||||||
|  |             formData.scaleText = value.label | ||||||
|  |             updateCompletion() | ||||||
|  |             $api.msg('企业规模选择成功') | ||||||
|  |         } | ||||||
|  |     }) | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // 添加联系人 | // 添加联系人 | ||||||
| const addContact = () => { | const addContact = () => { | ||||||
| @@ -573,6 +654,11 @@ const confirm = () => { | |||||||
|         return |         return | ||||||
|     } |     } | ||||||
|      |      | ||||||
|  |     if (!formData.scale.trim()) { | ||||||
|  |         $api.msg('请选择企业规模') | ||||||
|  |         return | ||||||
|  |     } | ||||||
|  |      | ||||||
|     // 验证身份证号格式 |     // 验证身份证号格式 | ||||||
|     const idCardRegex = /^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/ |     const idCardRegex = /^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/ | ||||||
|     if (!idCardRegex.test(formData.legalIdCard)) { |     if (!idCardRegex.test(formData.legalIdCard)) { | ||||||
| @@ -623,6 +709,7 @@ const confirm = () => { | |||||||
|         legalPhone: formData.legalPhone, |         legalPhone: formData.legalPhone, | ||||||
|         industryType: formData.industryType, |         industryType: formData.industryType, | ||||||
|         isLocalCompany: formData.isLocalCompany, |         isLocalCompany: formData.isLocalCompany, | ||||||
|  |         scale: formData.scaleText, | ||||||
|         companyContactList: formData.companyContactList.filter(contact => contact.contactPerson.trim() && contact.contactPersonPhone.trim()) |         companyContactList: formData.companyContactList.filter(contact => contact.contactPerson.trim() && contact.contactPersonPhone.trim()) | ||||||
|     } |     } | ||||||
|      |      | ||||||
| @@ -632,10 +719,19 @@ const confirm = () => { | |||||||
|     } |     } | ||||||
|      |      | ||||||
|     $api.createRequest('/app/user/registerUser', submitData, 'post') |     $api.createRequest('/app/user/registerUser', submitData, 'post') | ||||||
|         .then((resData) => { |         .then(async (resData) => { | ||||||
|             uni.hideLoading() |             uni.hideLoading() | ||||||
|             $api.msg('企业信息保存成功') |             $api.msg('企业信息保存成功') | ||||||
|              |              | ||||||
|  |             // 保存成功后,重新获取用户信息并更新缓存 | ||||||
|  |             try { | ||||||
|  |                 await userStore.getUserResume() | ||||||
|  |                 console.log('用户信息已更新到缓存') | ||||||
|  |             } catch (error) { | ||||||
|  |                 console.error('获取用户信息失败:', error) | ||||||
|  |                 // 即使获取用户信息失败,也不影响页面跳转 | ||||||
|  |             } | ||||||
|  |              | ||||||
|             // 跳转到首页或企业相关页面 |             // 跳转到首页或企业相关页面 | ||||||
|             uni.reLaunch({ |             uni.reLaunch({ | ||||||
|                 url: '/pages/index/index' |                 url: '/pages/index/index' | ||||||
|   | |||||||
| @@ -5,11 +5,39 @@ | |||||||
|         <image class="mp-background" src="/static/icon/background2.png" mode="aspectFill"></image> |         <image class="mp-background" src="/static/icon/background2.png" mode="aspectFill"></image> | ||||||
|         <!-- #endif --> |         <!-- #endif --> | ||||||
|          |          | ||||||
|  |         <!-- 企业账号显示卡片 --> | ||||||
|  |         <view class="enterprise-card btn-feel" v-if="shouldShowCompanyCard" @click="goToCompanyInfo"> | ||||||
|  |             <view class="card-content"> | ||||||
|  |                 <!-- 企业图标 --> | ||||||
|  |                 <view class="company-icon"> | ||||||
|  |                     <image  | ||||||
|  |                         v-if="companyInfo.avatar"  | ||||||
|  |                         :src="companyInfo.avatar"  | ||||||
|  |                         class="logo-image" | ||||||
|  |                         mode="aspectFit" | ||||||
|  |                     /> | ||||||
|  |                     <view v-else class="default-logo"> | ||||||
|  |                         <uni-icons type="home-filled" size="32" color="#256BFA"></uni-icons> | ||||||
|  |                     </view> | ||||||
|  |                 </view> | ||||||
|  |                  | ||||||
|  |                 <!-- 企业信息 --> | ||||||
|  |                 <view class="company-info"> | ||||||
|  |                     <view class="company-name">{{ companyInfo.name || '企业名称' }}</view> | ||||||
|  |                     <view class="company-details"> | ||||||
|  |                         <text class="industry">{{ companyInfo.industry || '互联网' }}</text> | ||||||
|  |                         <text class="separator">·</text> | ||||||
|  |                         <text class="size">{{ companyInfo.scale || '100-999人' }}</text> | ||||||
|  |                     </view> | ||||||
|  |                 </view> | ||||||
|  |             </view> | ||||||
|  |         </view> | ||||||
|  |          | ||||||
|         <view  |         <view  | ||||||
|             class="nav-hidden hidden-animation"  |             class="nav-hidden hidden-animation"  | ||||||
|             :class="{ 'hidden-height': shouldHideTop }" |             :class="{ 'hidden-height': shouldHideTop }" | ||||||
|         > |         > | ||||||
|             <view class="container-search"> |             <view class="container-search" v-if="shouldShowJobSeekerContent"> | ||||||
|                 <view class="search-input button-click" @click="navTo('/pages/search/search')"> |                 <view class="search-input button-click" @click="navTo('/pages/search/search')"> | ||||||
|                     <uni-icons class="iconsearch" color="#666666" type="search" size="18"></uni-icons> |                     <uni-icons class="iconsearch" color="#666666" type="search" size="18"></uni-icons> | ||||||
|                     <text class="inpute">职位名称、薪资要求等</text> |                     <text class="inpute">职位名称、薪资要求等</text> | ||||||
| @@ -93,7 +121,7 @@ | |||||||
|         </view> |         </view> | ||||||
|          |          | ||||||
|         <!-- 企业用户内容 --> |         <!-- 企业用户内容 --> | ||||||
|         <view class="company-content" v-if="shouldShowCompanyContent"> |         <!-- <view class="company-content" v-if="shouldShowCompanyContent"> | ||||||
|             <view class="company-header"> |             <view class="company-header"> | ||||||
|                 <text class="company-title">企业服务</text> |                 <text class="company-title">企业服务</text> | ||||||
|                 <text class="company-subtitle">为您提供专业的企业招聘服务</text> |                 <text class="company-subtitle">为您提供专业的企业招聘服务</text> | ||||||
| @@ -125,7 +153,7 @@ | |||||||
|                     <view class="company-title">人才库</view> |                     <view class="company-title">人才库</view> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> --> | ||||||
|          |          | ||||||
|         <!-- 吸顶筛选区域占位 --> |         <!-- 吸顶筛选区域占位 --> | ||||||
|         <view class="filter-placeholder" v-if="shouldStickyFilter && shouldShowJobSeekerContent"></view> |         <view class="filter-placeholder" v-if="shouldStickyFilter && shouldShowJobSeekerContent"></view> | ||||||
| @@ -378,20 +406,71 @@ const shouldShowJobSeekerContent = computed(() => { | |||||||
|     if (!hasLogin.value) { |     if (!hasLogin.value) { | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|     // 登录后根据用户类型判断 |      | ||||||
|     const userType = userInfo.value?.isCompanyUser; |     // 优先从store获取,如果为空则从缓存获取 | ||||||
|  |     const storeIsCompanyUser = userInfo.value?.isCompanyUser; | ||||||
|  |     const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|  |     const cachedIsCompanyUser = cachedUserInfo.isCompanyUser; | ||||||
|  |      | ||||||
|  |     // 获取用户类型:优先使用store中的isCompanyUser,如果store中没有,使用缓存中的isCompanyUser | ||||||
|  |     // 缓存中的值可能是字符串,需要转换为数值类型 | ||||||
|  |     const userType = storeIsCompanyUser !== undefined ? Number(storeIsCompanyUser) : Number(cachedIsCompanyUser); | ||||||
|  |      | ||||||
|     // 企业用户(isCompanyUser=0)不显示求职者内容,其他用户类型显示 |     // 企业用户(isCompanyUser=0)不显示求职者内容,其他用户类型显示 | ||||||
|     return userType !== 0; |     return userType !== 0; | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | // 企业信息数据 | ||||||
|  | const companyInfo = reactive({ | ||||||
|  |     name: '', | ||||||
|  |     avatar: '', | ||||||
|  |     industry: '', | ||||||
|  |     size: '', | ||||||
|  |     isVerified: false | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // 计算是否显示企业卡片 | ||||||
|  | const shouldShowCompanyCard = computed(() => { | ||||||
|  |     // 未登录时不显示 | ||||||
|  |     if (!hasLogin.value) { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // 优先从store获取,如果为空则从缓存获取 | ||||||
|  |     const storeIsCompanyUser = userInfo.value?.isCompanyUser; | ||||||
|  |     const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|  |     const cachedIsCompanyUser = cachedUserInfo.isCompanyUser; | ||||||
|  |      | ||||||
|  |     // 获取用户类型:优先使用store中的isCompanyUser,如果store中没有,使用缓存中的isCompanyUser | ||||||
|  |     // 缓存中的值可能是字符串,需要转换为数值类型 | ||||||
|  |     const userType = storeIsCompanyUser !== undefined ? Number(storeIsCompanyUser) : Number(cachedIsCompanyUser); | ||||||
|  |      | ||||||
|  |     // 只有企业用户(isCompanyUser=0)才显示企业卡片 | ||||||
|  |     if (userType !== 0) { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // 检查企业信息是否已完善 | ||||||
|  |     return companyInfo.name && companyInfo.name.trim() !== ''; | ||||||
|  | }); | ||||||
|  |  | ||||||
| // 计算是否显示企业用户内容 | // 计算是否显示企业用户内容 | ||||||
| const shouldShowCompanyContent = computed(() => { | const shouldShowCompanyContent = computed(() => { | ||||||
|     // 未登录时不显示企业内容 |     // 未登录时不显示企业内容 | ||||||
|     if (!hasLogin.value) { |     if (!hasLogin.value) { | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |      | ||||||
|  |     // 优先从store获取,如果为空则从缓存获取 | ||||||
|  |     const storeIsCompanyUser = userInfo.value?.isCompanyUser; | ||||||
|  |     const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|  |     const cachedIsCompanyUser = cachedUserInfo.isCompanyUser; | ||||||
|  |      | ||||||
|  |     // 获取用户类型:优先使用store中的isCompanyUser,如果store中没有,使用缓存中的isCompanyUser | ||||||
|  |     // 缓存中的值可能是字符串,需要转换为数值类型 | ||||||
|  |     const userType = storeIsCompanyUser !== undefined ? Number(storeIsCompanyUser) : Number(cachedIsCompanyUser); | ||||||
|  |      | ||||||
|     // 只有企业用户(isCompanyUser=0)才显示企业内容 |     // 只有企业用户(isCompanyUser=0)才显示企业内容 | ||||||
|     const userType = userInfo.value?.isCompanyUser; |  | ||||||
|     return userType === 0; |     return userType === 0; | ||||||
| }); | }); | ||||||
|  |  | ||||||
| @@ -404,6 +483,7 @@ import { useScrollDirection } from '@/hook/useScrollDirection'; | |||||||
| import { useColumnCount } from '@/hook/useColumnCount'; | import { useColumnCount } from '@/hook/useColumnCount'; | ||||||
| import WxAuthLogin from '@/components/WxAuthLogin/WxAuthLogin.vue'; | import WxAuthLogin from '@/components/WxAuthLogin/WxAuthLogin.vue'; | ||||||
| import IconfontIcon from '@/components/IconfontIcon/IconfontIcon.vue' | import IconfontIcon from '@/components/IconfontIcon/IconfontIcon.vue' | ||||||
|  | // 企业卡片组件已内联到模板中 | ||||||
| // 滚动状态管理 | // 滚动状态管理 | ||||||
| const shouldHideTop = ref(false); | const shouldHideTop = ref(false); | ||||||
| const shouldStickyFilter = ref(false); | const shouldStickyFilter = ref(false); | ||||||
| @@ -489,9 +569,66 @@ const { columnCount, columnSpace } = useColumnCount(() => { | |||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | // 获取企业信息 | ||||||
|  | const getCompanyInfo = () => { | ||||||
|  |     try { | ||||||
|  |         const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|  |         console.log('缓存中的userInfo:', cachedUserInfo); | ||||||
|  |          | ||||||
|  |         // 检查是否有company字段 | ||||||
|  |         if (cachedUserInfo.company) { | ||||||
|  |             const company = cachedUserInfo.company; | ||||||
|  |              | ||||||
|  |             // 基本信息 | ||||||
|  |             companyInfo.name = company.name || ''; | ||||||
|  |             companyInfo.avatar = company.avatar || ''; | ||||||
|  |             companyInfo.industry = company.industryType || '互联网'; | ||||||
|  |             companyInfo.size = company.companySize || '100-999人'; | ||||||
|  |              | ||||||
|  |             // 判断是否实名:legalIdCard字段有值则表示已实名 | ||||||
|  |             companyInfo.isVerified = !!(company.legalIdCard && company.legalIdCard.trim()); | ||||||
|  |              | ||||||
|  |             console.log('企业信息:', { | ||||||
|  |                 name: companyInfo.name, | ||||||
|  |                 industry: companyInfo.industry, | ||||||
|  |                 size: companyInfo.size, | ||||||
|  |                 isVerified: companyInfo.isVerified | ||||||
|  |             }); | ||||||
|  |         } else { | ||||||
|  |             console.log('缓存中没有company字段'); | ||||||
|  |             // 保持默认值 | ||||||
|  |         } | ||||||
|  |     } catch (error) { | ||||||
|  |         console.error('获取企业信息失败:', error); | ||||||
|  |         // 保持默认值 | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // 跳转到企业信息详情页面 | ||||||
|  | const goToCompanyInfo = () => { | ||||||
|  |     navTo('/pages/mine/company-info'); | ||||||
|  | }; | ||||||
|  |  | ||||||
| // 组件初始化时加载数据 | // 组件初始化时加载数据 | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|     getJobRecommend('refresh'); |     getJobRecommend('refresh'); | ||||||
|  |      | ||||||
|  |     // 获取企业信息 | ||||||
|  |     getCompanyInfo(); | ||||||
|  |      | ||||||
|  |     // 监听退出登录事件,显示微信登录弹窗 | ||||||
|  |     uni.$on('showLoginModal', () => { | ||||||
|  |         wxAuthLoginRef.value?.open(); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | onUnmounted(() => { | ||||||
|  |     uni.$off('showLoginModal'); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | onShow(() => { | ||||||
|  |     // 获取最新的企业信息 | ||||||
|  |     getCompanyInfo(); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| // 登录检查函数 | // 登录检查函数 | ||||||
| @@ -1548,4 +1685,133 @@ defineExpose({ loadData }); | |||||||
| .isBut{ | .isBut{ | ||||||
|     filter: grayscale(100%); |     filter: grayscale(100%); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // 企业账号显示卡片样式 | ||||||
|  | .enterprise-card | ||||||
|  |     margin: 20rpx 28rpx | ||||||
|  |     padding: 28rpx | ||||||
|  |     background: rgba(255, 255, 255, 0.9) | ||||||
|  |     backdrop-filter: blur(20rpx) | ||||||
|  |     -webkit-backdrop-filter: blur(20rpx) | ||||||
|  |     border-radius: 24rpx | ||||||
|  |     border: 1rpx solid rgba(255, 255, 255, 0.4) | ||||||
|  |     box-shadow: 0 8rpx 40rpx rgba(0, 0, 0, 0.08), 0 2rpx 8rpx rgba(0, 0, 0, 0.04) | ||||||
|  |     position: relative | ||||||
|  |     overflow: hidden | ||||||
|  |     cursor: pointer | ||||||
|  |     transition: all 0.3s ease | ||||||
|  |      | ||||||
|  |     &:active | ||||||
|  |         transform: scale(0.98) | ||||||
|  |         box-shadow: 0 4rpx 20rpx rgba(0, 0, 0, 0.12), 0 1rpx 4rpx rgba(0, 0, 0, 0.08) | ||||||
|  |      | ||||||
|  |     // 玻璃态效果 - 更强烈的渐变 | ||||||
|  |     &::before | ||||||
|  |         content: '' | ||||||
|  |         position: absolute | ||||||
|  |         top: 0 | ||||||
|  |         left: 0 | ||||||
|  |         right: 0 | ||||||
|  |         bottom: 0 | ||||||
|  |         background: linear-gradient(135deg,  | ||||||
|  |             rgba(255, 255, 255, 0.2) 0%,  | ||||||
|  |             rgba(255, 255, 255, 0.1) 50%,  | ||||||
|  |             rgba(255, 255, 255, 0.05) 100%) | ||||||
|  |         border-radius: 24rpx | ||||||
|  |         pointer-events: none | ||||||
|  |         z-index: 0 | ||||||
|  |      | ||||||
|  |     // 添加微妙的边框高光 | ||||||
|  |     &::after | ||||||
|  |         content: '' | ||||||
|  |         position: absolute | ||||||
|  |         top: 0 | ||||||
|  |         left: 0 | ||||||
|  |         right: 0 | ||||||
|  |         bottom: 0 | ||||||
|  |         border-radius: 24rpx | ||||||
|  |         padding: 1rpx | ||||||
|  |         background: linear-gradient(135deg,  | ||||||
|  |             rgba(255, 255, 255, 0.6) 0%,  | ||||||
|  |             rgba(255, 255, 255, 0.2) 100%) | ||||||
|  |         mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) | ||||||
|  |         -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) | ||||||
|  |         mask-composite: xor | ||||||
|  |         -webkit-mask-composite: xor | ||||||
|  |         pointer-events: none | ||||||
|  |         z-index: 1 | ||||||
|  |      | ||||||
|  |     .card-content | ||||||
|  |         display: flex | ||||||
|  |         align-items: center | ||||||
|  |         position: relative | ||||||
|  |         z-index: 2 | ||||||
|  |          | ||||||
|  |         .company-icon | ||||||
|  |             width: 88rpx | ||||||
|  |             height: 88rpx | ||||||
|  |             border-radius: 18rpx | ||||||
|  |             background: linear-gradient(135deg, #256BFA 0%, #4A90E2 100%) | ||||||
|  |             display: flex | ||||||
|  |             align-items: center | ||||||
|  |             justify-content: center | ||||||
|  |             margin-right: 28rpx | ||||||
|  |             flex-shrink: 0 | ||||||
|  |             box-shadow: 0 6rpx 16rpx rgba(37, 107, 250, 0.25) | ||||||
|  |             position: relative | ||||||
|  |              | ||||||
|  |             // 添加图标内部高光 | ||||||
|  |             &::before | ||||||
|  |                 content: '' | ||||||
|  |                 position: absolute | ||||||
|  |                 top: 4rpx | ||||||
|  |                 left: 4rpx | ||||||
|  |                 right: 4rpx | ||||||
|  |                 height: 20rpx | ||||||
|  |                 background: linear-gradient(180deg, rgba(255, 255, 255, 0.3) 0%, transparent 100%) | ||||||
|  |                 border-radius: 18rpx 18rpx 0 0 | ||||||
|  |                 pointer-events: none | ||||||
|  |              | ||||||
|  |             .default-logo | ||||||
|  |                 display: flex | ||||||
|  |                 align-items: center | ||||||
|  |                 justify-content: center | ||||||
|  |                 color: #ffffff | ||||||
|  |                  | ||||||
|  |         .company-info | ||||||
|  |             flex: 1 | ||||||
|  |             min-width: 0 | ||||||
|  |             z-index: 2 | ||||||
|  |             position: relative | ||||||
|  |              | ||||||
|  |             .company-name | ||||||
|  |                 font-size: 34rpx | ||||||
|  |                 font-weight: 600 | ||||||
|  |                 color: #000000 | ||||||
|  |                 line-height: 1.3 | ||||||
|  |                 margin-bottom: 10rpx | ||||||
|  |                 overflow: hidden | ||||||
|  |                 text-overflow: ellipsis | ||||||
|  |                 white-space: nowrap | ||||||
|  |                 font-family: 'PingFangSC-Medium', 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, 'Microsoft YaHei', sans-serif | ||||||
|  |                  | ||||||
|  |             .company-details | ||||||
|  |                 display: flex | ||||||
|  |                 align-items: center | ||||||
|  |                 font-size: 26rpx | ||||||
|  |                 color: #666666 | ||||||
|  |                 line-height: 1.2 | ||||||
|  |                  | ||||||
|  |                 .industry | ||||||
|  |                     color: #666666 | ||||||
|  |                     font-weight: 400 | ||||||
|  |                      | ||||||
|  |                 .separator | ||||||
|  |                     margin: 0 10rpx | ||||||
|  |                     color: #CCCCCC | ||||||
|  |                     font-weight: 300 | ||||||
|  |                      | ||||||
|  |                 .size | ||||||
|  |                     color: #666666 | ||||||
|  |                     font-weight: 400 | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -2,11 +2,7 @@ | |||||||
|     <view class="publish-job-page"> |     <view class="publish-job-page"> | ||||||
|         <!-- 头部导航 --> |         <!-- 头部导航 --> | ||||||
|         <view class="header"> |         <view class="header"> | ||||||
|             <view class="header-left" @click="goBack"> |  | ||||||
|                 <image src="@/static/icon/back.png" class="back-icon"></image> |  | ||||||
|             </view> |  | ||||||
|             <view class="header-title">发布岗位</view> |             <view class="header-title">发布岗位</view> | ||||||
|             <view class="header-right"></view> |  | ||||||
|         </view> |         </view> | ||||||
|  |  | ||||||
|         <!-- 主要内容 --> |         <!-- 主要内容 --> | ||||||
| @@ -216,10 +212,12 @@ | |||||||
|         <!-- 底部操作按钮 --> |         <!-- 底部操作按钮 --> | ||||||
|         <view class="footer"> |         <view class="footer"> | ||||||
|             <view class="btn-group"> |             <view class="btn-group"> | ||||||
|                 <button class="btn btn-cancel" @click="goBack">取消</button> |  | ||||||
|                 <button class="btn btn-publish" @click="publishJob">发布岗位</button> |                 <button class="btn btn-publish" @click="publishJob">发布岗位</button> | ||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> | ||||||
|  |          | ||||||
|  |         <!-- 自定义tabbar --> | ||||||
|  |         <CustomTabBar :currentPage="1" /> | ||||||
|     </view> |     </view> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| @@ -282,7 +280,9 @@ const calculateScrollViewHeight = () => { | |||||||
|     const windowHeight = systemInfo.windowHeight; |     const windowHeight = systemInfo.windowHeight; | ||||||
|     const headerHeight = 100; // 头部高度 |     const headerHeight = 100; // 头部高度 | ||||||
|     const footerHeight = 120; // 底部按钮高度 |     const footerHeight = 120; // 底部按钮高度 | ||||||
|     const scrollHeight = windowHeight - headerHeight - footerHeight; |     const tabbarHeight = 88; // 自定义tabbar高度 | ||||||
|  |     const extraPadding = 50; // 额外间距,确保内容不被遮挡 | ||||||
|  |     const scrollHeight = windowHeight - headerHeight - footerHeight - tabbarHeight - extraPadding; | ||||||
|     scrollViewHeight.value = `${scrollHeight}px`; |     scrollViewHeight.value = `${scrollHeight}px`; | ||||||
| }; | }; | ||||||
| const userType = ref(Number(userStore.userInfo.isCompanyUser)); | const userType = ref(Number(userStore.userInfo.isCompanyUser)); | ||||||
| @@ -417,10 +417,6 @@ const handleCompanySelected = (company) => { | |||||||
|     formData.companyId = company.id; |     formData.companyId = company.id; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // 返回上一页 |  | ||||||
| const goBack = () => { |  | ||||||
|     uni.navigateBack(); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| // 发布岗位 | // 发布岗位 | ||||||
| const publishJob = async () => { | const publishJob = async () => { | ||||||
| @@ -464,10 +460,10 @@ const publishJob = async () => { | |||||||
|                 icon: 'success' |                 icon: 'success' | ||||||
|             }); |             }); | ||||||
|              |              | ||||||
|             // 延迟返回 |             uni.redirectTo({ | ||||||
|             setTimeout(() => { |                 url: '/pages/index/index' | ||||||
|                 goBack(); |             }); | ||||||
|             }, 1500); |              | ||||||
|         } else { |         } else { | ||||||
|             uni.showToast({ |             uni.showToast({ | ||||||
|                 title: response.msg || '发布失败', |                 title: response.msg || '发布失败', | ||||||
| @@ -565,18 +561,6 @@ const validateForm = () => { | |||||||
|     background: #fff; |     background: #fff; | ||||||
|     border-bottom: 1rpx solid #eee; |     border-bottom: 1rpx solid #eee; | ||||||
|      |      | ||||||
|     .header-left { |  | ||||||
|         width: 60rpx; |  | ||||||
|         height: 60rpx; |  | ||||||
|         display: flex; |  | ||||||
|         align-items: center; |  | ||||||
|         justify-content: center; |  | ||||||
|          |  | ||||||
|         .back-icon { |  | ||||||
|             width: 40rpx; |  | ||||||
|             height: 40rpx; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|      |      | ||||||
|     .header-title { |     .header-title { | ||||||
|         font-size: 36rpx; |         font-size: 36rpx; | ||||||
| @@ -864,23 +848,22 @@ const validateForm = () => { | |||||||
| } | } | ||||||
|  |  | ||||||
| .bottom-safe-area { | .bottom-safe-area { | ||||||
|     height: 120rpx; |     height: 250rpx; | ||||||
|     background: transparent; |     background: transparent; | ||||||
| } | } | ||||||
|  |  | ||||||
| .footer { | .footer { | ||||||
|     position: fixed; |     position: fixed; | ||||||
|     bottom: 0; |     bottom: 140rpx; | ||||||
|     left: 0; |     left: 0; | ||||||
|     right: 0; |     right: 0; | ||||||
|     background: #fff; |     background: #fff; | ||||||
|     padding: 20rpx 30rpx; |     padding: 25rpx 30rpx; | ||||||
|     border-top: 1rpx solid #eee; |     border-top: 1rpx solid #eee; | ||||||
|     z-index: 100; |     z-index: 100; | ||||||
|      |      | ||||||
|     .btn-group { |     .btn-group { | ||||||
|         display: flex; |         display: flex; | ||||||
|         gap: 20rpx; |  | ||||||
|          |          | ||||||
|         .btn { |         .btn { | ||||||
|             flex: 1; |             flex: 1; | ||||||
| @@ -890,11 +873,6 @@ const validateForm = () => { | |||||||
|             font-weight: 500; |             font-weight: 500; | ||||||
|             border: none; |             border: none; | ||||||
|              |              | ||||||
|             &.btn-cancel { |  | ||||||
|                 background: #f5f5f5; |  | ||||||
|                 color: #666; |  | ||||||
|             } |  | ||||||
|              |  | ||||||
|             &.btn-publish { |             &.btn-publish { | ||||||
|                 background: #256BFA; |                 background: #256BFA; | ||||||
|                 color: #fff; |                 color: #fff; | ||||||
|   | |||||||
| @@ -1,15 +1,10 @@ | |||||||
| <template> | <template> | ||||||
|     <AppLayout title="企业信息" back-gorund-color="#F4F4F4"> |     <AppLayout back-gorund-color="#F4F4F4"> | ||||||
|         <!-- 头部进度显示 --> |  | ||||||
|         <view class="header-progress"> |  | ||||||
|             <text class="progress-text">{{ companyInfo.completeness || '100%' }}</text> |  | ||||||
|         </view> |  | ||||||
|  |  | ||||||
|         <!-- 编辑头像 --> |         <!-- 编辑头像 --> | ||||||
|         <view class="avatar-section btn-feel" @click="editAvatar"> |         <view class="avatar-section btn-feel" @click="editAvatar"> | ||||||
|             <view class="avatar-label">编辑头像</view> |             <view class="avatar-label">编辑头像</view> | ||||||
|             <view class="avatar-container"> |             <view class="avatar-container"> | ||||||
|                 <image class="company-avatar" :src="companyInfo.avatar || '/static/icon/company-avatar.png'"></image> |                 <image class="company-avatar" :src="companyInfo.avatar || '/static/imgs/avatar.jpg'"></image> | ||||||
|                 <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                 <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|             </view> |             </view> | ||||||
|         </view> |         </view> | ||||||
| @@ -19,7 +14,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('name')"> |             <view class="info-item btn-feel" @click="editInfo('name')"> | ||||||
|                 <view class="info-label">企业名称</view> |                 <view class="info-label">企业名称</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.name || '科里(北京)科技有限公司(喀什分公司)' }}</text> |                     <text class="info-value">{{ companyInfo.name || '暂无公司名称' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -27,7 +22,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('code')"> |             <view class="info-item btn-feel" @click="editInfo('code')"> | ||||||
|                 <view class="info-label">统一社会代码</view> |                 <view class="info-label">统一社会代码</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.socialCode || '6217171301012562295' }}</text> |                     <text class="info-value">{{ companyInfo.socialCode || '暂无统一社会代码' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -35,7 +30,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('location')"> |             <view class="info-item btn-feel" @click="editInfo('location')"> | ||||||
|                 <view class="info-label">企业注册地点</view> |                 <view class="info-label">企业注册地点</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.location || '北京' }}</text> |                     <text class="info-value">{{ companyInfo.location || '暂无注册地点' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -43,7 +38,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('description')"> |             <view class="info-item btn-feel" @click="editInfo('description')"> | ||||||
|                 <view class="info-label">企业信息介绍</view> |                 <view class="info-label">企业信息介绍</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.description || '公司成立于2003年01月27日,位于北京市大兴区经济技术产业开发区天泰一路3号一号楼南四、五楼,目前处于开业状态,经营范围包括信息技术咨询服务;科技中介服务;人工智能等。' }}</text> |                     <text class="info-value">{{ companyInfo.description || '暂无企业介绍' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -51,7 +46,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('legalPerson')"> |             <view class="info-item btn-feel" @click="editInfo('legalPerson')"> | ||||||
|                 <view class="info-label">企业法人姓名</view> |                 <view class="info-label">企业法人姓名</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.legalPerson || '孙正云' }}</text> |                     <text class="info-value">{{ companyInfo.legalPerson || '暂无法人信息' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -59,7 +54,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('contact1')"> |             <view class="info-item btn-feel" @click="editInfo('contact1')"> | ||||||
|                 <view class="info-label">企业联系人名称</view> |                 <view class="info-label">企业联系人名称</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.contact1Name || '吴宣萱' }}</text> |                     <text class="info-value">{{ companyInfo.contact1Name || '暂无联系人' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -67,7 +62,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('contact1Phone')"> |             <view class="info-item btn-feel" @click="editInfo('contact1Phone')"> | ||||||
|                 <view class="info-label">企业联系人电话</view> |                 <view class="info-label">企业联系人电话</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.contact1Phone || '15547143804' }}</text> |                     <text class="info-value">{{ companyInfo.contact1Phone || '暂无联系电话' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -75,7 +70,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('contact2')"> |             <view class="info-item btn-feel" @click="editInfo('contact2')"> | ||||||
|                 <view class="info-label">企业联系人名称</view> |                 <view class="info-label">企业联系人名称</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.contact2Name || '李杰' }}</text> |                     <text class="info-value">{{ companyInfo.contact2Name || '暂无联系人' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -83,7 +78,7 @@ | |||||||
|             <view class="info-item btn-feel" @click="editInfo('contact2Phone')"> |             <view class="info-item btn-feel" @click="editInfo('contact2Phone')"> | ||||||
|                 <view class="info-label">企业联系人电话</view> |                 <view class="info-label">企业联系人电话</view> | ||||||
|                 <view class="info-content"> |                 <view class="info-content"> | ||||||
|                     <text class="info-value">{{ companyInfo.contact2Phone || '10700010700' }}</text> |                     <text class="info-value">{{ companyInfo.contact2Phone || '暂无联系电话' }}</text> | ||||||
|                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                     <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
| @@ -94,22 +89,24 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { reactive, inject, onMounted } from 'vue'; | import { reactive, inject, onMounted } from 'vue'; | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
|  | import AppLayout from '@/components/AppLayout/AppLayout.vue'; | ||||||
|  |  | ||||||
| const { $api, navTo } = inject('globalFunction'); | const { $api, navTo } = inject('globalFunction'); | ||||||
|  |  | ||||||
| // 企业信息数据 | // 企业信息数据 | ||||||
| const companyInfo = reactive({ | const companyInfo = reactive({ | ||||||
|     name: '科里(北京)科技有限公司(喀什分公司)', |     name: '', | ||||||
|     avatar: '/static/icon/company-avatar.png', |     avatar: '/static/imgs/avatar.jpg', | ||||||
|     completeness: '100%', |     completeness: '100%', | ||||||
|     socialCode: '6217171301012562295', |     socialCode: '', | ||||||
|     location: '北京', |     location: '', | ||||||
|     description: '公司成立于2003年01月27日,位于北京市大兴区经济技术产业开发区天泰一路3号一号楼南四、五楼,目前处于开业状态,经营范围包括信息技术咨询服务;科技中介服务;人工智能等。', |     description: '', | ||||||
|     legalPerson: '孙正云', |     legalPerson: '', | ||||||
|     contact1Name: '吴宣萱', |     contact1Name: '', | ||||||
|     contact1Phone: '15547143804', |     contact1Phone: '', | ||||||
|     contact2Name: '李杰', |     contact2Name: '', | ||||||
|     contact2Phone: '10700010700' |     contact2Phone: '', | ||||||
|  |     isVerified: false // 实名状态 | ||||||
| }); | }); | ||||||
|  |  | ||||||
| function editAvatar() { | function editAvatar() { | ||||||
| @@ -166,24 +163,56 @@ onShow(() => { | |||||||
|     getCompanyInfo(); |     getCompanyInfo(); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | // 从缓存获取公司信息 | ||||||
| function getCompanyInfo() { | function getCompanyInfo() { | ||||||
|     // 这里可以调用API获取企业信息 |     try { | ||||||
|     // $api.createRequest('/app/company/info').then((resData) => { |         const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|     //     Object.assign(companyInfo, resData.data); |         console.log('缓存中的userInfo:', cachedUserInfo); | ||||||
|     // }); |          | ||||||
|  |         // 检查是否有company字段 | ||||||
|  |         if (cachedUserInfo.company) { | ||||||
|  |             const company = cachedUserInfo.company; | ||||||
|  |              | ||||||
|  |             // 基本信息 | ||||||
|  |             companyInfo.name = company.name || ''; | ||||||
|  |             companyInfo.socialCode = company.code || ''; | ||||||
|  |             companyInfo.location = company.registeredAddress || ''; | ||||||
|  |             companyInfo.description = company.description || ''; | ||||||
|  |             companyInfo.legalPerson = company.legalPerson || ''; | ||||||
|  |              | ||||||
|  |             // 联系人信息 | ||||||
|  |             if (company.companyContactList && company.companyContactList.length > 0) { | ||||||
|  |                 const contacts = company.companyContactList; | ||||||
|  |                 companyInfo.contact1Name = contacts[0]?.contactPerson || ''; | ||||||
|  |                 companyInfo.contact1Phone = contacts[0]?.contactPersonPhone || ''; | ||||||
|  |                 if (contacts.length > 1) { | ||||||
|  |                     companyInfo.contact2Name = contacts[1]?.contactPerson || ''; | ||||||
|  |                     companyInfo.contact2Phone = contacts[1]?.contactPersonPhone || ''; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             // 判断是否实名:legalIdCard字段有值则表示已实名 | ||||||
|  |             companyInfo.isVerified = !!(company.legalIdCard && company.legalIdCard.trim()); | ||||||
|  |              | ||||||
|  |             console.log('公司名称:', companyInfo.name); | ||||||
|  |             console.log('实名状态:', companyInfo.isVerified); | ||||||
|  |             console.log('legalIdCard值:', company.legalIdCard); | ||||||
|  |         } else { | ||||||
|  |             console.log('缓存中没有company字段'); | ||||||
|  |             // 保持默认值 | ||||||
|  |         } | ||||||
|  |     } catch (error) { | ||||||
|  |         console.error('获取公司信息失败:', error); | ||||||
|  |         // 保持默认值 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function goBack() { | ||||||
|  |     uni.navigateBack(); | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="stylus" scoped> | <style lang="stylus" scoped> | ||||||
| .header-progress { |  | ||||||
|     text-align: center; |  | ||||||
|     padding: 20rpx 0; |  | ||||||
|      |  | ||||||
|     .progress-text { |  | ||||||
|         font-size: 28rpx; |  | ||||||
|         color: #6C7282; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .avatar-section { | .avatar-section { | ||||||
|     display: flex; |     display: flex; | ||||||
|   | |||||||
| @@ -1,16 +1,21 @@ | |||||||
| <template> | <template> | ||||||
|     <AppLayout title="我的" back-gorund-color="#F4F4F4"> |     <AppLayout back-gorund-color="#F4F4F4"> | ||||||
|         <!-- 自定义tabbar --> |         <!-- 自定义tabbar --> | ||||||
|         <CustomTabBar :currentPage="4" /> |         <CustomTabBar :currentPage="4" /> | ||||||
|          |          | ||||||
|         <!-- 企业信息卡片 --> |         <!-- 企业信息卡片 --> | ||||||
|         <view class="company-info-card btn-feel" @click="goToCompanyInfo"> |         <view class="company-info-card btn-feel" @click="goToCompanyInfo"> | ||||||
|             <view class="company-avatar"> |             <view class="company-avatar"> | ||||||
|                 <image class="company-avatar-img" :src="companyInfo.avatar || '/static/icon/company-default.png'"></image> |                 <image class="company-avatar-img" :src="companyInfo.avatar || '/static/imgs/avatar.jpg'"></image> | ||||||
|             </view> |             </view> | ||||||
|             <view class="company-details"> |             <view class="company-details"> | ||||||
|                 <view class="company-name">{{ companyInfo.name || '科里喀什分公司' }}</view> |                 <view class="company-name">{{ companyInfo.name || '暂无公司名称' }}</view> | ||||||
|                 <view class="company-completeness">信息完整度 {{ companyInfo.completeness || '100%' }}</view> |                 <view class="company-completeness"> | ||||||
|  |                     信息完整度 {{ companyInfo.completeness || '100%' }} | ||||||
|  |                     <text class="verification-status" :class="{ 'verified': companyInfo.isVerified, 'unverified': !companyInfo.isVerified }"> | ||||||
|  |                         {{ companyInfo.isVerified ? '已实名' : '未实名' }} | ||||||
|  |                     </text> | ||||||
|  |                 </view> | ||||||
|             </view> |             </view> | ||||||
|             <view class="company-arrow"> |             <view class="company-arrow"> | ||||||
|                 <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> |                 <uni-icons color="#A2A2A2" type="right" size="16"></uni-icons> | ||||||
| @@ -22,14 +27,16 @@ | |||||||
|             <view class="service-title">服务专区</view> |             <view class="service-title">服务专区</view> | ||||||
|             <view class="service-item btn-feel"> |             <view class="service-item btn-feel"> | ||||||
|                 <view class="service-left"> |                 <view class="service-left"> | ||||||
|                     <image class="service-icon" src="/static/icon/real-name-auth.png"></image> |                     <uni-icons type="contact" size="20" color="#256BFA"></uni-icons> | ||||||
|                     <text class="service-text">实名认证</text> |                     <text class="service-text">实名认证</text> | ||||||
|                 </view> |                 </view> | ||||||
|                 <view class="service-status">已通过</view> |                 <view class="service-status" :class="{ 'verified': companyInfo.isVerified, 'unverified': !companyInfo.isVerified }"> | ||||||
|  |                     {{ companyInfo.isVerified ? '已通过' : '未认证' }} | ||||||
|  |                 </view> | ||||||
|             </view> |             </view> | ||||||
|             <view class="service-item btn-feel"> |             <view class="service-item btn-feel"> | ||||||
|                 <view class="service-left"> |                 <view class="service-left"> | ||||||
|                     <image class="service-icon" src="/static/icon/notification.png"></image> |                     <uni-icons type="notification" size="20" color="#256BFA"></uni-icons> | ||||||
|                     <text class="service-text">通知与提醒</text> |                     <text class="service-text">通知与提醒</text> | ||||||
|                 </view> |                 </view> | ||||||
|                 <view class="service-status">已开启</view> |                 <view class="service-status">已开启</view> | ||||||
| @@ -57,17 +64,19 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, inject, ref, onMounted } from 'vue'; | import { reactive, inject, ref, onMounted, onUnmounted } from 'vue'; | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
|  | import useUserStore from '@/stores/useUserStore'; | ||||||
|  |  | ||||||
| const { $api, navTo } = inject('globalFunction'); | const { $api, navTo } = inject('globalFunction'); | ||||||
| const popup = ref(null); | const popup = ref(null); | ||||||
|  |  | ||||||
| // 企业信息数据 | // 企业信息数据 | ||||||
| const companyInfo = reactive({ | const companyInfo = reactive({ | ||||||
|     name: '科里喀什分公司', |     name: '', | ||||||
|     avatar: '/static/icon/company-avatar.png', |     avatar: '/static/imgs/avatar.jpg', | ||||||
|     completeness: '100%' |     completeness: '100%', | ||||||
|  |     isVerified: false // 实名状态 | ||||||
| }); | }); | ||||||
|  |  | ||||||
| function goToCompanyInfo() { | function goToCompanyInfo() { | ||||||
| @@ -83,9 +92,11 @@ function close() { | |||||||
| } | } | ||||||
|  |  | ||||||
| function confirm() { | function confirm() { | ||||||
|     // 这里可以调用退出登录的API |     // 调用退出登录 | ||||||
|     console.log('退出登录'); |     useUserStore().logOut(); | ||||||
|     // 跳转到登录页面或首页 |     // 关闭弹窗 | ||||||
|  |     popup.value.close(); | ||||||
|  |     // 跳转到首页 | ||||||
|     uni.reLaunch({ |     uni.reLaunch({ | ||||||
|         url: '/pages/index/index' |         url: '/pages/index/index' | ||||||
|     }); |     }); | ||||||
| @@ -96,11 +107,45 @@ onShow(() => { | |||||||
|     getCompanyInfo(); |     getCompanyInfo(); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | // 监听退出登录事件,显示微信登录弹窗 | ||||||
|  | onMounted(() => { | ||||||
|  |     uni.$on('showLoginModal', () => { | ||||||
|  |         // 这里可以显示微信登录弹窗 | ||||||
|  |         // 由于这个页面没有 WxAuthLogin 组件,我们跳转到首页让首页处理 | ||||||
|  |         uni.reLaunch({ | ||||||
|  |             url: '/pages/index/index' | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | onUnmounted(() => { | ||||||
|  |     uni.$off('showLoginModal'); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // 从缓存获取公司信息 | ||||||
| function getCompanyInfo() { | function getCompanyInfo() { | ||||||
|     // 这里可以调用API获取企业信息 |     try { | ||||||
|     // $api.createRequest('/app/company/info').then((resData) => { |         const cachedUserInfo = uni.getStorageSync('userInfo') || {}; | ||||||
|     //     Object.assign(companyInfo, resData.data); |         console.log('缓存中的userInfo:', cachedUserInfo); | ||||||
|     // }); |          | ||||||
|  |         // 检查是否有company字段 | ||||||
|  |         if (cachedUserInfo.company) { | ||||||
|  |             companyInfo.name = cachedUserInfo.company.name || ''; | ||||||
|  |             // 判断是否实名:legalIdCard字段有值则表示已实名 | ||||||
|  |             companyInfo.isVerified = !!(cachedUserInfo.company.legalIdCard && cachedUserInfo.company.legalIdCard.trim()); | ||||||
|  |             console.log('公司名称:', companyInfo.name); | ||||||
|  |             console.log('实名状态:', companyInfo.isVerified); | ||||||
|  |             console.log('legalIdCard值:', cachedUserInfo.company.legalIdCard); | ||||||
|  |         } else { | ||||||
|  |             console.log('缓存中没有company字段'); | ||||||
|  |             companyInfo.name = ''; | ||||||
|  |             companyInfo.isVerified = false; | ||||||
|  |         } | ||||||
|  |     } catch (error) { | ||||||
|  |         console.error('获取公司信息失败:', error); | ||||||
|  |         companyInfo.name = ''; | ||||||
|  |         companyInfo.isVerified = false; | ||||||
|  |     } | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| @@ -140,6 +185,25 @@ function getCompanyInfo() { | |||||||
|         .company-completeness { |         .company-completeness { | ||||||
|             font-size: 28rpx; |             font-size: 28rpx; | ||||||
|             color: #6C7282; |             color: #6C7282; | ||||||
|  |             display: flex; | ||||||
|  |             align-items: center; | ||||||
|  |             gap: 16rpx; | ||||||
|  |              | ||||||
|  |             .verification-status { | ||||||
|  |                 font-size: 24rpx; | ||||||
|  |                 padding: 4rpx 12rpx; | ||||||
|  |                 border-radius: 12rpx; | ||||||
|  |                  | ||||||
|  |                 &.verified { | ||||||
|  |                     background-color: #E8F5E8; | ||||||
|  |                     color: #52C41A; | ||||||
|  |                 } | ||||||
|  |                  | ||||||
|  |                 &.unverified { | ||||||
|  |                     background-color: #FFF2E8; | ||||||
|  |                     color: #FA8C16; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
| @@ -177,21 +241,24 @@ function getCompanyInfo() { | |||||||
|             display: flex; |             display: flex; | ||||||
|             align-items: center; |             align-items: center; | ||||||
|              |              | ||||||
|             .service-icon { |  | ||||||
|                 width: 44rpx; |  | ||||||
|                 height: 44rpx; |  | ||||||
|                 margin-right: 16rpx; |  | ||||||
|             } |  | ||||||
|              |  | ||||||
|             .service-text { |             .service-text { | ||||||
|                 font-size: 28rpx; |                 font-size: 28rpx; | ||||||
|                 color: #333333; |                 color: #333333; | ||||||
|  |                 margin-left: 16rpx; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         .service-status { |         .service-status { | ||||||
|             font-size: 28rpx; |             font-size: 28rpx; | ||||||
|             color: #6E6E6E; |             color: #6E6E6E; | ||||||
|  |              | ||||||
|  |             &.verified { | ||||||
|  |                 color: #52C41A; | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             &.unverified { | ||||||
|  |                 color: #FA8C16; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -120,7 +120,7 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, inject, watch, ref, onMounted } from 'vue'; | import { reactive, inject, watch, ref, onMounted, onUnmounted } from 'vue'; | ||||||
| import { storeToRefs } from 'pinia'; | import { storeToRefs } from 'pinia'; | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
| const { $api, navTo } = inject('globalFunction'); | const { $api, navTo } = inject('globalFunction'); | ||||||
| @@ -145,6 +145,21 @@ onShow(() => { | |||||||
|     tabbarManager.updateSelected(4); |     tabbarManager.updateSelected(4); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | // 监听退出登录事件,显示微信登录弹窗 | ||||||
|  | onMounted(() => { | ||||||
|  |     uni.$on('showLoginModal', () => { | ||||||
|  |         // 这里可以显示微信登录弹窗 | ||||||
|  |         // 由于这个页面没有 WxAuthLogin 组件,我们跳转到首页让首页处理 | ||||||
|  |         uni.reLaunch({ | ||||||
|  |             url: '/pages/index/index' | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | onUnmounted(() => { | ||||||
|  |     uni.$off('showLoginModal'); | ||||||
|  | }); | ||||||
|  |  | ||||||
| function close() { | function close() { | ||||||
|     popup.value.close(); |     popup.value.close(); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -21,8 +21,8 @@ | |||||||
|                         <component :is="components[index]" :ref="(el) => handelComponentsRef(el, index)" /> |                         <component :is="components[index]" :ref="(el) => handelComponentsRef(el, index)" /> | ||||||
|                         <!-- #endif --> |                         <!-- #endif --> | ||||||
|                         <!-- #ifdef MP-WEIXIN --> |                         <!-- #ifdef MP-WEIXIN --> | ||||||
|                         <ReadComponent v-show="currentIndex === 0" :ref="(el) => handelComponentsRef(el, index)" /> |                         <ReadComponent v-show="state.current === 0" :ref="(el) => handelComponentsRef(el, index)" /> | ||||||
|                         <UnreadComponent v-show="currentIndex === 1" :ref="(el) => handelComponentsRef(el, index)" /> |                         <UnreadComponent v-show="state.current === 1" :ref="(el) => handelComponentsRef(el, index)" /> | ||||||
|                         <!-- #endif --> |                         <!-- #endif --> | ||||||
|                     </swiper-item> |                     </swiper-item> | ||||||
|                 </swiper> |                 </swiper> | ||||||
| @@ -31,24 +31,29 @@ | |||||||
|             <!-- 自定义tabbar --> |             <!-- 自定义tabbar --> | ||||||
|             <CustomTabBar :currentPage="3" /> |             <CustomTabBar :currentPage="3" /> | ||||||
|              |              | ||||||
|  |             <!-- 微信授权登录弹窗 --> | ||||||
|  |             <WxAuthLogin ref="wxAuthLoginRef" @success="handleLoginSuccess"></WxAuthLogin> | ||||||
|  |  | ||||||
|             <!-- 统一使用系统tabBar --> |             <!-- 统一使用系统tabBar --> | ||||||
|         </view> |         </view> | ||||||
|     </view> |     </view> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup> | <script setup> | ||||||
| import { reactive, inject, watch, ref, onMounted } from 'vue'; | import { reactive, inject, watch, ref, onMounted, onUnmounted } from 'vue'; | ||||||
| import { onLoad, onShow } from '@dcloudio/uni-app'; | import { onLoad, onShow } from '@dcloudio/uni-app'; | ||||||
| import Tabbar from '@/components/tabbar/midell-box.vue'; | import Tabbar from '@/components/tabbar/midell-box.vue'; | ||||||
| import ReadComponent from './read.vue'; | import ReadComponent from './read.vue'; | ||||||
| import UnreadComponent from './unread.vue'; | import UnreadComponent from './unread.vue'; | ||||||
| import { tabbarManager } from '@/utils/tabbarManager'; | import { tabbarManager } from '@/utils/tabbarManager'; | ||||||
|  | import WxAuthLogin from '@/components/WxAuthLogin/WxAuthLogin.vue'; | ||||||
| const loadedMap = reactive([false, false]); | const loadedMap = reactive([false, false]); | ||||||
| const swiperRefs = [ref(null), ref(null)]; | const swiperRefs = [ref(null), ref(null)]; | ||||||
| const components = [ReadComponent, UnreadComponent]; | const components = [ReadComponent, UnreadComponent]; | ||||||
| import { storeToRefs } from 'pinia'; | import { storeToRefs } from 'pinia'; | ||||||
| import { useReadMsg } from '@/stores/useReadMsg'; | import { useReadMsg } from '@/stores/useReadMsg'; | ||||||
| const { unreadCount } = storeToRefs(useReadMsg()); | const { unreadCount } = storeToRefs(useReadMsg()); | ||||||
|  | const wxAuthLoginRef = ref(null); | ||||||
|  |  | ||||||
| onShow(() => { | onShow(() => { | ||||||
|     // 获取消息列表 |     // 获取消息列表 | ||||||
| @@ -63,8 +68,23 @@ const state = reactive({ | |||||||
|  |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|     handleTabChange(state.current); |     handleTabChange(state.current); | ||||||
|  |      | ||||||
|  |     // 监听退出登录事件,显示微信登录弹窗 | ||||||
|  |     uni.$on('showLoginModal', () => { | ||||||
|  |         wxAuthLoginRef.value?.open(); | ||||||
|  |     }); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | onUnmounted(() => { | ||||||
|  |     uni.$off('showLoginModal'); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // 登录成功回调 | ||||||
|  | const handleLoginSuccess = () => { | ||||||
|  |     console.log('登录成功'); | ||||||
|  |     // 可以在这里添加登录成功后的处理逻辑 | ||||||
|  | }; | ||||||
|  |  | ||||||
| const handelComponentsRef = (el, index) => { | const handelComponentsRef = (el, index) => { | ||||||
|     if (el) { |     if (el) { | ||||||
|         swiperRefs[index].value = el; |         swiperRefs[index].value = el; | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| <template> | <template> | ||||||
|     <scroll-view scroll-y class="main-scroll"> |     <scroll-view scroll-y class="main-scroll"> | ||||||
|         <view class="scrollmain"> |         <view class="scrollmain"> | ||||||
|  |             <!-- 消息列表 --> | ||||||
|             <view |             <view | ||||||
|                 class="list-card press-button" |                 class="list-card press-button" | ||||||
|                 v-for="(item, index) in msgList" |                 v-for="(item, index) in msgList" | ||||||
| @@ -35,6 +36,13 @@ | |||||||
|                     <view class="info-text line_2">{{ item.subTitle || '消息' }}</view> |                     <view class="info-text line_2">{{ item.subTitle || '消息' }}</view> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
|  |              | ||||||
|  |             <!-- 暂无消息提示 --> | ||||||
|  |             <view class="empty-state" v-if="msgList.length === 0"> | ||||||
|  |                 <image class="empty-icon" src="/static/icon/empty.png" mode="aspectFit"></image> | ||||||
|  |                 <text class="empty-text">暂无消息</text> | ||||||
|  |                 <text class="empty-desc">您还没有收到任何消息</text> | ||||||
|  |             </view> | ||||||
|         </view> |         </view> | ||||||
|     </scroll-view> |     </scroll-view> | ||||||
| </template> | </template> | ||||||
| @@ -146,4 +154,26 @@ defineExpose({ loadData }); | |||||||
|             font-size: 28rpx; |             font-size: 28rpx; | ||||||
|             color: #6C7282; |             color: #6C7282; | ||||||
|             margin-top: 4rpx; |             margin-top: 4rpx; | ||||||
|  |  | ||||||
|  | // 空状态样式 | ||||||
|  | .empty-state | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     align-items: center; | ||||||
|  |     justify-content: center; | ||||||
|  |     padding: 120rpx 40rpx; | ||||||
|  |     .empty-icon | ||||||
|  |         width: 200rpx; | ||||||
|  |         height: 200rpx; | ||||||
|  |         margin-bottom: 40rpx; | ||||||
|  |         opacity: 0.6; | ||||||
|  |     .empty-text | ||||||
|  |         font-size: 32rpx; | ||||||
|  |         color: #999999; | ||||||
|  |         font-weight: 500; | ||||||
|  |         margin-bottom: 16rpx; | ||||||
|  |     .empty-desc | ||||||
|  |         font-size: 28rpx; | ||||||
|  |         color: #CCCCCC; | ||||||
|  |         font-weight: 400; | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| <template> | <template> | ||||||
|     <scroll-view scroll-y class="main-scroll"> |     <scroll-view scroll-y class="main-scroll"> | ||||||
|         <view class="scrollmain"> |         <view class="scrollmain"> | ||||||
|  |             <!-- 未读消息列表 --> | ||||||
|             <view |             <view | ||||||
|                 class="list-card press-button" |                 class="list-card press-button" | ||||||
|                 v-for="(item, index) in unreadMsgList" |                 v-for="(item, index) in unreadMsgList" | ||||||
| @@ -33,6 +34,13 @@ | |||||||
|                     <view class="info-text line_2">{{ item.subTitle || '消息' }}</view> |                     <view class="info-text line_2">{{ item.subTitle || '消息' }}</view> | ||||||
|                 </view> |                 </view> | ||||||
|             </view> |             </view> | ||||||
|  |              | ||||||
|  |             <!-- 暂无未读消息提示 --> | ||||||
|  |             <view class="empty-state" v-if="unreadMsgList.length === 0"> | ||||||
|  |                 <image class="empty-icon" src="/static/icon/empty.png" mode="aspectFit"></image> | ||||||
|  |                 <text class="empty-text">暂无未读消息</text> | ||||||
|  |                 <text class="empty-desc">您没有未读的消息</text> | ||||||
|  |             </view> | ||||||
|         </view> |         </view> | ||||||
|     </scroll-view> |     </scroll-view> | ||||||
| </template> | </template> | ||||||
| @@ -132,4 +140,26 @@ defineExpose({ loadData }); | |||||||
|             font-size: 28rpx; |             font-size: 28rpx; | ||||||
|             color: #6C7282; |             color: #6C7282; | ||||||
|             margin-top: 4rpx; |             margin-top: 4rpx; | ||||||
|  |  | ||||||
|  | // 空状态样式 | ||||||
|  | .empty-state | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     align-items: center; | ||||||
|  |     justify-content: center; | ||||||
|  |     padding: 120rpx 40rpx; | ||||||
|  |     .empty-icon | ||||||
|  |         width: 200rpx; | ||||||
|  |         height: 200rpx; | ||||||
|  |         margin-bottom: 40rpx; | ||||||
|  |         opacity: 0.6; | ||||||
|  |     .empty-text | ||||||
|  |         font-size: 32rpx; | ||||||
|  |         color: #999999; | ||||||
|  |         font-weight: 500; | ||||||
|  |         margin-bottom: 16rpx; | ||||||
|  |     .empty-desc | ||||||
|  |         font-size: 28rpx; | ||||||
|  |         color: #CCCCCC; | ||||||
|  |         font-weight: 400; | ||||||
| </style> | </style> | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								static/imgs/avatar.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/imgs/avatar.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 48 KiB | 
| @@ -48,31 +48,22 @@ export const useReadMsg = defineStore('readMsg', () => { | |||||||
|         const count = unreadCount.value |         const count = unreadCount.value | ||||||
|         const index = 3 |         const index = 3 | ||||||
|         const countVal = count > 99 ? '99+' : String(count) |         const countVal = count > 99 ? '99+' : String(count) | ||||||
|         if (count === 0) { |          | ||||||
|             uni.removeTabBarBadge({ |         // 更新徽章数据,不直接调用 uni.removeTabBarBadge 和 uni.setTabBarBadge | ||||||
|                 index |         // 因为项目使用的是自定义 TabBar,这些方法只能在原生 TabBar 页面使用 | ||||||
|             }) // 替换为你消息页面的 TabBar index |  | ||||||
|         badges.value[index] = { |         badges.value[index] = { | ||||||
|                 count: 0 |             count: count === 0 ? 0 : countVal | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             badges.value[index] = { |  | ||||||
|                 count: countVal |  | ||||||
|             } |  | ||||||
|             uni.setTabBarBadge({ |  | ||||||
|                 index, |  | ||||||
|                 text: countVal |  | ||||||
|             }) |  | ||||||
|         } |         } | ||||||
|  |          | ||||||
|  |         // 如果需要使用原生 TabBar 的徽章功能,需要确保在 TabBar 页面中调用 | ||||||
|  |         // 这里只更新数据,让自定义 TabBar 组件根据数据来显示徽章 | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     // 拉取消息列表 |     // 拉取消息列表 | ||||||
|     async function fetchMessages() { |     async function fetchMessages() { | ||||||
|         try { |         try { | ||||||
|             $api.createRequest('/app/notice/info', { |             $api.createRequest('/app/notice/info', {}, "GET").then((res) => { | ||||||
|                 isRead: 1 |  | ||||||
|             }, "GET").then((res) => { |  | ||||||
|                 msgList.value = res.data || [] |                 msgList.value = res.data || [] | ||||||
|                 updateTabBarBadge() |                 updateTabBarBadge() | ||||||
|             }) |             }) | ||||||
|   | |||||||
| @@ -64,7 +64,7 @@ const useUserStore = defineStore("user", () => { | |||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const logOut = (redirect = true) => { |     const logOut = (showLoginModal = true) => { | ||||||
|         hasLogin.value = false; |         hasLogin.value = false; | ||||||
|         token.value = '' |         token.value = '' | ||||||
|         resume.value = {} |         resume.value = {} | ||||||
| @@ -73,11 +73,10 @@ const useUserStore = defineStore("user", () => { | |||||||
|         uni.removeStorageSync('userInfo') |         uni.removeStorageSync('userInfo') | ||||||
|         uni.removeStorageSync('token') |         uni.removeStorageSync('token') | ||||||
|          |          | ||||||
|         // 只有在明确需要跳转时才跳转到登录页 |         // 如果需要显示登录弹窗,则通过事件通知页面显示微信登录弹窗 | ||||||
|         if (redirect) { |         if (showLoginModal) { | ||||||
|             uni.redirectTo({ |             // 通过 uni.$emit 发送全局事件,通知页面显示登录弹窗 | ||||||
|                 url: '/pages/complete-info/complete-info', |             uni.$emit('showLoginModal'); | ||||||
|             }); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 冯辉
					冯辉