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

153 lines
4.8 KiB

10 months ago
10 months ago
10 months ago
9 months ago
10 months ago
9 months ago
10 months ago
9 months ago
10 months ago
9 months ago
10 months ago
10 months ago
10 months ago
9 months ago
10 months ago
  1. <template>
  2. <view class="se-m-10">
  3. <view class="se-px-20 se-pt-10 se-zi-s">
  4. <u-search height="40" placeholder="搜索" :showAction="true" v-model="keyword"></u-search>
  5. </view>
  6. <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="onMasterDetail(items)">
  7. <view class="se-flex se-flex-h-sb">
  8. <view class="se-flex">
  9. <text class="se-fw-6 se-c-black se-fs-30">{{items.title}}</text>
  10. </view>
  11. <view class="se-c-orange se-fs-32 se-fw-6">
  12. {{items.salaryMin}}-{{items.salaryMax}}k
  13. </view>
  14. </view>
  15. <view class="se-py-10">
  16. <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>
  17. <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>
  18. <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>
  19. <!-- <text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5">水泥搬运</text> -->
  20. </view>
  21. <view class="se-flex se-flex-h-sb">
  22. <view class="se-flex">
  23. <u-icon class="se-ml-10" name="map"></u-icon>
  24. <text class="se-c-text-sub se-fs-24 se-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
  25. <text class="se-c-text-sub se-fs-24 se-pl-10 se-b-l">{{items.address}}</text>
  26. </view>
  27. <view class="se-c-text se-c-text-sub se-fs-24">
  28. {{items.createTime | formatTime}}
  29. </view>
  30. <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">
  31. <text class="se-ml-5">立即接单</text>
  32. </view>
  33. </view>
  34. </view>
  35. <u-empty v-if="tList && tList.length==0" mode="list"></u-empty>
  36. </view>
  37. </template>
  38. <script>
  39. import {
  40. bannerList,
  41. taskList,
  42. rolelist,
  43. industryList,
  44. getSysText
  45. } from "@/common/api.js"
  46. export default{
  47. data(){
  48. return{
  49. tpageNo:1,
  50. tpageSize:20,
  51. tList:[],
  52. id:null,
  53. keyword:""
  54. }
  55. },
  56. onLoad(options) {
  57. this.id=options.id
  58. this.onTaskList()
  59. },
  60. onReachBottom() {
  61. let that = this
  62. that.rpageNo = that.rpageNo + 1
  63. that.onTaskList()
  64. },
  65. filters:{
  66. formatTime(time) {
  67. const timestamp = new Date(time).getTime();
  68. const currentTime = new Date().getTime();
  69. console.info("currentTime",currentTime)
  70. const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
  71. // 计算月差,判断是否超过一个月
  72. const oneMonthInSeconds = 30 * 24 * 60 * 60;
  73. if (diff > oneMonthInSeconds) {
  74. let date = new Date(timestamp);
  75. let year = date.getFullYear();
  76. let month = date.getMonth() + 1;
  77. let day = date.getDate();
  78. if (month < 10) month = "0" + month;
  79. if (day < 10) day = "0" + day;
  80. return `${year}-${month}-${day}`;
  81. } else {
  82. // 计算秒、分钟、小时的差值
  83. if (diff < 60) {
  84. return `${Math.floor(diff)}秒钟前`;
  85. } else if (diff < 60 * 60) {
  86. return `${Math.floor(diff / 60)}分钟前`;
  87. } else if (diff < 60 * 60 * 24) {
  88. return `${Math.floor(diff / 60 / 60)}小时前`;
  89. } else {
  90. // 显示天数
  91. return `${Math.floor(diff / 60 / 60 / 24)}天前`;
  92. }
  93. }
  94. },
  95. formDate(date){
  96. return dayjs(date).format("YYYY-MM-DD").fromNow();
  97. },
  98. getDistance(lat1, lng1) {
  99. let lng2 = uni.getStorageSync("longitude")
  100. let lat2 = uni.getStorageSync("latitude")
  101. if(!lng2 && !lat2){
  102. return "请授权"
  103. }
  104. const R = 6371; // 地球半径,单位:km
  105. const radLat1 = (lat1 * Math.PI) / 180;
  106. const radLat2 = (lat2 * Math.PI) / 180;
  107. const deltaLat = radLat2 - radLat1;
  108. const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
  109. const a =
  110. Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
  111. Math.cos(radLat1) *
  112. Math.cos(radLat2) *
  113. Math.sin(deltaLng / 2) *
  114. Math.sin(deltaLng / 2);
  115. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  116. return (R * c).toFixed(2); // 返回保留两位小数的公里数
  117. }
  118. },
  119. methods:{
  120. onTaskList(){
  121. taskList({
  122. latitude:uni.getStorageSync("latitude"),
  123. longitude:uni.getStorageSync("longitude"),
  124. pageNo:this.tpageNo,
  125. pageSize:this.tpageSize
  126. }).then(response=>{
  127. if(this.tpageNo==1){
  128. this.tList = response.result.records
  129. }else{
  130. this.tList = this.tList.concat(response.result.records)
  131. }
  132. }).catch(error=>{
  133. })
  134. },
  135. onMasterDetail(event){
  136. console.info(event)
  137. uni.navigateTo({
  138. url:"/pages_subpack/work-detail/index?id="+event.id
  139. })
  140. }
  141. }
  142. }
  143. </script>
  144. <style>
  145. </style>