1 |
- {"remainingRequest":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\thread-loader\\dist\\cjs.js!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\views\\goods\\sale\\AddGoodsOneStore.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\views\\goods\\sale\\AddGoodsOneStore.vue","mtime":1655374732000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\babel.config.js","mtime":1655374732000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js","mtime":1655715099000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import CustomerPrice from "../components/CustomerPrice";
import LadderPrice from "../components/LadderPrice";
import CustomerTypePrice from "../components/CustomerTypePrice"; // import GoodsCategory from "@/component/common/GoodsCategory.vue";

import BrandSelModel from "@/component/goods/BrandSelModel.vue";
import Tinymce from "@/component/Tinymce";
import UploadQiniu from "@/component/common/UploadQiniu.vue"; // 新增分类

import AddCate from "@/component/goods/AddCate.vue";
import AddBrand from "../manageG/AddBrand";
import { getAllExpressRule, getAllCustomerSource } from "@/api/System";
import { getAllUnit, defineSpec, SpecManagegetAll, getQuickGoodsInfo, editQuickGoods, addBasicAndPublishGoods, getAllCategoryPost } from "@/api/goods";
import { addPauseSave, delPauseSave, getPauseSave } from "@/api/common";
const priceDataLi = {
  enabledLadder: 0,
  marketPrice: "",
  memberPrice: "",
  salePrice: "",
  setNum: 1,
  isSale: 5,
  salePriceAreaType: 1,
  // 客户类型和客户快速调价
  customerTypePrice: [],
  customerTypePriceOpen: false,
  customerPrice: [],
  customerPriceOpen: false,
  ladderPrice: [
    /* {
      from: 1,
      price: 0.01,
      to: 2
    }, {
      from: 3,
      price: 0.01,
      to: 4
    },
    {
      from: 5,
      price: 0.01,
      to: 999999999
    } */
  ]
};
import ClientListModal from "@/component/common/ClientListModal";
import RegionTree from "@/component/common/RegionTree";
import { mapGetters } from "vuex";
import { CustomerPriceAdjustmentAdd, addCustomerTypePriceAdjustment, getCustomerPriceByGoodsIds, getCustomerTypePriceByGoodsIds } from "@/api/Price";
import { getAllMerchantList } from "@/api/Merchants";
export default {
  name: "AddBaseData",
  components: {
    // GoodsCategory,
    BrandSelModel,
    Tinymce,
    UploadQiniu,
    AddCate,
    AddBrand,
    RegionTree,
    ClientListModal,
    CustomerPrice,
    CustomerTypePrice,
    LadderPrice
  },

  data() {
    const validateUnit = (rule, value, callback) => {
      if (value.unitName === "") {
        callback(new Error("请设置基本单位"));
      } else {
        callback();
      }
    };

    return {
      unitisMaster: "",
      unit_index: 0,
      sku_index: 0,
      ladderPrice: [],
      enabledLadder: 0,
      ladder_price_show: false,
      // 阶梯价弹窗
      type_price_show: false,
      // 客户类型价弹窗
      customerTypePriceOpen: false,
      // 客户类型价弹窗开关
      customerTypePrice: [],
      // 客户类型价弹窗数据
      customerPriceOpen: false,
      customerPrice: [],
      appoint_price_show: false,
      // 客户指定价弹窗
      customer_show: false,
      // 经营屏蔽->客户列表弹窗选择
      customer_list: [],
      // 经营屏蔽->客户列表
      customer_type_check: [],
      // 经营屏蔽->客户类型选择数组
      customer_type_list: [],
      // 经营屏蔽->客户类型列表
      region_arr: [],
      // 经营屏蔽->当前商品已选择过的区域
      page_tabs: "1",
      // 页面tab切换
      express_list: [],
      // 运费模版列表
      isEditSpec: 5,
      // 5 表示此商品从未采购过，允许用户随意编辑单位和属性；4 表示商品已经采购过，隐藏添加属性按钮，避免skuid重组
      // 计量单位
      self_spec_val: "",
      // 自定义属性值输入框
      spec_name_index: 0,
      // 属性名index
      self_spec_input: false,
      // 显示自定义属性值输入框
      spec_model: false,
      // 选择属性值弹窗
      spec_item_check: [],
      // 属性值弹窗单选value
      is_indeterminate_spec: false,
      // 批量选择属性值 全选选择框状态
      spec_check_all: false,
      // 属性值 全选选择框value
      spec_data: [],
      // 属性列表
      spec_data_child: [],
      // 属性值列表
      spec_table_Data: [],
      // 规格明细
      sku_list: [// 商品属性列表
      {
        spec_data_child: [],
        groupSpecId: "",
        self_spec_val: "",
        self_spec_input: false,
        groupSpecName: "",
        params: []
      }],
      add_model: false,
      // 新建分类
      dialogTitle: "新建分类",
      pid_arr: [],
      add_Brand: false,
      // 新增品牌
      pageName: "",
      // 暂存数据参数
      loading: false,
      img_list: [],
      // 关键词
      dynamicTags: [],
      inputVisible: false,
      inputValue: "",
      // 关键词 END
      assist_model: false,
      edit_assist_model: false,
      assist_index: 0,
      unit_options: [],
      // 计量单位弹窗
      assist_form: {
        unitName: "",
        barCode: "",
        isMaster: 4,
        isDefault: 4,
        isEditSpec: 5,
        unitId: "",
        conversion: ""
      },
      sel_brand: false,
      // 打开品牌选择弹窗
      sel_shop: false,
      // 打开店铺选择弹窗
      master_unit_name: "",
      base_form: {
        //  基本信息
        enableStatus: 5,
        // 是否上架
        isDistribution: 4,
        //负库存销售
        isShield: 4,
        // 经营屏蔽 4关闭 5开启
        isEq: 4,
        // 抄码商品
        specType: 1,
        // 是否多规格
        delUnitIds: [],
        // 辅助单位删除delUnitIds (unitId)
        delSpecSkuIds: [],
        // 属性删除delSpecSkuIds（这个用id）
        branchUnit: [],
        brandName: "",
        categoryId: "",
        assistCategoryId: "",
        categoryPath: [],
        // 分类选择
        assistCategoryPath: [],
        // 分类选择
        unitData: [],
        masterUnit: {
          barCode: "",
          weight: "",
          isMaster: 5,
          isDefault: 5,
          unitName: "",
          unitId: ""
        },
        describe: "",
        title: "",
        storage: "",
        code: "",
        barCode: "",
        // 商品条码
        weight: "",
        // 商品重量
        expireTime: "",
        brandId: "",
        tag: "",
        description: "",
        salesShop: "",
        images: [],
        deliverySupIds: ["1", "2"],
        // 物流支持 固定值 1 快递 2 自提 传参格式：1,2
        expressType: 1,
        // 快递运费 1 包邮 2 运费模版 3 固定费用
        expressFee: "",
        // 固定费用
        showExpress: 5,
        // 是否展示快递 5展示 4不展示
        ruleId: "",
        // 运费模版id
        notArea: [],
        //经营屏蔽地区
        notCustomerType: "",
        //经营屏蔽 客户类型屏蔽
        notCustomer: "",
        //经营屏蔽 客户屏蔽
        merchantId: "" //商户ID

      },
      sel_cities: [],
      // 商户列表
      base_rules: {
        // 基本信息验证
        images: [{
          type: "array",
          required: true,
          message: "请上传商品图片",
          trigger: "change"
        }],
        title: [{
          required: true,
          message: "请输入商品名称",
          trigger: "blur"
        }],
        categoryId: [{
          required: true,
          message: "请选择商品分类",
          trigger: "change"
        }],
        expireTime: [{
          required: true,
          message: "请输入商品保质期",
          trigger: "blur"
        }],
        // brandId: [{ required: true, message: '请选择商品品牌', trigger: 'change' }],
        // describe: [{ required: true, message: '请输入商品描述', trigger: 'blur' }],
        masterUnit: [{
          validator: validateUnit,
          trigger: "change"
        }],
        deliverySupIds: [{
          required: true,
          type: "array",
          message: "请选择物流支持",
          trigger: "change"
        }],
        ruleId: [{
          required: true,
          message: "请选择运费模板",
          trigger: "change"
        }],
        expressFee: [{
          required: true,
          message: "请输入运费",
          trigger: "blur"
        }] // branchUnit: [{ required: true, type: 'array', message: '请设置辅助单位', trigger: 'change' }]
        // tag: [{ required: true, message: '请设置商品关键词', trigger: 'change' }]

      },
      goods_id: 0,
      list_page_data: "1_10",
      unit_data: [],
      // 单位明细
      tabs_active: "",
      // 多属性单位切换
      isNew: 5,
      // 5 标示这是一个最近新增的商品，基本单位为最小单位，4标示这是之前的老数据，基本单位为最大单位
      category_data: [],
      //商品分类列表
      cate_props: {
        label: "title",
        value: "id",
        checkStrictly: true
      },
      assist_cate: [{
        assistCategoryPath: []
      }],
      sku_id: ""
    };
  },

  computed: { ...mapGetters({
      salePriceTimes: "MUser/salePriceTimes",
      systemType: "MUser/systemType" // 当前后台

    })
  },

  async created() {
    // 商户管理
    await this.getAllMerchantList(); // 商品分类列表

    await this.getAllCategoryPost();
    this.pageName = this.$route.name; // 属性管理

    await this.SpecManagegetAll();
    await this.getAllUnit(); // 客户类型

    await this.getAllCustomerSource();

    if (this.$route.params.id) {
      this.goods_id = this.$route.params.id;
      this.list_page_data = this.$route.params.page;
      await this.getGoodsBasicInfoById();
    } else {
      // 获取暂存信息
      await this.getPauseSave();
    }

    await this.getAllExpressRule();
  },

  methods: {
    // 获取运费模版
    async getAllExpressRule() {
      const {
        data
      } = await getAllExpressRule();
      this.express_list = data;
    },

    isDefaultChange(val, index, sIndex) {
      if (val === 5) {
        const target = this.$_common.deepClone(this.unit_data);

        if (this.base_form.specType === 2) {
          target.forEach((item, indexU) => {
            item.spec_table_Data.forEach((itemB, indexB) => {
              if (indexU !== sIndex) {
                itemB.isDefault = 4;
              } else {
                if (indexB !== index) {
                  itemB.isDefault = 4;
                }
              }
            });
          });
        } else {
          target.forEach((item, indexU) => {
            if (indexU !== index) {
              item.isDefault = 4;
            }
          });
        }

        this.unit_data = target;
      }
    },

    // 请求基本单位数据
    async getAllUnit() {
      const {
        data
      } = await getAllUnit({
        page: 1,
        pageSize: 99
      });
      this.unit_options = data;
    },

    modelClose() {
      this.add_model = false;
    },

    // 打开新增弹窗
    openModel(title, row) {
      this.add_model = true;
      this.dialogTitle = title;

      if (title === "新建子分类") {
        let link = row.link ? row.link.split(",").map(item => {
          return parseInt(item);
        }) : [];
        link.push(row.id);
        this.pid_arr = link;
      }
    },

    // 新增/编辑分类
    async subCategory() {
      this.getAllCategoryPost();
      this.$message("新建分类成功");
    },

    // 新建品牌
    submitBrand() {
      this.add_Brand = false;
    },

    // 添加暂存
    async AddTem() {
      const params = { ...this.base_form,
        specGroup: this.sku_list,
        specMultiple: this.spec_table_Data,
        tag: this.dynamicTags,
        assist_cate: this.assist_cate
      };
      this.loading = true;
      const data = await addPauseSave({
        key: this.pageName,
        data: params
      });
      this.loading = false;
      this.$message({
        type: "success",
        message: "暂存成功"
      });

      if (this.systemType === 3) {
        this.$closeCurrentGoEdit(`/goods/sale/MerchantsGoods`);
      } else {
        this.$closeCurrentGoEdit(`/goods/sale/PublishGoods`);
      }
    },

    // 删除暂存信息
    async delPauseSave() {
      const data = delPauseSave({
        key: this.pageName
      });
    },

    // 获取暂存信息
    async getPauseSave() {
      const {
        data
      } = await getPauseSave({
        key: this.pageName
      });
      if (JSON.stringify(data) === "{}") return;
      this.base_form = { ...data,
        categoryPath: Array.isArray(data.categoryPath) ? data.categoryPath : [],
        assistCategoryPath: Array.isArray(data.assistCategoryPath) ? data.assistCategoryPath : []
      };
      this.assist_cate = data.assist_cate || [{
        assistCategoryPath: []
      }];
      this.sku_list = data.specGroup || [];
      this.spec_table_Data = data.specMultiple || [];
      this.dynamicTags = data.tag || [];

      if (data.images) {
        this.img_list = data.images.map(item => {
          return {
            name: "",
            url: item
          };
        });
      }
    },

    // 规格图片
    uploadSpecSuccess(val, index, indexU) {
      let target = this.$_common.deepClone(this.unit_data);

      if (this.base_form.specType === 1) {
        target[index].specImage = {
          name: "",
          url: val
        };
      } else {
        target[indexU].spec_table_Data[index].specImage = {
          name: "",
          url: val
        };
      }

      this.unit_data = target;
    },

    // 添加规格项目
    addSkuP() {
      if (!this.goods_id) {
        this.sku_list.push({
          spec_data_child: [],
          self_spec_input: false,
          self_spec_val: "",
          groupSpecId: "",
          groupSpecName: "",
          params: []
        });
      } else {
        this.$confirm("新增规格会导致原有库存重置,请谨慎操作! 是否继续?", "提示", {
          confirmButtonText: "继续新增",
          cancelButtonText: "取消",
          type: "warning"
        }).then(() => {
          this.sku_list.push({
            spec_data_child: [],
            self_spec_input: false,
            self_spec_val: "",
            groupSpecId: "",
            groupSpecName: "",
            params: []
          });
        });
      }
    },

    // 规格明切换
    groupSpecIdChange(val, indexS) {
      let target = this.$_common.deepClone(this.sku_list);
      const specDataItem = this.spec_data.find(item => item.id === val);
      target[indexS].groupSpecName = specDataItem.specName;
      target[indexS].spec_data_child = specDataItem.child || [];
      target[indexS].params = [];
      this.sku_list = target; // 重排规格组合
      // this.specGroupRest()
      // console.log(this.sku_list)
      // console.log(this.spec_table_Data)
    },

    // 重排规格组合
    specGroupRest() {
      // 编辑页面存储详情接口返回规格组合id
      // this.spec_table_Data.forEach(item => {
      //   if (item.specGroupHash && this.base_form.delSpecSkuIds.indexOf(item.specGroupHash) === -1) {
      //     this.base_form.delSpecSkuIds.push(item.specGroupHash)
      //   }
      // })
      const skuArr = this.sku_list.map(item => {
        item.params = item.params.map(itemP => {
          return { ...itemP,
            groupSpecName: item.groupSpecName
          };
        });
        return item.params;
      });
      let skuArrDo = [];

      if (skuArr.length) {
        skuArrDo = this.doExchange(skuArr);
      } // 备份一份规格明细，用来填充重排规格组之前的图片


      const cloneUnitData = this.$_common.deepClone(this.unit_data);
      this.unit_data = this.unit_data.map((item, index) => {
        const cloneSpecGroup = cloneUnitData[index].spec_table_Data || [];
        return { ...item,
          spec_table_Data: skuArrDo.map(itemSp => {
            const indexSS = cloneSpecGroup.findIndex(itemC => itemC.id === itemSp.id);
            return { ...itemSp,
              barCode: indexSS > -1 ? cloneSpecGroup[indexSS].barCode : itemSp.barCode,
              weight: indexSS > -1 ? cloneSpecGroup[indexSS].weight : itemSp.weight,
              isDefault: indexSS > -1 ? cloneSpecGroup[indexSS].isDefault : itemSp.isDefault,
              specImage: indexSS > -1 ? cloneSpecGroup[indexSS].specImage : itemSp.specImage,
              inventory: indexSS > -1 ? cloneSpecGroup[indexSS].inventory : itemSp.inventory || 0,
              isEditSpec: indexSS > -1 ? cloneSpecGroup[indexSS].isEditSpec : itemSp.isEditSpec || 5,
              salePrice: indexSS > -1 ? cloneSpecGroup[indexSS].salePrice : itemSp.salePrice,
              enabledLadder: indexSS > -1 ? cloneSpecGroup[indexSS].enabledLadder : itemSp.enabledLadder,
              ladderPrice: indexSS > -1 ? cloneSpecGroup[indexSS].ladderPrice : itemSp.ladderPrice,
              marketPrice: indexSS > -1 ? cloneSpecGroup[indexSS].marketPrice : itemSp.marketPrice,
              memberPrice: indexSS > -1 ? cloneSpecGroup[indexSS].memberPrice : itemSp.memberPrice,
              setNum: indexSS > -1 ? cloneSpecGroup[indexSS].setNum : itemSp.setNum || 1,
              isSale: indexSS > -1 ? cloneSpecGroup[indexSS].isSale : itemSp.isSale || 5,
              customerTypePrice: indexSS > -1 ? cloneSpecGroup[indexSS].customerTypePrice : itemSp.customerTypePrice || [],
              customerTypePriceOpen: indexSS > -1 ? cloneSpecGroup[indexSS].customerTypePriceOpen : itemSp.customerTypePriceOpen || false,
              customerPrice: indexSS > -1 ? cloneSpecGroup[indexSS].customerPrice : itemSp.customerPrice || [],
              customerPriceOpen: indexSS > -1 ? cloneSpecGroup[indexSS].customerPriceOpen : itemSp.customerPriceOpen || false
            };
          })
        };
      }); // 判断是否是多属性

      this.base_form.specType = this.unit_data.some(item => item.spec_table_Data && item.spec_table_Data.length > 0) ? 2 : 1;

      if (this.base_form.specType === 2 && !this.tabs_active) {
        this.tabs_active = this.unit_data[0].unitName;
      }
    },

    // 规格组合
    doExchange(doubleArrays) {
      const len = doubleArrays.length;

      if (len >= 2) {
        const len1 = doubleArrays[0].length;
        const len2 = doubleArrays[1].length;
        const newlen = len1 * len2;
        const temp = new Array(newlen);
        let index = 0;

        for (let i = 0; i < len1; i++) {
          for (let j = 0; j < len2; j++) {
            temp[index] = {
              groupSpecId: doubleArrays[0][i].groupSpecId + "_" + doubleArrays[1][j].groupSpecId,
              groupSpecName: doubleArrays[0][i].groupSpecName + "_" + doubleArrays[1][j].groupSpecName,
              id: doubleArrays[0][i].id + "_" + doubleArrays[1][j].id,
              specName: doubleArrays[0][i].specName + "_" + doubleArrays[1][j].specName,
              specImage: {
                name: "",
                url: ""
              },
              setNum: 1,
              isSale: 5,
              salePrice: 0.01,
              enabledLadder: 0,
              ladderPrice: [],
              marketPrice: 0.01,
              memberPrice: "",
              barCode: "",
              weight: "",
              isDefault: 4,
              // 客户类型和客户快速调价
              customerTypePrice: [],
              customerTypePriceOpen: false,
              customerPrice: [],
              customerPriceOpen: false
            };
            index++;
          }
        }

        let newArray = new Array(len - 1);
        newArray[0] = temp;

        if (len > 2) {
          let _count = 1;

          for (let i = 2; i < len; i++) {
            newArray[_count] = doubleArrays[i];
            _count++;
          }
        }

        return this.doExchange(newArray);
      } else {
        return doubleArrays[0].map(item => {
          return { ...item,
            specImage: {
              name: "",
              url: ""
            },
            setNum: 1,
            isSale: 5,
            barCode: "",
            weight: "",
            isDefault: 4,
            salePrice: 0.01,
            enabledLadder: 0,
            ladderPrice: [],
            marketPrice: 0.01,
            memberPrice: "",
            // 客户类型和客户快速调价
            customerTypePrice: [],
            customerTypePriceOpen: false,
            customerPrice: [],
            customerPriceOpen: false
          };
        });
      }
    },

    // 自定义属性值输入框确定  添加自定义属性
    async selfSpecConfirm(index) {
      const target = this.$_common.deepClone(this.sku_list);

      if (!target[index].self_spec_val) {
        target[index].self_spec_input = false;
        this.sku_list = target;
        return;
      }

      const {
        data
      } = await defineSpec({
        specName: target[index].self_spec_val,
        pid: target[index].groupSpecId,
        hidden: 4
      });
      target[index].self_spec_input = false;
      target[index].params.push({
        specName: data.specName,
        id: data.id,
        groupSpecId: target[index].groupSpecId
      });
      target[index].self_spec_val = "";
      this.sku_list = target; // 重排规格组合

      this.specGroupRest();
    },

    // 新增规格值
    addSpecVal(indexS) {
      this.spec_model = true;
      this.spec_data_child = this.sku_list[indexS].spec_data_child;
      this.spec_name_index = indexS;
      this.spec_item_check = this.sku_list[indexS].params.map(item => item.id); // 使用属性值单选方法，为了设置全选选择框状态

      this.specItemChange(this.spec_item_check);
    },

    // 选择属性值
    selSpecVal() {
      const target = this.$_common.deepClone(this.sku_list);
      const specval = this.spec_data_child.filter(item => {
        return this.spec_item_check.findIndex(itemS => itemS === item.id) > -1;
      }).map(item => {
        return {
          specName: item.specName,
          id: item.id,
          groupSpecId: item.pid
        };
      });
      target[this.spec_name_index].params = this.$_common.unique(target[this.spec_name_index].params.concat(specval), ["id"]);
      this.sku_list = target;
      this.spec_model = false; // 重排规格组合

      this.specGroupRest();
    },

    // 属性值全选
    checkAllSpecChange(val) {
      this.is_indeterminate_spec = false;

      if (val) {
        this.spec_item_check = this.spec_data_child.map(item => {
          return item.id;
        });
      } else {
        this.spec_item_check = [];
      }
    },

    // 属性值单选
    specItemChange(val) {
      let checkedCount = val.length;
      this.spec_check_all = checkedCount === this.spec_data_child.length;
      this.is_indeterminate_spec = checkedCount > 0 && checkedCount < this.spec_data_child.length;
    },

    // 删除规格值
    delSpecVal(indexC, indexS, itemC) {
      this.$confirm("确定要删除该规格值吗?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        // 编辑页面规格明细操作
        if (this.goods_id) {
          this.base_form.delSpecSkuIds = this.spec_table_Data.filter(item => item.specName.indexOf(itemC.specName) > -1).map(itemM => {
            return itemM.specGroupHash;
          });
        } // 新增页面规格明细操作


        this.unit_data = this.unit_data.map(itemU => {
          return { ...itemU,
            spec_table_Data: itemU.spec_table_Data.filter(item => item.specName.indexOf(itemC.specName) === -1)
          };
        });
        const target = this.$_common.deepClone(this.sku_list);
        target[indexS].params.splice(indexC, 1);
        this.sku_list = target;
      });
    },

    // 删除规格组
    delGroupSpecId(indexS) {
      this.$confirm("确定要删除该规格组吗?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        this.sku_list.splice(indexS, 1);

        if (this.goods_id) {
          this.base_form.delSpecSkuIds = this.base_form.specMultiple.map(item => {
            return item.specGroupHash;
          });
        } // 重排规格组合


        this.specGroupRest();
      });
    },

    // 获取属性列表
    async SpecManagegetAll() {
      const {
        data,
        pageTotal
      } = await SpecManagegetAll({
        page: 1,
        pageSize: 50
      });
      this.spec_data = data.filter(item => item.specName !== "计量单位"); // this.unit_options = data.find(item => item.specName === '计量单位').child
    },

    // 选择图片
    uploadSuccess(val, res, file, fileList) {
      const imgArr = fileList.map(item => {
        return item.content;
      });

      if (this.base_form.images.length) {
        this.base_form.images = this.base_form.images.concat(imgArr);
      } else {
        this.base_form.images = imgArr;
      }

      this.img_list = this.base_form.images.map(item => {
        return {
          name: "",
          content: item
        };
      });
    },

    imgSortChange(fileList) {
      this.base_form.images = fileList.map(item => {
        return item.content;
      });
    },

    uploadRemove(file, fileList) {
      this.base_form.images = fileList.map(item => {
        return item.content;
      });
    },

    // 关键词删除
    handleClose(tag) {
      this.dynamicTags.splice(this.dynamicTags.indexOf(tag), 1);
    },

    // 关键词显示输入框
    showInput() {
      this.inputVisible = true;
      this.$nextTick(_ => {
        this.$refs.saveTagInput.$refs.input.focus();
      });
    },

    // 关键词显示输入确定
    handleInputConfirm() {
      let inputValue = this.inputValue;

      if (inputValue) {
        this.dynamicTags.push(inputValue);
      }

      this.inputVisible = false;
      this.inputValue = "";
    },

    // 关键词END
    // 设置计量单位
    // 删除辅助单位
    delFuUnit(row, it) {
      this.base_form.branchUnit.splice(it, 1);

      if (this.goods_id) {
        if (row.unitId && this.base_form.delUnitIds.indexOf(row.unitId) === -1) {
          this.base_form.delUnitIds.push(row.unitId);
        }

        const spec = this.unit_data.find(item => item.unitName === row.unitName);

        if (spec && spec.specGroupHash) {
          if (this.base_form.delSpecSkuIds.indexOf(spec.specGroupHash) === -1) {
            this.base_form.delSpecSkuIds.push(spec.specGroupHash);
          }
        }
      }

      this.unit_data.splice(it + 1, 1);
    },

    // 新增辅助单位
    addFuUnit() {
      this.assist_model = true;
      this.edit_assist_model = false;
      this.assist_form = {
        unitName: "",
        isMaster: 4,
        unitId: "",
        conversion: ""
      };
    },

    // 修改附单位
    EditFuUnit(it) {
      this.assist_model = true;
      this.edit_assist_model = true;
      this.assist_form = this.base_form.branchUnit[it];
      this.assist_index = it;
    },

    // 弹窗提交 辅助单位
    subAssist() {
      if (!this.assist_form.conversion) {
        this.$message.warning("请输入单位换算关系");
        return;
      }

      if (!this.assist_form.unitName) {
        this.$message.warning("请选择辅助单位");
        return;
      }

      this.base_form.branchUnit.push({ ...this.assist_form,
        isEditSpec: 5
      });

      if (this.base_form.specType === 2) {
        const specTableData = this.unit_data[0] ? this.$_common.deepClone(this.unit_data[0].spec_table_Data || []) : [];
        this.unit_data.push({ ...this.$_common.deepClone(this.assist_form),
          ...this.$_common.deepClone(priceDataLi),
          isMaster: 4,
          isEditSpec: 5,
          specImage: {
            name: "",
            url: ""
          },
          spec_table_Data: specTableData
        });
      } else {
        this.unit_data.push({ ...this.$_common.deepClone(this.assist_form),
          ...this.$_common.deepClone(priceDataLi),
          isMaster: 4,
          isEditSpec: 5,
          specImage: {
            name: "",
            url: ""
          }
        });
      } // 重排规格组合


      this.specGroupRest();
      this.assist_model = false;
    },

    // 基本单位切换
    masterUnitChange(val) {
      this.base_form.masterUnit.unitName = this.unit_options.find(item => item.id === val).unitName;
      const index = this.unit_data.findIndex(item => item.isMaster === 5);

      if (index === -1) {
        this.unit_data.unshift({ ...this.base_form.masterUnit,
          ...this.$_common.deepClone(priceDataLi),
          isMaster: 5,
          specImage: {
            name: "",
            url: ""
          }
        });
      } else {
        this.$set(this.unit_data, index, { ...this.unit_data[index],
          ...this.base_form.masterUnit
        });
      } // 重排规格组合


      this.specGroupRest();

      if (this.base_form.specType === 2) {
        this.tabs_active = this.unit_data[0].unitName;
      }
    },

    // 辅助单位切换
    branchUnitChange(val) {
      this.assist_form.unitName = this.unit_options.find(item => item.id === val).unitName;
    },

    // 获取详情
    async getGoodsBasicInfoById() {
      const {
        data
      } = await getQuickGoodsInfo(this.goods_id);
      this.region_arr = data.notArea;
      this.customer_type_check = data.notCustomerType ? data.notCustomerType.split(",").map(item => parseInt(item)) : [];
      this.customer_list = data.notCustomerLists || [];
      this.isEditSpec = data.isEditSpec; // return

      let masterUnit = data.unitData.find(item => item.isMaster === 5) || {
        barCode: "",
        weight: "",
        isMaster: 5,
        isDefault: 5,
        unitName: "",
        unitId: ""
      };
      this.isNew = masterUnit ? masterUnit.isNew || 4 : 4;
      let branchUnit = [];

      if (data.specType === 2) {
        const unitData = data.unitData.filter(item => item.isMaster === 4);
        branchUnit = (unitData || []).map(item => {
          return { ...item,
            isEditSpec: data.isEditSpec
          };
        });
      } else if (data.specType === 1) {
        const unitData = data.specMultiple.filter(item => item.isMaster === 4);
        branchUnit = (unitData || []).map(item => {
          return {
            conversion: item.conversion,
            id: item.id,
            isMaster: item.isMaster,
            unitId: item.unitId,
            unitName: item.unitName,
            isEditSpec: item.isEditSpec
          };
        });
      }

      this.base_form = { ...data,
        masterUnit: masterUnit,
        storage: data.storage,
        delUnitIds: [],
        delSpecSkuIds: [],
        specType: data.specType,
        branchUnit: branchUnit,
        categoryPath: data.categoryPath ? data.categoryPath.split(",").map(item => {
          return parseInt(item);
        }) : [],
        categoryId: data.categoryId,
        assistCategoryId: data.assistCategoryId,
        assistCategoryPath: data.assistCategoryPath || [],
        isEq: data.isEq,
        // 抄码商品
        isDistribution: data.isDistribution,
        // 负库存销售
        isShield: data.isShield,
        // 经营屏蔽
        deliverySupIds: data.deliverySupIds.split(","),
        // 物流支持 固定值 1 快递 2 自提 传参格式：1,2
        expressType: data.expressType,
        // 快递运费 1 包邮 2 运费模版 3 固定费用
        expressFee: data.expressFee,
        // 固定费用
        showExpress: data.showExpress,
        // 是否展示快递 5展示 4不展示
        ruleId: data.ruleId // 运费模版id

      }; // 副分类

      if (data.assistCategoryPath && data.assistCategoryPath.length) {
        this.assist_cate = data.assistCategoryPath.map(item => {
          return {
            assistCategoryPath: item.split(",").map(iteme => {
              return parseInt(iteme);
            })
          };
        });
      } else {
        this.assist_cate = [{
          assistCategoryPath: []
        }];
      }

      this.img_list = data.images.map(item => {
        return {
          name: "",
          url: item
        };
      });
      this.dynamicTags = data.tag.filter(item => !!item); // 多规格数据

      if (parseInt(this.base_form.specType) === 2) {
        this.sku_list = data.specGroup.map(item => {
          return {
            spec_data_child: this.spec_data.find(itemF => itemF.id === item.groupSpec.specId).child,
            groupSpecId: item.groupSpec.specId,
            groupSpecName: item.groupSpec.specName,
            self_spec_val: "",
            self_spec_input: false,
            params: item.params.map(itemC => {
              return {
                id: itemC.specValueId,
                specName: itemC.specValueName,
                groupSpecId: item.groupSpec.specId
              };
            })
          };
        });
        this.unit_data = data.unitData.map(item => {
          const specTableData = data.specMultiple.filter(itemU => itemU.unitId === item.unitId).map(itemSP => {
            return {
              isEditSpec: itemSP.isEditSpec,
              inventory: itemSP.inventory - 0,
              specGroupHash: itemSP.specGroupHash,
              id_D: itemSP.id,
              conversion: itemSP.conversion,
              unitId: itemSP.unitId,
              specName: (itemSP.specGroup || []).map(itemP => {
                return itemP.specValueName;
              }).join("_"),
              id: (itemSP.specGroup || []).map(itemP => {
                return itemP.specValueId;
              }).join("_"),
              groupSpecId: (itemSP.specGroup || []).map(itemP => {
                return itemP.specId;
              }).join("_"),
              groupSpecName: (itemSP.specGroup || []).map(itemP => {
                return itemP.specName;
              }).join("_"),
              specImage: {
                name: "",
                url: itemSP.specImage || ""
              },
              barCode: itemSP.barCode,
              weight: itemSP.weight,
              isDefault: itemSP.isDefault,
              salePrice: itemSP.salePrice.salePrice,
              enabledLadder: itemSP.salePrice.enabledLadder,
              ladderPrice: itemSP.salePrice.ladderPrice,
              marketPrice: itemSP.salePrice.marketPrice,
              memberPrice: itemSP.memberPrice,
              setNum: itemSP.salePrice.setNum,
              isSale: itemSP.isSale || 5,
              // 客户类型和客户快速调价
              customerTypePrice: [],
              customerTypePriceOpen: false,
              customerPrice: [],
              customerPriceOpen: false
            };
          });
          return { ...item,
            spec_table_Data: specTableData
          };
        });
        this.tabs_active = this.unit_data[0].unitName;
      } else {
        this.unit_data = data.specMultiple.map(item => {
          return {
            isEditSpec: item.isEditSpec,
            inventory: item.inventory - 0,
            specGroupHash: item.specGroupHash,
            id_D: item.id,
            isMaster: item.isMaster,
            conversion: item.conversion,
            unitName: item.unitName,
            unitId: item.unitId,
            specImage: {
              name: "",
              url: item.specImage || ""
            },
            barCode: item.barCode,
            weight: item.weight,
            isDefault: item.isDefault,
            salePrice: item.salePrice.salePrice,
            enabledLadder: item.salePrice.enabledLadder,
            ladderPrice: item.salePrice.ladderPrice,
            marketPrice: item.salePrice.marketPrice,
            memberPrice: item.memberPrice,
            setNum: item.salePrice.setNum,
            isSale: item.isSale || 5,
            // 客户类型和客户快速调价
            customerTypePrice: [],
            customerTypePriceOpen: false,
            customerPrice: [],
            customerPriceOpen: false
          };
        });
      } // 获取指定商品的最后生效的客户调价单数据


      await this.getCustomerPriceByGoodsIds(); //获取指定商品的最后生效的客户类型调价数据

      await this.getCustomerTypePriceByGoodsIds();
    },

    // 发布商品
    async submitGoods() {
      // console.log(JSON.stringify(this.unit_data))
      // console.log(this.unit_data)
      // return
      this.$refs["base_form"].validate(async valid => {
        if (valid) {
          let specGroup = [];
          let specMultiple = [];

          if (this.base_form.specType === 2) {
            // 多规格
            specGroup = this.sku_list.map(item => {
              return {
                groupSpec: {
                  specName: item.groupSpecName,
                  specId: item.groupSpecId
                },
                params: item.params.map(item => {
                  return {
                    specValueId: item.id,
                    specValueName: item.specName
                  };
                })
              };
            });
            this.unit_data.forEach(item => {
              item.spec_table_Data.forEach(itemSP => {
                let specIdG = (itemSP.id + "").split("_");
                let specNameG = itemSP.specName.split("_");
                let groupSpecNameG = itemSP.groupSpecName.split("_");
                let groupSpecIdG = (itemSP.groupSpecId + "").split("_");
                let specGroupS = groupSpecIdG.map((itemUU, indexUU) => {
                  return {
                    specId: groupSpecIdG[indexUU],
                    specName: groupSpecNameG[indexUU],
                    specValueName: specNameG[indexUU],
                    specValueId: specIdG[indexUU]
                  };
                });
                let salePriceS = {
                  conversion: item.conversion || 0,
                  unitName: item.unitName + "_" + itemSP.specName,
                  unitId: item.unitId,
                  isMaster: item.isMaster,
                  deleteStatus: itemSP.deleteStatus || 4,
                  enabledLadder: itemSP.enabledLadder,
                  salePriceAreaType: 1,
                  salePrice: itemSP.salePrice,
                  ladderPrice: itemSP.ladderPrice,
                  marketPrice: itemSP.marketPrice,
                  memberPrice: itemSP.memberPrice,
                  setNum: itemSP.setNum,
                  isSale: itemSP.isSale
                };
                let customerPrice = [];
                itemSP.customerPrice.forEach(itemP => {
                  if (!item.priceId) {
                    customerPrice.push({
                      price: itemP.price,
                      unitName: itemP.unitName,
                      adjPricetag: itemP.adjPricetag,
                      customerName: itemP.name,
                      customerId: itemP.id,
                      ladderPrice: itemP.ladderPrice
                    });
                  }
                });
                let customerTypePrice = [];
                itemSP.customerTypePrice.forEach(itemP => {
                  if (!item.priceId) {
                    customerTypePrice.push({
                      price: itemP.price,
                      unitName: itemP.unitName,
                      adjPricetag: itemP.adjPricetag,
                      customerName: itemP.name,
                      customerType: itemP.id,
                      ladderPrice: itemP.ladderPrice
                    });
                  }
                });
                specMultiple.push({
                  unitId: item.unitId,
                  unitName: item.unitName,
                  isMaster: item.isMaster,
                  conversion: item.conversion || 0,
                  specImage: itemSP.specImage.url,
                  isDefault: itemSP.isDefault,
                  barCode: itemSP.barCode,
                  weight: itemSP.weight,
                  specGroup: specGroupS,
                  salePrice: salePriceS,
                  customerPrice: customerPrice,
                  customerTypePrice: customerTypePrice
                });
              });
            });
          } else {
            // 单规格
            specMultiple = this.unit_data.map(item => {
              const salePriceS = {
                conversion: item.conversion || 0,
                unitName: item.unitName,
                unitId: item.unitId,
                isMaster: item.isMaster,
                deleteStatus: item.deleteStatus || 4,
                enabledLadder: item.enabledLadder,
                salePriceAreaType: 1,
                salePrice: item.salePrice,
                ladderPrice: item.ladderPrice,
                marketPrice: item.marketPrice,
                memberPrice: item.memberPrice,
                setNum: item.setNum,
                isSale: item.isSale
              };
              let customerPrice = [];
              item.customerPrice.forEach(itemP => {
                if (!itemP.priceId) {
                  customerPrice.push({
                    price: itemP.price,
                    unitName: itemP.unitName,
                    adjPricetag: itemP.adjPricetag,
                    customerName: itemP.name,
                    customerId: itemP.id,
                    ladderPrice: itemP.ladderPrice
                  });
                }
              });
              let customerTypePrice = [];
              item.customerTypePrice.forEach(itemP => {
                if (!itemP.priceId) {
                  customerTypePrice.push({
                    price: itemP.price,
                    adjPricetag: itemP.adjPricetag,
                    customerName: itemP.name,
                    customerType: itemP.id,
                    unitName: itemP.unitName,
                    ladderPrice: itemP.ladderPrice
                  });
                }
              });
              return {
                barCode: item.barCode,
                weight: item.weight,
                isDefault: item.isDefault,
                unitId: item.unitId,
                unitName: item.unitName,
                isMaster: item.isMaster,
                conversion: item.conversion || 0,
                specImage: item.specImage.url,
                specGroup: [],
                salePrice: salePriceS,
                customerTypePrice: customerTypePrice,
                customerPrice: customerPrice
              };
            });
          }

          const isFSale = specMultiple.every(item => item.salePrice.isSale === 4);

          if (isFSale) {
            this.$message.warning("至少保留一条规格的销售状态为【启用】");
            return;
          }

          const unitData = this.$_common.deepClone(this.base_form.branchUnit);
          unitData.unshift(this.base_form.masterUnit);
          const notCustomer = this.customer_list.map(item => {
            return item.id;
          }); // 副分类数据组装

          let assistCategoryPath = [];
          let assistCategoryId = []; // 过滤只有选择分类的数据

          const assistCate = this.assist_cate.filter(item => !!item.assistCategoryPath.length);
          assistCate.forEach(item => {
            assistCategoryPath.push(item.assistCategoryPath.join(","));
            assistCategoryId.push(item.assistCategoryPath[item.assistCategoryPath.length - 1]);
          });
          const params = {
            merchantId: this.base_form.merchantId,
            categoryPath: this.base_form.categoryPath.join(","),
            categoryId: this.base_form.categoryId,
            assistCategoryPath: assistCategoryPath,
            assistCategoryId: assistCategoryId.join(","),
            title: this.base_form.title,
            storage: this.base_form.storage,
            delUnitIds: this.base_form.delUnitIds,
            delSpecSkuIds: this.base_form.delSpecSkuIds,
            specType: this.base_form.specType,
            createUserName: this.userName,
            specGroup: specGroup,
            specMultiple: specMultiple,
            unitData: unitData,
            describe: this.base_form.describe,
            code: this.base_form.code,
            barCode: this.base_form.barCode,
            weight: this.base_form.weight,
            expireTime: this.base_form.expireTime,
            brandId: this.base_form.brandId,
            tag: this.dynamicTags.join(","),
            description: this.base_form.description,
            noSalesShop: "",
            images: this.base_form.images,
            enableStatus: this.base_form.enableStatus,
            isEq: this.base_form.isEq,
            //抄码商品
            isDistribution: this.base_form.isDistribution,
            //是否负库存销售
            isShield: this.base_form.isShield,
            //经营屏蔽
            deliverySupIds: this.base_form.deliverySupIds.join(","),
            // 物流支持 固定值 1 快递 2 自提 传参格式：1,2
            expressType: this.base_form.expressType,
            // 快递运费 1 包邮 2 运费模版 3 固定费用
            expressFee: this.base_form.expressFee,
            // 固定费用
            showExpress: this.base_form.showExpress,
            // 是否展示快递 5展示 4不展示
            ruleId: this.base_form.ruleId,
            // 运费模版id
            notArea: this.base_form.isShield === 5 ? this.base_form.notArea : [],
            // 经营屏蔽地区
            notCustomerType: this.base_form.isShield === 5 ? this.customer_type_check.join(",") : "",
            //经营屏蔽 客户类型屏蔽
            notCustomer: this.base_form.isShield === 5 ? notCustomer.join(",") : "",
            //经营屏蔽 客户屏蔽
            isStore: this.systemType === 3
          }; // console.log(params)
          // return

          this.loading = true;
          let target = {};

          try {
            if (this.$route.params.id) {
              target = await editQuickGoods({ ...params,
                id: this.goods_id,
                basicGoodsId: this.base_form.basicGoodsId
              });
            } else {
              target = await addBasicAndPublishGoods(params);
            }

            this.loading = false;
            this.$message({
              type: "success",
              message: "提交成功"
            });
            await this.delPauseSave();

            if (this.systemType === 3) {
              await this.$closeCurrentGoEdit(`/goods/sale/MerchantsGoods`);
            } else {
              await this.$closeCurrentGoEdit(`/goods/sale/PublishGoods`);
            }
          } finally {
            this.loading = false;
          }
        }
      });
    },

    // 商品分类选择
    categoryChange(val) {
      this.base_form.categoryId = val[val.length - 1];
    },

    // 商品副分类选择
    categoryAssistChange(val) {
      this.base_form.assistCategoryId = val[val.length - 1];
    },

    // 品牌选择
    brandConfirm(val) {
      if (val.length > 1) {
        this.$message({
          type: "error",
          message: "请选择一个品牌！"
        });
        return;
      }

      this.base_form.brandName = val[0].title;
      this.base_form.brandId = val[0].id;
    },

    // 计算市场价
    salePriceBlur(index, indexU) {
      if (this.base_form.specType === 1) {
        const target = this.$_common.deepClone(this.unit_data);
        const marketPrice = this.$NP.times(target[index].salePrice, this.salePriceTimes);
        target[index] = { ...target[index],
          marketPrice: marketPrice
        }; // 当前失去焦点的为主单位

        if (target[index].isMaster === 5) {
          // 单位换算关系存在且这个单位为辅助单位且当前单位未设置过价格
          target.forEach(item => {
            if (item.conversion && item.isMaster === 4 && !item.salePrice) {
              item.salePrice = this.$NP.times(target[index].salePrice, item.conversion);
              item.marketPrice = this.$NP.times(marketPrice, item.conversion);
            }
          });
        }

        this.unit_data = target;
      } else {
        this.unit_data[indexU].spec_table_Data[index].marketPrice = this.$NP.times(this.unit_data[indexU].spec_table_Data[index].salePrice, this.salePriceTimes);
      }
    },

    // 会员价失去焦点
    memberPriceBlur(index) {
      // 根据比例自动换算 会员价
      if (this.base_form.specType === 1) {
        const target = this.$_common.deepClone(this.unit_data);
        target.forEach(item => {
          if (item.conversion && item.isMaster === 4) {
            item.memberPrice = this.$NP.times(target[index].memberPrice, item.conversion);
          }
        });
        this.unit_data = target;
      }
    },

    // 规格明细同步数据
    otherSetPrice(row, index) {
      const target = this.$_common.deepClone(this.unit_data);
      target[index].spec_table_Data = target[index].spec_table_Data.map(item => {
        return { ...item,
          marketPrice: row.marketPrice,
          memberPrice: row.memberPrice,
          salePrice: row.salePrice,
          enabledLadder: row.enabledLadder,
          ladderPrice: row.ladderPrice,
          setNum: row.setNum,
          isSale: row.isSale || 5,
          specImage: row.specImage,
          barCode: row.barCode,
          weight: row.weight,
          // 客户类型和客户快速调价
          customerTypePrice: row.customerTypePrice,
          customerTypePriceOpen: row.customerTypePriceOpen,
          customerPrice: row.customerPrice,
          customerPriceOpen: row.customerPriceOpen
        };
      });
      this.unit_data = target;
    },

    // 规格明细删除
    specDetailDel(row, index) {
      let target = this.$_common.deepClone(this.unit_data);

      if (this.goods_id) {
        if (this.base_form.delSpecSkuIds.indexOf(row.specGroupHash) === -1) {
          this.base_form.delSpecSkuIds.push(row.specGroupHash);
        }
      }

      target = target.map(item => {
        item.spec_table_Data.splice(index, 1);
        return item;
      }); // target[0].spec_table_Data.splice(index, 1)

      const specNameArr = row.specName.indexOf("_") ? row.specName.split("_") : row.specName;
      let isFalseVal = "";

      for (let i in specNameArr) {
        let itemS = specNameArr[i];
        const isHave = target.some(itemU => {
          return itemU.spec_table_Data.find(item => item.specName.indexOf(itemS) > -1);
        });

        if (!isHave) {
          isFalseVal = itemS;
          break;
        }
      } // console.log("isStay,", isFalseVal);


      if (isFalseVal) {
        this.sku_list.forEach(item => {
          const indexP = item.params.findIndex(itemP => itemP.specName === isFalseVal);

          if (indexP > -1) {
            item.params.splice(indexP, 1);
          }
        });
      }

      this.unit_data = target;
    },

    // 选择商铺
    selChose(val, row) {
      this.base_form.shopId = row[0].id;
      this.base_form.shopName = row[0].name;
    },

    // 地区选择
    selRegion(row) {
      this.base_form.notArea = row.map(item => {
        return item.codePath;
      });
    },

    // 获取客户类型
    async getAllCustomerSource() {
      const data = await getAllCustomerSource({
        page: 1,
        pageSize: 50
      });
      this.customer_type_list = data.data;
    },

    // 选择客户
    customerSel(val) {
      this.customer_list = val;
    },

    // 删除客户
    deleteCustomer(index) {
      this.customer_list.splice(index, 1);
    },

    // 打开指定价弹窗
    openModal(index, key, row, indexU) {
      // 获取阶梯价数据，做阶梯价调价
      if (row) {
        this.unitisMaster = row.isMaster;
        this.sku_id = row.id;
        this.ladderPrice = row.ladderPrice;
        this.enabledLadder = row.enabledLadder;

        if (key === "type_price_show") {
          // 客户类型指定价调价数据
          this.customerTypePriceOpen = row.customerTypePriceOpen;
          this.customerTypePrice = row.customerTypePrice;
        }

        if (key === "appoint_price_show") {
          // 客户指定价调价数据
          this.customerPriceOpen = row.customerPriceOpen;
          this.customerPrice = row.customerPrice;
        }
      }

      this.sku_index = index;

      if (indexU > -1) {
        this.unit_index = indexU;
      }

      this[key] = true;
    },

    // 指定价数据确定
    appointPriceConfirm(customerPriceOpen, customerPrice) {
      console.log(customerPrice);

      if (this.base_form.specType === 1) {
        // 单规格
        const target = this.$_common.deepClone(this.unit_data);
        target[this.sku_index].customerPriceOpen = customerPriceOpen;
        target[this.sku_index].customerPrice = customerPriceOpen ? customerPrice : [];
        this.unit_data = target;
      } else {
        // 多规格
        const target = this.$_common.deepClone(this.unit_data);
        target[this.unit_index].spec_table_Data[this.sku_index].customerPriceOpen = customerPriceOpen;
        target[this.unit_index].spec_table_Data[this.sku_index].customerPrice = customerPriceOpen ? customerPrice : [];
        this.unit_data = target;
      }
    },

    // 指定价数据取消
    appointPriceCancel() {
      this.appoint_price_show = false;
    },

    typePriceConfirm(customerTypePriceOpen, customerTypePrice) {
      if (this.base_form.specType === 1) {
        // 单规格
        const target = this.$_common.deepClone(this.unit_data);
        target[this.sku_index].customerTypePriceOpen = customerTypePriceOpen;
        target[this.sku_index].customerTypePrice = customerTypePriceOpen ? customerTypePrice : [];
        this.unit_data = target;
      } else {
        // 多规格
        const target = this.$_common.deepClone(this.unit_data);
        target[this.unit_index].spec_table_Data[this.sku_index].customerTypePriceOpen = customerTypePriceOpen;
        target[this.unit_index].spec_table_Data[this.sku_index].customerTypePrice = customerTypePriceOpen ? customerTypePrice : [];
        this.unit_data = target;
      }
    },

    typePriceCancel() {
      this.type_price_show = false;
    },

    // 阶梯价设置
    ladderPriceConfirm(enabledLadder, ladderPrice) {
      if (this.base_form.specType === 1) {
        // 单规格
        const target = this.$_common.deepClone(this.unit_data);

        if (this.base_form.isEq === 5) {
          // 抄码商品根据比例自动换算销售价
          target.forEach(item => {
            item.enabledLadder = enabledLadder;

            if (enabledLadder) {
              if (item.conversion && item.isMaster === 4) {
                item.ladderPrice = ladderPrice.map(ladder => {
                  return { ...ladder,
                    price: this.$NP.times(ladder.price, item.conversion)
                  };
                });
              } else {
                item.ladderPrice = ladderPrice;
              }
            } else {
              item.ladderPrice = [];
            }
          });
        } else {
          target[this.sku_index].enabledLadder = enabledLadder;
          target[this.sku_index].ladderPrice = enabledLadder ? ladderPrice : [];
        }

        this.unit_data = target;
      } else {
        // 多规格
        const target = this.$_common.deepClone(this.unit_data);
        target[this.unit_index].spec_table_Data[this.sku_index].enabledLadder = enabledLadder;
        target[this.unit_index].spec_table_Data[this.sku_index].ladderPrice = enabledLadder ? ladderPrice : [];
        this.unit_data = target;
      }
    },

    ladderPriceCancel() {
      this.ladder_price_show = false;
    },

    // 客户调价单
    async CustomerPriceAdjustmentAdd(params) {
      if (!params.length) return;
      const {
        data
      } = await CustomerPriceAdjustmentAdd(params);
    },

    // 客户类型调价单
    async addCustomerTypePriceAdjustment(params) {
      if (!params.length) return;
      const {
        data
      } = await addCustomerTypePriceAdjustment(params);
    },

    // 商品分类列表
    async getAllCategoryPost() {
      const {
        data
      } = await getAllCategoryPost({
        enableStatus: 5
      });

      if (JSON.stringify(data) === "{}") {
        this.category_data = [];
      } else {
        this.category_data = data;
      }
    },

    // 自定义选择即改变
    clickChange(event) {
      event.target.parentElement.parentElement.firstChild.click();
    },

    delAssistCate(index) {
      this.assist_cate.splice(index, 1);
    },

    addAssistCate() {
      this.assist_cate.push({
        assistCategoryPath: []
      });
    },

    // 获取商户列表
    async getAllMerchantList() {
      const {
        data
      } = await getAllMerchantList();
      this.sel_cities = data;
    },

    // 抄码商品切换
    isEqChange(val) {
      if (this.isEditSpec !== 4 && val === 5) {
        this.base_form.masterUnit = {
          isDefault: 5,
          isMaster: 5,
          weight: "",
          unitName: "",
          unitId: "",
          barCode: ""
        };
        this.base_form.branchUnit = [];
        this.unit_data = [];
      }
    },

    // 获取指定商品的最后生效的客户调价单数据
    async getCustomerPriceByGoodsIds() {
      const {
        data,
        pageTotal
      } = await getCustomerPriceByGoodsIds({
        goodsId: this.goods_id,
        page: 1,
        pageSize: 200
      });
      this.customerPrice = data;
    },

    // 获取指定商品的最后生效的客户类型调价数据
    async getCustomerTypePriceByGoodsIds() {
      const {
        data
      } = await getCustomerTypePriceByGoodsIds({
        goodsId: this.goods_id,
        page: 1,
        pageSize: 20
      });
      this.customerTypePrice = data;
      this.adjustmentData();
    },

    adjustmentData() {
      if (this.base_form.specType === 1) {
        this.unit_data = this.unit_data.map(item => {
          //客户类型价
          let customerTypePrice = [];
          this.customerTypePrice.forEach(type => {
            if (type.salePrice && type.salePrice.length) {
              type.salePrice.forEach(pitem => {
                if (parseInt(pitem.skuId) === item.id_D) {
                  customerTypePrice.push({
                    adjPricetag: pitem.adjPricetag,
                    ladderPrice: pitem.ladderPrice || [],
                    price: pitem.price,
                    name: type.customerTypeName,
                    id: type.customerType,
                    priceId: type.id
                  });
                }
              });
            }
          }); //客户价

          let customerPrice = [];
          this.customerPrice.forEach(type => {
            if (type.salePrice && type.salePrice.length) {
              type.salePrice.forEach(pitem => {
                if (parseInt(pitem.skuId) === item.id_D) {
                  customerPrice.push({
                    adjPricetag: pitem.adjPricetag,
                    ladderPrice: pitem.ladderPrice || [],
                    price: pitem.price,
                    name: type.customerName,
                    id: type.customerId,
                    priceId: type.id
                  });
                }
              });
            }
          });
          return { ...item,
            // 客户类型和客户快速调价
            customerTypePrice: customerTypePrice,
            customerTypePriceOpen: customerTypePrice.length > 0,
            customerPrice: customerPrice,
            customerPriceOpen: customerPrice.length > 0
          };
        });
      } else {
        this.unit_data = this.unit_data.map(itemU => {
          return { ...itemU,
            spec_table_Data: itemU.spec_table_Data.map(item => {
              //客户类型价
              let customerTypePrice = [];
              this.customerTypePrice.forEach(type => {
                if (type.salePrice && type.salePrice.length) {
                  type.salePrice.forEach(pitem => {
                    if (parseInt(pitem.skuId) === item.id_D) {
                      customerTypePrice.push({
                        adjPricetag: pitem.adjPricetag,
                        ladderPrice: pitem.ladderPrice || [],
                        price: pitem.price,
                        name: type.customerTypeName,
                        id: type.customerType,
                        priceId: type.id
                      });
                    }
                  });
                }
              }); //客户价

              let customerPrice = [];
              this.customerPrice.forEach(type => {
                if (type.salePrice && type.salePrice.length) {
                  type.salePrice.forEach(pitem => {
                    if (parseInt(pitem.skuId) === item.id_D) {
                      customerPrice.push({
                        adjPricetag: pitem.adjPricetag,
                        ladderPrice: pitem.ladderPrice || [],
                        price: pitem.price,
                        name: type.customerName,
                        id: type.customerId,
                        priceId: type.id
                      });
                    }
                  });
                }
              });
              return { ...item,
                customerTypePrice: customerTypePrice,
                customerTypePriceOpen: customerTypePrice.length > 0,
                customerPrice: customerPrice,
                customerPriceOpen: customerPrice.length > 0
              };
            })
          };
        });
      }

      console.log(" this.unit_data:", this.unit_data);
    }

  }
};"},null]}
|