|                                                                                                                                                                                                               |  | <template>	<view class="u-page se-w-vw-100">		<!-- 招聘信息头部 -->		<view class="se-m-20 se-br-20 se-bs-b se-bgc-white se-py-20 se-px-30" v-if="jobInfo">			<view class="se-flex se-flex-h-sb se-mb-10">				<view class="se-flex se-fw-6">					<text class="se-c-black se-fs-30">{{jobInfo.title}}</text>					<text class="se-mx-10 se-b-l"></text>					<text class="se-fs-28 se-c-orange">日薪:{{jobInfo.salaryDay}}</text>				</view>				<view class="se-c-orange se-fs-32 se-fw-6">					{{jobInfo.salaryMin}}-{{jobInfo.salaryMax}}k				</view>			</view>			<view class="se-py-10">				<text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5"					v-if="jobInfo.categoryOne_dictText">{{jobInfo.categoryOne_dictText}}</text>				<text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5"					v-if="jobInfo.categoryTwo_dictText">{{jobInfo.categoryTwo_dictText}}</text>			</view>			<view class="se-flex se-flex-h-sb">				<view class="se-flex se-flex-h-c">					<u-icon name="map"></u-icon>					<text class="se-c-text-sub se-fs-24 se-pl-10 se-toe-3">{{jobInfo.address}}</text>				</view>				<view                 style="flex-shrink: 0;"                class="se-c-orange se-fs-24 se-fw-6">					共{{orderList.length}}个订单				</view>			</view>		</view>				<!-- 招聘状态显示 -->		<view class="se-px-40 se-pb-20" v-if="jobInfo">			<view class="se-flex se-flex-h-c">				<view class="se-py-8 se-px-20 se-br-15" 					:style="jobInfo.status == 1 ? 'background-color: rgba(255, 77, 79, 0.15);' : 'background-color: rgba(82, 196, 26, 0.15);'">					<text :style="jobInfo.status == 1 ? 'color: #d32f2f; font-weight: 600;' : 'color: #388e3c; font-weight: 600;'" 						class="se-fs-26">						{{jobInfo.status == 1 ? '已招满' : '招聘中'}}					</text>				</view>			</view>		</view>				<view class="se-p-40">			<view class="se-px-40 se-mb-30 se-py-30 se-bgc-white se-br-40 se-bs-b" 				v-for="(item, index) in orderList" 				:key="index"				@click="onOrderDetail(item)">				<view class="se-flex se-flex-h-sb se-fw-6 se-fs-32 se-pb-20">					<view class="se-flex">											</view>					<view class="se-c-red">						{{ getStatusText(item) }}					</view>				</view>				<view class="se-flex se-bgc-f5 se-br-20 se-p-20">					<view class="se-w-160 se-h-160">						<image class="se-w-160 se-h-160 se-br-10" :src="item.employResume ?                         item.employResume.headImage                        : '/static/image/user.png'" mode="aspectFill"></image>					</view>					<view class="se-ml-20 se-flex se-flex-v-sa se-flex-ai-fs se-flex-1">						<view class="se-fw-6 se-c-black se-fs-30 se-display-ib se-mb-10">求职者:{{item.jobName}}</view>						<view class="se-fs-24 se-c-text-third se-display-ib se-mb-5">联系电话:{{item.jobPhone}}</view>						<view class="se-fs-24 se-c-text-third se-display-ib se-mb-5">接单时间:{{item.createTime | formatTime}}</view>						<view class="se-fs-24 se-c-text-third se-display-ib se-mb-5">工作地址:{{item.jobAddress}}</view>					</view>				</view>			</view>			<u-empty v-if="orderList && orderList.length==0" mode="list" text="暂无订单信息"></u-empty>		</view>				<!-- 已招满按钮 -->		<view class="se-p-40 se-pt-0" v-if="jobInfo && jobInfo.status == 0">			<view class="se-bgc-orange se-br-20 se-py-30 se-flex se-flex-h-c se-flex-v-c" 				@click="onStopJob">				<text class="se-c-white se-fs-32 se-fw-6">已招满</text>			</view>		</view>	</view></template>
<script>	import {		getTaskById,		stopJob	} from "@/common/api.js"	import {		getStatusText	} from "@/utils/statusText.js"
	export default {		data() {			return {				orderList: [],				jobInfo: null,				jobId: null			}		},		filters: {			formatTime(time) {				if (!time) return '';				// 处理时间戳格式(可能是毫秒或字符串)
				let timestamp;				if (typeof time === 'number') {					// 如果是数字,直接使用
					timestamp = time;				} else {					// 如果是字符串,转换为时间戳
					timestamp = new Date(time).getTime();				}								const currentTime = new Date().getTime();				const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
				// 计算月差,判断是否超过一个月
				const oneMonthInSeconds = 30 * 24 * 60 * 60;				if (diff > oneMonthInSeconds) {					let date = new Date(timestamp);					let year = date.getFullYear();					let month = date.getMonth() + 1;					let day = date.getDate();
					if (month < 10) month = "0" + month;					if (day < 10) day = "0" + day;
					return `${year}-${month}-${day}`;				} else {					// 计算秒、分钟、小时的差值
					if (diff < 60) {						return `${Math.floor(diff)}秒钟前`;					} else if (diff < 60 * 60) {						return `${Math.floor(diff / 60)}分钟前`;					} else if (diff < 60 * 60 * 24) {						return `${Math.floor(diff / 60 / 60)}小时前`;					} else {						// 显示天数
						return `${Math.floor(diff / 60 / 60 / 24)}天前`;					}				}			}		},		onLoad(options) {			if (options.jobId) {				this.jobId = options.jobId;			}		},        onShow(){			this.getJobDetail();        },		methods: {			getStatusText,
			getJobDetail() {				getTaskById({ id: this.jobId }).then(response => {					if (response.success) {						this.jobInfo = response.result;						this.orderList = this.jobInfo.employOrder || [];						// 设置页面标题
						uni.setNavigationBarTitle({							title: `${this.jobInfo.title} - 订单列表`						});					} else {						uni.showToast({							title: '获取工作详情失败',							icon: 'none'						});					}				})			},			onOrderDetail(order) {				uni.navigateTo({					url: `/pages_subpack/order-detail/boss?orderId=${order.id}&type=true`				});			},						onStopJob() {				uni.showModal({					title: '确认操作',					content: '确定要将此招聘标记为已招满吗?',					success: (res) => {						if (res.confirm) {							this.stopJobRequest();						}					}				});			},						stopJobRequest() {				stopJob({ id: this.jobId }).then(response => {					if (response.success) {						uni.showToast({							title: '操作成功',							icon: 'success'						});						// 更新本地状态
						this.jobInfo.status = 1;						// 返回上一页或刷新页面
						setTimeout(() => {							uni.navigateBack();						}, 800);					} else {						uni.showToast({							title: response.message || '操作失败',							icon: 'none'						});					}				}).catch(error => {					console.error('停止招聘失败:', error);					uni.showToast({						title: '网络错误',						icon: 'none'					});				});			}		}	}</script>
<style></style>
 |