123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263 |
- import { required, diyRequired } from '@/components/template/rules_verify.js'
- import { goodsPurchaseRetItemImportCode, goodsPurchaseRetDetail } from '@/api/merchandisePurchaseReturn.js'
- export default {
- data() {
- return {}
- },
- computed: {
- storage_goods() {
- return [
- {
- columnAttributes: {
- label: '品牌',
- prop: 'brandName',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '商品大类',
- prop: 'mainName',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '商品小类',
- prop: 'smallName',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '商品名称',
- prop: 'goodsMaterialName',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '厂物料编码',
- prop: 'factoryNo',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '规格型号',
- prop: 'specsName',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '单位',
- prop: 'unit'
- },
- render: (h, { row, column, index }) => {
- return <div style="padding:0 6px">{{ C: '整套', I: '单个' }[row[column.columnAttributes.prop]] || ''}</div>
- }
- },
- {
- columnAttributes: {
- label: '*退货数量',
- prop: 'retQty',
- width: 160
- },
- render: (h, { row, column, index }) => {
- return !!~[0,1].indexOf(this.formDialogType) ? (
- <div class="redbordererr">
- <el-form-item
- label=""
- lebel-width="0px"
- prop={`items.${index}.${column.columnAttributes.prop}`}
- rules={[diyRequired.bind(this)((rule, value)=>{
- if(this.logs){
- this.logs.push({index:index, errMsg:`${column.columnAttributes.label}不能为空`})
- }
- this?.tishicuowu?.()
- return new Error('必须填写')
- })]}
- >
- <el-input
- value={row[column.columnAttributes.prop]}
- onInput={val => {
- if (Number(val) > Number(row.qty)) {
- row[column.columnAttributes.prop] = Number(row.qty)
- } else {
- row[column.columnAttributes.prop] = val ? Number(val) : ''
- }
- row.retAmount = (row[column.columnAttributes.prop] * Number(row.price)).toFixed(2)
- row.retInsideQty =
- parseInt(Number(row.insideQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
- row.retOutQty =
- parseInt(Number(row.outQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
- row.retPartsQty =
- parseInt(Number(row.partsQty) / Number(row.qty)) * Number(row[column.columnAttributes.prop])
- }}
- type="number"
- placeholder="请输入"
- ></el-input>
- </el-form-item>
- </div>
- ) : (
- <div style="padding:0 6px">{row[column.columnAttributes.prop]}</div>
- )
- }
- },
- {
- columnAttributes: {
- label: '退货内机数量',
- prop: 'retInsideQty',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '退货外机数量',
- prop: 'retOutQty',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '退货配件数量',
- prop: 'retPartsQty',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '导入内机条码数量',
- prop: 'insideCodeQty',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '导入外机条码数量',
- prop: 'outCodeQty',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '导入配件条码数量',
- prop: 'partsCodeQty',
- width: 120
- }
- },
- {
- columnAttributes: {
- label: '退款金额',
- prop: 'retAmount',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '采购数量',
- prop: 'qty',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '内机数量',
- prop: 'insideQty'
- }
- },
- {
- columnAttributes: {
- label: '外机数量',
- prop: 'outQty'
- }
- },
- {
- columnAttributes: {
- label: '配件数量',
- prop: 'partsQty'
- }
- },
- {
- columnAttributes: {
- label: '采购价格',
- prop: 'price',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '采购金额',
- prop: 'amount',
- width: 160
- }
- },
- {
- columnAttributes: {
- label: '库存数量',
- prop: 'stockQty'
- }
- },
- ...(() => {
- if (this.formDialogType < 2 && !~['WAIT', 'OK', 'FAIL'].indexOf(this.formData.status)) {
- return [
- {
- columnAttributes: {
- label: '操作',
- fixed: 'right',
- width: 140
- },
- render: (h, { row, column, index }) => {
- return (
- <div style="padding:0 6px" class="operation-btns">
- <el-button
- type="text"
- onClick={() => {
- this.formData?.items?.splice(index, 1)
- }}
- >
- 删除
- </el-button>
- </div>
- )
- }
- }
- ]
- } else if (this.formDialogType < 2 && !!~[].indexOf(this.formData.status) && this.joinCode) {
- return [
- {
- columnAttributes: {
- label: '操作',
- fixed: 'right',
- width: 140
- },
- render: (h, { row, column, index }) => {
- return (
- <div style="padding:0 6px" class="operation-btns">
- {this.importButton(goodsPurchaseRetItemImportCode, '导入条码', { id: this.formData.id, purchaseRetItemId: row.id }, () => { }, () => {
- if (this.formData.id) {
- // 更新表单信息
- goodsPurchaseRetDetail({ id: this.formData.id }).then(res => {
- Object.assign(this.formData, res.data, {
- fileUrl: res.data.fileUrl ? [{ url: res.data.fileUrl }] : [],
- items: res.data.items.map(item => ({ ...item, details: {} }))
- })
- })
- }
- })}
- </div>
- )
- }
- }
- ]
- }
- return []
- })()
- ]
- }
- },
- methods: {}
- }
|