out_storage_goods.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. import { required, diyRequired } from '@/components/template/rules_verify.js'
  2. import { goodsPurchaseRetItemImportCode, goodsPurchaseRetDetail } from '@/api/merchandisePurchaseReturn.js'
  3. export default {
  4. data() {
  5. return {}
  6. },
  7. computed: {
  8. storage_goods() {
  9. return [
  10. {
  11. columnAttributes: {
  12. label: '品牌',
  13. prop: 'brandName',
  14. width: 160
  15. }
  16. },
  17. {
  18. columnAttributes: {
  19. label: '商品大类',
  20. prop: 'mainName',
  21. width: 160
  22. }
  23. },
  24. {
  25. columnAttributes: {
  26. label: '商品小类',
  27. prop: 'smallName',
  28. width: 160
  29. }
  30. },
  31. {
  32. columnAttributes: {
  33. label: '商品名称',
  34. prop: 'goodsMaterialName',
  35. width: 160
  36. }
  37. },
  38. {
  39. columnAttributes: {
  40. label: '厂物料编码',
  41. prop: 'factoryNo',
  42. width: 120
  43. }
  44. },
  45. {
  46. columnAttributes: {
  47. label: '规格型号',
  48. prop: 'specsName',
  49. width: 120
  50. }
  51. },
  52. {
  53. columnAttributes: {
  54. label: '单位',
  55. prop: 'unit'
  56. },
  57. render: (h, { row, column, index }) => {
  58. return <div style="padding:0 6px">{{ C: '整套', I: '单个' }[row[column.columnAttributes.prop]] || ''}</div>
  59. }
  60. },
  61. {
  62. columnAttributes: {
  63. label: '*退货数量',
  64. prop: 'retQty',
  65. width: 160
  66. },
  67. render: (h, { row, column, index }) => {
  68. return !!~[0,1].indexOf(this.formDialogType) ? (
  69. <div class="redbordererr">
  70. <el-form-item
  71. label=""
  72. lebel-width="0px"
  73. prop={`items.${index}.${column.columnAttributes.prop}`}
  74. rules={[diyRequired.bind(this)((rule, value)=>{
  75. if(this.logs){
  76. this.logs.push({index:index, errMsg:`${column.columnAttributes.label}不能为空`})
  77. }
  78. this?.tishicuowu?.()
  79. return new Error('必须填写')
  80. })]}
  81. >
  82. <el-input
  83. value={row[column.columnAttributes.prop]}
  84. onInput={val => {
  85. if (Number(val) > Number(row.qty)) {
  86. row[column.columnAttributes.prop] = Number(row.qty)
  87. } else {
  88. row[column.columnAttributes.prop] = val ? Number(val) : ''
  89. }
  90. row.retAmount = (row[column.columnAttributes.prop] * Number(row.price)).toFixed(2)
  91. row.retInsideQty =
  92. parseInt(Number(row.insideQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
  93. row.retOutQty =
  94. parseInt(Number(row.outQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
  95. row.retPartsQty =
  96. parseInt(Number(row.partsQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
  97. }}
  98. type="number"
  99. placeholder="请输入"
  100. ></el-input>
  101. </el-form-item>
  102. </div>
  103. ) : (
  104. <div style="padding:0 6px">{row[column.columnAttributes.prop]}</div>
  105. )
  106. }
  107. },
  108. {
  109. columnAttributes: {
  110. label: '退货内机数量',
  111. prop: 'retInsideQty',
  112. width: 120
  113. }
  114. },
  115. {
  116. columnAttributes: {
  117. label: '退货外机数量',
  118. prop: 'retOutQty',
  119. width: 120
  120. }
  121. },
  122. {
  123. columnAttributes: {
  124. label: '退货配件数量',
  125. prop: 'retPartsQty',
  126. width: 120
  127. }
  128. },
  129. {
  130. columnAttributes: {
  131. label: '导入内机条码数量',
  132. prop: 'insideCodeQty',
  133. width: 120
  134. }
  135. },
  136. {
  137. columnAttributes: {
  138. label: '导入外机条码数量',
  139. prop: 'outCodeQty',
  140. width: 120
  141. }
  142. },
  143. {
  144. columnAttributes: {
  145. label: '导入配件条码数量',
  146. prop: 'partsCodeQty',
  147. width: 120
  148. }
  149. },
  150. {
  151. columnAttributes: {
  152. label: '退款金额',
  153. prop: 'retAmount',
  154. width: 160
  155. }
  156. },
  157. {
  158. columnAttributes: {
  159. label: '采购数量',
  160. prop: 'qty',
  161. width: 160
  162. }
  163. },
  164. {
  165. columnAttributes: {
  166. label: '内机数量',
  167. prop: 'insideQty'
  168. }
  169. },
  170. {
  171. columnAttributes: {
  172. label: '外机数量',
  173. prop: 'outQty'
  174. }
  175. },
  176. {
  177. columnAttributes: {
  178. label: '配件数量',
  179. prop: 'partsQty'
  180. }
  181. },
  182. {
  183. columnAttributes: {
  184. label: '采购价格',
  185. prop: 'price',
  186. width: 160
  187. }
  188. },
  189. {
  190. columnAttributes: {
  191. label: '采购金额',
  192. prop: 'amount',
  193. width: 160
  194. }
  195. },
  196. {
  197. columnAttributes: {
  198. label: '库存数量',
  199. prop: 'stockQty'
  200. }
  201. },
  202. ...(() => {
  203. if (this.formDialogType < 2 && !~['WAIT', 'OK', 'FAIL'].indexOf(this.formData.status)) {
  204. return [
  205. {
  206. columnAttributes: {
  207. label: '操作',
  208. fixed: 'right',
  209. width: 140
  210. },
  211. render: (h, { row, column, index }) => {
  212. return (
  213. <div style="padding:0 6px" class="operation-btns">
  214. <el-button
  215. type="text"
  216. onClick={() => {
  217. this.formData?.items?.splice(index, 1)
  218. }}
  219. >
  220. 删除
  221. </el-button>
  222. </div>
  223. )
  224. }
  225. }
  226. ]
  227. } else if (this.formDialogType < 2 && !!~[].indexOf(this.formData.status) && this.joinCode) {
  228. return [
  229. {
  230. columnAttributes: {
  231. label: '操作',
  232. fixed: 'right',
  233. width: 140
  234. },
  235. render: (h, { row, column, index }) => {
  236. return (
  237. <div style="padding:0 6px" class="operation-btns">
  238. {this.importButton(goodsPurchaseRetItemImportCode, '导入条码', { id: this.formData.id, purchaseRetItemId: row.id }, () => { }, () => {
  239. if (this.formData.id) {
  240. // 更新表单信息
  241. goodsPurchaseRetDetail({ id: this.formData.id }).then(res => {
  242. Object.assign(this.formData, res.data, {
  243. fileUrl: res.data.fileUrl ? [{ url: res.data.fileUrl }] : [],
  244. items: res.data.items.map(item => ({ ...item, details: {} }))
  245. })
  246. })
  247. }
  248. })}
  249. </div>
  250. )
  251. }
  252. }
  253. ]
  254. }
  255. return []
  256. })()
  257. ]
  258. }
  259. },
  260. methods: {}
  261. }