out_storage_goods.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. import { required } from '@/components/template/rules_verify.js'
  2. import { goodsPurchaseRetItemImportCode } 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: 'specsName',
  42. width: 120
  43. }
  44. },
  45. {
  46. columnAttributes: {
  47. label: '单位',
  48. prop: 'unit'
  49. },
  50. render: (h, { row, column, index }) => {
  51. return <div style="padding:0 6px">{{ C: '整套', I: '单个' }[row[column.columnAttributes.prop]] || ''}</div>
  52. }
  53. },
  54. {
  55. columnAttributes: {
  56. label: '退货数量',
  57. prop: 'retQty',
  58. width: 160
  59. },
  60. render: (h, { row, column, index }) => {
  61. return this.formDialogType == 0 ? (
  62. <div class="redbordererr">
  63. <el-form-item
  64. label=""
  65. lebel-width="0px"
  66. prop={`items.${index}.${column.columnAttributes.prop}`}
  67. rules={required}
  68. >
  69. <el-input
  70. value={row[column.columnAttributes.prop]}
  71. onInput={val => {
  72. if (Number(val) > Number(row.qty)) {
  73. row[column.columnAttributes.prop] = Number(row.qty)
  74. } else {
  75. row[column.columnAttributes.prop] = val ? Number(val) : ''
  76. }
  77. row.retAmount = (row[column.columnAttributes.prop] * Number(row.price)).toFixed(2)
  78. row.retInsideQty =
  79. parseInt(Number(row.insideQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
  80. row.retOutQty =
  81. parseInt(Number(row.outQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
  82. row.retPartsQty =
  83. parseInt(Number(row.partsQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
  84. }}
  85. type="number"
  86. placeholder="请输入"
  87. ></el-input>
  88. </el-form-item>
  89. </div>
  90. ) : (
  91. <div style="padding:0 6px">{row[column.columnAttributes.prop]}</div>
  92. )
  93. }
  94. },
  95. {
  96. columnAttributes: {
  97. label: '退货内机数量',
  98. prop: 'retInsideQty',
  99. width: 120
  100. }
  101. },
  102. {
  103. columnAttributes: {
  104. label: '退货外机数量',
  105. prop: 'retOutQty',
  106. width: 120
  107. }
  108. },
  109. {
  110. columnAttributes: {
  111. label: '退货配件数量',
  112. prop: 'retPartsQty',
  113. width: 120
  114. }
  115. },
  116. {
  117. columnAttributes: {
  118. label: '导入内机条码数量',
  119. prop: 'insideCodeQty',
  120. width: 120
  121. }
  122. },
  123. {
  124. columnAttributes: {
  125. label: '导入外机条码数量',
  126. prop: 'outCodeQty',
  127. width: 120
  128. }
  129. },
  130. {
  131. columnAttributes: {
  132. label: '导入配件条码数量',
  133. prop: 'partsCodeQty',
  134. width: 120
  135. }
  136. },
  137. {
  138. columnAttributes: {
  139. label: '退款金额',
  140. prop: 'retAmount',
  141. width: 160
  142. }
  143. },
  144. {
  145. columnAttributes: {
  146. label: '采购数量',
  147. prop: 'qty',
  148. width: 160
  149. }
  150. },
  151. {
  152. columnAttributes: {
  153. label: '内机数量',
  154. prop: 'insideQty'
  155. }
  156. },
  157. {
  158. columnAttributes: {
  159. label: '外机数量',
  160. prop: 'outQty'
  161. }
  162. },
  163. {
  164. columnAttributes: {
  165. label: '配件数量',
  166. prop: 'partsQty'
  167. }
  168. },
  169. {
  170. columnAttributes: {
  171. label: '采购价格',
  172. prop: 'price',
  173. width: 160
  174. }
  175. },
  176. {
  177. columnAttributes: {
  178. label: '采购金额',
  179. prop: 'amount',
  180. width: 160
  181. }
  182. },
  183. {
  184. columnAttributes: {
  185. label: '库存数量',
  186. prop: 'stockQty'
  187. }
  188. },
  189. ...(() => {
  190. if (this.formDialogType < 2) {
  191. return [
  192. {
  193. columnAttributes: {
  194. label: '操作',
  195. fixed: 'right',
  196. width: 140
  197. },
  198. render: (h, { row, column, index }) => {
  199. return (
  200. <div style="padding:0 6px" class="operation-btns">
  201. {!~['SAVE', 'WAIT', 'OK', 'FAIL'].indexOf(this.formData.status) ? (
  202. <el-button
  203. type="text"
  204. onClick={() => {
  205. this.formData?.items?.splice(index, 1)
  206. }}
  207. >
  208. 删除
  209. </el-button>
  210. ) : !!~['SAVE'].indexOf(this.formData.status) ? (
  211. this.importButton(goodsPurchaseRetItemImportCode, '导入条码', { purchaseRetItemId: row.id }, ()=>{}, ()=>{
  212. if (this.formData.id) {
  213. // 更新表单信息
  214. goodsPurchaseRetDetail({ id: this.formData.id }).then(res => {
  215. Object.assign(this.formData, res.data, {
  216. fileUrl: res.data.fileUrl ? [{ url: res.data.fileUrl }] : [],
  217. items: res.data.items.map(item => ({ ...item, details: {} }))
  218. })
  219. })
  220. }
  221. })
  222. ) : null}
  223. </div>
  224. )
  225. }
  226. }
  227. ]
  228. }
  229. return []
  230. })()
  231. ]
  232. }
  233. },
  234. methods: {}
  235. }