12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232 |
- <template>
- <div class="borderless" v-loading="pageLoading">
- <div class="customer-head">
- <div class="customer-back">
- <!-- <i class="back-icon el-icon-arrow-left"></i><i style="font-style:normal">返回管理列表</i>-->
- <el-button
- type="danger"
- style="border: none;background: none;color: red"
- icon="el-icon-arrow-left"
- @click="backToList"
- >返回列表
- </el-button>
- </div>
- <div class="add-customer-btn" v-if="showBut">
- <el-button
- type="primary"
- size="small"
- v-if="detailData.status == 1"
- class="el-button--small-yh "
- @click.stop="openEdit"
- >编辑
- </el-button>
- <!-- <el-button-->
- <!-- type="info"-->
- <!-- @click.stop="editCustomer('save')"-->
- <!-- v-if="form.deliveryStatus == '录入'"-->
- <!-- size="small"-->
- <!-- >确认发货</el-button-->
- <!-- >-->
- <!-- <el-button-->
- <!-- type="info"-->
- <!-- @click.stop="editCustomer('repeal')"-->
- <!-- v-if="form.deliveryStatus != '录入'"-->
- <!-- size="small"-->
- <!-- >撤销发货</el-button-->
- <!-- >-->
- <!-- <el-button-->
- <!-- type="success"-->
- <!-- :disabled="!form.id"-->
- <!-- size="small"-->
- <!-- @click="copyDoc"-->
- <!-- >-->
- <!-- 复制单据-->
- <!-- </el-button>-->
- <el-button
- type="primary"
- :disabled="disabled"
- @click="editCustomer('submit')"
- :loading="subLoading"
- v-if="detailData.status != 1"
- size="small"
- >保存数据
- </el-button>
- </div>
- </div>
- <div class="customer-main">
- <trade-card title="基础信息">
- <avue-form
- ref="form"
- class="trading-form"
- v-model="form"
- :option="option"
- >
- <template slot="corpId">
- <crop-select
- v-model="form.corpId"
- corpType="KH"
- disabled
- ></crop-select>
- </template>
- <template slot="belongToCorpId">
- <crop-select v-model="form.belongToCorpId" corpType="GS" disabled></crop-select>
- </template>
- <template slot="storageId">
- <warehouse-select
- v-model="form.storageId"
- :configuration="configuration2"
- :disabled="detailData.status == 1"
- ></warehouse-select>
- </template>
- </avue-form>
- </trade-card>
- <trade-card title="商品信息">
- <avue-crud
- ref="crud"
- :data="data"
- :option="tableOption"
- @row-del="rowDel"
- @saveColumn="saveColumn"
- @resetColumn="resetColumn"
- :summary-method="summaryMethod"
- :cell-style="cellStyle"
- >
- <template slot="headerSerial">
- <el-button
- type="primary"
- icon="el-icon-plus"
- size="mini"
- @click.stop="addRow"
- :disabled="detailData.status == 1"
- circle
- ></el-button>
- </template>
- <template slot="menuLeft">
- <el-button
- type="primary"
- icon="el-icon-plus"
- size="small"
- @click.stop="newDetails"
- :disabled="detailData.status == 1"
- >批量录入</el-button
- >
- <el-button
- type="info"
- icon="el-icon-printer"
- size="small"
- @click.stop="openReport()"
- >报表打印</el-button
- >
- <el-button :type="!form.customsStatus?'info':'primary'" size="small" :disabled="!form.id" @click.native="dialog = true;fudaSatus = 1"
- >已报关</el-button>
- <el-button :type="!form.shippingStatus?'info':'warning'" size="small" :disabled="!form.id" @click.native="dialog = true;fudaSatus = 2"
- >已出运</el-button>
- <el-button :type="form.documentaryStatus == '已完成'?'success':'info'" size="small" :disabled="!form.id" @click.native="dialog = true;fudaSatus = 3"
- >已完成</el-button>
- </template>
- <template slot-scope="{ row }" slot="corpId">
- {{ row.corpsName }}
- </template>
- <template slot="itemType" slot-scope="{ row }">
- <el-select
- v-if="row.$cellEdit"
- v-model="row.itemType"
- filterable
- allow-create
- default-first-option
- placeholder="请输入"
- @focus="itemTypeFocus(row)"
- >
- <el-option
- v-for="(item, index) in itemtypeList"
- :key="index"
- :label="item.value"
- :value="item.value"
- >
- </el-option>
- </el-select>
- <span v-else>{{ row.itemType }}</span>
- </template>
- <template slot="cname" slot-scope="{ row, index }">
- <el-button
- size="small"
- type="text"
- @click="rePick(row, index)"
- :disabled="disabled"
- class="picker"
- style="padding:4px 10px;float:left"
- >选择</el-button
- >
- <span> {{ row.cname }}</span>
- </template>
- <template slot="taxRate" slot-scope="{ row }">
- <el-input
- v-if="row.$cellEdit"
- size="mini"
- v-model="row.taxRate"
- oninput="value=value.replace(/[^0-9.]/g,'').replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')"
- @change="taxRateChange(row)"
- placeholder="请输入"
- />
- <span v-else>{{ row.taxRate }}</span>
- </template>
- <template slot="menu" slot-scope="{ row, index }">
- <el-button
- size="small"
- icon="el-icon-edit"
- type="text"
- @click="rowCell(row, index)"
- :disabled="disabled"
- >{{ row.$cellEdit ? "保存" : "修改" }}</el-button
- >
- <el-button
- size="small"
- icon="el-icon-edit"
- type="text"
- @click="rowDel(row)"
- >删 除</el-button
- >
- </template>
- <template slot="price" slot-scope="{ row }">
- <el-input
- v-if="row.$cellEdit"
- v-model="row.price"
- size="small"
- oninput="value=value.replace(/[^0-9.]/g,'').replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')"
- @change="priceChange(row)"
- ></el-input>
- <span v-else>{{ row.price }}</span>
- </template>
- <template slot="actualQuantity" slot-scope="{ row }">
- <el-input
- v-if="row.$cellEdit"
- v-model="row.actualQuantity"
- size="small"
- oninput='this.value=this.value.replace(/[^(\d)]/g,"")'
- @change="quantityChange(row)"
- ></el-input>
- <span v-else>{{ row.actualQuantity | IntegerFormat }}</span>
- </template>
- </avue-crud>
- </trade-card>
- <fee-info
- ref="feeInfo"
- :orderFeesList="orderFeesList"
- :disabled="detailData.status == 1"
- feeUrl="/blade-deliver-goods/deliveryfees/update"
- />
- <containerTitle title="合同附件"></containerTitle>
- <c-upload
- typeUpload="CK"
- :data="orderFilesList"
- :disabled="detailData.status == 1"
- :enumerationValue="76"
- deleteUrl="/blade-deliver-goods/deliveryfiles/update"
- />
- </div>
- <el-dialog
- title="导入商品"
- append-to-body
- class="el-dialogDeep"
- :visible.sync="dialogVisible"
- width="80%"
- :close-on-click-modal="false"
- :destroy-on-close="true"
- :close-on-press-escape="false"
- @close="closeGoods"
- top="5vh"
- v-dialog-drag
- >
- <span>
- <el-row>
- <el-col :span="4">
- <div>
- <el-scrollbar>
- <basic-container>
- <avue-tree
- :option="treeOption"
- @node-click="nodeClick"
- :style="treeStyle"
- />
- </basic-container>
- </el-scrollbar>
- </div>
- </el-col>
- <el-col :span="20">
- <avue-crud
- :option="goodsOption"
- :table-loading="loading"
- :data="goodsList"
- ref="goodsCrud"
- :search.sync="search"
- @search-change="searchChange"
- @refresh-change="refreshChange"
- @selection-change="selectionChange"
- @row-click="rowClick"
- :page.sync="page"
- @on-load="onLoad"
- @saveColumn="saveGoodsColumn"
- @resetColumn="resetGoodsColumn"
- :cell-style="cellStyle"
- ></avue-crud>
- </el-col>
- </el-row>
- </span>
- <span slot="footer" class="dialog-footer">
- <el-button @click="dialogVisible = false">取 消</el-button>
- <el-button
- type="primary"
- @click="importGoods"
- :disabled="selectionList.length == 0"
- >导入</el-button
- >
- </span>
- </el-dialog>
- <report-dialog
- :switchDialog="switchDialog"
- :reportId="form.id"
- reportName="客户询价"
- @onClose="onClose()"
- ></report-dialog>
- <el-dialog
- title="选择日期"
- :visible.sync="dialog"
- v-if="dialog"
- width="30%"
- append-to-body>
- <span>
- <el-date-picker
- v-model="pickerValue"
- type="date"
- style="width: 100%;"
- size="small"
- value-format="yyyy-MM-dd HH:ss:mm"
- placeholder="选择日期">
- </el-date-picker>
- </span>
- <span slot="footer" class="dialog-footer">
- <el-button @click="dialog = false;pickerValue = ''">取 消</el-button>
- <el-button type="primary" @click="PSModification(fudaSatus)">确 定</el-button>
- </span>
- </el-dialog>
- </div>
- </template>
- <script>
- import tableOption from "./config/customerContact.json";
- import goodsOption from "./config/commodity.json";
- import feeInfo from "@/components/fee-info/main";
- import {
- detail,
- submit,
- delItem,
- getDeptLazyTree,
- getGoods,
- getSpecification,
- save,
- repeal, purchaseStatusUpdate
- } from "@/api/basicData/invoice";
- import uploadFile from "@/components/upload-file/main";
- import reportDialog from "@/components/report-dialog/main";
- import { micrometerFormat, IntegerFormat } from "@/util/validate";
- import { contrastObj, contrastList } from "@/util/contrastData";
- import _ from "lodash";
- import fa from "element-ui/src/locale/lang/fa";
- export default {
- name: "detailsPageEdit",
- data() {
- return {
- fudaSatus:0,
- dialog:false,
- pickerValue:'',
- treeStyle: "height:" + (window.innerHeight - 315) + "px",
- configuration2: {
- multipleChoices: false,
- multiple: false,
- collapseTags: false,
- placeholder: "请点击右边按钮选择",
- dicData: []
- },
- switchDialog: false,
- form: {
- deliveryStatus: "录入"
- },
- disabled: false,
- dialogVisible: false,
- tableOption: {},
- option: {
- menuBtn: false,
- labelWidth: 100,
- disabled: false,
- column: [
- {
- label: "客户名称",
- prop: "corpId",
- rules: [
- {
- required: false,
- message: "",
- trigger: "blur"
- }
- ],
- span: 8,
- slot: true
- },{
- label: "公司主体",
- prop: "belongToCorpId",
- disabled: true,
- span: 8,
- rules: [
- {
- required: false,
- message: "",
- trigger: "blur"
- }
- ]
- },
- {
- label: "系统号",
- prop: "sysNo",
- disabled: true,
- span: 8
- },
- {
- label: "销售订单号",
- prop: "srcOrderNo",
- disabled: true,
- span: 8
- },
- {
- label: "订单状态",
- prop: "deliveryStatus",
- span: 8,
- type: "select",
- dicUrl: "/api/blade-system/dict-biz/dictionary?code=order_status",
- props: {
- label: "dictValue",
- value: "dictValue"
- },
- disabled: true,
- }, {
- label: "提单号",
- prop: "billLadingNo",
- span: 8,
- rules: [
- {
- required: true,
- message: "",
- trigger: "blur"
- }
- ]
- },
- {
- label: "客户详情",
- prop: "clientMessage",
- span: 8,
- type: "textarea",
- minRows: 2,
- disabled: true,
- },{
- label: "订单日期",
- prop: "businesDate",
- span: 8,
- disabled: true,
- },{
- label: "计划交货日期",
- prop: "plannedDeliveryDate",
- span: 8,
- disabled: true,
- },{
- label: "联系人",
- prop: "corpAttn",
- disabled: true,
- span: 8
- },
- {
- label: "电话",
- prop: "corpTel",
- disabled: true,
- span: 8
- },{
- label: "起运港",
- prop: "portOfLoad",
- span: 8,
- disabled: true,
- },{
- label: "目的港",
- prop: "portOfDestination",
- span: 8,
- disabled: true,
- },{
- label: "运输方式",
- prop: "transport",
- span: 8,
- disabled: true,
- },{
- label: "日期条款",
- prop: "dateClause",
- span: 8,
- disabled: true,
- },{
- label: "日期说明",
- prop: "dateDesc",
- span: 8,
- disabled: true,
- },{
- label: "货物类型",
- prop: "cargoType",
- span: 8,
- disabled: true,
- },{
- label: "价格条款",
- prop: "priceTerms",
- span: 8,
- disabled: true,
- },{
- label: "价格条款描述",
- prop: "priceTermsDescription",
- span: 8,
- disabled: true,
- },{
- label: "付款方式",
- prop: "paymentType",
- span: 8,
- disabled: true,
- },{
- label: "收付款方式描述",
- prop: "paymentTypeDescription",
- span: 8,
- disabled: true,
- },{
- label: "币别",
- prop: "currency",
- span: 8,
- disabled: true,
- },{
- label: "汇率",
- prop: "exchangeRate",
- span: 8,
- disabled: true,
- },{
- label: "采购备注",
- prop: "purchaseRemark",
- type: "textarea",
- minRows: 2,
- disabled: true,
- span: 24
- },{
- label: "船务备注",
- prop: "shippingRemark",
- type: "textarea",
- minRows: 2,
- disabled: true,
- span: 24
- },
- {
- label: "备注",
- prop: "deliveryRemarks",
- type: "textarea",
- minRows: 2,
- span: 24
- }
- ]
- },
- treeOption: {
- nodeKey: "id",
- lazy: true,
- treeLoad: function(node, resolve) {
- const parentId = node.level === 0 ? 0 : node.data.id;
- getDeptLazyTree(parentId).then(res => {
- resolve(
- res.data.data.map(item => {
- return {
- ...item,
- leaf: !item.hasChildren
- };
- })
- );
- });
- },
- addBtn: false,
- menu: false,
- size: "small",
- props: {
- label: "title",
- value: "value",
- children: "children"
- }
- },
- page: {
- pageSize: 10,
- currentPage: 1,
- total: 0
- },
- goodsOption: {},
- data: [],
- goodsList: [],
- selectionList: [],
- treeDeptId: null,
- orderFeesList: [],
- orderFilesList: [],
- itemtypeList: [],
- oldform: {
- deliveryStatus: "录入"
- },
- olddata: [],
- oldorderFeesList: [],
- oldorderFilesList: [],
- reData: null,
- loading: false,
- subLoading: false,
- pageLoading: false,
- showBut: true,
- search: {}
- };
- },
- props: {
- detailData: {
- type: Object
- }
- },
- components: {
- reportDialog,
- feeInfo,
- uploadFile
- },
- async created() {
- if (this.$route.query.pageType == "Generate") {
- this.getGenerate(JSON.parse(this.$route.query.data));
- }
- if (this.detailData.id) {
- this.getDetail(this.detailData.id);
- }
- this.tableOption = await this.getColumnData(
- this.getColumnName(9),
- tableOption
- );
- this.goodsOption = await this.getColumnData(
- this.getColumnName(30),
- goodsOption
- );
- if (this.detailData.status == 1) {
- this.option.disabled = true;
- }
- this.getWorkDicts("product_properties").then(res => {
- this.findObject(this.tableOption.column, "itemProp").dicData =
- res.data.data;
- });
- this.getWorkDicts("unit").then(res => {
- this.findObject(this.tableOption.column, "unit").dicData = res.data.data;
- });
- },
- filters: {
- IntegerFormat(num) {
- return IntegerFormat(num);
- }
- },
- methods: {
- cellStyle() {
- return "padding:0;height:40px;";
- },
- copyDoc() {
- this.$emit("copyOrder", this.form.id);
- },
- PSModification(type){
- if (!this.pickerValue)return this.$message.error("请选择日期")
- const loading = this.$loading({
- lock: true,
- text: '操作中',
- spinner: 'el-icon-loading',
- background: 'rgba(255,255,255,0.7)'
- });
- purchaseStatusUpdate({
- id:this.form.id,
- documentaryStatusType:type,
- documentaryDate:this.pickerValue,
- customsDate:this.pickerValue,
- shippingDate:this.pickerValue
- }).then(res=>{
- loading.close();
- this.$message.success("操作成功")
- this.pickerValue = ''
- this.dialog = false
- this.getDetail(this.form.id);
- }).catch(err=>{
- loading.close();
- this.pickerValue = ''
- this.dialog = false
- })
- },
- rePick(row, index) {
- this.reData = {
- ...row,
- index: index
- };
- this.newDetails();
- },
- itemTypeFocus(row) {
- this.itemtypeList = [];
- getSpecification({ goodId: row.itemId }).then(res => {
- const data = res.data.data;
- this.itemtypeList = data.map(item => ({ value: item }));
- });
- },
- //编辑
- rowCell(row, index) {
- if (row.$cellEdit == true) {
- this.$set(row, "$cellEdit", false);
- } else {
- this.$set(row, "$cellEdit", true);
- }
- },
- priceChange(row) {
- console.log(row);
- if (!row.price) {
- row.price = 0;
- } else {
- row.contractAmount = _.multiply(row.price, row.actualQuantity).toFixed(
- 2
- );
- }
- },
- quantityChange(row) {
- if (!row.actualQuantity) {
- row.actualQuantity = 0;
- } else {
- row.contractAmount = _.multiply(row.price, row.actualQuantity).toFixed(
- 2
- );
- }
- },
- taxRateChange(row) {
- if (Number(row.taxRate) >= 100) {
- row.taxRate = 0;
- this.$message.error("税率不能超过100%");
- }
- },
- rowSave(row) {
- console.log(row);
- this.$set(row, "$cellEdit", false);
- },
- rowDel(row) {
- this.$confirm("确定删除数据?", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- }).then(() => {
- if (row.id) {
- delItem(row.id).then(res => {
- this.$message({
- type: "success",
- message: "删除成功!"
- });
- this.data.splice(row.$index, 1);
- });
- } else {
- this.$message({
- type: "success",
- message: "删除成功!"
- });
- this.data.splice(row.$index, 1);
- }
- });
- },
- importGoods() {
- if (this.reData) {
- console.log(this.reData);
- if (this.selectionList.length != 1) {
- return this.$message.error("重新选择的时候只能选择一条数据");
- } else {
- this.selectionList.forEach(e => {
- this.data.forEach((item, index) => {
- if (index == this.reData.index) {
- item.itemId = e.id;
- item.code = e.code;
- item.cname = e.cname;
- item.priceCategory = e.goodsTypeName;
- item.itemUrl = e.url;
- item.itemProp = this.reData.itemProp;
- item.productDesc = e.cnameDescription;
- item.itemType = this.reData.itemType;
- item.tradeTerms = this.reData.tradeTerms;
- item.price = this.reData.price;
- item.orderQuantity = this.reData.orderQuantity;
- item.insurance = this.reData.insurance;
- item.freight = this.reData.freight;
- item.discount = this.reData.discount;
- item.amount = this.reData.amount;
- item.taxRate = this.reData.taxRate;
- item.unit = e.unit;
- item.remarks = this.reData.remarks;
- item.$cellEdit = true;
- }
- });
- });
- }
- } else {
- this.selectionList.forEach(e => {
- this.data.push({
- itemId: e.id,
- code: e.code,
- cname: e.cname,
- priceCategory: e.goodsTypeName,
- itemUrl: e.url,
- itemProp: null,
- productDesc: e.cnameDescription,
- itemType: null,
- tradeTerms: null,
- price: 0,
- orderQuantity: 0,
- insurance: 0,
- freight: 0,
- discount: null,
- amount: 0,
- taxRate: 0,
- unit: e.unit,
- remarks: null,
- $cellEdit: true
- });
- });
- }
- this.dialogVisible = false;
- },
- refreshChange() {
- this.onLoad(this.page);
- },
- addRow() {
- this.data.push({ $cellEdit: true });
- },
- closeGoods() {
- this.selectionList = [];
- this.treeDeptId = "";
- this.reData = null;
- },
- selectionChange(list) {
- this.selectionList = list;
- },
- rowClick(row) {
- this.$refs.goodsCrud.toggleSelection([this.goodsList[row.$index]]);
- },
- nodeClick(data) {
- this.treeDeptId = data.id;
- this.page.currentPage = 1;
- this.onLoad(this.page);
- },
- searchChange(params, done) {
- this.search = this.deepClone(params);
- this.onLoad(this.page, params);
- done();
- },
- //费用查询
- onLoad(page, params = {}) {
- let obj = this.deepClone(Object.assign(params, this.search));
- this.loading = true;
- getGoods(page.currentPage, page.pageSize, this.treeDeptId, obj).then(
- res => {
- const data = res.data.data;
- this.page.total = data.total;
- this.goodsList = data.records;
- this.loading = false;
- if (this.page.total) {
- this.goodsOption.height = window.innerHeight - 350;
- }
- }
- );
- },
- //商品明细导入
- newDetails() {
- this.dialogVisible = !this.dialogVisible;
- },
- getDetail(id) {
- this.loading = true;
- this.showBut = false;
- this.pageLoading = true;
- const loading = this.$loading({
- lock: true,
- text: '操作中',
- spinner: 'el-icon-loading',
- background: 'rgba(255,255,255,0.7)'
- });
- detail(id)
- .then(res => {
- if (this.detailData.status == "copy") {
- delete res.data.data.id;
- delete res.data.data.sysNo;
- delete res.data.data.orderNo;
- delete res.data.data.orgOrderNo;
- delete res.data.data.srcOrderNo;
- delete res.data.data.createTime;
- delete res.data.data.createUser;
- delete res.data.data.createUserName;
- delete res.data.data.updateTime;
- delete res.data.data.updateUser;
- delete res.data.data.updateUserName;
- delete res.data.data.morderNo;
- delete res.data.data.status;
- delete res.data.data.ifEnquiry;
- delete res.data.data.ifShipping;
- delete res.data.data.customsStatus;
- delete res.data.data.shippingStatus;
- delete res.data.data.documentaryStatus;
- res.data.data.orderStatus = "录入";
- res.data.data.deliveryItemsList.forEach(e => {
- delete e.id;
- delete e.pid;
- delete e.createTime;
- delete e.createUser;
- delete e.updateTime;
- delete e.updateUser;
- delete e.orgOrderNo;
- delete e.srcId;
- delete e.status;
- delete e.isDeleted;
- });
- res.data.data.deliveryFeesList.forEach(e => {
- delete e.id;
- delete e.pid;
- delete e.createTime;
- delete e.createUser;
- delete e.updateTime;
- delete e.updateUser;
- delete e.status;
- delete e.isDeleted;
- });
- res.data.data.deliveryFilesList.forEach(e => {
- delete e.id;
- delete e.pid;
- delete e.createTime;
- delete e.createUser;
- delete e.updateTime;
- delete e.updateUser;
- delete e.status;
- delete e.isDeleted;
- });
- }
- this.form = res.data.data;
- this.data = res.data.data.deliveryItemsList;
- this.orderFeesList = res.data.data.deliveryFeesList;
- this.orderFilesList = res.data.data.deliveryFilesList;
- this.oldform = res.data.data;
- this.olddata = this.deepClone(res.data.data.deliveryItemsList);
- this.oldorderFeesList = this.deepClone(
- res.data.data.deliveryFeesList
- );
- this.oldorderFilesList = this.deepClone(
- res.data.data.deliveryFilesList
- );
- loading.close();
- }).finally(() => {
- this.loading = false;
- this.showBut = true;
- this.pageLoading = false;
- loading.close();
- });
- },
- getGenerate(data) {
- this.form = data;
- this.data = data.orderItemsList;
- this.orderFeesList = data.deliveryFeesList;
- },
- //修改提交触发
- editCustomer(status, status2) {
- this.$refs["form"].validate((valid, done) => {
- done();
- if (valid) {
- let orderFeesList = this.$refs.feeInfo.submitData();
- for (let i = 0; i < orderFeesList.length; i++) {
- if (orderFeesList[i].corpId == null) {
- return this.$message.error(`请输入第${i + 1}行的结算中心`);
- }
- if (orderFeesList[i].price == 0) {
- return this.$message.error(`请正确输入第${i + 1}行的价格`);
- }
- if (orderFeesList[i].actualQuantity == 0) {
- return this.$message.error(`请正确输入第${i + 1}行的数量`);
- }
- }
- this.data.forEach((e, index) => {
- e.sort = Number(index) + 1
- })
- const orderFilesList = this.$refs.uploadFile.submitData();
- if (status == "submit") {
- this.subLoading = true;
- submit({
- ...this.form,
- deliveryItemsList: this.data,
- deliveryFeesList: orderFeesList,
- deliveryFilesList: this.orderFilesList
- })
- .then(res => {
- this.$message.success("保存成功");
- this.form = res.data.data;
- this.data = res.data.data.deliveryItemsList;
- this.orderFeesList = res.data.data.deliveryFeesList;
- this.orderFilesList = res.data.data.deliveryFilesList;
- this.oldform = res.data.data;
- this.olddata = this.deepClone(res.data.data.deliveryItemsList);
- this.oldorderFeesList = this.deepClone(
- res.data.data.deliveryFeesList
- );
- this.oldorderFilesList = this.deepClone(
- res.data.data.deliveryFilesList
- );
- if (status2 == "goBack") {
- if (this.form.id) {
- this.unLock({
- moduleName: "fh",
- tableName: "business_order",
- billId: this.form.id,
- billNo: this.form.orgOrderNo
- });
- }
- this.$emit("goBack");
- this.leaveDetailsKey(this.$route.name);
- }
- })
- .finally(() => {
- this.subLoading = false;
- });
- }
- if (status == "save") {
- this.$confirm("此操作将确认发货, 是否继续?", "提示", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- }).then(() => {
- save({
- ...this.form,
- deliveryItemsList: this.data,
- deliveryFeesList: orderFeesList,
- deliveryFilesList: this.orderFilesList
- }).then(res => {
- this.form = res.data.data;
- this.data = res.data.data.deliveryItemsList;
- this.orderFeesList = res.data.data.deliveryFeesList;
- this.orderFilesList = res.data.data.deliveryFilesList;
- this.oldform = res.data.data;
- this.olddata = this.deepClone(res.data.data.deliveryItemsList);
- this.oldorderFeesList = this.deepClone(
- res.data.data.deliveryFeesList
- );
- this.oldorderFilesList = this.deepClone(
- res.data.data.deliveryFilesList
- );
- this.$message.success("提交成功");
- });
- });
- }
- if (status == "repeal") {
- this.$confirm("此操作将撤销发货, 是否继续?", "提示", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- }).then(() => {
- repeal({
- ...this.form,
- deliveryItemsList: this.data,
- deliveryFeesList: orderFeesList,
- deliveryFilesList: this.orderFilesList
- }).then(res => {
- this.form = res.data.data;
- this.data = res.data.data.deliveryItemsList;
- this.orderFeesList = res.data.data.deliveryFeesList;
- this.orderFilesList = res.data.data.deliveryFilesList;
- this.$message.success("撤销成功");
- this.oldform = res.data.data;
- this.olddata = this.deepClone(res.data.data.deliveryItemsList);
- this.oldorderFeesList = this.deepClone(
- res.data.data.deliveryFeesList
- );
- this.oldorderFilesList = this.deepClone(
- res.data.data.deliveryFilesList
- );
- });
- });
- }
- } else {
- return false;
- }
- });
- },
- //返回列表
- backToList() {
- let orderFeesList = this.$refs.feeInfo.submitData();
- if (
- contrastObj(this.form, this.oldform) ||
- contrastList(this.data, this.olddata) ||
- contrastList(orderFeesList, this.oldorderFeesList) ||
- contrastList(this.orderFilesList, this.oldorderFilesList)
- ) {
- this.$confirm("数据发生变化未有提交记录, 是否提交?", "提示", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- })
- .then(() => {
- this.editCustomer("submit", "goBack");
- })
- .catch(() => {
- if (this.form.id) {
- this.unLock({
- moduleName: "fh",
- tableName: "business_order",
- billId: this.form.id,
- billNo: this.form.orgOrderNo
- });
- }
- this.$emit("goBack");
- this.leaveDetailsKey(this.$route.name);
- });
- } else {
- if (this.form.id) {
- this.unLock({
- moduleName: "fh",
- tableName: "business_order",
- billId: this.form.id,
- billNo: this.form.orgOrderNo
- });
- }
- this.$emit("goBack");
- this.leaveDetailsKey(this.$route.name);
- }
- },
- openReport() {
- this.switchDialog = !this.switchDialog;
- },
- onClose(val) {
- this.switchDialog = val;
- },
- summaryMethod({ columns, data }) {
- const sums = [];
- if (columns.length > 0) {
- columns.forEach((item, index) => {
- sums[0] = "合计";
- if (
- item.property == "actualQuantity" ||
- item.property == "contractAmount"
- ) {
- let qtySum = 0;
- let amountSum = 0;
- data.forEach(e => {
- qtySum = _.add(qtySum, Number(e.actualQuantity));
- amountSum = _.add(amountSum, Number(e.contractAmount));
- this.form.totalQuantity = qtySum;
- this.form.deliveryAmount = amountSum;
- });
- //数量总计
- if (item.property == "actualQuantity") {
- sums[index] = qtySum ? qtySum.toFixed(2) : "0.00";
- }
- //金额总计
- if (item.property == "contractAmount") {
- sums[index] = micrometerFormat(amountSum);
- }
- }
- });
- }
- return sums;
- },
- openEdit() {
- const data = {
- moduleName: "fh",
- tableName: "business_order",
- billId: this.form.id,
- no: localStorage.getItem("browserID"),
- billNo: this.form.orgOrderNo
- };
- this.inDetailsKey(this.$route.name, {
- moduleName: "fh",
- tableName: "business_order",
- billId: this.form.id,
- billNo: this.form.orgOrderNo
- });
- this.checkLock(data).then(res => {
- if (res.data.code == 200) {
- this.onLock(data).then(res => {
- if (res.data.code == 200) {
- this.detailData.status = 2;
- this.option = this.$options.data().option;
- this.$refs.crud.refreshTable();
- }
- });
- }
- });
- },
- async saveColumn() {
- const inSave = await this.saveColumnData(
- this.getColumnName(9),
- this.tableOption
- );
- if (inSave) {
- this.$nextTick(() => {
- this.$refs.crud.doLayout();
- });
- this.$message.success("保存成功");
- //关闭窗口
- this.$refs.crud.$refs.dialogColumn.columnBox = false;
- }
- },
- async resetColumn() {
- this.tableOption = tableOption;
- const inSave = await this.delColumnData(
- this.getColumnName(9),
- tableOption
- );
- if (inSave) {
- this.$nextTick(() => {
- this.$refs.crud.doLayout();
- });
- this.$message.success("重置成功");
- //关闭窗口
- setTimeout(() => {
- this.$refs.crud.$refs.dialogColumn.columnBox = false;
- }, 1000);
- }
- },
- async saveGoodsColumn() {
- const inSave = await this.saveColumnData(
- this.getColumnName(30),
- this.goodsOption
- );
- if (inSave) {
- this.$nextTick(() => {
- this.$refs.goodsCrud.doLayout();
- });
- this.$message.success("保存成功");
- //关闭窗口
- this.$refs.goodsCrud.$refs.dialogColumn.columnBox = false;
- }
- },
- async resetGoodsColumn() {
- this.goodsOption = goodsOption;
- const inSave = await this.delColumnData(
- this.getColumnName(30),
- goodsOption
- );
- if (inSave) {
- this.$nextTick(() => {
- this.$refs.goodsCrud.doLayout();
- });
- this.$message.success("重置成功");
- //关闭窗口
- setTimeout(() => {
- this.$refs.goodsCrud.$refs.dialogColumn.columnBox = false;
- }, 1000);
- }
- }
- }
- };
- </script>
- <style lang="scss" scoped>
- .trading-form ::v-deep .el-form-item {
- margin-bottom: 8px !important;
- }
- ::v-deep .el-form-item__error {
- display: none !important;
- }
- ::v-deep .select-component {
- display: flex !important;
- }
- </style>
|