用工小程序前端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

330 lines
10 KiB

<template>
<view class="se-m-10">
<u-sticky>
<view class="se-px-20 se-pt-10 se-zi-s se-bgc-white">
<u-search height="40" placeholder="搜索" :showAction="true" v-model="keyword" @search="onSearch()"
@clickIcon="onSearch()"
@clear="onSearch"
@custom="onSearch()"></u-search>
</view>
<u-tabs class="se-bgc-white se-pb-20" :current="current" lineWidth="30" lineColor="#FF7A31" :activeStyle="{
color: '#303133',
fontWeight: 'bold',
transform: 'scale(1.05)'
}" :inactiveStyle="{
color: '#606266',
transform: 'scale(1)'
}" itemStyle="padding-left: 15px; padding-right: 15px; height: 34px;" :list="navList" @click="navClick($event)">
</u-tabs>
</u-sticky>
<template v-if="current==1">
<view class="se-m-20 se-br-20 se-bs-b se-bgc-white se-py-20 se-px-30" v-for="(items,indexs) in tList"
:key="indexs" @click="onTaskDetail(items)">
<view class="se-flex se-flex-h-sb">
<view class="se-flex se-fw-6">
<text class="se-c-black se-fs-30">{{items.title}}</text>
<text class="se-mx-10 se-b-l"></text>
<text class="se-fs-28 se-c-orange">日薪:{{items.salaryDay}}</text>
</view>
<view class="se-c-orange se-fs-32 se-fw-6">
{{items.salaryMin}}-{{items.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="items.categoryOne_dictText">{{items.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="items.categoryTwo_dictText">{{items.categoryTwo_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="items.payType_dictText">{{items.payType_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-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
<text class="se-c-text-sub se-fs-24 se-pl-10 se-b-l se-toe-3"
style="max-width: 220rpx;">{{items.address}}</text>
</view>
<view class="se-c-text se-c-text-sub se-fs-24">
{{items.createTime | formatTime}}
</view>
<view
class="se-flex se-flex-h-c se-py-10 se-px-20 se-br-12 se-fs-22 se-c-orange se-bgc-ffd se-fw-6">
<text class="se-ml-5">立即接单</text>
</view>
</view>
</view>
<u-empty v-if="tList && tList.length==0" mode="list"></u-empty>
</template>
<template v-if="current==0">
<view class="se-m-20 se-br-20 se-bs-b se-bgc-white se-py-20 se-px-30" v-for="(items,indexs) in rlist"
:key="indexs">
<view class="se-flex se-flex-h-sb" @click.capture="onRoleDetail(items)">
<view class="se-flex">
<view class="se-a-100">
<image class="se-a-100 se-br-p-50 se-bgc-f5" :src="items.employResume.headImage" mode="">
</image>
</view>
<view class="se-ml-20 se-flex se-flex-v-c se-flex-ai-fs">
<text
class="se-fw-6 se-c-black se-fs-30">{{items.employResume.name?items.employResume.name:items.hanHaiMember.nickName}}<text
class="se-mx-10 se-b-l"></text><text
class="se-fs-28 se-c-orange">日薪:{{items.dayMoney}}</text> </text>
<text
class="se-fs-24 se-c-text-third">{{items.employResume.sex==1?"男":"女"}}-{{items.employResume.nation?items.employResume.nation:"未知"}}-{{items.employResume.age}}</text>
<view class="se-py-10 se-px-20 se-br-12 se-fs-22 se-c-orange se-bgc-ffd se-fw-6 se-toe-1"
style="max-width: 100rpx;">
{{items.categoryOne_dictText}}
</view>
</view>
<!-- <view class="se-flex se-flex-h-c">
<view class="se-py-10 se-px-20 se-br-12 se-fs-22 se-c-orange se-bgc-ffd se-ml-20 se-fw-6 se-toe-1" style="max-width: 100rpx;">
{{items.categoryOne_dictText}}
</view>
</view> -->
</view>
<view class="se-c-orange se-fs-32 se-fw-6">
{{items.salaryMin}}-{{items.salaryMax}}
</view>
</view>
<view>
<text class="se-c-text-third se-fs-22 se-mt-10">{{items.createTime}}</text>
</view>
<view class="se-flex se-flex-h-sb">
<text class="se-c-text-sub se-fs-24 se-toe-5" style="max-width: 100rpx;width: 100rpx;">
{{items.categoryTwo_dictText}}
<!-- <u-parse v-if="items.brief" :content="items.brief"></u-parse> -->
</text>
<text class="se-c-text-sub se-fs-24 se-toe-5" style="max-width: 350rpx;width:350rpx;">
{{items.address}}
<!-- <u-parse v-if="items.brief" :content="items.brief"></u-parse> -->
</text>
<view @click.capture="onCustomerService(items.employAuthenticationPerson.phone)"
class="se-flex se-flex-h-c se-py-10 se-px-20 se-br-12 se-fs-22 se-c-orange se-bgc-ffd se-fw-6">
<u-icon color="#FF7A31" name="phone-fill"></u-icon>
<text class="se-ml-5">联系他</text>
</view>
</view>
</view>
<u-empty v-if="rlist && rlist.length==0" mode="list"></u-empty>
</template>
</view>
</template>
<script>
import {
bannerList,
taskList,
rolelist,
industryList,
querySeekList,
getSysText
} from "@/common/api.js"
export default {
data() {
return {
tpageNo: 1,
tpageSize: 20,
tList: [],
rpageNo: 1,
rpageSize: 20,
rlist: [],
id: null,
keyword: "",
current: 0,
navList: [{
name: '求职大厅',
},
{
name: '招聘大厅',
}
],
}
},
onLoad(options) {
this.id = options.id
if (options.title) {
uni.setNavigationBarTitle({
title: options.title
})
}
// this.onTaskList()
this.onRolelist()
},
onReachBottom() {
let that = this
if (that.current == 0) {
that.rpageNo = that.rpageNo + 1
that.onRolelist()
} else if (that.current == 1) {
that.tpageNo = that.tpageNo + 1
this.onTaskList()
}
},
onPullDownRefresh() {
let that = this
if (that.current == 0) {
that.rpageNo = 1
that.rlist = []
that.onRolelist()
} else if (that.current == 1) {
that.tpageNo = 1
that.tList = []
this.onTaskList()
}
},
filters: {
formatTime(time) {
const timestamp = new Date(time).getTime();
const currentTime = new Date().getTime();
console.info("currentTime", currentTime)
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)}天前`;
}
}
},
formDate(date) {
return dayjs(date).format("YYYY-MM-DD").fromNow();
},
getDistance(lat1, lng1) {
let lng2 = uni.getStorageSync("longitude")
let lat2 = uni.getStorageSync("latitude")
if (!lng2 && !lat2) {
return "请授权"
}
const R = 6371; // 地球半径,单位:km
const radLat1 = (lat1 * Math.PI) / 180;
const radLat2 = (lat2 * Math.PI) / 180;
const deltaLat = radLat2 - radLat1;
const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
const a =
Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
Math.cos(radLat1) *
Math.cos(radLat2) *
Math.sin(deltaLng / 2) *
Math.sin(deltaLng / 2);
const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
return (R * c).toFixed(2); // 返回保留两位小数的公里数
}
},
methods: {
navClick(event) {
this.current = event.index
this.keyword = ""
if (event.index == 0) {
this.rpageNo = 1
this.onRolelist()
} else if (event.index == 1) {
this.tpageNo = 1
this.onTaskList()
}
},
onSearch() {
let that = this
if (that.current == 0) {
that.rpageNo = 1
that.onRolelist()
} else if (that.current == 1) {
that.tpageNo = 1
this.onTaskList()
}
},
onRolelist() {
querySeekList({
pageNo: this.rpageNo,
pageSize: this.rpageSize,
address: this.keyword,
categoryOne: this.id,
}).then(response => {
console.info("response", response)
if (this.rpageNo == 1) {
this.rlist = response.result.records
} else {
this.rlist = this.rlist.concat(response.result.records)
}
}).catch(error => {
})
},
onTaskList() {
taskList({
latitude: uni.getStorageSync("latitude"),
longitude: uni.getStorageSync("longitude"),
pageNo: this.tpageNo,
title: this.keyword,
categoryOne: this.id,
pageSize: this.tpageSize
}).then(response => {
if (this.tpageNo == 1) {
this.tList = response.result.records
} else {
this.tList = this.tList.concat(response.result.records)
}
}).catch(error => {
})
},
onTaskDetail(event) {
console.info(event)
uni.navigateTo({
url: "/pages_subpack/work-detail/index?id=" + event.id
})
},
onRoleDetail(event) {
console.info("event", event)
uni.navigateTo({
url: "/pages_subpack/master-detail/index?id=" + event.id
})
},
onCustomerService(phome) {
let that = this
// let obj = that.$utils.getkeyContent('phone')
if (uni.canIUse('makePhoneCall')) {
uni.makePhoneCall({
phoneNumber: String(phome),
success: function() {
console.log('拨打电话成功');
},
fail: function() {
console.log('拨打电话失败');
}
});
} else {
console.log('你的设备不支持拨打电话功能');
}
},
}
}
</script>
<style>
</style>