created.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <template>
  2. <view class="common-page" style="padding: 0;">
  3. <view class="form-page">
  4. <u-form ref="formRef" :model="form" :rules="rules" labelPosition="left" label-width="85px">
  5. <u-form-item label="快递单号:" prop="waybillCode" required>
  6. <template v-if="isReadonly && form.waybillCode">
  7. <text class="readonly-text">{{ form.waybillCode }}</text>
  8. </template>
  9. <u-input v-else v-model="form.waybillCode" placeholder="请输入快递单号" clearable></u-input>
  10. </u-form-item>
  11. <u-form-item label="订单编号:" prop="orderId" required>
  12. <template v-if="isReadonly && form.orderId">
  13. <text class="clickable-text" @click="goToOrderDetail">{{ form.orderId }}</text>
  14. </template>
  15. <u-input v-else v-model="form.orderId" placeholder="请输入订单编号" clearable></u-input>
  16. </u-form-item>
  17. <u-form-item label="任务类型:" prop="taskType" required>
  18. <u-input v-model="taskTypeText" readonly suffixIcon="arrow-down" placeholder="请选择"
  19. @click="showTaskTypePicker = true"></u-input>
  20. </u-form-item>
  21. <u-form-item label="任务详情:" prop="taskDetail" required>
  22. <u-textarea v-model="form.taskDetail" placeholder="请输入" :height="120"
  23. :autoHeight="true"></u-textarea>
  24. </u-form-item>
  25. <u-form-item label="上传图片:" prop="imgInfo" required>
  26. <cy-upload :filename="form.imgInfo" @update:filename="form.imgInfo = $event" />
  27. </u-form-item>
  28. </u-form>
  29. </view>
  30. <u-picker :show="showTaskTypePicker" :columns="[taskTypeOptions]" title="选择任务类型" @confirm="onPickTaskType"
  31. @cancel="showTaskTypePicker = false" @close="showTaskTypePicker = false"></u-picker>
  32. <view class="fixed-bottom">
  33. <u-button type="warning" size="large" @click="onCancel">取消</u-button>
  34. <u-button type="primary" size="large" :loading="submitting" @click="onSubmit">提交</u-button>
  35. </view>
  36. </view>
  37. </template>
  38. <script setup>
  39. import { ref } from 'vue'
  40. import { onLoad } from '@dcloudio/uni-app'
  41. import CyUpload from '@/components/cy-upload/index.vue'
  42. const formRef = ref(null)
  43. const submitting = ref(false)
  44. const form = ref({
  45. waybillCode: '',
  46. orderId: '',
  47. taskType: '',
  48. taskDetail: '',
  49. imgInfo: []
  50. })
  51. const rules = {
  52. waybillCode: [{ required: true, message: '请输入快递单号' }],
  53. orderId: [{ required: true, message: '请输入订单编号' }],
  54. taskType: [{ required: true, message: '请选择任务类型' }],
  55. taskDetail: [{ required: true, message: '请输入任务详情' }],
  56. }
  57. const taskTypeOptions = ref([])
  58. const showTaskTypePicker = ref(false)
  59. const taskTypeText = ref('')
  60. // 获取任务类型字典
  61. const getTaskTypeOptions = async () => {
  62. try {
  63. const res = await uni.$u.http.get('/system/dict/data/type/task_type')
  64. if (res.code === 200 && res.data) {
  65. taskTypeOptions.value = res.data.map(item => ({
  66. text: item.dictLabel,
  67. value: parseInt(item.dictValue)
  68. }))
  69. }
  70. } catch (e) {
  71. console.error('获取任务类型失败', e)
  72. }
  73. }
  74. const onPickTaskType = (e) => {
  75. console.log(e)
  76. const cell = e.value?.[0]
  77. form.value.taskType = cell?.value || ''
  78. taskTypeText.value = cell?.text || ''
  79. showTaskTypePicker.value = false
  80. }
  81. const onCancel = () => {
  82. uni.navigateBack()
  83. }
  84. const goToOrderDetail = () => {
  85. if (!form.value.orderId) return
  86. uni.navigateTo({
  87. url: `/pages/index/detail/index?id=${form.value.orderId}`
  88. })
  89. }
  90. const workOrderId = ref('')
  91. const isEdit = ref(false)
  92. const isReadonly = ref(false)
  93. const expressTypeFromScan = ref(0)
  94. const onLoadDetail = async (id) => {
  95. try {
  96. const res = await uni.$u.http.get('/app/workOrder/getWorkOrderDetail', {
  97. params: { workOrderId: id }
  98. })
  99. if (res.code === 200 && res.data) {
  100. const data = res.data
  101. form.value.waybillCode = data.waybillCode || ''
  102. form.value.orderId = data.orderId || ''
  103. form.value.taskDetail = data.deatil || data.taskDetail || ''
  104. form.value.imgInfo = data.imgInfo?.imgUrlList?.length ? data.imgInfo.imgUrlList : []
  105. // 加载任务类型字典
  106. await getTaskTypeOptions()
  107. // 回显任务类型
  108. if (data.taskType) {
  109. form.value.taskType = data.taskType
  110. const matchedType = taskTypeOptions.value.find(item => item.value === data.taskType)
  111. if (matchedType) {
  112. taskTypeText.value = matchedType.text
  113. }
  114. }
  115. }
  116. } catch (e) {
  117. console.error(e)
  118. }
  119. }
  120. const onSubmit = async () => {
  121. if (submitting.value) return
  122. try {
  123. await formRef.value?.validate?.()
  124. } catch (e) {
  125. return
  126. }
  127. submitting.value = true
  128. const payload = {
  129. taskType: form.value.taskType,
  130. inspectionStatus: 0, // 默认未验货
  131. deatil: form.value.taskDetail,
  132. waybillCode: form.value.waybillCode,
  133. orderId: form.value.orderId,
  134. type: 2, // 工单类型:2-收书
  135. imgInfo: form.value.imgInfo,
  136. handleUsers: []
  137. }
  138. if (isEdit.value) {
  139. payload.id = workOrderId.value
  140. payload.updateType = 1
  141. }
  142. const apiUrl = isEdit.value ? '/app/workOrder/update' : '/app/workOrder/createWorkOrder'
  143. try {
  144. const res = await uni.$u.http.post(apiUrl, payload)
  145. if (res?.code === 200) {
  146. uni.$u.toast('提交成功')
  147. uni.navigateBack()
  148. } else {
  149. uni.$u.toast(res?.msg || '提交失败')
  150. }
  151. } catch (err) {
  152. uni.$u.toast('网络错误,已本地保存')
  153. } finally {
  154. submitting.value = false
  155. }
  156. }
  157. onLoad((options) => {
  158. form.value.waybillCode = options?.waybillCode || ''
  159. form.value.orderId = options?.orderId || ''
  160. if (options?.expressType) {
  161. expressTypeFromScan.value = parseInt(options.expressType)
  162. }
  163. if (options?.readonly == 1) {
  164. isReadonly.value = true
  165. }
  166. if (options?.mode === 'edit' && options?.workOrderId) {
  167. isEdit.value = true
  168. isReadonly.value = true
  169. workOrderId.value = options.workOrderId
  170. uni.setNavigationBarTitle({ title: '编辑工单' })
  171. onLoadDetail(options.workOrderId)
  172. } else {
  173. uni.setNavigationBarTitle({ title: '提交工单' })
  174. }
  175. // 加载任务类型字典
  176. getTaskTypeOptions()
  177. })
  178. </script>
  179. <style lang="scss" scoped>
  180. .form-page {
  181. padding: 24rpx 24rpx 140rpx;
  182. background: #ffffff;
  183. }
  184. .divider {
  185. height: 16rpx;
  186. background: #f4f5f5;
  187. margin: 20rpx 0;
  188. }
  189. .readonly-text {
  190. font-size: 28rpx;
  191. color: #333;
  192. line-height: 60rpx;
  193. }
  194. .clickable-text {
  195. font-size: 28rpx;
  196. color: #2979ff;
  197. line-height: 60rpx;
  198. }
  199. </style>