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

137 lines
4.4 KiB

  1. <template>
  2. <view>
  3. <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 taskList" :key="indexs" @click="onMasterDetail(items)">
  4. <view class="se-flex se-flex-h-sb">
  5. <view class="se-flex">
  6. <text class="se-fw-6 se-c-black se-fs-30">{{items.title}}|日薪:{{items.salaryDay}}</text>
  7. </view>
  8. <view class="se-c-orange se-fs-32 se-fw-6">
  9. {{items.salaryMin}}-{{items.salaryMax}}k
  10. </view>
  11. </view>
  12. <view class="se-py-10">
  13. <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>
  14. <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>
  15. <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>
  16. </view>
  17. <view class="se-flex se-flex-h-sb">
  18. <view class="se-flex se-flex-h-c">
  19. <u-icon name="map"></u-icon>
  20. <text class="se-c-text-sub se-fs-24 se-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
  21. <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>
  22. </view>
  23. <view class="se-c-text se-c-text-sub se-fs-24">
  24. {{items.createTime | formatTime}}
  25. </view>
  26. <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">
  27. <text class="se-ml-5">修改</text>
  28. </view>
  29. <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">
  30. <text class="se-ml-5">删除</text>
  31. </view>
  32. </view>
  33. </view>
  34. <u-empty v-if="taskList && taskList.length==0" mode="list"></u-empty>
  35. </view>
  36. </template>
  37. <script>
  38. import {
  39. queryJobListByUserId
  40. } from "@/common/api.js"
  41. export default{
  42. data(){
  43. return{
  44. taskList:[
  45. ]
  46. }
  47. },
  48. filters:{
  49. formatTime(time) {
  50. const timestamp = new Date(time).getTime();
  51. const currentTime = new Date().getTime();
  52. console.info("currentTime",currentTime)
  53. const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
  54. // 计算月差,判断是否超过一个月
  55. const oneMonthInSeconds = 30 * 24 * 60 * 60;
  56. if (diff > oneMonthInSeconds) {
  57. let date = new Date(timestamp);
  58. let year = date.getFullYear();
  59. let month = date.getMonth() + 1;
  60. let day = date.getDate();
  61. if (month < 10) month = "0" + month;
  62. if (day < 10) day = "0" + day;
  63. return `${year}-${month}-${day}`;
  64. } else {
  65. // 计算秒、分钟、小时的差值
  66. if (diff < 60) {
  67. return `${Math.floor(diff)}秒钟前`;
  68. } else if (diff < 60 * 60) {
  69. return `${Math.floor(diff / 60)}分钟前`;
  70. } else if (diff < 60 * 60 * 24) {
  71. return `${Math.floor(diff / 60 / 60)}小时前`;
  72. } else {
  73. // 显示天数
  74. return `${Math.floor(diff / 60 / 60 / 24)}天前`;
  75. }
  76. }
  77. },
  78. formDate(date){
  79. return dayjs(date).format("YYYY-MM-DD").fromNow();
  80. },
  81. getDistance(lat1, lng1) {
  82. let lng2 = uni.getStorageSync("longitude")
  83. let lat2 = uni.getStorageSync("latitude")
  84. if(!lng2 && !lat2){
  85. return "请授权"
  86. }
  87. const R = 6371; // 地球半径,单位:km
  88. const radLat1 = (lat1 * Math.PI) / 180;
  89. const radLat2 = (lat2 * Math.PI) / 180;
  90. const deltaLat = radLat2 - radLat1;
  91. const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
  92. const a =
  93. Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
  94. Math.cos(radLat1) *
  95. Math.cos(radLat2) *
  96. Math.sin(deltaLng / 2) *
  97. Math.sin(deltaLng / 2);
  98. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  99. return (R * c).toFixed(2); // 返回保留两位小数的公里数
  100. }
  101. },
  102. onLoad() {
  103. this.onQueryJobListByUserId();
  104. },
  105. methods:{
  106. onMasterDetail(event){
  107. uni.navigateTo({
  108. url:"/pages_subpack/work-detail/index?id="+event.id
  109. })
  110. },
  111. onQueryJobListByUserId(){
  112. console.log("进入了我发布的招聘页面")
  113. queryJobListByUserId({}).then(response=>{
  114. this.taskList = response.result.records
  115. }).catch(error=>{
  116. })
  117. }
  118. }
  119. }
  120. </script>
  121. <style>
  122. </style>