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

172 lines
5.4 KiB

7 months ago
4 months ago
7 months ago
2 months ago
7 months ago
7 months ago
3 months ago
7 months ago
3 months ago
3 months ago
7 months ago
4 months ago
7 months ago
4 months ago
7 months ago
4 months ago
7 months ago
4 months ago
7 months ago
3 months ago
7 months ago
6 months ago
7 months ago
4 months ago
7 months ago
4 months ago
7 months ago
  1. <template>
  2. <view>
  3. <view class="se-mt-10">
  4. <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)">
  5. <view class="se-flex se-flex-h-sb">
  6. <view class="se-flex se-fw-6">
  7. <text class="se-c-black se-fs-30">{{items.title}}</text>
  8. <text class="se-mx-10 se-b-l"></text>
  9. <text class="se-fs-28 se-c-orange">日薪:{{items.salaryDay}}</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. </view>
  20. <view class="se-flex se-flex-h-sb">
  21. <view class="se-flex se-flex-h-c">
  22. <u-icon name="map"></u-icon>
  23. <text class="se-c-text-sub se-fs-24 se-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
  24. <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>
  25. </view>
  26. <view class="se-c-text se-c-text-sub se-fs-24">
  27. {{items.createTime | formatTime}}
  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. <!-- <view class="release-box" @click="toNavigator()">
  37. <image class="se-a-70 se-br-p-50" src="@/static/image/release_btn.png" mode=""></image>
  38. <text class="se-c-white se-fs-30 se-fw-6">师傅发布</text>
  39. </view> -->
  40. </view>
  41. </template>
  42. <script>
  43. export default{
  44. props:["taskList"],
  45. components:{
  46. },
  47. data(){
  48. return{
  49. keyword:"",
  50. list: [
  51. 'https://cdn.uviewui.com/uview/swiper/swiper2.png'
  52. ],
  53. filterData:[
  54. [
  55. { text: '全国', value: '', select:true },
  56. { text: '状态1', value: 1, select:false },
  57. { text: '状态2', value: 2, select:false },
  58. { text: '状态3', value: 3, select:false }
  59. ],
  60. [
  61. { text: '选择工种', value: '', select:true },
  62. { text: '类型1', value: 1, select:false },
  63. { text: '类型2', value: 2, select:false },
  64. { text: '类型3', value: 3, select:false },
  65. ]
  66. ],
  67. defaultIndex:[0,0]
  68. }
  69. },
  70. filters:{
  71. formatTime(time) {
  72. const timestamp = new Date(time).getTime();
  73. const currentTime = new Date().getTime();
  74. console.info("currentTime",currentTime)
  75. const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
  76. // 计算月差,判断是否超过一个月
  77. const oneMonthInSeconds = 30 * 24 * 60 * 60;
  78. if (diff > oneMonthInSeconds) {
  79. let date = new Date(timestamp);
  80. let year = date.getFullYear();
  81. let month = date.getMonth() + 1;
  82. let day = date.getDate();
  83. if (month < 10) month = "0" + month;
  84. if (day < 10) day = "0" + day;
  85. return `${year}-${month}-${day}`;
  86. } else {
  87. // 计算秒、分钟、小时的差值
  88. if (diff < 60) {
  89. return `${Math.floor(diff)}秒钟前`;
  90. } else if (diff < 60 * 60) {
  91. return `${Math.floor(diff / 60)}分钟前`;
  92. } else if (diff < 60 * 60 * 24) {
  93. return `${Math.floor(diff / 60 / 60)}小时前`;
  94. } else {
  95. // 显示天数
  96. return `${Math.floor(diff / 60 / 60 / 24)}天前`;
  97. }
  98. }
  99. },
  100. formDate(date){
  101. return dayjs(date).format("YYYY-MM-DD").fromNow();
  102. },
  103. getDistance(lat1, lng1) {
  104. let lng2 = uni.getStorageSync("longitude")
  105. let lat2 = uni.getStorageSync("latitude")
  106. if(!lng2 && !lat2){
  107. return "请授权"
  108. }
  109. const R = 6371; // 地球半径,单位:km
  110. const radLat1 = (lat1 * Math.PI) / 180;
  111. const radLat2 = (lat2 * Math.PI) / 180;
  112. const deltaLat = radLat2 - radLat1;
  113. const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
  114. const a =
  115. Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
  116. Math.cos(radLat1) *
  117. Math.cos(radLat2) *
  118. Math.sin(deltaLng / 2) *
  119. Math.sin(deltaLng / 2);
  120. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  121. return (R * c).toFixed(2); // 返回保留两位小数的公里数
  122. }
  123. },
  124. methods:{
  125. onSelected(res){
  126. console.info(res)
  127. },
  128. change(event){
  129. console.info(event)
  130. },
  131. click(event){
  132. console.info(event)
  133. },
  134. toNavigator(){
  135. uni.navigateTo({
  136. url:"/pages_subpack/release/index?status=2"
  137. })
  138. },
  139. onMasterDetail(event){
  140. console.info(event)
  141. console.info("------------"+event.id)
  142. uni.navigateTo({
  143. url:"/pages_subpack/work-detail/index?id="+event.id
  144. })
  145. }
  146. }
  147. }
  148. </script>
  149. <style>
  150. .release-box{
  151. width: 250rpx;
  152. height: 80rpx;
  153. background: #ff5d18;
  154. border: 4rpx solid rgba(255,255,255,0.68);
  155. border-radius: 44rpx;
  156. box-shadow: 0px 6rpx 12rpx 0px rgba(0,0,0,0.16);
  157. display: flex;
  158. justify-content: center;
  159. align-items: center;
  160. position: fixed;
  161. bottom: 40rpx;
  162. left: 250rpx;
  163. }
  164. </style>