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\\manageG\\AddBaseData.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\views\\goods\\manageG\\AddBaseData.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 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 "./AddBrand";
import SelectShop from "@/component/goods/SelectShop.vue";
import { getAllUnit, defineSpec, SpecManagegetAll, getGoodsBasicInfoById, editGoodsBasic, addGoodsBasic, getAllCategoryPost } from "@/api/goods";
import { addPauseSave, delPauseSave, getPauseSave } from "@/api/common";
import { getAllMerchantList } from "@/api/Merchants";
export default {
  name: "AddBaseData",
  components: {
    // GoodsCategory,
    BrandSelModel,
    Tinymce,
    UploadQiniu,
    AddCate,
    AddBrand,
    SelectShop
  },

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

    return {
      // 计量单位
      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: "",
        isMaster: 4,
        isDefault: 4,
        weight: "",
        unitId: "",
        barCode: "",
        conversion: ""
      },
      sel_brand: false,
      // 打开品牌选择弹窗
      sel_shop: false,
      // 打开店铺选择弹窗
      master_unit_name: "",
      base_form: {
        //  基本信息
        specType: 1,
        // 是否多规格
        delUnitIds: [],
        // 辅助单位删除delUnitIds (unitId)
        delSpecSkuIds: [],
        // 属性删除delSpecSkuIds（这个用id）
        branchUnit: [],
        brandName: "",
        categoryPath: [],
        // 分类选择
        assistCategoryPath: [],
        //副分类
        noSalesShop: [],
        unitData: [],
        isEq: 4,
        //是否是抄码商品
        masterUnit: {
          isDefault: 5,
          isMaster: 5,
          weight: "",
          unitName: "",
          unitId: "",
          barCode: ""
        },
        describe: "",
        storage: "",
        title: "",
        code: "",
        barCode: "",
        // 商品条码
        categoryId: "",
        assistCategoryId: "",
        expireTime: "",
        brandId: "",
        tag: "",
        description: "",
        salesShop: "",
        images: [],
        merchantId: "" //商户ID

      },
      base_rules: {
        // 基本信息验证
        title: [{
          required: true,
          message: "请输入商品名称",
          trigger: "blur"
        }],
        categoryId: [{
          required: true,
          message: "请选择商品分类",
          trigger: "change"
        }],
        expireTime: [{
          required: true,
          message: "请输入商品保质期",
          trigger: "blur"
        }],
        masterUnit: [{
          validator: validateUnit,
          trigger: "change"
        }]
      },
      images_rules: {
        images: [{
          type: "array",
          required: true,
          message: "请上传商品图片",
          trigger: "change"
        }]
      },
      base_goods_id: 0,
      isEditSpec: 5,
      // 5 表示此商品从未采购过，允许用户随意编辑单位和属性；4 表示商品已经采购过，隐藏添加属性按钮，避免skuid重组
      isNew: 5,
      // 5 标示这是一个最近新增的商品，基本单位为最小单位，4标示这是之前的老数据，基本单位为最大单位3
      sel_merchant: false,
      sel_cities: [],
      category_data: [],
      //商品分类列表
      cate_props: {
        label: "title",
        value: "id",
        checkStrictly: true
      },
      assist_cate: [{
        assistCategoryPath: []
      }],
      page_tabs: "1",
      step_active: 1
    };
  },

  async created() {
    // this.getAllGoodsSupport();
    // 商品分类列表
    await this.getAllCategoryPost();
    this.pageName = this.$route.name; // 商户管理

    await this.getAllMerchantList(); // 属性管理

    await this.SpecManagegetAll();
    await this.getAllUnit();

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

  async activated() {
    if (this.$_isInit()) return;
    this.pageName = this.$route.name;
    this.step_active = 1;
    this.page_tabs = "1";

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

  methods: {
    // 默认单位change
    isDefaultChange(val, index, sIndex) {
      // 多规格数据
      if (this.spec_table_Data.length > 0) {
        if (val === 5) {
          const target = this.$_common.deepClone(this.spec_table_Data);
          target.forEach((item, indexS) => {
            item.barCode.forEach((itemB, indexB) => {
              if (indexS !== sIndex) {
                itemB.isDefault = 4;
              } else {
                if (indexB !== index) {
                  itemB.isDefault = 4;
                }
              }
            });
          });
          this.spec_table_Data = target;
        }
      } else {
        if (val === 5) {
          if (index === "masterUnit") {
            this.base_form.branchUnit.forEach(item => {
              item.isDefault = 4;
            });
          } else {
            this.base_form.masterUnit.isDefault = 4;
            this.base_form.branchUnit.forEach((item, indexU) => {
              if (indexU !== index) {
                item.isDefault = 4;
              }
            });
          }
        }
      }
    },

    // 请求基本单位数据
    async getAllUnit() {
      const {
        data
      } = await getAllUnit({
        page: 1,
        pageSize: 99,
        source: 4
      });
      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() {
      await this.getAllCategoryPost();
    },

    // 新建品牌
    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
      };
      const data = await addPauseSave({
        key: this.pageName,
        data: params
      });
      this.$message({
        type: "success",
        message: "暂存成功"
      });
      this.$closeCurrentGoEdit("/goods/manageG/BaseDataList");
    },

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

      if (type) {
        this.$message({
          type: "success",
          message: "清除暂存成功"
        });
        this.$closeCurrentGoEdit("/goods/manageG/AddBaseData");
      }
    },

    // 获取暂存信息
    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 : []
      };
      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
          };
        });
      }
    },

    // 规格明细删除
    specDetailDel(row, index) {
      if (row.specGroupHash && this.base_form.delSpecSkuIds.indexOf(row.specGroupHash) === -1) {
        this.base_form.delSpecSkuIds.push(row.specGroupHash);
      }

      this.spec_table_Data.splice(index, 1);
      const specNameArr = row.specName.indexOf("_") ? row.specName.split("_") : row.specName; // console.log('specNameArr', row.specName)
      // console.log('this.spec_table_Data', this.spec_table_Data)

      let isFalseVal = "";

      for (let i in specNameArr) {
        let itemS = specNameArr[i]; // console.log(itemS)
        // console.log(this.spec_table_Data.find(item => item.specName.indexOf(itemS) > -1))

        if (!this.spec_table_Data.find(item => item.specName.indexOf(itemS) > -1)) {
          isFalseVal = itemS;
          break;
        }
      } // console.log('isStay,', isFalseVal)
      // console.log(this.sku_list)


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

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

    // ddel(val) {
    //   this.from.categoryPath = val;
    // },
    // 规格图片
    uploadSpecSuccess(val, index) {
      let target = this.$_common.deepClone(this.spec_table_Data);
      target[index].specImage = {
        name: "",
        url: val
      };
      this.spec_table_Data = target;
    },

    // 添加规格项目
    addSkuP() {
      if (this.isEditSpec === 5) {
        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: []
          });
        }).catch(() => {});
      }
    },

    // 规格明切换
    groupSpecIdChange(val, indexS) {
      let target = this.$_common.deepClone(this.sku_list);
      const specDataItem = this.spec_data.find(item => item.id === val);
      const isHave = target.find(item => item.groupSpecName === specDataItem.specName);

      if (isHave) {
        target[indexS].groupSpecId = "";
        this.sku_list = target;
        this.$message.warning(`属性:【${specDataItem.specName}】已存在`);
        return;
      }

      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 cloneSpecGroup = this.$_common.deepClone(this.spec_table_Data);
      const skuArr = this.sku_list.map(item => {
        item.params = item.params.map(itemP => {
          return { ...itemP,
            groupSpecName: item.groupSpecName
          };
        });
        return item.params;
      }); // console.log('skuArr::', skuArr)

      this.spec_table_Data = this.doExchange(skuArr); // console.log(this.spec_table_Data)

      this.spec_table_Data.forEach(item => {
        const index = cloneSpecGroup.findIndex(itemC => itemC.id === item.id);

        if (index > -1) {
          item.barCode = cloneSpecGroup[index].barCode;
          item.specImage = cloneSpecGroup[index].specImage;
          item.inventory = cloneSpecGroup[index].inventory;
          item.isEditSpec = cloneSpecGroup[index].isEditSpec || 5;
        }
      });
    },

    // 规格组合
    doExchange(doubleArrays) {
      const len = doubleArrays.length;
      let unitData = this.$_common.deepClone(this.base_form.branchUnit);
      unitData.unshift(this.base_form.masterUnit);
      const barCodeArr = unitData.map(item => {
        return { ...item,
          barCode: "",
          weight: "",
          isDefault: 4
        };
      });

      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: ""
              },
              barCode: this.$_common.deepClone(barCodeArr)
            };
            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 if (len > 0) {
        return doubleArrays[0].map(item => {
          return { ...item,
            barCode: this.$_common.deepClone(barCodeArr),
            specImage: {
              name: "",
              url: ""
            }
          };
        });
      } else {
        return [];
      }
    },

    // 自定义属性值输入框确定  添加自定义属性
    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 isHave = target[index].params.find(item => item.specName === target[index].self_spec_val);

      if (isHave) {
        this.$message.warning(`属性值:【${target[index].self_spec_val}】已存在`);
        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.base_goods_id) {
          this.base_form.delSpecSkuIds = this.spec_table_Data.filter(item => item.specName.indexOf(itemC.specName) > -1).map(itemM => {
            return itemM.specGroupHash;
          });
        }

        this.spec_table_Data = this.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); // 重排规格组合

        this.specGroupRest();
      });
    },

    // 获取属性列表
    async SpecManagegetAll() {
      const {
        data,
        pageTotal
      } = await SpecManagegetAll({
        page: 1,
        pageSize: 100
      });
      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
        };
      });

      if (this.img_list.length > 10) {
        this.$message.warning("图片最多只能选择十张");
        this.img_list = this.img_list.slice(0, 10);
      }
    },

    // 图片拖拽排序
    imgSortChange(list) {
      this.base_form.images = list.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) {
      if (row.unitId && this.base_form.delUnitIds.indexOf(row.unitId) === -1) {
        this.base_form.delUnitIds.push(row.unitId);
      }

      this.spec_table_Data = this.spec_table_Data.map(item => {
        return { ...item,
          barCode: item.barCode.filter(item => item.unitId !== row.unitId)
        };
      });
      this.base_form.branchUnit.splice(it, 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;
      }

      if (!this.edit_assist_model) {
        this.assist_form.weight = this.base_form.masterUnit.weight * this.assist_form.conversion;
        this.base_form.branchUnit.push(this.assist_form);
      } else {
        this.base_form.branchUnit[this.assist_index] = this.assist_form;
      }

      this.assist_model = false;
      this.spec_table_Data = this.spec_table_Data.map(item => {
        item.barCode.push(this.$_common.deepClone(this.assist_form));
        return { ...item
        };
      });
    },

    changeWeight() {
      const target = this.$_common.deepClone(this.base_form.branchUnit);
      target.forEach(item => {
        item.weight = this.base_form.masterUnit.weight * item.conversion;
      });
      this.base_form.branchUnit = target;
    },

    // 基本单位切换
    masterUnitChange({
      value,
      $event
    }) {
      // 编辑页面把删除 的单位ID存储下来
      if (!!this.base_goods_id) {
        const unitData = this.$_common.deepClone(this.base_form.unitData);
        this.base_form.delUnitIds = unitData.map(item => item.unitId);

        if (this.base_form.specType === 1) {
          const specMultiple = this.$_common.deepClone(this.base_form.specMultiple);
          this.base_form.delSpecSkuIds = specMultiple.map(item => item.id);
        } //把所有的单位删除，重新设置一个新的主单位


        if (this.base_form.masterUnit.id) {
          delete this.base_form.masterUnit.id;
        }
      }

      const val = value;
      this.base_form.masterUnit.unitName = this.unit_options.find(item => item.id === val).unitName; // 重置辅助单位

      this.base_form.branchUnit = [];
      this.spec_table_Data = this.spec_table_Data.map(item => {
        const index = item.barCode.findIndex(itemF => itemF.isMaster === 5);
        const barObj = { ...this.$_common.deepClone(this.base_form.masterUnit),
          barCode: item.barCode[index].barCode || ""
        };
        this.$set(item.barCode, index, barObj);
        return item;
      });
    },

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

    // 获取详情
    async getGoodsBasicInfoById() {
      const {
        data
      } = await getGoodsBasicInfoById(this.base_goods_id);
      this.isEditSpec = data.isEditSpec;
      const unitData = this.$_common.deepClone(data.unitData);
      const masterUnit = unitData.find(item => item.isMaster === 5) || {};
      const branchUnit = unitData.filter(item => item.isMaster === 4);
      this.isNew = masterUnit.isNew || 4;
      this.base_form = { ...data,
        noSalesShop: data.noSalesShop ? data.noSalesShop.split(",").map(item => parseInt(item)) : [],
        masterUnit: masterUnit,
        delUnitIds: [],
        delSpecSkuIds: [],
        specType: data.specType,
        branchUnit: branchUnit,
        categoryPath: data.categoryPath ? data.categoryPath.split(",").map(item => {
          return parseInt(item);
        }) : [],
        assistCategoryPath: data.assistCategoryPath || []
      };

      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 ? data.tag.split(",") : [];
      this.base_form.brandName = data.brandTitle; // 多规格数据

      if (parseInt(this.base_form.specType) === 2) {
        this.sku_list = data.specGroup.map(item => {
          const specData = this.spec_data.find(itemF => itemF.id === item.groupSpec.specId);
          return {
            spec_data_child: specData ? specData.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.spec_table_Data = data.specMultiple.map(item => {
          let barCodeA = [];

          for (let b in item.barCode) {
            let unitB = data.unitData.find(itemF => parseInt(itemF.unitId) === parseInt(b));

            if (unitB) {
              barCodeA.push({ ...unitB,
                barCode: item.barCode[b],
                weight: item.weight[b],
                isDefault: item.isDefault[b]
              });
            }
          }

          return {
            barCode: barCodeA,
            isEditSpec: item.isEditSpec,
            inventory: item.inventory - 0,
            specGroupHash: item.specGroupHash,
            id_D: item.id,
            unitId: item.unitId,
            specName: item.specGroup.map(itemP => {
              return itemP.specValueName;
            }).join("_"),
            id: item.specGroup.map(itemP => {
              return itemP.specValueId;
            }).join("_"),
            groupSpecId: item.specGroup.map(itemP => {
              return itemP.specId;
            }).join("_"),
            groupSpecName: item.specGroup.map(itemP => {
              return itemP.specName;
            }).join("_"),
            specImage: {
              name: "",
              url: item.specImage
            }
          };
        });
      }
    },

    // 发布商品
    async submitGoods() {
      if (!this.base_form.title.trim()) {
        this.$message.warning("商品名称不能为空");
        return;
      }

      if (!this.base_form.categoryPath.length) {
        this.$message.warning("商品分类不能为空");
        return;
      }

      if (!this.base_form.masterUnit.unitId) {
        this.$message.warning("请选择基本单位");
        return;
      }

      this.$refs["base_form"].validate(async valid => {
        if (valid) {
          let specGroup = [];
          let specMultiple = [];

          if (!this.base_form.images.length) {
            this.$message.warning("请上传商品图片");
            return;
          }

          if (this.base_form.masterUnit.weight < 0) {
            this.$message.warning("商品重量不能为负数");
            return;
          }

          if (this.spec_table_Data.length > 0) {
            // 多规格
            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
                  };
                })
              };
            });
            specMultiple = this.spec_table_Data.map((item, index) => {
              let specVal = []; // 属性id

              let specId = []; // 属性组id

              let specName = []; // 属性组名

              let specValueName = []; // 属性名

              if ((item.id + "").indexOf("_") > -1) {
                specVal = item.id.split("_");
                specId = item.groupSpecId.split("_");
                specValueName = item.specName.split("_");
                specName = item.groupSpecName.split("_");
              } else {
                specVal = [item.id];
                specId = [item.groupSpecId];
                specName = [item.groupSpecName];
                specValueName = [item.specName];
              } // 条码


              let barCodeO = {};
              let isDefaultO = {};
              let weightO = {};
              item.barCode.forEach(itemB => {
                barCodeO[itemB.unitId] = itemB.barCode;
                isDefaultO[itemB.unitId] = itemB.isDefault;
                weightO[itemB.unitId] = itemB.weight;
              });
              let returnParams = {
                specImage: item.specImage.url,
                specGroup: specVal.map((itemV, indexV) => {
                  return {
                    specId: specId[indexV],
                    specName: specName[indexV],
                    specValueName: specValueName[indexV],
                    specValueId: itemV
                  };
                }),
                barCode: barCodeO,
                isDefault: isDefaultO,
                weight: weightO
              };

              if (this.$route.params.id) {
                returnParams.specGroupHash = item.specGroupHash;
                returnParams.id = item.id_D;
              }

              return returnParams;
            });
          } else {
            this.base_form.specType = 1;
          }

          let unitDataD = this.$_common.deepClone(this.base_form.branchUnit);
          unitDataD.unshift(this.base_form.masterUnit);
          const unitDataA = unitDataD.map(item => {
            if (this.base_form.specType === 2) {
              item.barCode = "";
              item.isDefault = 4;
              item.weight = "";
            }

            if (this.base_form.delSpecSkuIds.indexOf(item.specGroupHash) !== -1 && this.base_form.specType === 1) {
              delete item.id;
            }

            return item;
          }); // 副分类数据组装

          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(","),
            assistCategoryPath: assistCategoryPath,
            categoryId: this.base_form.categoryId,
            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,
            specGroup: specGroup,
            specMultiple: specMultiple,
            unitData: unitDataA,
            describe: this.base_form.describe,
            code: this.base_form.code,
            barCode: this.base_form.barCode,
            expireTime: this.base_form.expireTime,
            isEq: this.base_form.isEq,
            brandId: this.base_form.brandId,
            tag: this.dynamicTags.join(","),
            description: this.base_form.description,
            noSalesShop: this.base_form.noSalesShop.join(","),
            images: this.base_form.images
          };
          this.loading = true;
          let target = {};

          try {
            if (this.$route.params.id) {
              target = await editGoodsBasic(this.base_goods_id, params);
            } else {
              target = await addGoodsBasic(params);
            }

            const data = target;
            this.loading = false;
            this.$message({
              type: "success",
              message: "提交成功"
            });
            await this.delPauseSave();
            this.$closeCurrentGoEdit(`/goods/manageG/BaseDataList`);
          } catch {
            this.loading = false;
          }
        }
      });
    },

    // 商品分类选择
    categoryChange(val, row) {
      // this.base_form.categoryPath = row;
      this.base_form.categoryId = val[val.length - 1]; // this.base_form.categoryPath.push(this.$_common.deepClone(goodsItem));
    },

    // 品牌选择
    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;
    },

    async getAllMerchantList() {
      const {
        data
      } = await getAllMerchantList();
      this.sel_cities = data;
    },

    // 商品分类列表
    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: []
      });
    },

    // 下一步
    tagNext() {
      if (this.page_tabs === "1") {
        this.$refs["base_form"].validate(valid => {
          if (valid) {
            if (!this.base_form.masterUnit.unitId) {
              this.$message.warning("请选择基本单位");
              return;
            }

            this.page_tabs = "2";
            this.step_active = 2;
          }
        });
      } else if (this.page_tabs === "2") {
        if (!this.base_form.images.length) {
          this.$message.warning("请上传商品图片");
          return;
        }

        this.page_tabs = "3";
        this.step_active = 3;
      }
    },

    // 上一步
    tagLast() {
      if (this.page_tabs === "3") {
        this.step_active = 2;
        this.page_tabs = "2";
      } else if (this.page_tabs === "2") {
        this.page_tabs = "1";
        this.step_active = 1;
      }
    },

    tabClick() {
      if (this.page_tabs === "1") {
        this.step_active = 1;
      } else if (this.page_tabs === "2") {
        this.step_active = 2;
      } else if (this.page_tabs === "3") {
        this.step_active = 3;
      }
    },

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

  }
};"},null]}
|