| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253 |
- <template>
- <el-form ref="form" :model="form" :rules="rules">
- <ele-pro-table
- ref="table"
- :needPage="false"
- :columns="columns"
- :datasource="form.datasource"
- class="time-form"
- @columns-change="handleColumnChange"
- :cache-key="cacheKeyUrl"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar>
- <div class="headbox">
- <el-button
- v-if="isShowAdd && needProduce != 4"
- size="small"
- type="primary"
- icon="el-icon-plus"
- class="ele-btn-icon"
- @click="handlAdd"
- >
- 新增
- </el-button>
- <el-button
- v-if="isShowAdd && needProduce == 4"
- size="small"
- type="primary"
- icon="el-icon-plus"
- class="ele-btn-icon"
- @click="handParent()"
- >
- 新增
- </el-button>
- </div>
- </template>
- <template v-slot:technicalDrawings="{ row, $index }">
- <el-form-item :prop="'datasource.' + $index + '.technicalDrawings'">
- <fileMain v-model="row.technicalDrawings" type="view"></fileMain>
- </el-form-item>
- </template>
- <template v-slot:remark="{ row, $index }">
- <el-form-item :prop="'datasource.' + $index + '.remark'">
- <el-input
- clearable
- v-model="row.remark"
- type="textarea"
- placeholder="请输入"
- />
- </el-form-item>
- </template>
- <template v-slot:stockLedger="scope">
- <el-form-item>
- <el-popover
- @hide="() => (selection = [])"
- placement="right"
- width="60%"
- trigger="hover"
- >
- <ele-pro-table
- :ref="'childrenTable' + scope.$index"
- row-key="id"
- max-height="300px"
- :selection.sync="selection"
- :needPage="false"
- :columns="childrenColumns"
- :datasource="scope.row.sendProductDetail"
- cache-key="stockLedgerRoleTable"
- class="time-form"
- >
- <!-- 表头工具栏 -->
- <template v-slot:toolbar="childrenScope">
- <div class="headbox">
- <el-button
- size="small"
- type="primary"
- icon="el-icon-plus"
- class="ele-btn-icon"
- @click="stockLedgerSelect(scope.row, scope.$index)"
- >
- 选择
- </el-button>
- <el-button
- size="small"
- type="danger"
- icon="el-icon-delete"
- class="ele-btn-icon"
- :disabled="!selection.length"
- @click="stockLedgerRemove(scope.$index)"
- >
- 删除
- </el-button>
- </div>
- </template>
- </ele-pro-table>
- <el-button type="text" slot="reference">明细</el-button>
- </el-popover>
- </el-form-item>
- </template>
- <template v-slot:packagingStrength="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.packagingStrength'"
- >
- <DictSelection
- dict-name="包装强度"
- v-model="scope.row.extField.packagingStrength"
- ></DictSelection>
- </el-form-item>
- </template>
- <template v-slot:packagingDensity="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.packagingDensity'"
- >
- <DictSelection
- dict-name="包装密度"
- v-model="scope.row.extField.packagingDensity"
- ></DictSelection>
- </el-form-item>
- </template>
- <template v-slot:totalCount="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.totalCount'"
- :rules="[{ required: true, message: '请输入', trigger: 'blur' }]"
- >
- <el-input
- v-model="scope.row.totalCount"
- @input="(val) => changeCount1(scope.row, scope.$index)"
- ></el-input>
- </el-form-item>
- </template>
- <template v-slot:batchNo="scope">
- <el-form-item :prop="'datasource.' + scope.$index + '.batchNo'">
- <el-input v-model="scope.row.batchNo" v-no-chinese></el-input>
- </el-form-item>
- </template>
- <template v-slot:blockCount="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.blockCount'"
- :rules="[{ required: true, message: '请输入', trigger: 'blur' }]"
- >
- <el-input
- v-model="scope.row.blockCount"
- @input="
- (val) => tableHandleKeyUp(scope.row, scope.$index, 'blockCount')
- "
- ></el-input>
- </el-form-item>
- </template>
- <template v-slot:receiveTotalWeight="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.receiveTotalWeight'"
- >
- <el-input-number
- :controls="false"
- v-model="scope.row.receiveTotalWeight"
- @input="changeSendTotalWeight(scope.row, scope.$index)"
- style="width: 60%; margin-right: 10px"
- >
- </el-input-number>
- <el-button
- size="small"
- type="primary"
- v-if="entrustedCode"
- @click.native="(e) => handleInnerBound(e, scope.row, scope.$index)"
- >选择
- </el-button>
- </el-form-item>
- </template>
- <template v-slot:sendTotalWeight="scope">
- <el-form-item :prop="'datasource.' + scope.$index + '.sendTotalWeight'">
- <el-input-number
- :controls="false"
- v-model="scope.row.sendTotalWeight"
- style="width: 100%"
- @input="changeSendTotalWeight(scope.row, scope.$index)"
- >
- </el-input-number>
- </el-form-item>
- </template>
- <template v-slot:increaseTotalWeight="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.increaseTotalWeight'"
- >
- <el-input-number
- :controls="false"
- v-model="scope.row.increaseTotalWeight"
- style="width: 100%"
- >
- </el-input-number>
- </el-form-item>
- </template>
- <template v-slot:warehouseId="scope">
- <el-form-item
- :prop="'datasource.' + scope.$index + '.warehouseId'"
- :rules="[{ required: true, message: '请选择仓库', trigger: 'blur' }]"
- >
- <el-select
- v-model="scope.row.warehouseId"
- placeholder="请选择"
- @change="warehouseChange(scope.$index, scope.row)"
- >
- <el-option
- v-for="item in scope.row.warehouseList"
- :key="item.warehouseId"
- :label="item.warehouseName"
- :value="item.warehouseId"
- >
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- <template v-slot:singlePrice="scope">
- <el-form-item
- style="margin-bottom: 20px"
- :prop="'datasource.' + scope.$index + '.singlePrice'"
- :rules="{
- required: true,
- message: '请输入正确的单价',
- trigger: 'change'
- }"
- >
- <el-input
- v-model="scope.row.singlePrice"
- placeholder="请输入"
- @input="changeCount"
- type="number"
- >
- <template slot="append">元</template>
- </el-input>
- </el-form-item>
- </template>
- <template v-slot:notaxSinglePrice="scope">
- <el-form-item
- style="margin-bottom: 20px"
- :prop="'datasource.' + scope.$index + '.notaxSinglePrice'"
- >
- <el-input
- v-model="scope.row.notaxSinglePrice"
- placeholder="请输入"
- type="number"
- >
- <template slot="append">元</template>
- </el-input>
- </el-form-item>
- </template>
- <template v-slot:singleWeight="scope" v-if="needProduce == 4">
- <el-form-item
- style="margin-bottom: 20px"
- :rules="{
- required: false,
- pattern: numberReg,
- trigger: 'change'
- }"
- :prop="'datasource.' + scope.$index + '.singleWeight'"
- >
- <el-input
- v-model="scope.row.singleWeight"
- placeholder="请输入"
- ></el-input>
- </el-form-item>
- </template>
- <template v-slot:headerWarehouseNum="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- <template v-slot:headerWarehouseId="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- <template v-slot:headerTotalCount="{ column }">
- <span class="is-required">{{ column.label }}</span>
- </template>
- <template v-slot:headerReceiveTotalWeight="{ column }">
- <span :class="{ 'is-required': entrustedCode && pricingWay == 2 }">{{
- column.label
- }}</span>
- </template>
- <!-- 操作列 -->
- <template v-slot:action="scope">
- <el-popconfirm
- class="ele-action"
- title="确定要删除吗?"
- @confirm="remove(scope.$index)"
- >
- <template v-slot:reference>
- <el-link type="danger" :underline="false" icon="el-icon-delete">
- 删除
- </el-link>
- </template>
- </el-popconfirm>
- <el-link
- type="primary"
- :underline="false"
- icon="el-icon-edit"
- @click="selectStockLedgerDialogOpen(scope.row)"
- >
- 替代料
- </el-link>
- </template>
- </ele-pro-table>
- <product-list
- ref="productListRef"
- :orderId="orderId"
- @changeParent="changeParent"
- ></product-list>
- <!--入库详情-->
- <innertboundDetailsDialog
- v-if="innerboundDetailsDialogFlag"
- ref="innerboundDetailsDialogRef"
- :innerboundDetailsDialogFlag.sync="innerboundDetailsDialogFlag"
- @saveDate="saveInnerDate"
- ></innertboundDetailsDialog>
- <!-- 库存台账 -->
- <stock-ledger-dialog
- v-if="stockLedgerDialogFlag"
- :stock-ledger-dialog-flag.sync="stockLedgerDialogFlag"
- ref="stockLedgerDialogRef"
- @getStockLedger="getStockLedger"
- ></stock-ledger-dialog>
- <selectStockLedgerDialog
- ref="selectStockLedgerDialogRef"
- @changeParent="replaceTable"
- ></selectStockLedgerDialog>
- <BIZproductList
- ref="BIZproductListRef"
- classType="1"
- :isGetInventoryTotal="true"
- @changeParent="changeParentBiz"
- :typeIds="typeIds"
- :isFirstRefreshTable="true"
- ></BIZproductList>
- </el-form>
- </template>
- <script>
- import { numberReg } from 'ele-admin';
- import dictMixins from '@/mixins/dictMixins';
- import productList from './product-list.vue';
- import {
- getWarehouseList,
- getWarehouseOutStock,
- getIdWarehouseList
- } from '@/api/saleManage/saleorder';
- import { copyObj } from '@/utils/util';
- import { getFile } from '@/api/system/file';
- import innertboundDetailsDialog from '@/BIZComponents/innerboundDetailsDialog.vue';
- import stockLedgerDialog from './stockLedger/stockLedgerDialog.vue';
- import { fieldModelAPI } from '@/api/main';
- import getDynamicsColumns from '@/mixins/getDynamicsColumns';
- import fileMain from '@/components/addDoc/index.vue';
- import selectStockLedgerDialog from '@/BIZComponents/selectStockLedger/selectStockLedgerDialog.vue'; //库存台账
- import BIZproductList from '@/BIZComponents/product-list.vue';
- import { lbjtList } from '@/enum/dict.js';
- import { parameterGetByCode } from '@/api/main/index.js';
- import tabMixins from '@/mixins/tableColumnsMixin';
- export default {
- mixins: [dictMixins, getDynamicsColumns,tabMixins],
- props: {
- orderId: String,
- needProduce: [String, Number],
- entrustedCode: String,
- pricingWay: [String, Number],
- isShowAdd: {
- type: Boolean,
- default: true
- },
- typeIds: {
- type: Array,
- default: () => []
- }
- },
- components: {
- fileMain,
- innertboundDetailsDialog,
- productList,
- stockLedgerDialog,
- selectStockLedgerDialog,
- BIZproductList
- },
- data() {
- const defaultForm = {
- key: null,
- endTime: '',
- isFirst: 0,
- name: '',
- startTime: '',
- workHour: '',
- technicalDrawings: []
- // warehouseCode:"",
- // warehouseId:'',
- // warehouseName:'',
- };
- return {
- cacheKeyUrl: 'eos-saleManage-invoice-inventoryTable',
- current: {},
- childrenColumns: [
- {
- width: 45,
- type: 'selection',
- columnKey: 'selection',
- align: 'center'
- },
- {
- width: 45,
- type: 'index',
- columnKey: 'index',
- align: 'center',
- fixed: 'left'
- },
- {
- minWidth: 100,
- prop: 'code',
- label: '编码',
- align: 'center'
- },
- {
- minWidth: 140,
- prop: 'barcodes',
- label: '发货条码',
- align: 'center'
- },
- {
- minWidth: 100,
- prop: 'engrave',
- label: '刻码',
- align: 'center'
- }
- ],
- selection: [],
- discountTotalPrice: 0.0,
- allPrice: 0.0,
- curIndex: null,
- innerboundDetailsDialogFlag: false,
- stockLedgerDialogFlag: false,
- numberReg,
- defaultForm,
- warehouseList: [],
- dynamicsColumns: [],
- form: {
- datasource: []
- },
- rules: {},
- isTotalCount: 0
- };
- },
- created() {
- this.requestDict('产地');
- this.requestDict('生产类型');
- //销售发货数量是否限制不能大于采购总数//0否 1是
- parameterGetByCode({
- code: 'saleOrder_invoice_productList_totalCount'
- }).then((res) => {
- this.isTotalCount = res.value;
- });
- },
- computed: {
- canHandl() {
- return this.form.datasource.length;
- },
- contractId() {
- return this.$store.state.order.contractId;
- },
- clientEnvironmentId() {
- return this.$store.state.user.info.clientEnvironmentId;
- },
- columns() {
- return [
- {
- width: 45,
- type: 'index',
- columnKey: 'index',
- align: 'center',
- fixed: 'left'
- },
- {
- width: 200,
- prop: 'productName',
- label: '名称',
- slot: 'productName',
- align: 'center'
- },
- {
- width: 120,
- prop: 'productCode',
- label: '编码',
- slot: 'productCode',
- align: 'center'
- },
- {
- width: 200,
- prop: 'productCategoryName',
- label: '类型',
- slot: 'productCategoryName',
- align: 'center'
- },
- {
- width: 160,
- prop: 'batchNo',
- label: '批次号',
- slot: 'batchNo',
- align: 'center'
- },
- {
- width: 160,
- prop: 'productBrand',
- label: '牌号',
- slot: 'productBrand',
- align: 'center'
- },
- {
- width: 120,
- prop: 'modelType',
- label: '型号',
- slot: 'modelType',
- align: 'center'
- },
- {
- width: 120,
- prop: 'specification',
- label: '规格',
- slot: 'specification',
- align: 'center'
- },
- {
- width: 120,
- prop: 'imgCode',
- align: 'center',
- label: '图号/件号',
- showOverflowTooltip: true
- },
- {
- width: 120,
- prop: 'produceType',
- align: 'center',
- label: '属性类型',
- formatter: (row, column) => {
- if (row.produceType) {
- return row.produceType
- .map((item) => {
- return lbjtList[item];
- })
- .toString();
- }
- },
- showOverflowTooltip: true
- },
- ...this.dynamicsColumns,
- {
- width: 120,
- prop: 'customerMark',
- label: '客户代号',
- slot: 'customerMark',
- align: 'center'
- },
- {
- width: 200,
- prop: 'warehouseId',
- label: '仓库名称',
- slot: 'warehouseId',
- headerSlot: 'headerWarehouseId',
- align: 'center'
- },
- {
- width: 100,
- prop: 'warehouseNum',
- label: '库存',
- align: 'center',
- slot: 'warehouseNum'
- },
- // {
- // width: 100,
- // prop: 'stockLedger',
- // label: '发货明细',
- // slot: 'stockLedger',
- // align: 'center'
- // },
- {
- width: 120,
- prop: 'totalCount',
- label: '发货数量',
- slot: 'totalCount',
- headerSlot: 'headerTotalCount',
- align: 'center'
- },
- {
- width: 120,
- prop: 'orderTotalCount',
- label: '订单数量',
- slot: 'orderTotalCount',
- align: 'center'
- },
- {
- width: 80,
- prop: 'measuringUnit',
- label: '计量单位',
- slot: 'measuringUnit',
- align: 'center'
- },
- {
- width: 120,
- prop: 'blockCount',
- label: '发货块数',
- slot: 'blockCount',
- align: 'center',
- show: this.clientEnvironmentId == '4'
- },
- {
- width: 120,
- prop: 'singleWeight',
- label: '单重',
- slot: 'singleWeight',
- align: 'center'
- },
- {
- width: 200,
- prop: 'receiveTotalWeight',
- label: '收货总重',
- slot: 'receiveTotalWeight',
- align: 'center',
- headerSlot: 'headerReceiveTotalWeight'
- },
- {
- width: 100,
- prop: 'sendTotalWeight',
- label: '发货总重',
- slot: 'sendTotalWeight',
- align: 'center'
- },
- {
- width: 100,
- prop: 'increaseTotalWeight',
- label: '增重重量',
- slot: 'increaseTotalWeight',
- align: 'center'
- },
- {
- width: 100,
- prop: 'weightUnit',
- label: '重量单位',
- slot: 'weightUnit',
- align: 'center'
- },
- // {
- // width: 160,
- // prop: 'pricingWay',
- // label: '计价方式',
- // slot: 'pricingWay',
- // align: 'center',
- // formatter: (row, column) => {
- // return row.pricingWay == 1
- // ? '按数量计费'
- // : row.pricingWay == 2
- // ? '按重量计费'
- // : '';
- // }
- // },
- // {
- // width: 180,
- // prop: 'singlePrice',
- // label: '单价',
- // slot: 'singlePrice',
- // align: 'center'
- // },
- // {
- // width: 160,
- // prop: 'taxRate',
- // label: '税率',
- // formatter: (_row, _column, cellValue) => {
- // return _row.taxRate ? _row.taxRate + '%' : '';
- // },
- // align: 'center'
- // },
- // {
- // width: 180,
- // prop: 'notaxSinglePrice',
- // label: '不含税单价',
- // slot: 'notaxSinglePrice',
- // align: 'center'
- // },
- // {
- // width: 160,
- // prop: 'discountSinglePrice',
- // label: '折后单价',
- // slot: 'discountSinglePrice',
- // align: 'center'
- // },
- // {
- // width: 120,
- // prop: 'totalPrice',
- // label: '合计',
- // slot: 'totalPrice',
- // align: 'center'
- // },
- // {
- // width: 160,
- // prop: 'notaxTotalPrice',
- // label: '含税合计',
- // align: 'center'
- // },
- // {
- // width: 120,
- // prop: 'discountTotalPrice',
- // label: '折后合计',
- // slot: 'discountTotalPrice',
- // align: 'center'
- // },
- {
- width: 80,
- prop: 'deliveryDays',
- label: '交期(天)',
- slot: 'deliveryDays',
- align: 'center'
- },
- {
- width: 200,
- prop: 'guaranteePeriod',
- label: '质保期',
- slot: 'guaranteePeriod',
- formatter: (_row, _column, cellValue) => {
- let val = '';
- if (_row.guaranteePeriod) {
- val += _row.guaranteePeriod;
- }
- if (_row.guaranteePeriodUnitName) {
- val += _row.guaranteePeriodUnitName;
- }
- return val;
- },
- align: 'center'
- },
- {
- prop: 'provenance',
- label: '产地',
- slot: 'provenance',
- align: 'center',
- // show:this.contractBookType==2,
- minWidth: 200,
- showOverflowTooltip: true,
- formatter: (row, column) => {
- return row.provenance && row.provenance.length
- ? row.provenance
- .map((item) => this.getDictValue('产地', item))
- .join(',')
- : '';
- }
- },
- {
- width: 130,
- prop: 'technicalAnswerName',
- label: '技术答疑人',
- slot: 'technicalAnswerName',
- align: 'center'
- },
- {
- width: 220,
- prop: 'technicalParams',
- label: '技术参数',
- slot: 'technicalParams',
- align: 'center'
- },
- {
- width: 240,
- prop: 'technicalDrawings',
- label: '技术图纸',
- slot: 'technicalDrawings',
- align: 'center'
- },
- {
- width: 220,
- prop: 'remark',
- label: '备注',
- slot: 'remark',
- align: 'center'
- },
- {
- columnKey: 'action',
- label: '操作',
- width: 180,
- align: 'center',
- resizable: false,
- slot: 'action',
- fixed: 'right',
- showOverflowTooltip: true
- }
- ];
- }
- },
- methods: {
- downloadFile(file) {
- getFile({ objectName: file.storePath }, file.name);
- },
- //发货明细选择
- stockLedgerSelect(row, index) {
- this.curIndex = index;
- this.stockLedgerDialogFlag = true;
- this.$nextTick(() => {
- this.$refs.stockLedgerDialogRef.init(row.sendProductDetail, row);
- });
- },
- changeCount1(row, index) {
- this.tableHandleKeyUp(row, index, 'sum');
- this.changeCount();
- },
- //改变数量
- changeCount() {
- this.form.datasource.forEach((item, index) => {
- if (item.pricingWay == 1) {
- this.$set(
- this.form.datasource[index],
- 'discountTotalPrice',
- item.discountSinglePrice * item.totalCount
- );
- this.$set(
- this.form.datasource[index],
- 'totalPrice',
- item.singlePrice * item.totalCount
- );
- }
- if (item.pricingWay == 2) {
- this.$set(
- this.form.datasource[index],
- 'discountTotalPrice',
- item.discountSinglePrice *
- item.totalCount *
- (item.singleWeight || 0)
- );
- this.$set(
- this.form.datasource[index],
- 'totalPrice',
- item.singlePrice * item.totalCount * (item.singleWeight || 0)
- );
- }
- });
- },
- //获取
- getStockLedger(sendProductDetail) {
- if (!this.form.datasource[this.curIndex].sendProductDetail)
- this.form.datasource[this.curIndex].sendProductDetail = [];
- let row = this.form.datasource[this.curIndex];
- row.sendProductDetail.push(...sendProductDetail);
- this.form.datasource[this.curIndex] = row;
- this.$refs['childrenTable' + this.curIndex].reload();
- this.$refs.table.reload();
- },
- //删除发货明细
- stockLedgerRemove(PIndex) {
- let row = this.form.datasource[PIndex];
- this.selection.forEach((item) => {
- let index = row.sendProductDetail.findIndex((i) => i.id == item.id);
- row.sendProductDetail.splice(index, 1);
- });
- this.form.datasource[PIndex] = row;
- this.$refs['childrenTable' + PIndex].reload();
- this.$refs.table.reload();
- this.selection = [];
- },
- async warehouseChange(index, row) {
- const data = row.warehouseList.find(
- (item) => item.warehouseId == row.warehouseId
- );
- this.$set(
- this.form.datasource[index],
- 'warehouseName',
- data.warehouseName
- );
- this.$set(
- this.form.datasource[index],
- 'warehouseCode',
- data.warehouseCode
- );
- const warehouseOutStock = await getWarehouseOutStock({
- warehouseId: data.warehouseId,
- code: row.productCode
- });
- this.$set(
- this.form.datasource[index],
- 'warehouseNum',
- warehouseOutStock || 0
- );
- },
- //修改发货总重
- changeSendTotalWeight(row, index) {
- this.curIndex = index;
- this.setIcreaseTotalWeight(row);
- },
- //入库单详情
- handleInnerBound(e, rows, index) {
- this.curIndex = index;
- this.innerboundDetailsDialogFlag = true;
- this.$nextTick(() => {
- let row = {
- code: this.entrustedCode
- };
- this.$refs.innerboundDetailsDialogRef.init(row);
- });
- },
- //选择入库单信息
- saveInnerDate(data = []) {
- let totalWeight = data.reduce((num, row) => {
- num += Number(row.weight);
- return num;
- }, 0);
- this.$set(
- this.form.datasource[this.curIndex],
- 'receiveTotalWeight',
- totalWeight
- );
- console.log(totalWeight, 'totalWeight');
- this.setIcreaseTotalWeight(this.form.datasource[this.curIndex]);
- },
- getWeightPrice() {
- let increaseTotalWeight =
- this.form.datasource[this.curIndex].increaseTotalWeight;
- let singlePrice = this.form.datasource[this.curIndex].singlePrice;
- let discountSinglePrice =
- this.form.datasource[this.curIndex].discountSinglePrice;
- this.$set(
- this.form.datasource[this.curIndex],
- 'totalPrice',
- (Number(increaseTotalWeight) * Number(singlePrice)).toFixed(2)
- );
- this.$set(
- this.form.datasource[this.curIndex],
- 'discountTotalPrice',
- (Number(discountSinglePrice) * Number(increaseTotalWeight)).toFixed(2)
- );
- },
- //设置增重总重
- setIcreaseTotalWeight(row) {
- let receiveTotalWeight = Number(
- this.form.datasource[this.curIndex]?.receiveTotalWeight
- );
- let sendTotalWeight = Number(
- this.form.datasource[this.curIndex]?.sendTotalWeight
- );
- this.$set(
- this.form.datasource[this.curIndex],
- 'increaseTotalWeight',
- (sendTotalWeight - receiveTotalWeight).toFixed(2)
- );
- if (row.pricingWay == 2) {
- this.getWeightPrice();
- }
- this.$refs.table.reload();
- this.$forceUpdate();
- },
- // 表格:模数、数量(方)、块数输入框 输入事件
- tableHandleKeyUp(row, index, name) {
- if (row.specification) {
- let modelArr = row.specification.split('*');
- let modelLong = modelArr[0]; // model规格长度
- let modeWide = modelArr[1]; // model规格宽度
- let modeHight = modelArr[2].substr(0, modelArr[2].indexOf('cm')); // model规格高度
- modeHight = Number(modeHight);
- if (name === 'sum') {
- row.blockCount = Math.floor(
- row.totalCount / ((modelLong * modeWide * modeHight) / 1000000)
- );
- } else if (name === 'blockCount') {
- row.totalCount =
- (Number(row.blockCount) * modelLong * modeWide * modeHight) /
- 1000000;
- this.changeCount();
- }
- }
- },
- //选择产品回调
- async changeParent(obj, idx) {
- obj.orderTotalCount = obj.totalCount;
- obj.id = '';
- obj['tempId'] = idx;
- this.$set(
- this.form.datasource,
- this.form.datasource.length,
- copyObj(obj)
- );
- },
- //选择产品回调
- changeParentBiz(obj = [], idx) {
- obj.forEach(async (item, index) => {
- let i = idx == -1 ? index : idx;
- let row = JSON.parse(JSON.stringify(this.defaultForm));
- row.key = this.form.datasource.length + 1;
- let parasm = idx == -1 ? row : this.form.datasource[i];
- this.$set(parasm, 'productId', item.id);
- this.$set(parasm, 'categoryName', item.name);
- this.$set(parasm, 'productCategoryId', item.categoryLevelId);
- this.$set(parasm, 'productBrand', item.brandNum);
- this.$set(parasm, 'productCategoryName', item.categoryLevelPath);
- this.$set(parasm, 'productCode', item.code);
- this.$set(parasm, 'productName', item.name);
- this.$set(parasm, 'modelType', item.modelType);
- this.$set(parasm, 'availableCountBase', item.availableCountBase);
- this.$set(parasm, 'measuringUnit', item.measuringUnit);
- this.$set(parasm, 'specification', item.specification);
- this.$set(parasm, 'weightUnit', item.weightUnit);
- this.$set(parasm, 'imgCode', item.imgCode);
- this.$set(parasm, 'produceType', item.componentAttribute);
- this.$set(parasm, 'approvalNumber', item.extField?.approvalNumber);
- this.$set(parasm, 'extField', item.extField || {});
- this.$set(parasm, 'singleWeight', item.netWeight);
- this.$set(parasm, 'pricingWay', item.pricingWay || 1);
- this.$set(parasm, 'singlePrice', 0);
- this.$set(parasm, 'discountSinglePrice', 0);
- this.$set(parasm, 'receiveTotalWeight', 0);
- this.$set(parasm, 'sendTotalWeight', 0);
- this.$set(parasm, 'increaseTotalWeight', 0);
- this.$set(
- parasm,
- 'warehouseList',
- await getIdWarehouseList({
- categoryId: item.id
- })
- );
- this.$set(
- parasm,
- 'packingSpecification',
- item.extField?.packingSpecification
- );
- this.$set(
- parasm,
- 'supplierMark',
- this.form.datasource[0]?.supplierMark
- );
- if (item.purchaseOrigins?.length > 0) {
- item.purchaseOrigins = item.purchaseOrigins.map((val) => val + '');
- }
- this.$set(parasm, 'provenance', item.purchaseOrigins || []);
- if (idx == -1) {
- this.form.datasource.push(row);
- }
- });
- },
- replaceTable(list) {
- list.forEach((item) => {
- item['relationId'] = this.current.tempId;
- });
- this.$emit('replaceTableChange', list);
- },
- // validateTotalCount(row) {
- // return (rule, value, callback) => {
- // if (isNaN(value) || Number(value) <= 0) {
- // this.$message.error('请输入大于0的数');
- // callback(false);
- // } else else {
- // callback();
- // }
- // };
- // },
- // 返回列表数据
- getTableValue() {
- let comitDatasource = this.form.datasource;
- if (comitDatasource.length === 0) return [];
- comitDatasource.forEach(async (v) => {
- v.totalCount = Number(v.totalCount);
- v.technicalDrawings = Array.isArray(v.technicalDrawings)
- ? v.technicalDrawings
- : [];
- v.customerReqFiles = Array.isArray(v.customerReqFiles)
- ? v.customerReqFiles
- : [];
- v.industryArtFiles = v.industryArtFiles || [];
- v.otherFiles = v.otherFiles || [];
- });
- return comitDatasource;
- },
- getPrice() {
- return [this.allPrice];
- },
- //修改回显
- putTableValue(data) {
- if (data) {
- this.form.datasource = data;
- data.forEach(async (item, index) => {
- if (item.warehouseId) {
- this.$set(
- this.form.datasource[index],
- 'warehouseNum',
- await getWarehouseOutStock({
- warehouseId: item.warehouseId,
- code: item.productCode
- })
- );
- }
- this.$set(
- this.form.datasource[index],
- 'warehouseList',
- await getIdWarehouseList({
- categoryId: item.productId
- })
- );
- //保存初始收货总重
- this.oldReceiveTotalWeight = this.form.datasource.map((item) => {
- return {
- productCode: item.productCode,
- oldReceiveTotalWeight: item.receiveTotalWeight
- };
- });
- this.form.datasource.forEach((item, index) => {
- this.$set(
- this.form.datasource[index],
- 'receiveTotalWeight',
- item.receiveTotalWeight || 0
- );
- item.sendTotalWeight =
- item.sendTotalWeight ||
- Number(item.totalCount) * Number(item.singleWeight) ||
- 0;
- if (this.outsourceSendCode) {
- item.increaseTotalWeight =
- Number(item.receiveTotalWeight) -
- Number(item.sendTotalWeight);
- } else {
- item.increaseTotalWeight =
- item.increaseTotalWeight || item.receiveTotalWeight || 0;
- }
- });
- this.changeCount();
- });
- }
- },
- remove(i) {
- this.form.datasource.splice(i, 1);
- this.setSort();
- },
- // 清空表格
- restTable() {
- this.form.datasource = [];
- },
- // 重新排序
- setSort() {
- this.form.datasource.forEach((n, index) => {
- n.key = index + 1;
- });
- },
- //选择产品
- handParent() {
- if (!this.orderId) return this.$message.error('请先选择订单');
- this.$refs.BIZproductListRef.open('', -1);
- },
- // 添加
- handlAdd() {
- if (!this.orderId) return this.$message.error('请先选择订单');
- this.$refs.productListRef.open(this.form.datasource);
- },
- //库存台账
- selectStockLedgerDialogOpen(row) {
- this.current = row;
- this.$refs.selectStockLedgerDialogRef.open();
- },
- validateForm(callback) {
- //开始表单校验
- this.$refs.form.validate((valid, obj) => {
- let is = false;
- this.form.datasource.forEach((item) => {
- if (Number(item.totalCount) > item.orderTotalCount) {
- is = true;
- }
- });
- if (is) {
- this.$message.warning('发货数量大于订单总数量');
- if (this.isTotalCount == 1) {
- callback(false);
- }
- }
- if (obj) {
- let messages = Object.keys(obj).map((key) => obj[key][0]);
- if (messages.length > 0) {
- this.$message.warning(messages[0].message);
- }
- }
- callback(valid);
- });
- }
- }
- };
- </script>
- <style lang="scss" scoped>
- .headbox {
- display: flex;
- justify-content: flex-start;
- align-items: center;
- .amount {
- font-size: 14px;
- font-weight: bold;
- padding-right: 30px;
- }
- }
- .time-form .el-form-item {
- margin-bottom: 0 !important;
- }
- ::v-deep .period {
- display: flex;
- .borderleftnone {
- .el-input--medium .el-input__inner {
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
- }
- }
- .borderrightnone {
- .el-input--medium .el-input__inner {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- }
- }
- }
- ::v-deep .time-form tbody > tr:hover > td {
- background-color: transparent !important;
- }
- ::v-deep .time-form .el-table tr {
- background-color: #ffffff;
- }
- .pricebox {
- display: flex;
- justify-content: flex-start;
- align-items: center;
- font-weight: bold;
- }
- </style>
|