|  | @@ -0,0 +1,625 @@
 | 
	
		
			
				|  |  | +<template>
 | 
	
		
			
				|  |  | +  <div class="borderless" v-loading="pageLoading">
 | 
	
		
			
				|  |  | +    <div class="customer-head">
 | 
	
		
			
				|  |  | +      <div class="customer-back">
 | 
	
		
			
				|  |  | +        <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">
 | 
	
		
			
				|  |  | +        <el-button
 | 
	
		
			
				|  |  | +          type="primary"
 | 
	
		
			
				|  |  | +          size="small"
 | 
	
		
			
				|  |  | +          class="el-button--small-yh"
 | 
	
		
			
				|  |  | +          @click.stop="openEdit"
 | 
	
		
			
				|  |  | +        >编 辑</el-button>
 | 
	
		
			
				|  |  | +        <el-button
 | 
	
		
			
				|  |  | +          type="success"
 | 
	
		
			
				|  |  | +          :disabled="!form.id"
 | 
	
		
			
				|  |  | +          size="small"
 | 
	
		
			
				|  |  | +          @click="copyDoc"
 | 
	
		
			
				|  |  | +        >
 | 
	
		
			
				|  |  | +          复制单据
 | 
	
		
			
				|  |  | +        </el-button>
 | 
	
		
			
				|  |  | +        <el-button
 | 
	
		
			
				|  |  | +          type="primary"
 | 
	
		
			
				|  |  | +          @click="editCustomer"
 | 
	
		
			
				|  |  | +          size="small"
 | 
	
		
			
				|  |  | +        >保存数据
 | 
	
		
			
				|  |  | +        </el-button>
 | 
	
		
			
				|  |  | +      </div>
 | 
	
		
			
				|  |  | +    </div>
 | 
	
		
			
				|  |  | +    <div class="customer-main">
 | 
	
		
			
				|  |  | +      <containerTitle title="基础信息"/>
 | 
	
		
			
				|  |  | +      <basic-container :showBtn="true">
 | 
	
		
			
				|  |  | +        <avue-form
 | 
	
		
			
				|  |  | +          ref="form"
 | 
	
		
			
				|  |  | +          class="trading-form"
 | 
	
		
			
				|  |  | +          v-model="form"
 | 
	
		
			
				|  |  | +          :option="option"
 | 
	
		
			
				|  |  | +        >
 | 
	
		
			
				|  |  | +          <template slot="corpId">
 | 
	
		
			
				|  |  | +            <crop-select
 | 
	
		
			
				|  |  | +              v-model="form.corpId"
 | 
	
		
			
				|  |  | +              @getCorpData="getCorpData"
 | 
	
		
			
				|  |  | +              corpType="KH"
 | 
	
		
			
				|  |  | +            ></crop-select>
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +          <template slot="storageId">
 | 
	
		
			
				|  |  | +            <warehouse-select
 | 
	
		
			
				|  |  | +              v-model="form.storageId"
 | 
	
		
			
				|  |  | +              :configuration="configurationWarehouse"/>
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +        </avue-form>
 | 
	
		
			
				|  |  | +      </basic-container>
 | 
	
		
			
				|  |  | +      <containerTitle title="商品信息"/>
 | 
	
		
			
				|  |  | +      <basic-container>
 | 
	
		
			
				|  |  | +        <avue-crud
 | 
	
		
			
				|  |  | +          ref="crud"
 | 
	
		
			
				|  |  | +          :data="dataList"
 | 
	
		
			
				|  |  | +          :option="tableOption"
 | 
	
		
			
				|  |  | +          :cell-style="cellStyle"
 | 
	
		
			
				|  |  | +          @saveColumn="saveColumn"
 | 
	
		
			
				|  |  | +          @resetColumn="resetColumn"
 | 
	
		
			
				|  |  | +        >
 | 
	
		
			
				|  |  | +          <template slot="menuLeft">
 | 
	
		
			
				|  |  | +            <el-button
 | 
	
		
			
				|  |  | +              type="primary"
 | 
	
		
			
				|  |  | +              icon="el-icon-plus"
 | 
	
		
			
				|  |  | +              size="small"
 | 
	
		
			
				|  |  | +              @click.stop="newDetails"
 | 
	
		
			
				|  |  | +            >录入明细</el-button>
 | 
	
		
			
				|  |  | +            <el-button
 | 
	
		
			
				|  |  | +              type="info"
 | 
	
		
			
				|  |  | +              icon="el-icon-printer"
 | 
	
		
			
				|  |  | +              size="small"
 | 
	
		
			
				|  |  | +              @click.stop="openReport()"
 | 
	
		
			
				|  |  | +            >报 表</el-button
 | 
	
		
			
				|  |  | +            >
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +          <template slot="menu" slot-scope="{ row, index }">
 | 
	
		
			
				|  |  | +            <el-button
 | 
	
		
			
				|  |  | +              size="small"
 | 
	
		
			
				|  |  | +              icon="el-icon-edit"
 | 
	
		
			
				|  |  | +              type="text"
 | 
	
		
			
				|  |  | +              @click="rowCell(row, index)"
 | 
	
		
			
				|  |  | +            >{{ row.$cellEdit ? "保存" : "修改" }}</el-button
 | 
	
		
			
				|  |  | +            >
 | 
	
		
			
				|  |  | +            <el-button
 | 
	
		
			
				|  |  | +              size="small"
 | 
	
		
			
				|  |  | +              icon="el-icon-delete"
 | 
	
		
			
				|  |  | +              type="text"
 | 
	
		
			
				|  |  | +              @click="rowDel(row, index)"
 | 
	
		
			
				|  |  | +            >删除</el-button
 | 
	
		
			
				|  |  | +            >
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +          <template slot="cname" slot-scope="{ row, index }">
 | 
	
		
			
				|  |  | +            <span v-if="row.$cellEdit" style="display:flex">
 | 
	
		
			
				|  |  | +              <el-select
 | 
	
		
			
				|  |  | +                v-model="row.itemId"
 | 
	
		
			
				|  |  | +                placeholder="请选择"
 | 
	
		
			
				|  |  | +                size="small"
 | 
	
		
			
				|  |  | +                style="width:60%"
 | 
	
		
			
				|  |  | +                @change="cnameChange(row, index)"
 | 
	
		
			
				|  |  | +              >
 | 
	
		
			
				|  |  | +                <el-option
 | 
	
		
			
				|  |  | +                  v-for="item in goodsoptions"
 | 
	
		
			
				|  |  | +                  :key="item.id"
 | 
	
		
			
				|  |  | +                  :label="item.cname"
 | 
	
		
			
				|  |  | +                  :value="item.id"
 | 
	
		
			
				|  |  | +                >
 | 
	
		
			
				|  |  | +                </el-option>
 | 
	
		
			
				|  |  | +              </el-select>
 | 
	
		
			
				|  |  | +              <el-button
 | 
	
		
			
				|  |  | +                icon="el-icon-search"
 | 
	
		
			
				|  |  | +                size="small"
 | 
	
		
			
				|  |  | +                @click="rePick(row, index)"
 | 
	
		
			
				|  |  | +              ></el-button>
 | 
	
		
			
				|  |  | +            </span>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            <span v-else> {{ row.cname }}</span>
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +          <template slot="actualQuantity" slot-scope="{ row, index }">
 | 
	
		
			
				|  |  | +            <el-input
 | 
	
		
			
				|  |  | +              v-if="row.$cellEdit"
 | 
	
		
			
				|  |  | +              v-model="row.actualQuantity"
 | 
	
		
			
				|  |  | +              size="small"
 | 
	
		
			
				|  |  | +            ></el-input>
 | 
	
		
			
				|  |  | +            <span v-else>{{ row.actualQuantity }}</span>
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +          <template slot="price" slot-scope="{ row, index }">
 | 
	
		
			
				|  |  | +            <el-input
 | 
	
		
			
				|  |  | +              v-if="row.$cellEdit"
 | 
	
		
			
				|  |  | +              v-model="row.price"
 | 
	
		
			
				|  |  | +              size="small"
 | 
	
		
			
				|  |  | +            ></el-input>
 | 
	
		
			
				|  |  | +            <span v-else>{{ row.price }}</span>
 | 
	
		
			
				|  |  | +          </template>
 | 
	
		
			
				|  |  | +        </avue-crud>
 | 
	
		
			
				|  |  | +      </basic-container>
 | 
	
		
			
				|  |  | +    </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"
 | 
	
		
			
				|  |  | +              @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>
 | 
	
		
			
				|  |  | +  </div>
 | 
	
		
			
				|  |  | +</template>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +<script>
 | 
	
		
			
				|  |  | +import tableOption from "./config/customerContact.json";
 | 
	
		
			
				|  |  | +import goodsOption from "./config/commodity.json";
 | 
	
		
			
				|  |  | +import {getDeptLazyTree,
 | 
	
		
			
				|  |  | +  getGoods,} from "@/api/basicData/customerInquiry";
 | 
	
		
			
				|  |  | +import {getUserInfo} from "@/api/system/user";
 | 
	
		
			
				|  |  | +import {selectGoodsNum} from "@/api/basicData/inventoryAccount"; // 库存查询
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +export default {
 | 
	
		
			
				|  |  | +  name: "detail",
 | 
	
		
			
				|  |  | +  props: {
 | 
	
		
			
				|  |  | +    detailData: {
 | 
	
		
			
				|  |  | +      type: Object
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  },
 | 
	
		
			
				|  |  | +  data() {
 | 
	
		
			
				|  |  | +    return {
 | 
	
		
			
				|  |  | +      pageLoading: false,
 | 
	
		
			
				|  |  | +      form: {},
 | 
	
		
			
				|  |  | +      option: {
 | 
	
		
			
				|  |  | +        menuBtn: false,
 | 
	
		
			
				|  |  | +        labelWidth: 100,
 | 
	
		
			
				|  |  | +        column: [
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "客户名称",
 | 
	
		
			
				|  |  | +            prop: "corpId",
 | 
	
		
			
				|  |  | +            rules: [
 | 
	
		
			
				|  |  | +              {
 | 
	
		
			
				|  |  | +                required: true,
 | 
	
		
			
				|  |  | +                message: " ",
 | 
	
		
			
				|  |  | +                trigger: "change"
 | 
	
		
			
				|  |  | +              }
 | 
	
		
			
				|  |  | +            ],
 | 
	
		
			
				|  |  | +            span: 16,
 | 
	
		
			
				|  |  | +            slot: true
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "系统号",
 | 
	
		
			
				|  |  | +            prop: "sysNo",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +            disabled: true
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "业务时间",
 | 
	
		
			
				|  |  | +            prop: "businesDate",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +            type: "date",
 | 
	
		
			
				|  |  | +            format: "yyyy-MM-dd",
 | 
	
		
			
				|  |  | +            valueFormat: "yyyy-MM-dd 00:00:00",
 | 
	
		
			
				|  |  | +            rules: [
 | 
	
		
			
				|  |  | +              {
 | 
	
		
			
				|  |  | +                required: true,
 | 
	
		
			
				|  |  | +                message: "",
 | 
	
		
			
				|  |  | +                trigger: "blur"
 | 
	
		
			
				|  |  | +              }
 | 
	
		
			
				|  |  | +            ]
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "电话",
 | 
	
		
			
				|  |  | +            prop: "corpTel",
 | 
	
		
			
				|  |  | +            span: 8
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "地址",
 | 
	
		
			
				|  |  | +            prop: "arrivalAddress",
 | 
	
		
			
				|  |  | +            span: 8
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "打印时间",
 | 
	
		
			
				|  |  | +            prop: "a",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +            disabled: true
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "客户欠款",
 | 
	
		
			
				|  |  | +            prop: "a",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "总数量",
 | 
	
		
			
				|  |  | +            prop: "b",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "应收金额",
 | 
	
		
			
				|  |  | +            prop: "c",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "总金额",
 | 
	
		
			
				|  |  | +            prop: "d",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "经办人",
 | 
	
		
			
				|  |  | +            prop: "e",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "制单人",
 | 
	
		
			
				|  |  | +            prop: "createUser",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +            disabled: true,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "结算方式",
 | 
	
		
			
				|  |  | +            prop: "paymentType",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +            type: "select",
 | 
	
		
			
				|  |  | +            dicUrl: "/api/blade-system/dict-biz/dictionary?code=payment_term",
 | 
	
		
			
				|  |  | +            props: {
 | 
	
		
			
				|  |  | +              label: "dictValue",
 | 
	
		
			
				|  |  | +              value: "dictValue"
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "配送方式",
 | 
	
		
			
				|  |  | +            prop: "f",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +          {
 | 
	
		
			
				|  |  | +            label: "发货仓库",
 | 
	
		
			
				|  |  | +            prop: "storageId",
 | 
	
		
			
				|  |  | +            span: 8,
 | 
	
		
			
				|  |  | +          },
 | 
	
		
			
				|  |  | +        ],
 | 
	
		
			
				|  |  | +      },
 | 
	
		
			
				|  |  | +      dataList: [],
 | 
	
		
			
				|  |  | +      tableOption: {},
 | 
	
		
			
				|  |  | +      dialogVisible: false,
 | 
	
		
			
				|  |  | +      selectionList: [],
 | 
	
		
			
				|  |  | +      treeDeptId: null,
 | 
	
		
			
				|  |  | +      reData: null,
 | 
	
		
			
				|  |  | +      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
 | 
	
		
			
				|  |  | +      },
 | 
	
		
			
				|  |  | +      search: {},
 | 
	
		
			
				|  |  | +      goodsList: [],
 | 
	
		
			
				|  |  | +      loading: false,
 | 
	
		
			
				|  |  | +      goodsOption: {},
 | 
	
		
			
				|  |  | +      treeStyle: "height:" + (window.innerHeight - 315) + "px",
 | 
	
		
			
				|  |  | +      goodsoptions: [],
 | 
	
		
			
				|  |  | +      // 仓库配置
 | 
	
		
			
				|  |  | +      configurationWarehouse: {
 | 
	
		
			
				|  |  | +        multipleChoices: false,
 | 
	
		
			
				|  |  | +        multiple: false,
 | 
	
		
			
				|  |  | +        collapseTags: false,
 | 
	
		
			
				|  |  | +        placeholder: "请点击右边按钮选择",
 | 
	
		
			
				|  |  | +        dicData: [],
 | 
	
		
			
				|  |  | +      },
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  },
 | 
	
		
			
				|  |  | +  async created() {
 | 
	
		
			
				|  |  | +    this.tableOption = await this.getColumnData(
 | 
	
		
			
				|  |  | +      this.getColumnName(79),
 | 
	
		
			
				|  |  | +      tableOption
 | 
	
		
			
				|  |  | +    );
 | 
	
		
			
				|  |  | +    this.goodsOption = await this.getColumnData(
 | 
	
		
			
				|  |  | +      this.getColumnName(80),
 | 
	
		
			
				|  |  | +      goodsOption
 | 
	
		
			
				|  |  | +    );
 | 
	
		
			
				|  |  | +    getGoods(1, 500).then(res => {
 | 
	
		
			
				|  |  | +      this.goodsoptions = res.data.data.records;
 | 
	
		
			
				|  |  | +    });
 | 
	
		
			
				|  |  | +    getUserInfo().then(res => {
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'createUser', res.data.data.realName)
 | 
	
		
			
				|  |  | +    })
 | 
	
		
			
				|  |  | +    if (this.detailData.id) {
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'paymentType', '到付')
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'id', this.detailData.id)
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'businesDate', this.detailData.row.businesDate)
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'corpId', this.detailData.row.corpsName)
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'corpTel', '1918766221')
 | 
	
		
			
				|  |  | +      this.$set(this.form, 'arrivalAddress', '山东省青岛市')
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  },
 | 
	
		
			
				|  |  | +  methods: {
 | 
	
		
			
				|  |  | +    cellStyle() {
 | 
	
		
			
				|  |  | +      return "padding:0;height:40px;";
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    openEdit() {},
 | 
	
		
			
				|  |  | +    copyDoc() {
 | 
	
		
			
				|  |  | +      this.$emit("copyOrder", this.form.id);
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    getCorpData(row) {},
 | 
	
		
			
				|  |  | +    //修改提交触发
 | 
	
		
			
				|  |  | +    editCustomer(status) {
 | 
	
		
			
				|  |  | +      this.$message.success('保存成功')
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    //返回列表
 | 
	
		
			
				|  |  | +    backToList() {
 | 
	
		
			
				|  |  | +      this.$emit("goBack");
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    async saveColumn() {
 | 
	
		
			
				|  |  | +      const inSave = await this.saveColumnData(
 | 
	
		
			
				|  |  | +        this.getColumnName(79),
 | 
	
		
			
				|  |  | +        this.tableOption
 | 
	
		
			
				|  |  | +      );
 | 
	
		
			
				|  |  | +      if (inSave) {
 | 
	
		
			
				|  |  | +        this.$message.success("保存成功");
 | 
	
		
			
				|  |  | +        //关闭窗口
 | 
	
		
			
				|  |  | +        this.$refs.crud.$refs.dialogColumn.columnBox = false;
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    async resetColumn() {
 | 
	
		
			
				|  |  | +      this.tableOption = tableOption;
 | 
	
		
			
				|  |  | +      const inSave = await this.delColumnData(
 | 
	
		
			
				|  |  | +        this.getColumnName(79),
 | 
	
		
			
				|  |  | +        tableOption
 | 
	
		
			
				|  |  | +      );
 | 
	
		
			
				|  |  | +      if (inSave) {
 | 
	
		
			
				|  |  | +        this.$message.success("重置成功");
 | 
	
		
			
				|  |  | +        //关闭窗口
 | 
	
		
			
				|  |  | +        setTimeout(() => {
 | 
	
		
			
				|  |  | +          this.$refs.crud.$refs.dialogColumn.columnBox = false;
 | 
	
		
			
				|  |  | +        }, 1000);
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    //商品明细导入
 | 
	
		
			
				|  |  | +    newDetails() {
 | 
	
		
			
				|  |  | +      // if (!this.form.corpId) {
 | 
	
		
			
				|  |  | +      //   return this.$message.error("请选择客户名称");
 | 
	
		
			
				|  |  | +      // }
 | 
	
		
			
				|  |  | +      this.dialogVisible = !this.dialogVisible;
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    importGoods() {
 | 
	
		
			
				|  |  | +      if (this.reData) {
 | 
	
		
			
				|  |  | +        if (this.selectionList.length != 1) {
 | 
	
		
			
				|  |  | +          return this.$message.error("重新选择的时候只能选择一条数据");
 | 
	
		
			
				|  |  | +        } else {
 | 
	
		
			
				|  |  | +          this.selectionList.forEach(e => {
 | 
	
		
			
				|  |  | +            this.dataList.forEach((item, index) => {
 | 
	
		
			
				|  |  | +              if (index == this.reData.index) {
 | 
	
		
			
				|  |  | +                item.itemId = e.id;
 | 
	
		
			
				|  |  | +                item.code = e.code;
 | 
	
		
			
				|  |  | +                item.cname = e.cname;
 | 
	
		
			
				|  |  | +                item.corpId = e.corpId;
 | 
	
		
			
				|  |  | +                item.corpName = e.corpName;
 | 
	
		
			
				|  |  | +                item.brandItem = e.brandItem;
 | 
	
		
			
				|  |  | +                item.specsOne = e.specsOne;
 | 
	
		
			
				|  |  | +                item.specsTwo = e.specsTwo;
 | 
	
		
			
				|  |  | +                item.typeno = e.typeno;
 | 
	
		
			
				|  |  | +                item.priceCategory = e.goodsTypeName;
 | 
	
		
			
				|  |  | +                item.$cellEdit = true;
 | 
	
		
			
				|  |  | +              }
 | 
	
		
			
				|  |  | +            });
 | 
	
		
			
				|  |  | +          });
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +      } else {
 | 
	
		
			
				|  |  | +        this.selectionList.forEach(e => {
 | 
	
		
			
				|  |  | +          this.dataList.push({
 | 
	
		
			
				|  |  | +            itemId: e.id,
 | 
	
		
			
				|  |  | +            code: e.code,
 | 
	
		
			
				|  |  | +            cname: e.cname,
 | 
	
		
			
				|  |  | +            brandItem: e.brandItem,
 | 
	
		
			
				|  |  | +            specsOne: e.specsOne,
 | 
	
		
			
				|  |  | +            specsTwo: e.specsTwo,
 | 
	
		
			
				|  |  | +            typeno: e.typeno,
 | 
	
		
			
				|  |  | +            corpId: e.corpId,
 | 
	
		
			
				|  |  | +            corpName: e.corpName,
 | 
	
		
			
				|  |  | +            price: 0,
 | 
	
		
			
				|  |  | +            amount: 0,
 | 
	
		
			
				|  |  | +            $cellEdit: true
 | 
	
		
			
				|  |  | +          });
 | 
	
		
			
				|  |  | +        });
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +      this.dialogVisible = false;
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    closeGoods() {
 | 
	
		
			
				|  |  | +      this.selectionList = [];
 | 
	
		
			
				|  |  | +      this.treeDeptId = "";
 | 
	
		
			
				|  |  | +      this.reData = null;
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    nodeClick(data) {
 | 
	
		
			
				|  |  | +      this.treeDeptId = data.id;
 | 
	
		
			
				|  |  | +      this.page.currentPage = 1;
 | 
	
		
			
				|  |  | +      this.onLoad(this.page);
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    //费用查询
 | 
	
		
			
				|  |  | +    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;
 | 
	
		
			
				|  |  | +          if (this.page.total) {
 | 
	
		
			
				|  |  | +            this.goodsOption.height = window.innerHeight - 350;
 | 
	
		
			
				|  |  | +          }
 | 
	
		
			
				|  |  | +        })
 | 
	
		
			
				|  |  | +        .finally(() => {
 | 
	
		
			
				|  |  | +          this.loading = false;
 | 
	
		
			
				|  |  | +        });
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    searchChange(params, done) {
 | 
	
		
			
				|  |  | +      this.search = this.deepClone(params);
 | 
	
		
			
				|  |  | +      this.onLoad(this.page, params);
 | 
	
		
			
				|  |  | +      done();
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    selectionChange(list) {
 | 
	
		
			
				|  |  | +      this.selectionList = list;
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    rowClick(row) {
 | 
	
		
			
				|  |  | +      this.$refs.goodsCrud.toggleSelection([this.goodsList[row.$index]]);
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    async saveGoodsColumn() {
 | 
	
		
			
				|  |  | +      const inSave = await this.saveColumnData(
 | 
	
		
			
				|  |  | +        this.getColumnName(80),
 | 
	
		
			
				|  |  | +        this.goodsOption
 | 
	
		
			
				|  |  | +      );
 | 
	
		
			
				|  |  | +      if (inSave) {
 | 
	
		
			
				|  |  | +        this.$message.success("保存成功");
 | 
	
		
			
				|  |  | +        //关闭窗口
 | 
	
		
			
				|  |  | +        this.$refs.goodsCrud.$refs.dialogColumn.columnBox = false;
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    async resetGoodsColumn() {
 | 
	
		
			
				|  |  | +      this.goodsOption = goodsOption;
 | 
	
		
			
				|  |  | +      const inSave = await this.delColumnData(
 | 
	
		
			
				|  |  | +        this.getColumnName(80),
 | 
	
		
			
				|  |  | +        goodsOption
 | 
	
		
			
				|  |  | +      );
 | 
	
		
			
				|  |  | +      if (inSave) {
 | 
	
		
			
				|  |  | +        this.$message.success("重置成功");
 | 
	
		
			
				|  |  | +        //关闭窗口
 | 
	
		
			
				|  |  | +        setTimeout(() => {
 | 
	
		
			
				|  |  | +          this.$refs.goodsCrud.$refs.dialogColumn.columnBox = false;
 | 
	
		
			
				|  |  | +        }, 1000);
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    openReport() {},
 | 
	
		
			
				|  |  | +    rowCell(row, index) {
 | 
	
		
			
				|  |  | +      if (row.$cellEdit == true) {
 | 
	
		
			
				|  |  | +        this.$set(row, "$cellEdit", false);
 | 
	
		
			
				|  |  | +      } else {
 | 
	
		
			
				|  |  | +        this.$set(row, "$cellEdit", true);
 | 
	
		
			
				|  |  | +      }
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    rowDel(row, index) {
 | 
	
		
			
				|  |  | +      this.$confirm("确定删除数据?", {
 | 
	
		
			
				|  |  | +        confirmButtonText: "确定",
 | 
	
		
			
				|  |  | +        cancelButtonText: "取消",
 | 
	
		
			
				|  |  | +        type: "warning"
 | 
	
		
			
				|  |  | +      }).then(() => {
 | 
	
		
			
				|  |  | +        if (row.id) {
 | 
	
		
			
				|  |  | +        } else {
 | 
	
		
			
				|  |  | +          this.$message({
 | 
	
		
			
				|  |  | +            type: "success",
 | 
	
		
			
				|  |  | +            message: "删除成功!"
 | 
	
		
			
				|  |  | +          });
 | 
	
		
			
				|  |  | +          this.data.splice(row.$index, 1);
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +      });
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    cnameChange(row) {
 | 
	
		
			
				|  |  | +      this.goodsoptions.forEach(e => {
 | 
	
		
			
				|  |  | +        if (e.id == row.itemId) {
 | 
	
		
			
				|  |  | +          row.cname = e.cname;
 | 
	
		
			
				|  |  | +          row.code = e.code;
 | 
	
		
			
				|  |  | +          row.corpId = e.corpId;
 | 
	
		
			
				|  |  | +          row.corpName = e.corpName;
 | 
	
		
			
				|  |  | +          row.brandItem = e.brandItem;
 | 
	
		
			
				|  |  | +          row.specsOne = e.specsOne;
 | 
	
		
			
				|  |  | +          row.specsTwo = e.specsTwo;
 | 
	
		
			
				|  |  | +          row.typeno = e.typeno;
 | 
	
		
			
				|  |  | +          row.priceCategory = e.goodsTypeName;
 | 
	
		
			
				|  |  | +          row.purchaseAmount = 0;
 | 
	
		
			
				|  |  | +          row.amount = 0;
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +      });
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    rePick(row, index) {
 | 
	
		
			
				|  |  | +      this.reData = {
 | 
	
		
			
				|  |  | +        ...row,
 | 
	
		
			
				|  |  | +        index: index
 | 
	
		
			
				|  |  | +      };
 | 
	
		
			
				|  |  | +      this.newDetails();
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +  },
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +</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>
 |