用工小程序前端代码
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.

329 lines
10 KiB

3 months ago
3 months ago
2 months ago
3 months ago
3 months ago
2 months ago
2 months ago
2 months ago
2 months ago
3 months ago
3 months ago
a. 前端小程序部分: ⅰ. 授权登录成功之后,后面点击头像进行个人资料编辑的时候,原来的历史个人资料需要展示在表单上:头像,昵称,手机号码 (已处理) ⅱ. 个人中心手机号码下方,如果做了企业认证则显示企业公司名称 (已处理 展示认证状态) ⅲ. 对接流水钱包的数据,让数据渲染正确,能正常提交以及审核提现,提现需要增加一个用户真实姓名的字段,提现需要一个到账状态,提现功能区看酒布代码或者是真世界代码,确保功能的完整性 提现新增字段 realName (已处理) ⅳ. 我的服务这些设置的小图标需要换成正常的,如果没画的区阿里巴巴矢量图标库找一个合适的(已处理) ⅴ. 企业入驻:公司地址需要吊起地图,记录经纬度,另外审核通过状态的数据,不能再进行修改 (已处理) longitude:"",latitude:"", ⅵ. 个人入住:审核通过状态的数据,不能再进行修改(已处理) ⅶ. 我的简历:审核通过状态的数据,不能再进行修改(没有status 字段) ⅷ. 发布订单:出行方式字段对接一下select_go字段,结算方式说明前端要跟后台数据说明同步 (已处理)selectGo ⅸ. 分类管理:点击分类管理可以只查询当前一级分类数据,另外名称搜索功能需要增加一下 (已处理) X. 工作详情里面的公司地址要能点击到地图中去,另外右边增加一个拨打电话的按钮 (这个是微信组件 不能添加) Xⅰ. 列表数据处理一下下拉刷新数据,每次数据没有更新,没有下啦刷新处理 (已处理)
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
a. 前端小程序部分: ⅰ. 授权登录成功之后,后面点击头像进行个人资料编辑的时候,原来的历史个人资料需要展示在表单上:头像,昵称,手机号码 (已处理) ⅱ. 个人中心手机号码下方,如果做了企业认证则显示企业公司名称 (已处理 展示认证状态) ⅲ. 对接流水钱包的数据,让数据渲染正确,能正常提交以及审核提现,提现需要增加一个用户真实姓名的字段,提现需要一个到账状态,提现功能区看酒布代码或者是真世界代码,确保功能的完整性 提现新增字段 realName (已处理) ⅳ. 我的服务这些设置的小图标需要换成正常的,如果没画的区阿里巴巴矢量图标库找一个合适的(已处理) ⅴ. 企业入驻:公司地址需要吊起地图,记录经纬度,另外审核通过状态的数据,不能再进行修改 (已处理) longitude:"",latitude:"", ⅵ. 个人入住:审核通过状态的数据,不能再进行修改(已处理) ⅶ. 我的简历:审核通过状态的数据,不能再进行修改(没有status 字段) ⅷ. 发布订单:出行方式字段对接一下select_go字段,结算方式说明前端要跟后台数据说明同步 (已处理)selectGo ⅸ. 分类管理:点击分类管理可以只查询当前一级分类数据,另外名称搜索功能需要增加一下 (已处理) X. 工作详情里面的公司地址要能点击到地图中去,另外右边增加一个拨打电话的按钮 (这个是微信组件 不能添加) Xⅰ. 列表数据处理一下下拉刷新数据,每次数据没有更新,没有下啦刷新处理 (已处理)
3 months ago
a. 前端小程序部分: ⅰ. 授权登录成功之后,后面点击头像进行个人资料编辑的时候,原来的历史个人资料需要展示在表单上:头像,昵称,手机号码 (已处理) ⅱ. 个人中心手机号码下方,如果做了企业认证则显示企业公司名称 (已处理 展示认证状态) ⅲ. 对接流水钱包的数据,让数据渲染正确,能正常提交以及审核提现,提现需要增加一个用户真实姓名的字段,提现需要一个到账状态,提现功能区看酒布代码或者是真世界代码,确保功能的完整性 提现新增字段 realName (已处理) ⅳ. 我的服务这些设置的小图标需要换成正常的,如果没画的区阿里巴巴矢量图标库找一个合适的(已处理) ⅴ. 企业入驻:公司地址需要吊起地图,记录经纬度,另外审核通过状态的数据,不能再进行修改 (已处理) longitude:"",latitude:"", ⅵ. 个人入住:审核通过状态的数据,不能再进行修改(已处理) ⅶ. 我的简历:审核通过状态的数据,不能再进行修改(没有status 字段) ⅷ. 发布订单:出行方式字段对接一下select_go字段,结算方式说明前端要跟后台数据说明同步 (已处理)selectGo ⅸ. 分类管理:点击分类管理可以只查询当前一级分类数据,另外名称搜索功能需要增加一下 (已处理) X. 工作详情里面的公司地址要能点击到地图中去,另外右边增加一个拨打电话的按钮 (这个是微信组件 不能添加) Xⅰ. 列表数据处理一下下拉刷新数据,每次数据没有更新,没有下啦刷新处理 (已处理)
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
3 months ago
  1. <template>
  2. <view class="se-m-10">
  3. <u-sticky>
  4. <view class="se-px-20 se-pt-10 se-zi-s se-bgc-white">
  5. <u-search height="40" placeholder="搜索" :showAction="true" v-model="keyword" @search="onSearch()"
  6. @clickIcon="onSearch()"
  7. @clear="onSearch"
  8. @custom="onSearch()"></u-search>
  9. </view>
  10. <u-tabs class="se-bgc-white se-pb-20" :current="current" lineWidth="30" lineColor="#FF7A31" :activeStyle="{
  11. color: '#303133',
  12. fontWeight: 'bold',
  13. transform: 'scale(1.05)'
  14. }" :inactiveStyle="{
  15. color: '#606266',
  16. transform: 'scale(1)'
  17. }" itemStyle="padding-left: 15px; padding-right: 15px; height: 34px;" :list="navList" @click="navClick($event)">
  18. </u-tabs>
  19. </u-sticky>
  20. <template v-if="current==1">
  21. <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"
  22. :key="indexs" @click="onTaskDetail(items)">
  23. <view class="se-flex se-flex-h-sb">
  24. <view class="se-flex se-fw-6">
  25. <text class="se-c-black se-fs-30">{{items.title}}</text>
  26. <text class="se-mx-10 se-b-l"></text>
  27. <text class="se-fs-28 se-c-orange">日薪:{{items.salaryDay}}</text>
  28. </view>
  29. <view class="se-c-orange se-fs-32 se-fw-6">
  30. {{items.salaryMin}}-{{items.salaryMax}}k
  31. </view>
  32. </view>
  33. <view class="se-py-10">
  34. <text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5"
  35. v-if="items.categoryOne_dictText">{{items.categoryOne_dictText}}</text>
  36. <text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5"
  37. v-if="items.categoryTwo_dictText">{{items.categoryTwo_dictText}}</text>
  38. <text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5"
  39. v-if="items.payType_dictText">{{items.payType_dictText}}</text>
  40. </view>
  41. <view class="se-flex se-flex-h-sb">
  42. <view class="se-flex se-flex-h-c">
  43. <u-icon name="map"></u-icon>
  44. <text
  45. class="se-c-text-sub se-fs-24 se-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
  46. <text class="se-c-text-sub se-fs-24 se-pl-10 se-b-l se-toe-3"
  47. style="max-width: 220rpx;">{{items.address}}</text>
  48. </view>
  49. <view class="se-c-text se-c-text-sub se-fs-24">
  50. {{items.createTime | formatTime}}
  51. </view>
  52. <view
  53. 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">
  54. <text class="se-ml-5">立即接单</text>
  55. </view>
  56. </view>
  57. </view>
  58. <u-empty v-if="tList && tList.length==0" mode="list"></u-empty>
  59. </template>
  60. <template v-if="current==0">
  61. <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"
  62. :key="indexs">
  63. <view class="se-flex se-flex-h-sb" @click.capture="onRoleDetail(items)">
  64. <view class="se-flex">
  65. <view class="se-a-100">
  66. <image class="se-a-100 se-br-p-50 se-bgc-f5" :src="items.employResume.headImage" mode="">
  67. </image>
  68. </view>
  69. <view class="se-ml-20 se-flex se-flex-v-c se-flex-ai-fs">
  70. <text
  71. class="se-fw-6 se-c-black se-fs-30">{{items.employResume.name?items.employResume.name:items.hanHaiMember.nickName}}<text
  72. class="se-mx-10 se-b-l"></text><text
  73. class="se-fs-28 se-c-orange">日薪:{{items.dayMoney}}</text> </text>
  74. <text
  75. class="se-fs-24 se-c-text-third">{{items.employResume.sex==1?"男":"女"}}-{{items.employResume.nation?items.employResume.nation:"未知"}}-{{items.employResume.age}}</text>
  76. <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"
  77. style="max-width: 100rpx;">
  78. {{items.categoryOne_dictText}}
  79. </view>
  80. </view>
  81. <!-- <view class="se-flex se-flex-h-c">
  82. <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;">
  83. {{items.categoryOne_dictText}}
  84. </view>
  85. </view> -->
  86. </view>
  87. <view class="se-c-orange se-fs-32 se-fw-6">
  88. {{items.salaryMin}}-{{items.salaryMax}}
  89. </view>
  90. </view>
  91. <view>
  92. <text class="se-c-text-third se-fs-22 se-mt-10">{{items.createTime}}</text>
  93. </view>
  94. <view class="se-flex se-flex-h-sb">
  95. <text class="se-c-text-sub se-fs-24 se-toe-5" style="max-width: 100rpx;width: 100rpx;">
  96. {{items.categoryTwo_dictText}}
  97. <!-- <u-parse v-if="items.brief" :content="items.brief"></u-parse> -->
  98. </text>
  99. <text class="se-c-text-sub se-fs-24 se-toe-5" style="max-width: 350rpx;width:350rpx;">
  100. {{items.address}}
  101. <!-- <u-parse v-if="items.brief" :content="items.brief"></u-parse> -->
  102. </text>
  103. <view @click.capture="onCustomerService(items.employAuthenticationPerson.phone)"
  104. 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">
  105. <u-icon color="#FF7A31" name="phone-fill"></u-icon>
  106. <text class="se-ml-5">联系他</text>
  107. </view>
  108. </view>
  109. </view>
  110. <u-empty v-if="rlist && rlist.length==0" mode="list"></u-empty>
  111. </template>
  112. </view>
  113. </template>
  114. <script>
  115. import {
  116. bannerList,
  117. taskList,
  118. rolelist,
  119. industryList,
  120. querySeekList,
  121. getSysText
  122. } from "@/common/api.js"
  123. export default {
  124. data() {
  125. return {
  126. tpageNo: 1,
  127. tpageSize: 20,
  128. tList: [],
  129. rpageNo: 1,
  130. rpageSize: 20,
  131. rlist: [],
  132. id: null,
  133. keyword: "",
  134. current: 0,
  135. navList: [{
  136. name: '求职大厅',
  137. },
  138. {
  139. name: '招聘大厅',
  140. }
  141. ],
  142. }
  143. },
  144. onLoad(options) {
  145. this.id = options.id
  146. if (options.title) {
  147. uni.setNavigationBarTitle({
  148. title: options.title
  149. })
  150. }
  151. // this.onTaskList()
  152. this.onRolelist()
  153. },
  154. onReachBottom() {
  155. let that = this
  156. if (that.current == 0) {
  157. that.rpageNo = that.rpageNo + 1
  158. that.onRolelist()
  159. } else if (that.current == 1) {
  160. that.tpageNo = that.tpageNo + 1
  161. this.onTaskList()
  162. }
  163. },
  164. onPullDownRefresh() {
  165. let that = this
  166. if (that.current == 0) {
  167. that.rpageNo = 1
  168. that.rlist = []
  169. that.onRolelist()
  170. } else if (that.current == 1) {
  171. that.tpageNo = 1
  172. that.tList = []
  173. this.onTaskList()
  174. }
  175. },
  176. filters: {
  177. formatTime(time) {
  178. const timestamp = new Date(time).getTime();
  179. const currentTime = new Date().getTime();
  180. console.info("currentTime", currentTime)
  181. const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
  182. // 计算月差,判断是否超过一个月
  183. const oneMonthInSeconds = 30 * 24 * 60 * 60;
  184. if (diff > oneMonthInSeconds) {
  185. let date = new Date(timestamp);
  186. let year = date.getFullYear();
  187. let month = date.getMonth() + 1;
  188. let day = date.getDate();
  189. if (month < 10) month = "0" + month;
  190. if (day < 10) day = "0" + day;
  191. return `${year}-${month}-${day}`;
  192. } else {
  193. // 计算秒、分钟、小时的差值
  194. if (diff < 60) {
  195. return `${Math.floor(diff)}秒钟前`;
  196. } else if (diff < 60 * 60) {
  197. return `${Math.floor(diff / 60)}分钟前`;
  198. } else if (diff < 60 * 60 * 24) {
  199. return `${Math.floor(diff / 60 / 60)}小时前`;
  200. } else {
  201. // 显示天数
  202. return `${Math.floor(diff / 60 / 60 / 24)}天前`;
  203. }
  204. }
  205. },
  206. formDate(date) {
  207. return dayjs(date).format("YYYY-MM-DD").fromNow();
  208. },
  209. getDistance(lat1, lng1) {
  210. let lng2 = uni.getStorageSync("longitude")
  211. let lat2 = uni.getStorageSync("latitude")
  212. if (!lng2 && !lat2) {
  213. return "请授权"
  214. }
  215. const R = 6371; // 地球半径,单位:km
  216. const radLat1 = (lat1 * Math.PI) / 180;
  217. const radLat2 = (lat2 * Math.PI) / 180;
  218. const deltaLat = radLat2 - radLat1;
  219. const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
  220. const a =
  221. Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
  222. Math.cos(radLat1) *
  223. Math.cos(radLat2) *
  224. Math.sin(deltaLng / 2) *
  225. Math.sin(deltaLng / 2);
  226. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  227. return (R * c).toFixed(2); // 返回保留两位小数的公里数
  228. }
  229. },
  230. methods: {
  231. navClick(event) {
  232. this.current = event.index
  233. this.keyword = ""
  234. if (event.index == 0) {
  235. this.rpageNo = 1
  236. this.onRolelist()
  237. } else if (event.index == 1) {
  238. this.tpageNo = 1
  239. this.onTaskList()
  240. }
  241. },
  242. onSearch() {
  243. let that = this
  244. if (that.current == 0) {
  245. that.rpageNo = 1
  246. that.onRolelist()
  247. } else if (that.current == 1) {
  248. that.tpageNo = 1
  249. this.onTaskList()
  250. }
  251. },
  252. onRolelist() {
  253. querySeekList({
  254. pageNo: this.rpageNo,
  255. pageSize: this.rpageSize,
  256. address: this.keyword,
  257. categoryOne: this.id,
  258. }).then(response => {
  259. console.info("response", response)
  260. if (this.rpageNo == 1) {
  261. this.rlist = response.result.records
  262. } else {
  263. this.rlist = this.rlist.concat(response.result.records)
  264. }
  265. }).catch(error => {
  266. })
  267. },
  268. onTaskList() {
  269. taskList({
  270. latitude: uni.getStorageSync("latitude"),
  271. longitude: uni.getStorageSync("longitude"),
  272. pageNo: this.tpageNo,
  273. title: this.keyword,
  274. categoryOne: this.id,
  275. pageSize: this.tpageSize
  276. }).then(response => {
  277. if (this.tpageNo == 1) {
  278. this.tList = response.result.records
  279. } else {
  280. this.tList = this.tList.concat(response.result.records)
  281. }
  282. }).catch(error => {
  283. })
  284. },
  285. onTaskDetail(event) {
  286. console.info(event)
  287. uni.navigateTo({
  288. url: "/pages_subpack/work-detail/index?id=" + event.id
  289. })
  290. },
  291. onRoleDetail(event) {
  292. console.info("event", event)
  293. uni.navigateTo({
  294. url: "/pages_subpack/master-detail/index?id=" + event.id
  295. })
  296. },
  297. onCustomerService(phome) {
  298. let that = this
  299. // let obj = that.$utils.getkeyContent('phone')
  300. if (uni.canIUse('makePhoneCall')) {
  301. uni.makePhoneCall({
  302. phoneNumber: String(phome),
  303. success: function() {
  304. console.log('拨打电话成功');
  305. },
  306. fail: function() {
  307. console.log('拨打电话失败');
  308. }
  309. });
  310. } else {
  311. console.log('你的设备不支持拨打电话功能');
  312. }
  313. },
  314. }
  315. }
  316. </script>
  317. <style>
  318. </style>