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

207 lines
6.3 KiB

5 months ago
  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"
  4. :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"
  17. v-if="items.categoryOne_dictText">{{items.categoryOne_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"
  19. v-if="items.categoryTwo_dictText">{{items.categoryTwo_dictText}}</text>
  20. <text class="se-c-text-sub se-fs-22 se-mr-10 se-py-5 se-px-20 se-br-5 se-bgc-f5"
  21. v-if="items.payType_dictText">{{items.payType_dictText}}</text>
  22. </view>
  23. <view class="se-flex se-flex-h-sb">
  24. <view class="se-flex se-flex-h-c">
  25. <u-icon name="map"></u-icon>
  26. <text
  27. class="se-c-text-sub se-fs-24 se-pr-10">{{items.latitude,items.longitude | getDistance}}km</text>
  28. <text class="se-c-text-sub se-fs-24 se-pl-10 se-b-l se-toe-3"
  29. style="max-width: 220rpx;">{{items.address}}</text>
  30. </view>
  31. <view class="se-c-text se-c-text-sub se-fs-24">
  32. {{items.createTime | formatTime}}
  33. </view>
  34. <view v-if="!items.employOrder.length"
  35. style="flex-shrink: 0;"
  36. @click.stop="onEditJob(items)"
  37. 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">
  38. <text class="se-ml-5">修改</text>
  39. </view>
  40. <view v-if="!items.employOrder.length"
  41. style="flex-shrink: 0;"
  42. @click.stop="onDeleteJob(items)"
  43. 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">
  44. <text class="se-ml-5">删除</text>
  45. </view>
  46. <view v-else
  47. style="flex-shrink: 0;"
  48. 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">
  49. <text class="se-ml-5">{{ items.employOrder.length }}人接单</text>
  50. </view>
  51. </view>
  52. </view>
  53. <u-empty v-if="taskList && taskList.length==0" mode="list"></u-empty>
  54. </view>
  55. </template>
  56. <script>
  57. import {
  58. queryJobListByUserId,
  59. deleteJob
  60. } from "@/common/api.js"
  61. export default {
  62. data() {
  63. return {
  64. taskList: [
  65. ]
  66. }
  67. },
  68. filters: {
  69. formatTime(time) {
  70. const timestamp = new Date(time).getTime();
  71. const currentTime = new Date().getTime();
  72. console.info("currentTime", currentTime)
  73. const diff = (currentTime - timestamp) / 1000; // 时间差,单位:秒
  74. // 计算月差,判断是否超过一个月
  75. const oneMonthInSeconds = 30 * 24 * 60 * 60;
  76. if (diff > oneMonthInSeconds) {
  77. let date = new Date(timestamp);
  78. let year = date.getFullYear();
  79. let month = date.getMonth() + 1;
  80. let day = date.getDate();
  81. if (month < 10) month = "0" + month;
  82. if (day < 10) day = "0" + day;
  83. return `${year}-${month}-${day}`;
  84. } else {
  85. // 计算秒、分钟、小时的差值
  86. if (diff < 60) {
  87. return `${Math.floor(diff)}秒钟前`;
  88. } else if (diff < 60 * 60) {
  89. return `${Math.floor(diff / 60)}分钟前`;
  90. } else if (diff < 60 * 60 * 24) {
  91. return `${Math.floor(diff / 60 / 60)}小时前`;
  92. } else {
  93. // 显示天数
  94. return `${Math.floor(diff / 60 / 60 / 24)}天前`;
  95. }
  96. }
  97. },
  98. formDate(date) {
  99. return dayjs(date).format("YYYY-MM-DD").fromNow();
  100. },
  101. getDistance(lat1, lng1) {
  102. let lng2 = uni.getStorageSync("longitude")
  103. let lat2 = uni.getStorageSync("latitude")
  104. if (!lng2 && !lat2) {
  105. return "请授权"
  106. }
  107. const R = 6371; // 地球半径,单位:km
  108. const radLat1 = (lat1 * Math.PI) / 180;
  109. const radLat2 = (lat2 * Math.PI) / 180;
  110. const deltaLat = radLat2 - radLat1;
  111. const deltaLng = ((lng2 - lng1) * Math.PI) / 180;
  112. const a =
  113. Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
  114. Math.cos(radLat1) *
  115. Math.cos(radLat2) *
  116. Math.sin(deltaLng / 2) *
  117. Math.sin(deltaLng / 2);
  118. const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
  119. return (R * c).toFixed(2); // 返回保留两位小数的公里数
  120. }
  121. },
  122. onShow() {
  123. this.onQueryJobListByUserId();
  124. },
  125. methods: {
  126. onMasterDetail(event) {
  127. // 如果有订单,跳转到订单列表页面
  128. if(event.employOrder && event.employOrder.length > 0){
  129. // 传递工作ID
  130. uni.navigateTo({
  131. url: "/pages_subpack/hire/order-list?jobId=" + event.id
  132. });
  133. }else{
  134. // 没有订单,跳转到工作详情页面
  135. uni.navigateTo({
  136. url: "/pages_subpack/work-detail/index?id=" + event.id
  137. });
  138. }
  139. },
  140. onQueryJobListByUserId() {
  141. console.log("进入了我发布的招聘页面")
  142. queryJobListByUserId({}).then(response => {
  143. this.taskList = response.result.records
  144. }).catch(error => {
  145. })
  146. },
  147. onEditJob(item) {
  148. // 跳转到编辑招聘页面
  149. uni.navigateTo({
  150. url: `/pages_subpack/release/index?status=1&editId=${item.id}`
  151. });
  152. },
  153. onDeleteJob(item) {
  154. // 显示删除确认对话框
  155. uni.showModal({
  156. title: '确认删除',
  157. content: '确定要删除这条招聘信息吗?',
  158. success: (res) => {
  159. if (res.confirm) {
  160. this.deleteJobById(item.id);
  161. }
  162. }
  163. });
  164. },
  165. deleteJobById(jobId) {
  166. uni.showLoading({
  167. title: '删除中...'
  168. });
  169. // 调用删除API
  170. deleteJob({ id: jobId }).then(response => {
  171. uni.hideLoading();
  172. if (response.code === 200) {
  173. uni.showToast({
  174. title: '删除成功',
  175. icon: 'success'
  176. });
  177. // 重新加载列表
  178. this.onQueryJobListByUserId();
  179. } else {
  180. uni.showToast({
  181. title: response.message || '删除失败',
  182. icon: 'none'
  183. });
  184. }
  185. }).catch(error => {
  186. uni.hideLoading();
  187. uni.showToast({
  188. title: '删除失败',
  189. icon: 'none'
  190. });
  191. });
  192. }
  193. }
  194. }
  195. </script>
  196. <style>
  197. </style>