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

206 lines
6.7 KiB

6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
4 months ago
6 months ago
4 months ago
6 months ago
6 months ago
3 months ago
6 months ago
3 months ago
3 months ago
6 months ago
4 months ago
6 months ago
3 months ago
6 months ago
3 months ago
6 months ago
6 months ago
6 months ago
4 months ago
6 months ago
6 months ago
6 months ago
3 months ago
6 months ago
6 months ago
6 months ago
4 months ago
6 months ago
4 months ago
6 months ago
  1. <template>
  2. <view>
  3. <!-- <view class="se-flex se-flex-h-sb se-px-40 se-py-30 se-bgc-orange se-zi-s">
  4. <view class="se-c-white se-fs-28">
  5. <view class="se-bgc-white se-py-5 se-px-10 se-fw-6 se-br-12 se-c-orange se-fs-24 se-display-ib">
  6. </view>
  7. <text class="se-ml-10 se-fw-6 se-fs-28">用工平台</text>
  8. </view>
  9. <view class="se-br-30 se-bgc-white se-fw-6 se-c-orange se-fs-28 se-px-20 se-py-10">
  10. 企业/个人端
  11. </view>
  12. </view>
  13. <view class="se-px-20 se-pt-10 se-zi-s">
  14. <u-search height="40" placeholder="搜索" :showAction="false" v-model="keyword"></u-search>
  15. </view>
  16. <view class="se-px-20 se-pb-20 se-pt-40 se-zi-s">
  17. <u-swiper
  18. height="300rpx"
  19. style="background-color: transparent;height: 300rpx;"
  20. :list="list"
  21. @change="change"
  22. @click="click"
  23. ></u-swiper>
  24. </view> -->
  25. <!-- <view class="se-p-20">
  26. <view class="se-flex se-flex-ai-c se-pb-10">
  27. <view class="line-orange"></view>
  28. <view class="se-ml-10 se-fs-32 se-c-black se-fw-6">
  29. 信息大厅
  30. </view>
  31. </view>
  32. </view> -->
  33. <!-- <screenWork :filterData='filterData' :defaultIndex='defaultIndex' @onSelected='onSelected' @onIntellect="onIntellect"></screenWork> -->
  34. <view class="se-mt-10">
  35. <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)">
  36. <view class="se-flex se-flex-h-sb">
  37. <view class="se-flex">
  38. <text class="se-fw-6 se-c-black se-fs-30">{{items.title}}</text>
  39. </view>
  40. <view class="se-c-orange se-fs-32 se-fw-6">
  41. {{items.salaryMin}}-{{items.salaryMax}}k
  42. </view>
  43. </view>
  44. <view class="se-py-10">
  45. <!-- <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.tag">{{items.tag}}</text> -->
  46. <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>
  47. <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>
  48. <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>
  49. </view>
  50. <view class="se-flex se-flex-h-sb">
  51. <view class="se-flex se-flex-h-c">
  52. <u-icon name="map"></u-icon>
  53. <text class="se-c-text-sub se-fs-24 se-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
  54. <!-- <text class="se-c-text-sub se-fs-24 se-pr-10">100km</text> -->
  55. <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>
  56. </view>
  57. <view class="se-c-text se-c-text-sub se-fs-24">
  58. {{items.createTime | formatTime}}
  59. </view>
  60. <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">
  61. <text class="se-ml-5">立即接单</text>
  62. </view>
  63. </view>
  64. </view>
  65. <u-empty v-if="taskList && taskList.length==0" mode="list"></u-empty>
  66. </view>
  67. <!-- <view class="release-box" @click="toNavigator()">
  68. <image class="se-a-70 se-br-p-50" src="@/static/image/release_btn.png" mode=""></image>
  69. <text class="se-c-white se-fs-30 se-fw-6">师傅发布</text>
  70. </view> -->
  71. </view>
  72. </template>
  73. <script>
  74. // import screenWork from "./screen-work.vue"
  75. export default{
  76. props:["taskList"],
  77. components:{
  78. // screenWork
  79. },
  80. data(){
  81. return{
  82. keyword:"",
  83. list: [
  84. 'https://cdn.uviewui.com/uview/swiper/swiper2.png'
  85. ],
  86. filterData:[
  87. [
  88. { text: '全国', value: '', select:true },
  89. { text: '状态1', value: 1, select:false },
  90. { text: '状态2', value: 2, select:false },
  91. { text: '状态3', value: 3, select:false }
  92. ],
  93. [
  94. { text: '选择工种', value: '', select:true },
  95. { text: '类型1', value: 1, select:false },
  96. { text: '类型2', value: 2, select:false },
  97. { text: '类型3', value: 3, select:false },
  98. ]
  99. ],
  100. defaultIndex:[0,0]
  101. }
  102. },
  103. filters:{
  104. formatTime(time) {
  105. const timestamp = new Date(time).getTime();
  106. const currentTime = new Date().getTime();
  107. console.info("currentTime",currentTime)
  108. const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
  109. // 计算月差,判断是否超过一个月
  110. const oneMonthInSeconds = 30 * 24 * 60 * 60;
  111. if (diff > oneMonthInSeconds) {
  112. let date = new Date(timestamp);
  113. let year = date.getFullYear();
  114. let month = date.getMonth() + 1;
  115. let day = date.getDate();
  116. if (month < 10) month = "0" + month;
  117. if (day < 10) day = "0" + day;
  118. return `${year}-${month}-${day}`;
  119. } else {
  120. // 计算秒、分钟、小时的差值
  121. if (diff < 60) {
  122. return `${Math.floor(diff)}秒钟前`;
  123. } else if (diff < 60 * 60) {
  124. return `${Math.floor(diff / 60)}分钟前`;
  125. } else if (diff < 60 * 60 * 24) {
  126. return `${Math.floor(diff / 60 / 60)}小时前`;
  127. } else {
  128. // 显示天数
  129. return `${Math.floor(diff / 60 / 60 / 24)}天前`;
  130. }
  131. }
  132. },
  133. formDate(date){
  134. return dayjs(date).format("YYYY-MM-DD").fromNow();
  135. },
  136. getDistance(lat1, lng1) {
  137. let lng2 = uni.getStorageSync("longitude")
  138. let lat2 = uni.getStorageSync("latitude")
  139. if(!lng2 && !lat2){
  140. return "请授权"
  141. }
  142. const R = 6371; // 地球半径,单位:km
  143. const radLat1 = (lat1 * Math.PI) / 180;
  144. const radLat2 = (lat2 * Math.PI) / 180;
  145. const deltaLat = radLat2 - radLat1;
  146. const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
  147. const a =
  148. Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
  149. Math.cos(radLat1) *
  150. Math.cos(radLat2) *
  151. Math.sin(deltaLng / 2) *
  152. Math.sin(deltaLng / 2);
  153. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  154. return (R * c).toFixed(2); // 返回保留两位小数的公里数
  155. }
  156. },
  157. methods:{
  158. onSelected(res){
  159. console.info(res)
  160. },
  161. change(event){
  162. console.info(event)
  163. },
  164. click(event){
  165. console.info(event)
  166. },
  167. toNavigator(){
  168. uni.navigateTo({
  169. url:"/pages_subpack/release/index?status=2"
  170. })
  171. },
  172. onMasterDetail(event){
  173. console.info(event)
  174. console.info("------------"+event.id)
  175. uni.navigateTo({
  176. url:"/pages_subpack/work-detail/index?id="+event.id
  177. })
  178. }
  179. }
  180. }
  181. </script>
  182. <style>
  183. .release-box{
  184. width: 250rpx;
  185. height: 80rpx;
  186. background: #ff5d18;
  187. border: 4rpx solid rgba(255,255,255,0.68);
  188. border-radius: 44rpx;
  189. box-shadow: 0px 6rpx 12rpx 0px rgba(0,0,0,0.16);
  190. display: flex;
  191. justify-content: center;
  192. align-items: center;
  193. position: fixed;
  194. bottom: 40rpx;
  195. left: 250rpx;
  196. }
  197. </style>