form.vue 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. <template>
  2. <xn-form-container
  3. :title="formData.id ? '编辑过磅记录' : '增加过磅记录'"
  4. :width="700"
  5. v-model:open="open"
  6. :destroy-on-close="true"
  7. @close="onClose"
  8. >
  9. <a-form ref="formRef" :model="formData" :rules="formRules" layout="vertical">
  10. <a-form-item label="关联本地数据ID:" name="relationId">
  11. <a-input v-model:value="formData.relationId" placeholder="请输入关联本地数据ID" allow-clear />
  12. </a-form-item>
  13. <a-form-item label="车牌号码:" name="licensePlate">
  14. <a-input v-model:value="formData.licensePlate" placeholder="请输入车牌号码" allow-clear />
  15. </a-form-item>
  16. <a-form-item label="车牌颜色:" name="plateColor">
  17. <a-input v-model:value="formData.plateColor" placeholder="请输入车牌颜色" allow-clear />
  18. </a-form-item>
  19. <a-form-item label="车次编码:" name="carNumber">
  20. <a-input v-model:value="formData.carNumber" placeholder="请输入车次编码" allow-clear />
  21. </a-form-item>
  22. <a-form-item label="过毛时间:" name="grossTime">
  23. <a-date-picker v-model:value="formData.grossTime" value-format="YYYY-MM-DD HH:mm:ss" show-time placeholder="请选择过毛时间" style="width: 100%" />
  24. </a-form-item>
  25. <a-form-item label="过皮时间:" name="tareTime">
  26. <a-date-picker v-model:value="formData.tareTime" value-format="YYYY-MM-DD HH:mm:ss" show-time placeholder="请选择过皮时间" style="width: 100%" />
  27. </a-form-item>
  28. <a-form-item label="皮重类型:" name="tareType">
  29. <a-input v-model:value="formData.tareType" placeholder="请输入皮重类型" allow-clear />
  30. </a-form-item>
  31. <a-form-item label="毛量:" name="grossWeight">
  32. <a-input v-model:value="formData.grossWeight" placeholder="请输入毛量" allow-clear />
  33. </a-form-item>
  34. <a-form-item label="皮重:" name="tareWeight">
  35. <a-input v-model:value="formData.tareWeight" placeholder="请输入皮重" allow-clear />
  36. </a-form-item>
  37. <a-form-item label="净重:" name="netWeight">
  38. <a-input v-model:value="formData.netWeight" placeholder="请输入净重" allow-clear />
  39. </a-form-item>
  40. <a-form-item label="矿发重量:" name="kfWeight">
  41. <a-input v-model:value="formData.kfWeight" placeholder="请输入矿发重量" allow-clear />
  42. </a-form-item>
  43. <a-form-item label="司机姓名:" name="driverName">
  44. <a-input v-model:value="formData.driverName" placeholder="请输入司机姓名" allow-clear />
  45. </a-form-item>
  46. <a-form-item label="司机电话:" name="driverMobile">
  47. <a-input v-model:value="formData.driverMobile" placeholder="请输入司机电话" allow-clear />
  48. </a-form-item>
  49. <a-form-item label="货品名称:" name="goodsName">
  50. <a-input v-model:value="formData.goodsName" placeholder="请输入货品名称" allow-clear />
  51. </a-form-item>
  52. <a-form-item label="规格型号:" name="goodsModel">
  53. <a-input v-model:value="formData.goodsModel" placeholder="请输入规格型号" allow-clear />
  54. </a-form-item>
  55. <a-form-item label="收货单位:" name="receiptCompany">
  56. <a-input v-model:value="formData.receiptCompany" placeholder="请输入收货单位" allow-clear />
  57. </a-form-item>
  58. <a-form-item label="发货单位:" name="shippingCompany">
  59. <a-input v-model:value="formData.shippingCompany" placeholder="请输入发货单位" allow-clear />
  60. </a-form-item>
  61. <a-form-item label="运输路线:" name="transportCompany">
  62. <a-input v-model:value="formData.transportCompany" placeholder="请输入运输路线" allow-clear />
  63. </a-form-item>
  64. <a-form-item label="运输单位:" name="transportRoute">
  65. <a-input v-model:value="formData.transportRoute" placeholder="请输入运输单位" allow-clear />
  66. </a-form-item>
  67. <a-form-item label="过毛车牌图片:" name="grossPlateName">
  68. <a-input v-model:value="formData.grossPlateName" placeholder="请输入过毛车牌图片" allow-clear />
  69. </a-form-item>
  70. <a-form-item label="过毛车图片:" name="grossLicenseName">
  71. <a-input v-model:value="formData.grossLicenseName" placeholder="请输入过毛车图片" allow-clear />
  72. </a-form-item>
  73. <a-form-item label="过毛车头相机抓拍:" name="grossCaptureHead">
  74. <a-input v-model:value="formData.grossCaptureHead" placeholder="请输入过毛车头相机抓拍" allow-clear />
  75. </a-form-item>
  76. <a-form-item label="过毛车尾相机抓拍:" name="grossCaptureTail">
  77. <a-input v-model:value="formData.grossCaptureTail" placeholder="请输入过毛车尾相机抓拍" allow-clear />
  78. </a-form-item>
  79. <a-form-item label="过毛车仓相机抓拍:" name="grossCaptureWare">
  80. <a-input v-model:value="formData.grossCaptureWare" placeholder="请输入过毛车仓相机抓拍" allow-clear />
  81. </a-form-item>
  82. <a-form-item label="过毛车身相机抓拍:" name="grossCaptureBody">
  83. <a-input v-model:value="formData.grossCaptureBody" placeholder="请输入过毛车身相机抓拍" allow-clear />
  84. </a-form-item>
  85. <a-form-item label="过毛磅房相机抓拍:" name="grossCapturePoundRoom">
  86. <a-input v-model:value="formData.grossCapturePoundRoom" placeholder="请输入过毛磅房相机抓拍" allow-clear />
  87. </a-form-item>
  88. <a-form-item label="过皮车牌图片:" name="tarePlateName">
  89. <a-input v-model:value="formData.tarePlateName" placeholder="请输入过皮车牌图片" allow-clear />
  90. </a-form-item>
  91. <a-form-item label="过皮车图片:" name="tareLicenseName">
  92. <a-input v-model:value="formData.tareLicenseName" placeholder="请输入过皮车图片" allow-clear />
  93. </a-form-item>
  94. <a-form-item label="过皮车头相机抓拍:" name="tareCaptureHead">
  95. <a-input v-model:value="formData.tareCaptureHead" placeholder="请输入过皮车头相机抓拍" allow-clear />
  96. </a-form-item>
  97. <a-form-item label="过皮车尾相机抓拍:" name="tareCaptureTail">
  98. <a-input v-model:value="formData.tareCaptureTail" placeholder="请输入过皮车尾相机抓拍" allow-clear />
  99. </a-form-item>
  100. <a-form-item label="过皮车仓相机抓拍:" name="tareCaptureWare">
  101. <a-input v-model:value="formData.tareCaptureWare" placeholder="请输入过皮车仓相机抓拍" allow-clear />
  102. </a-form-item>
  103. <a-form-item label="过皮车身相机抓拍:" name="tareCaptureBody">
  104. <a-input v-model:value="formData.tareCaptureBody" placeholder="请输入过皮车身相机抓拍" allow-clear />
  105. </a-form-item>
  106. <a-form-item label="过皮磅房相机抓拍:" name="tareCapturePoundRoom">
  107. <a-input v-model:value="formData.tareCapturePoundRoom" placeholder="请输入过皮磅房相机抓拍" allow-clear />
  108. </a-form-item>
  109. <a-form-item label="备注1:" name="extKey1">
  110. <a-input v-model:value="formData.extKey1" placeholder="请输入备注1" allow-clear />
  111. </a-form-item>
  112. <a-form-item label="备注2:" name="extKey2">
  113. <a-input v-model:value="formData.extKey2" placeholder="请输入备注2" allow-clear />
  114. </a-form-item>
  115. </a-form>
  116. <template #footer>
  117. <a-button style="margin-right: 8px" @click="onClose">关闭</a-button>
  118. <a-button type="primary" @click="onSubmit" :loading="submitLoading">保存</a-button>
  119. </template>
  120. </xn-form-container>
  121. </template>
  122. <script setup name="bizRecordForm">
  123. import { cloneDeep } from 'lodash-es'
  124. import { required } from '@/utils/formRules'
  125. import bizRecordApi from '@/api/biz/bizRecordApi'
  126. // 抽屉状态
  127. const open = ref(false)
  128. const emit = defineEmits({ successful: null })
  129. const formRef = ref()
  130. // 表单数据
  131. const formData = ref({})
  132. const submitLoading = ref(false)
  133. // 打开抽屉
  134. const onOpen = (record) => {
  135. open.value = true
  136. if (record) {
  137. let recordData = cloneDeep(record)
  138. formData.value = Object.assign({}, recordData)
  139. }
  140. }
  141. // 关闭抽屉
  142. const onClose = () => {
  143. formRef.value.resetFields()
  144. formData.value = {}
  145. open.value = false
  146. }
  147. // 默认要校验的
  148. const formRules = {
  149. relationId: [required('请输入关联本地数据ID')],
  150. licensePlate: [required('请输入车牌号码')],
  151. }
  152. // 验证并提交数据
  153. const onSubmit = () => {
  154. formRef.value
  155. .validate()
  156. .then(() => {
  157. submitLoading.value = true
  158. const formDataParam = cloneDeep(formData.value)
  159. bizRecordApi
  160. .bizRecordSubmitForm(formDataParam, formDataParam.id)
  161. .then(() => {
  162. onClose()
  163. emit('successful')
  164. })
  165. .finally(() => {
  166. submitLoading.value = false
  167. })
  168. })
  169. .catch(() => {})
  170. }
  171. // 抛出函数
  172. defineExpose({
  173. onOpen
  174. })
  175. </script>