e7cde724083bd0b9c0fa9858da669c1f.json 143 KB

1
  1. {"remainingRequest":"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\\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 = [];
      }
    }

  }
};"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgyBA;AACA;AACA;AACA,6D,CACA;;AACA;AACA;AACA;AACA,SACAA,UADA,EAEAC,UAFA,EAGAC,gBAHA,EAIAC,qBAJA,EAKAC,cALA,EAMAC,aANA,EAOAC,kBAPA,QAQA,aARA;AASA;AACA;AACA;EACAC,mBADA;EAEAC;IACA;IACAC,aAFA;IAGAC,OAHA;IAIAC,WAJA;IAKAC,OALA;IAMAC,QANA;IAOAC;EAPA,CAFA;;EAWAC;IACA;MACA;QACAC;MACA,CAFA,MAEA;QACAA;MACA;IACA,CANA;;IAOA;MACA;MACAC,iBAFA;MAEA;MACAC,kBAHA;MAGA;MACAC,sBAJA;MAIA;MACAC,iBALA;MAKA;MACAC,mBANA;MAMA;MACAC,4BAPA;MAOA;MACAC,qBARA;MAQA;MACAC,aATA;MASA;MACAC,mBAVA;MAUA;MACAC,mBAXA;MAWA;MACAC,WACA;MACA;QACAF,mBADA;QAEAG,eAFA;QAGAX,iBAHA;QAIAE,sBAJA;QAKAU,iBALA;QAMAC;MANA,CAFA,CAZA;MAuBAC,gBAvBA;MAuBA;MACAC,mBAxBA;MAyBAC,WAzBA;MA0BAC,gBA1BA;MA0BA;MACAC,YA3BA;MA2BA;MACAC,cA5BA;MA6BAC,YA7BA;MA8BA;MACAC,eA/BA;MAgCAC,mBAhCA;MAiCAC,cAjCA;MAkCA;MACAC,mBAnCA;MAoCAC,wBApCA;MAqCAC,eArCA;MAsCAC,gBAtCA;MAuCA;MACAC;QACAC,YADA;QAEAC,WAFA;QAGAC,YAHA;QAIAC,UAJA;QAKAC,UALA;QAMAC,WANA;QAOAC;MAPA,CAxCA;MAiDAC,gBAjDA;MAiDA;MACAC,eAlDA;MAkDA;MACAC,oBAnDA;MAoDAC;QACA;QACAC,WAFA;QAEA;QACAC,cAHA;QAGA;QACAC,iBAJA;QAIA;QACAC,cALA;QAMAC,aANA;QAOAC,gBAPA;QAOA;QACAC,sBARA;QAQA;QACAC,eATA;QAUAC,YAVA;QAWAC,OAXA;QAWA;QACAC;UACAnB,YADA;UAEAD,WAFA;UAGAE,UAHA;UAIAH,YAJA;UAKAI,UALA;UAMAC;QANA,CAZA;QAoBAiB,YApBA;QAqBAC,WArBA;QAsBAC,SAtBA;QAuBAC,QAvBA;QAwBApB,WAxBA;QAwBA;QACAqB,cAzBA;QA0BAC,oBA1BA;QA2BAC,cA3BA;QA4BAC,WA5BA;QA6BAC,OA7BA;QA8BAC,eA9BA;QA+BAC,aA/BA;QAgCAC,UAhCA;QAiCAC,cAjCA,CAiCA;;MAjCA,CApDA;MAuFAC;QACA;QACAX,QACA;UAAAY;UAAAC;UAAAC;QAAA,CADA,CAFA;QAKAZ,aACA;UAAAU;UAAAC;UAAAC;QAAA,CADA,CALA;QAQAV,aACA;UAAAQ;UAAAC;UAAAC;QAAA,CADA,CARA;QAWAjB;UAAAkB;UAAAD;QAAA;MAXA,CAvFA;MAqGAE;QACAP,SACA;UACAQ,aADA;UAEAL,cAFA;UAGAC,kBAHA;UAIAC;QAJA,CADA;MADA,CArGA;MA+GAI,gBA/GA;MAgHAC,aAhHA;MAgHA;MACAC,QAjHA;MAiHA;MACAC,mBAlHA;MAmHAC,cAnHA;MAoHAC,iBApHA;MAoHA;MACAC;QACAC,cADA;QAEAC,WAFA;QAGAC;MAHA,CArHA;MA0HAC,cACA;QACAnC;MADA,CADA,CA1HA;MA+HAoC,cA/HA;MAgIAC;IAhIA;EAkIA,CArJA;;EAsJA;IACA;IACA;IACA;IACA,iCAJA,CAMA;;IACA,gCAPA,CAQA;;IACA;IACA;;IACA;MACA;MACA;IACA,CAHA,MAGA;MACA;MACA;IACA;EACA,CAxKA;;EAyKA;IACA;IACA;IACA;IACA;;IACA;MACA;MACA;IACA,CAHA,MAGA;MACA;MACA;IACA;EACA,CArLA;;EAsLAC;IACA;IACAC;MACA;MACA;QACA;UACA;UACAC;YACAC;cACA;gBACAC;cACA,CAFA,MAEA;gBACA;kBACAA;gBACA;cACA;YACA,CARA;UASA,CAVA;UAWA;QACA;MACA,CAhBA,MAgBA;QACA;UACA;YACA;cACAD;YACA,CAFA;UAGA,CAJA,MAIA;YACA;YACA;cACA;gBACAA;cACA;YACA,CAJA;UAKA;QACA;MACA;IACA,CApCA;;IAqCA;IACA;MACA;QAAAzF;MAAA;QACA2F,OADA;QAEAC,YAFA;QAGAC;MAHA;MAMA;IACA,CA9CA;;IA+CAC;MACA;IACA,CAjDA;;IAkDA;IACAC;MACA;MACA;;MACA;QACA,sBACAC;UACA;QACA,CAFA,CADA,GAIA,EAJA;QAKAC;QACA;MACA;IACA,CA/DA;;IAgEA;IACA;MACA;IACA,CAnEA;;IAoEA;IACAC;MACA;IACA,CAvEA;;IAwEA;IACA;MACA,iBACA,iBADA;QAEAC,wBAFA;QAGAC,kCAHA;QAIAvC,qBAJA;QAKAsB;MALA;MAOA;QACAkB,kBADA;QAEArG;MAFA;MAIA;QACAwE,eADA;QAEAJ;MAFA;MAIA;IACA,CA1FA;;IA2FA;IACA;MACA;QACAiC;MADA;;MAIA;QACA;UACA7B,eADA;UAEAJ;QAFA;QAIA;MACA;IACA,CAxGA;;IAyGA;IACA;MACA;QAAApE;MAAA;QACAqG;MADA;MAIA;MACA,mBACA,OADA;QAEAtD,iDACA/C,iBADA,GAEA;MAJA;MAMA;QAAAgD;MAAA;MACA;MACA;MACA;;MACA;QACA;UACA;YACAxD,QADA;YAEA8G;UAFA;QAIA,CALA;MAMA;IACA,CAlIA;;IAoIA;IACAC;MACA,IACAP,qBACA,8DAFA,EAGA;QACA;MACA;;MACA;MACA,gDACAA,uBADA,GAEAA,YAFA,CARA,CAWA;MACA;;MACA;;MACA;QACA,2BADA,CAEA;QACA;;QACA,IACA,2BACAP,yCADA,CADA,EAIA;UACAe;UACA;QACA;MACA,CA1BA,CA2BA;MACA;;;MACA;QACA;UACA,qCACAC,sCADA;;UAGA;YACAhB;UACA;QACA,CAPA;MAQA;IACA,CA5KA;;IA6KA;IACA;IACA;IACA;IACAiB;MACA;MACAlB;QACAhG,QADA;QAEA8G;MAFA;MAIA;IACA,CAxLA;;IAyLA;IACAK;MACA;QACA;UACAjG,mBADA;UAEAN,sBAFA;UAGAF,iBAHA;UAIAW,eAJA;UAKAC,iBALA;UAMAC;QANA;MAQA,CATA,MASA;QACA,cACA,4BADA,EAEA,IAFA,EAGA;UACA6F,yBADA;UAEAC,sBAFA;UAGArC;QAHA,CAHA,EASAsC,IATA,CASA;UACA;YACApG,mBADA;YAEAN,sBAFA;YAGAF,iBAHA;YAIAW,eAJA;YAKAC,iBALA;YAMAC;UANA;QAQA,CAlBA,EAmBAgG,KAnBA,CAmBA,QAnBA;MAoBA;IACA,CA1NA;;IA2NA;IACAC;MACA;MACA;MACA,2BACAvB,oDADA;;MAGA;QACAD;QACA;QACA;QACA;MACA;;MACAA;MACAA;MACAA;MACA,uBAfA,CAgBA;MACA;MACA;MACA;IACA,CAhPA;;IAiPA;IACAyB;MACA;MACA;QACA,IACAxB,sBACA,+DAFA,EAGA;UACA;QACA;MACA,CAPA,EAFA,CAUA;;MACA;MACA;QACAA;UACA,SACA,QADA;YAEA3E;UAFA;QAIA,CALA;QAMA;MACA,CARA,EAZA,CAqBA;;MACA,+CAtBA,CAuBA;;MAEA;QACA,uCACAoG,6BADA;;QAGA;UACAzB;UACAA;UACAA;UACAA;QACA;MACA,CAVA;IAWA,CAtRA;;IAuRA;IACA0B;MACA;MACA;MACAjE;MACA;QACA,SACA,OADA;UAEAd,WAFA;UAGAF,UAHA;UAIAD;QAJA;MAMA,CAPA;;MAQA;QACA;QACA;QACA;QACA;QACA;;QACA;UACA;YACAmF;cACAvG,aACAwG,iCACA,GADA,GAEAA,8BAJA;cAKAvG,eACAuG,mCACA,GADA,GAEAA,gCARA;cASAC,uDATA;cAUAC,UACAF,8BACA,GADA,GAEAA,2BAbA;cAcAG;gBACAhI,QADA;gBAEA8G;cAFA,CAdA;cAkBAlE;YAlBA;YAoBAqF;UACA;QACA;;QACA;QACAC;;QACA;UACA;;UACA;YACAA;YACAC;UACA;QACA;;QACA;MACA,CAzCA,MAyCA;QACA;UACA,SACA,OADA;YAEAvF,4CAFA;YAGAoF;cACAhI,QADA;cAEA8G;YAFA;UAHA;QAQA,CATA;MAUA,CAXA,MAWA;QACA;MACA;IACA,CA3VA;;IA4VA;IACA;MACA;;MAEA;QACAd;QACA;QACA;MACA,CAPA,CAQA;;;MACA,yCACAC,qDADA;;MAGA;QACA,sBACA,yCADA;QAGAD;QACAA;QACA;QACA;MACA,CApBA,CAqBA;;;MACA;QAAAxF;MAAA;QACAuH,qCADA;QAEAK,8BAFA;QAGAC;MAHA;MAKArC;MACAA;QACA+B,uBADA;QAEAD,WAFA;QAGAzG;MAHA;MAKA2E;MACA,uBAlCA,CAmCA;;MACA;IACA,CAlYA;;IAmYA;IACAsC;MACA;MACA;MACA;MACA,wDACArC,eADA,EAJA,CAOA;;MACA;IACA,CA7YA;;IA8YA;IACAsC;MACA;MACA,qCACAC,MADA,CACAvC;QACA,OACA,+DADA;MAGA,CALA,EAMAwC,GANA,CAMAxC;QACA;UACA8B,uBADA;UAEAD,WAFA;UAGAzG;QAHA;MAKA,CAZA;MAaA2E,2DACAA,mDADA,EAEA,MAFA;MAIA;MACA,wBApBA,CAqBA;;MACA;IACA,CAtaA;;IAuaA;IACA0C;MACA;;MACA;QACA;UACA;QACA,CAFA;MAGA,CAJA,MAIA;QACA;MACA;IACA,CAjbA;;IAkbA;IACAC;MACA;MACA;MACA,6BACAC,8DADA;IAEA,CAxbA;;IAybA;IACAC;MACA;QACAzB,uBADA;QAEAC,sBAFA;QAGArC;MAHA,GAIAsC,IAJA,CAIA;QACA;UACA,oDACAkB,MADA,CACAvC,kDADA,EAEAwC,GAFA,CAEAK;YACA;UACA,CAJA;QAKA;;QACA,mDACA7C,oDADA;QAGA;QACAD;QACA;MACA,CAlBA;IAmBA,CA9cA;;IA+cA;IACA+C;MACA;QACA3B,uBADA;QAEAC,sBAFA;QAGArC;MAHA,GAIAsC,IAJA,CAIA;QACA,gCADA,CAEA;;QACA;MACA,CARA;IASA,CA1dA;;IA4dA;IACA;MACA;QAAA9G;QAAAwI;MAAA;QACA7C,OADA;QAEAC;MAFA;MAKA,+DANA,CAOA;IACA,CAreA;;IAseA;IACA6C;MACA;QACA;MACA,CAFA;;MAGA;QACA;MACA,CAFA,MAEA;QACA;MACA;;MACA;QACA;UACAjJ,QADA;UAEAkJ;QAFA;MAIA,CALA;;MAMA;QACA;QACA;MACA;IACA,CA1fA;;IA2fA;IACAC;MACA;QACA;MACA,CAFA;IAGA,CAhgBA;;IAigBAC;MACA;QACA;MACA,CAFA;IAGA,CArgBA;;IAsgBA;IACAC;MACA;IACA,CAzgBA;;IA0gBA;IACAC;MACA;MACA;QACA;MACA,CAFA;IAGA,CAhhBA;;IAihBA;IACAC;MACA;;MACA;QACA;MACA;;MACA;MACA;IACA,CAzhBA;;IA0hBA;IACA;IACA;IACAC;MACA,IACAhD,cACA,oDAFA,EAGA;QACA;MACA;;MACA;QACA,SACA,OADA;UAEA5D;QAFA;MAIA,CALA;MAMA;IACA,CA3iBA;;IA4iBA;IACA6G;MACA;MACA;MACA;QACAlH,YADA;QAEAC,WAFA;QAGAG,UAHA;QAIAE;MAJA;IAMA,CAtjBA;;IAujBA;IACA6G;MACA;MACA;MACA;MACA;IACA,CA7jBA;;IA8jBA;IACAC;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA,0BACA,8DADA;QAEA;MACA,CAJA,MAIA;QACA;MACA;;MACA;MACA;QACA1D;QACA,SACA;QADA;MAGA,CALA;IAMA,CAtlBA;;IAulBA2D;MACA;MACA5D;QACAC;MACA,CAFA;MAGA;IACA,CA7lBA;;IA8lBA;IACA4D;MAAApE;MAAAqE;IAAA;MACA;MACA;QACA;QAEA;;QACA;UACA,6CACA,2BADA;UAGA;QACA,CATA,CAWA;;;QACA;UACA;QACA;MACA;;MAEA;MACA,4DACA7D,uBADA,EAEA1D,QAFA,CApBA,CAuBA;;MACA;MACA;QACA;QACA,iBACA,qDADA;UAEAK;QAFA;QAIA;QACA;MACA,CARA;IASA,CAjoBA;;IAkoBA;IACAmH;MACA,mDACA9D,uBADA,EAEA1D,QAFA;IAGA,CAvoBA;;IAwoBA;IACA;MACA;QAAA/B;MAAA;MAEA;MACA;MACA;MACA;MACA;MACA,mBACA,OADA;QAEAiD,gCACAjD,uDADA,GAEA,EAJA;QAKAoD,sBALA;QAMAT,cANA;QAOAC,iBAPA;QAQAF,uBARA;QASAG,sBATA;QAUAE,kCACA/C;UACA;QACA,CAFA,CADA,GAIA,EAdA;QAeAgD;MAfA;;MAiBA;QACA;UACA;YACAA;cACA;YACA,CAFA;UADA;QAKA,CANA;MAOA,CARA,MAQA;QACA,oBACA;UACAA;QADA,CADA;MAKA;;MAEA;QACA;UACAxD,QADA;UAEA8G;QAFA;MAIA,CALA;MAMA;MACA,2CAhDA,CAiDA;;MACA;QACA;UACA,qCACAkD,2CADA;UAGA;YACA9I,+CADA;YAEAG,kCAFA;YAGAC,sCAHA;YAIAZ,iBAJA;YAKAE,sBALA;YAMAW;cACA;gBACAuG,qBADA;gBAEAC,6BAFA;gBAGA1G;cAHA;YAKA,CANA;UANA;QAcA,CAlBA;QAmBA;UACA;;UACA;YACA,+BACA2I,+CADA;;YAGA;cACAC,gBACA,QADA;gBAEArH,wBAFA;gBAGAF,sBAHA;gBAIAD;cAJA;YAMA;UACA;;UACA;YACAG,iBADA;YAEAsC,2BAFA;YAGAgF,6BAHA;YAIAC,iCAJA;YAKAC,aALA;YAMAzH,mBANA;YAOAoF,yBACAU,GADA,CACAxB;cACA;YACA,CAHA,EAIAoD,IAJA,CAIA,GAJA,CAPA;YAYAvC,mBACAW,GADA,CACAxB;cACA;YACA,CAHA,EAIAoD,IAJA,CAIA,GAJA,CAZA;YAiBAhJ,4BACAoH,GADA,CACAxB;cACA;YACA,CAHA,EAIAoD,IAJA,CAIA,GAJA,CAjBA;YAsBA/I,8BACAmH,GADA,CACAxB;cACA;YACA,CAHA,EAIAoD,IAJA,CAIA,GAJA,CAtBA;YA2BArC;cACAhI,QADA;cAEA8G;YAFA;UA3BA;QAgCA,CA/CA;MAgDA;IACA,CAhwBA;;IAiwBA;IACA;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;UACA;UACA;;UAEA;YACA;YACA;UACA;;UACA;YACA;YACA;UACA;;UACA;YACA;YACA;YACAH;cACA;gBACA2D;kBACAvC,4BADA;kBAEAwC;gBAFA,CADA;gBAKAhJ;kBACA;oBACAiJ,oBADA;oBAEAC;kBAFA;gBAIA,CALA;cALA;YAYA,CAbA;YAcA7D;cACA,iBADA,CACA;;cACA,gBAFA,CAEA;;cACA,kBAHA,CAGA;;cACA,uBAJA,CAIA;;cACA;gBACA8D;gBACAH;gBACAE;gBACA1C;cACA,CALA,MAKA;gBACA2C;gBACAH;gBACAxC;gBACA0C;cACA,CAfA,CAgBA;;;cACA;cACA;cACA;cACAxE;gBACA0E;gBACAC;gBACAC;cACA,CAJA;cAKA;gBACA7C,6BADA;gBAEArB;kBACA;oBACA4D,sBADA;oBAEAxC,0BAFA;oBAGA0C,oCAHA;oBAIAD;kBAJA;gBAMA,CAPA,CAFA;gBAUA5H,iBAVA;gBAWAH,qBAXA;gBAYAC;cAZA;;cAcA;gBACAoI;gBACAA;cACA;;cACA;YACA,CA5CA;UA6CA,CA9DA,MA8DA;YACA;UACA;;UACA;UACAC;UACA;YACA;cACA9E;cACAA;cACAA;YACA;;YACA,IACA,6DACA,EADA,IAEA,6BAHA,EAIA;cACA;YACA;;YACA;UACA,CAdA,EA/EA,CA8FA;;UACA;UACA,0BAhGA,CAiGA;;UACA,2CACAA,wCADA;UAGA+E;YACAxH;YACAU,sBACA+B,2DADA;UAGA,CALA;UAMA;YACAxB,qCADA;YAEAlB,mDAFA;YAGAC,sCAHA;YAIAS,qCAJA;YAKAC,4CALA;YAMAH,2BANA;YAOAD,+BAPA;YAQAX,qCARA;YASAC,2CATA;YAUAF,iCAVA;YAWAyD,oBAXA;YAYAC,0BAZA;YAaAlD,mBAbA;YAcAG,iCAdA;YAeAG,yBAfA;YAgBApB,+BAhBA;YAiBAuB,qCAjBA;YAkBAR,yBAlBA;YAmBAS,+BAnBA;YAoBAC,+BApBA;YAqBAC,uCArBA;YAsBAb,iDAtBA;YAuBAe;UAvBA;UAyBA;UACA;;UACA;YACA;cACAwB;YACA,CAFA,MAEA;cACAA;YACA;;YACA;YACA;YAEA;cACAhB,eADA;cAEAJ;YAFA;YAIA;YACA;UACA,CAfA,CAeA;YACA;UACA;QACA;MACA,CA1JA;IA2JA,CA16BA;;IA26BA;IACAqG;MACA;MACA,gDAFA,CAGA;IACA,CAh7BA;;IAi7BA;IACAC;MACA;QACA;UACAlG,aADA;UAEAJ;QAFA;QAIA;MACA;;MACA;MACA;IACA,CA57BA;;IA67BA;MACA;QAAApE;MAAA;MACA;IACA,CAh8BA;;IAi8BA;IACA;MACA;QAAAA;MAAA;QACA2K;MADA;;MAIA;QACA;MACA,CAFA,MAEA;QACA;MACA;IACA,CA58BA;;IA68BA;IACAC;MACAC;IACA,CAh9BA;;IAi9BAC;MACA;IACA,CAn9BA;;IAo9BAC;MACA;QACA/H;MADA;IAGA,CAx9BA;;IAy9BA;IACAgI;MACA;QACA;UACA;YACA;cACA;cACA;YACA;;YACA;YACA;UACA;QACA,CATA;MAUA,CAXA,MAWA;QACA;UACA;UACA;QACA;;QACA;QACA;MACA;IACA,CA9+BA;;IA++BA;IACAC;MACA;QACA;QACA;MACA,CAHA,MAGA;QACA;QACA;MACA;IACA,CAx/BA;;IAy/BAC;MACA;QACA;MACA,CAFA,MAEA;QACA;MACA,CAFA,MAEA;QACA;MACA;IACA,CAjgCA;;IAkgCA;IACAC;MACA;QACA;UACAlJ,YADA;UAEAD,WAFA;UAGAE,UAHA;UAIAH,YAJA;UAKAI,UALA;UAMAC;QANA;QAQA;MACA;IACA;;EA/gCA;AAtLA","names":["getAllUnit","defineSpec","SpecManagegetAll","getGoodsBasicInfoById","editGoodsBasic","addGoodsBasic","getAllCategoryPost","name","components","BrandSelModel","Tinymce","UploadQiniu","AddCate","AddBrand","SelectShop","data","callback","self_spec_val","spec_name_index","self_spec_input","spec_model","spec_item_check","is_indeterminate_spec","spec_check_all","spec_data","spec_data_child","spec_table_Data","sku_list","groupSpecId","groupSpecName","params","add_model","dialogTitle","pid_arr","add_Brand","pageName","loading","img_list","dynamicTags","inputVisible","inputValue","assist_model","edit_assist_model","assist_index","unit_options","assist_form","unitName","isMaster","isDefault","weight","unitId","barCode","conversion","sel_brand","sel_shop","master_unit_name","base_form","specType","delUnitIds","delSpecSkuIds","branchUnit","brandName","categoryPath","assistCategoryPath","noSalesShop","unitData","isEq","masterUnit","describe","storage","title","code","categoryId","assistCategoryId","expireTime","brandId","tag","description","salesShop","images","merchantId","base_rules","required","message","trigger","validator","images_rules","type","base_goods_id","isEditSpec","isNew","sel_merchant","sel_cities","category_data","cate_props","label","value","checkStrictly","assist_cate","page_tabs","step_active","methods","isDefaultChange","target","item","itemB","page","pageSize","source","modelClose","openModel","row","link","submitBrand","specGroup","specMultiple","key","url","specDetailDel","isFalseVal","itemP","uploadSpecSuccess","addSkuP","confirmButtonText","cancelButtonText","then","catch","groupSpecIdChange","specGroupRest","itemC","doExchange","temp","doubleArrays","id","specName","specImage","index","newArray","_count","pid","hidden","addSpecVal","selSpecVal","filter","map","checkAllSpecChange","specItemChange","checkedCount","delSpecVal","itemM","delGroupSpecId","pageTotal","uploadSuccess","content","imgSortChange","uploadRemove","handleClose","showInput","handleInputConfirm","delFuUnit","addFuUnit","EditFuUnit","subAssist","changeWeight","masterUnitChange","$event","branchUnitChange","itemF","barCodeA","inventory","specGroupHash","id_D","join","groupSpec","specId","specValueId","specValueName","specVal","barCodeO","isDefaultO","weightO","returnParams","unitDataD","assistCate","categoryChange","brandConfirm","enableStatus","clickChange","event","delAssistCate","addAssistCate","tagNext","tagLast","tabClick","isEqChange"],"sourceRoot":"src/views/goods/manageG","sources":["AddBaseData.vue"],"sourcesContent":["<!--添加基础资料-->\n<template>\n <ContainerTit>\n <div slot=\"headr\">\n <el-button class=\"bottom-btn\" @click=\"tagLast\">上一步</el-button>\n <el-button\n v-if=\"page_tabs !== '3'\"\n class=\"bottom-btn\"\n type=\"primary\"\n @click=\"tagNext\"\n >\n 下一步\n </el-button>\n <el-button\n v-if=\"page_tabs === '3'\"\n class=\"bottom-btn\"\n type=\"primary\"\n :loading=\"loading\"\n @click=\"submitGoods\"\n >\n 完成,提交发布\n </el-button>\n </div>\n <div class=\"order_top\">\n <div class=\"order_top_content\">\n <el-steps :active=\"step_active\" align-center>\n <el-step title=\"商品信息\" icon=\"el-icon-document\"></el-step>\n <el-step title=\"商品图集\" icon=\"el-icon-picture-outline\"></el-step>\n <el-step title=\"商品属性\" icon=\"el-icon-document\"></el-step>\n </el-steps>\n </div>\n </div>\n <div class=\"order_midden\">\n <div class=\"goods-tab-view\">\n <div class=\"btn-view\">\n <el-button v-if=\"!base_goods_id\" @click=\"delPauseSave(1)\">\n 清空缓存\n </el-button>\n <el-button v-if=\"!base_goods_id\" @click=\"AddTem\">暂存</el-button>\n <el-button\n v-if=\"$route.name !== 'BaseDataDetail'\"\n type=\"primary\"\n :loading=\"loading\"\n @click=\"submitGoods\"\n >\n 保存\n </el-button>\n </div>\n <el-tabs v-model=\"page_tabs\" @tab-click=\"tabClick\">\n <el-tab-pane label=\"商品信息\" name=\"1\"></el-tab-pane>\n <el-tab-pane label=\"商品图集\" name=\"2\"></el-tab-pane>\n <el-tab-pane label=\"商品属性\" name=\"3\"></el-tab-pane>\n </el-tabs>\n </div>\n <div class=\"detail-tab-item\">\n <el-form\n v-show=\"page_tabs === '1'\"\n ref=\"base_form\"\n :model=\"base_form\"\n label-width=\"120px\"\n :rules=\"base_rules\"\n size=\"small\"\n >\n <div class=\"detail-tab-main\">\n <el-row>\n <el-col :span=\"24\">\n <p class=\"order_midden_left_text\">\n <span class=\"el-icon-arrow-right\"></span>\n <span>商品信息</span>\n </p>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item label=\"商品名称:\" prop=\"title\">\n <el-input\n v-model=\"base_form.title\"\n style=\"width: 100%\"\n placeholder=\"请输入商品名称\"\n ></el-input>\n </el-form-item>\n <el-form-item label=\"商品分类:\" prop=\"categoryId\">\n <el-cascader\n v-model=\"base_form.categoryPath\"\n clearable\n style=\"width: calc(100% - 100px)\"\n placeholder=\"请选择商品分类\"\n :options=\"category_data\"\n :props=\"cate_props\"\n @change=\"categoryChange\"\n >\n <div slot-scope=\"scope\" @click=\"clickChange\">\n {{ scope.data.title }}\n </div>\n </el-cascader>\n <el-button size=\"mini\" type=\"text\" @click=\"add_model = true\">\n 【新建分类】\n </el-button>\n </el-form-item>\n <el-form-item label=\"副分类:\">\n <div v-for=\"(item, index) in assist_cate\" :key=\"index\">\n <el-cascader\n v-model=\"item.assistCategoryPath\"\n clearable\n style=\"width: calc(100% - 120px)\"\n placeholder=\"请选择商品分类\"\n :options=\"category_data\"\n :props=\"cate_props\"\n >\n <div slot-scope=\"scope\" @click=\"clickChange\">\n {{ scope.data.title }}\n </div>\n </el-cascader>\n <el-button\n v-if=\"index === 0\"\n size=\"mini\"\n type=\"text\"\n @click=\"addAssistCate\"\n >\n 【添加】\n </el-button>\n <el-button\n v-if=\"assist_cate.length > 1\"\n size=\"mini\"\n type=\"text\"\n @click=\"delAssistCate(index)\"\n >\n 【删除】\n </el-button>\n </div>\n </el-form-item>\n <el-form-item label=\"商品品牌:\" prop=\"brandId\">\n <el-input\n v-model=\"base_form.brandName\"\n readonly\n style=\"width: calc(100% - 100px)\"\n placeholder=\"请选择商品品牌\"\n >\n <i\n slot=\"suffix\"\n class=\"el-input__icon el-icon-search\"\n @click=\"sel_brand = true\"\n ></i>\n </el-input>\n <el-button size=\"mini\" type=\"text\" @click=\"add_Brand = true\">\n 【新建品牌】\n </el-button>\n </el-form-item>\n <el-form-item\n v-if=\"shelfLifeSetUp === 5\"\n label=\"保质期:\"\n prop=\"expireTime\"\n >\n <el-input-number\n v-model=\"base_form.expireTime\"\n style=\"width: calc(100% - 30px)\"\n :controls=\"false\"\n :min=\"1\"\n placeholder=\"请输入商品保质期\"\n ></el-input-number>\n 天\n </el-form-item>\n <el-form-item label=\"抄码商品:\" prop=\"describe\">\n <el-switch\n v-model=\"base_form.isEq\"\n class=\"switchStyle\"\n :disabled=\"isEditSpec === 4\"\n active-text=\"是\"\n inactive-text=\"否\"\n active-color=\"#2153D4\"\n inactive-color=\"#879BBA\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n @change=\"isEqChange\"\n ></el-switch>\n </el-form-item>\n <el-form-item label=\"关键词:\" prop=\"tag\">\n <el-tag\n v-for=\"tag in dynamicTags\"\n :key=\"tag\"\n closable\n :disable-transitions=\"false\"\n @close=\"handleClose(tag)\"\n >\n {{ tag }}\n </el-tag>\n <el-input\n v-if=\"inputVisible\"\n ref=\"saveTagInput\"\n v-model=\"inputValue\"\n class=\"input-new-tag\"\n size=\"small\"\n @keyup.enter.native=\"handleInputConfirm\"\n @blur=\"handleInputConfirm\"\n ></el-input>\n <el-button\n v-else\n class=\"button-new-tag\"\n size=\"small\"\n style=\"\n width: 80px;\n height: 28px;\n font-size: 14px;\n border-radius: 3px;\n line-height: 3px;\n \"\n @click=\"showInput\"\n >\n + 新增\n </el-button>\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item label=\"商品编码:\" prop=\"code\">\n <el-input\n v-model=\"base_form.code\"\n style=\"width: 100%\"\n disabled\n placeholder=\"商品编码自动生成\"\n ></el-input>\n </el-form-item>\n <el-form-item label=\"货架编码:\" prop=\"code\">\n <el-input\n v-model=\"base_form.storage\"\n style=\"width: 100%\"\n placeholder=\"货架编码\"\n ></el-input>\n </el-form-item>\n <el-form-item label=\"禁止销售店铺:\">\n <SelectShop\n v-model=\"base_form.noSalesShop\"\n width=\"530\"\n :multiple=\"true\"\n :enable=\"true\"\n />\n </el-form-item>\n <el-form-item label=\"商品卖点:\" prop=\"describe\">\n <el-input\n v-model=\"base_form.describe\"\n style=\"width: 100%\"\n placeholder=\"请输入商品卖点\"\n ></el-input>\n </el-form-item>\n <el-form-item label=\"商户:\">\n <el-select\n v-if=\"!base_goods_id\"\n v-model=\"base_form.merchantId\"\n placeholder=\"选择商户\"\n style=\"width: 100%\"\n clearable\n >\n <el-option\n v-for=\"(item, index) in sel_cities\"\n :key=\"index\"\n :label=\"item.name\"\n :value=\"item.id\"\n ></el-option>\n </el-select>\n <el-input\n v-else\n v-model=\"base_form.merchantName\"\n style=\"width: 100%\"\n disabled\n ></el-input>\n </el-form-item>\n </el-col>\n </el-row>\n </div>\n <div class=\"detail-tab-main\">\n <div class=\"order_midden_left_text\">\n <span class=\"el-icon-arrow-right\"></span>\n <span>商品单位</span>\n <el-button\n size=\"mini\"\n type=\"text\"\n @click=\"$router.push('/goods/manageG/UnitMeasurement')\"\n >\n 【单位管理】\n </el-button>\n <el-button size=\"mini\" type=\"text\" @click=\"getAllUnit\">\n 【刷新】\n </el-button>\n <span class=\"desc-span\">\n (在商品【采购之后】,基本单位不允许修改,基本单位为最小度量单位)\n </span>\n </div>\n <el-form-item prop=\"masterUnit\">\n <div slot=\"label\">\n <span style=\"color: #e60000\">*</span>\n <span>基本单位</span>\n <el-tooltip\n effect=\"dark\"\n content=\"基本单位与辅助单位之间须有固定的换算关系,例如:1箱牛奶=24盒,【单位关系】为24,基本单位为【盒】,辅助单位为【箱】\"\n placement=\"top-start\"\n >\n <i class=\"el-icon-info\"></i>\n </el-tooltip>\n :\n </div>\n <vxe-select\n v-model=\"base_form.masterUnit.unitId\"\n :disabled=\"isEditSpec === 4\"\n placeholder=\"请选择基本单位\"\n @change=\"masterUnitChange\"\n >\n <vxe-option\n v-for=\"(itemU, indexU) in unit_options\"\n :key=\"indexU\"\n :label=\"itemU.unitName\"\n :disabled=\"\n base_form.isEq === 5 &&\n itemU.unitName !== 'KG' &&\n itemU.unitName !== '斤'\n \"\n :value=\"itemU.id\"\n ></vxe-option>\n </vxe-select>\n <div v-if=\"!spec_table_Data.length\" style=\"display: inline-block\">\n <vxe-input\n v-model=\"base_form.masterUnit.barCode\"\n style=\"width: 200px; margin: 0 12px\"\n placeholder=\"请输入商品条码\"\n ></vxe-input>\n <vxe-input\n v-model=\"base_form.masterUnit.weight\"\n type=\"number\"\n style=\"width: 200px\"\n placeholder=\"请输入商品重量\"\n @blur=\"changeWeight\"\n >\n <template #suffix>\n <span style=\"color: #2d405e\">g</span>\n </template>\n </vxe-input>\n <span style=\"margin-left: 24px\">默认单位:</span>\n <el-switch\n v-model=\"base_form.masterUnit.isDefault\"\n class=\"switchStyle\"\n active-color=\"#2153D4\"\n inactive-color=\"#879BBA\"\n active-text=\"是\"\n inactive-text=\"否\"\n :inactive-value=\"4\"\n :active-value=\"5\"\n @change=\"isDefaultChange($event, 'masterUnit')\"\n ></el-switch>\n </div>\n </el-form-item>\n <el-form-item prop=\"branchUnit\" label=\"辅助单位:\">\n <div\n v-for=\"(itemA, indext) in base_form.branchUnit\"\n :key=\"indext\"\n :style=\"{\n display: !spec_table_Data.length ? 'block' : 'inline-block',\n }\"\n >\n <el-tag\n :closable=\"isEditSpec === 5 || base_form.isEq === 5\"\n :disable-transitions=\"false\"\n @close=\"delFuUnit(itemA, indext)\"\n >\n <span v-if=\"itemA.isNew === 4\">\n 1{{ base_form.masterUnit.unitName }}={{ itemA.conversion\n }}{{ itemA.unitName }}\n </span>\n <span v-else>\n 1{{ itemA.unitName }}={{ itemA.conversion\n }}{{ base_form.masterUnit.unitName }}\n </span>\n </el-tag>\n <div\n v-if=\"!spec_table_Data.length\"\n style=\"display: inline-block\"\n >\n <el-input\n v-model=\"itemA.barCode\"\n style=\"width: 200px; margin: 0 10px\"\n placeholder=\"请输入商品条码\"\n ></el-input>\n <el-input\n v-model=\"itemA.weight\"\n style=\"width: 200px\"\n placeholder=\"请输入商品重量\"\n >\n <el-button slot=\"append\">g</el-button>\n </el-input>\n <span style=\"margin-left: 10px; font-size: 12px\">\n 默认单位:\n </span>\n <el-switch\n v-model=\"itemA.isDefault\"\n class=\"switchStyle\"\n active-color=\"#2153D4\"\n inactive-color=\"#879BBA\"\n active-text=\"是\"\n inactive-text=\"否\"\n :inactive-value=\"4\"\n :active-value=\"5\"\n @change=\"isDefaultChange($event, indext)\"\n ></el-switch>\n </div>\n </div>\n <el-button\n v-if=\"\n base_form.isEq === 4 ||\n (base_form.isEq === 5 && base_form.branchUnit.length < 1)\n \"\n :disabled=\"!base_form.masterUnit.unitName\"\n type=\"text\"\n @click=\"addFuUnit\"\n >\n <i\n style=\"font-size: 14px; margin-right: 10px\"\n class=\"iconfont icon-xinzeng\"\n ></i>\n <span>新增单位</span>\n </el-button>\n </el-form-item>\n </div>\n </el-form>\n <el-form v-show=\"page_tabs === '2'\" label-width=\"120px\" size=\"small\">\n <div class=\"detail-tab-main\">\n <div class=\"order_midden_left_text\">\n <span class=\"el-icon-arrow-right\"></span>\n <span>商品图集</span>\n <span class=\"desc-span\">\n (建议上传尺寸375px*375px,格式:jpg,jpeg,png;\n 大小:建议小于1M。)\n </span>\n </div>\n <el-form-item prop=\"images\" label-width=\"20px\">\n <UploadQiniu\n :limit=\"10\"\n :file-list=\"img_list\"\n @uploadSuccess=\"uploadSuccess\"\n @imgSortChange=\"imgSortChange\"\n @handleRemove=\"uploadRemove\"\n />\n </el-form-item>\n <div class=\"order_midden_left_text\">\n <span class=\"el-icon-arrow-right\"></span>\n <span>商品详情</span>\n </div>\n <Tinymce v-model=\"base_form.description\" :height=\"300\" />\n </div>\n </el-form>\n <el-form v-show=\"page_tabs === '3'\" label-width=\"120px\" size=\"small\">\n <div class=\"detail-tab-main\">\n <div class=\"order_midden_left_text\">\n <span class=\"el-icon-arrow-right\"></span>\n <span>商品属性</span>\n <el-button\n size=\"mini\"\n type=\"text\"\n @click=\"$router.push('/goods/manageG/SpecManage')\"\n >\n 【属性管理】\n </el-button>\n <el-button size=\"mini\" type=\"text\" @click=\"SpecManagegetAll\">\n 【刷新】\n </el-button>\n <span v-if=\"isEditSpec === 5\" class=\"desc-span\">\n (在该商品【采购之前】若不设置商品属性,在该商品【采购之后】,属性不允许重新设置,请谨慎操作!)\n </span>\n <span v-else class=\"desc-span\">\n (请确认当前属性是否有库存,一旦删除该属性无法售卖;新增规格会导致原有库存重置;请谨慎操作!)\n </span>\n </div>\n <div v-if=\"!sku_list.length\">\n <el-button type=\"primary\" @click=\"addSkuP\">添加属性</el-button>\n </div>\n <div v-for=\"(itemS, indexS) in sku_list\" :key=\"indexS\">\n <el-form-item prop=\"groupSpecId\" label=\"属性名:\">\n <el-select\n v-model=\"itemS.groupSpecId\"\n style=\"width: 100%\"\n filterable\n :disabled=\"isEditSpec === 4\"\n placeholder=\"请选择属性\"\n @change=\"groupSpecIdChange($event, indexS)\"\n >\n <el-option\n v-for=\"(itemU, indexU) in spec_data\"\n :key=\"indexU\"\n :label=\"itemU.specName\"\n :value=\"itemU.id\"\n ></el-option>\n </el-select>\n <el-button\n v-if=\"isEditSpec === 5\"\n type=\"text\"\n size=\"mini\"\n @click=\"delGroupSpecId(indexS)\"\n >\n 删除\n </el-button>\n <el-button\n v-if=\"indexS === 0 && isEditSpec === 5\"\n type=\"text\"\n @click=\"addSkuP\"\n >\n <i\n style=\"font-size: 14px; margin-right: 5px\"\n class=\"iconfont icon-xinzeng\"\n ></i>\n 添加属性\n </el-button>\n </el-form-item>\n <el-form-item label=\"属性值:\" prop=\"params\">\n <el-tag\n v-for=\"(itemC, indexC) in itemS.params\"\n :key=\"indexC\"\n :closable=\"isEditSpec === 5\"\n :disable-transitions=\"false\"\n @close=\"delSpecVal(indexC, indexS, itemC)\"\n >\n {{ itemC.specName }}\n </el-tag>\n <el-button\n :disabled=\"!itemS.groupSpecId\"\n type=\"text\"\n @click=\"addSpecVal(indexS)\"\n >\n + 选择属性值\n </el-button>\n <el-input\n v-if=\"itemS.self_spec_input\"\n v-model=\"itemS.self_spec_val\"\n size=\"small\"\n style=\"width: 200px\"\n placeholder=\"请输入内容\"\n >\n <el-button\n slot=\"append\"\n icon=\"el-icon-check\"\n @click=\"selfSpecConfirm(indexS)\"\n ></el-button>\n </el-input>\n <el-button\n v-else\n :disabled=\"!itemS.groupSpecId\"\n type=\"text\"\n @click=\"itemS.self_spec_input = true\"\n >\n + 新增属性值\n </el-button>\n </el-form-item>\n </div>\n <!-- 规格明细-->\n <div v-show=\"spec_table_Data.length > 0\">\n <p class=\"order_midden_left_text\">\n <span class=\"el-icon-arrow-right\"></span>\n <span>规格明细</span>\n </p>\n <el-table :data=\"spec_table_Data\">\n <el-table-column width=\"50\" type=\"index\"></el-table-column>\n <el-table-column\n v-for=\"(item, index) in sku_list\"\n :key=\"index\"\n prop=\"specName\"\n min-width=\"100px\"\n :label=\"item.groupSpecName\"\n >\n <template slot-scope=\"scope\">\n {{\n scope.row.specName.indexOf(\"_\") > -1\n ? scope.row.specName.split(\"_\")[index] || \"\"\n : scope.row.specName\n }}\n </template>\n </el-table-column>\n <el-table-column\n prop=\"specImage\"\n label=\"规格图片\"\n min-width=\"140px\"\n >\n <template slot-scope=\"scope\">\n <UploadQiniu\n :width=\"50\"\n is-btn=\"picture\"\n :file-list=\"\n scope.row.specImage.url ? [scope.row.specImage] : []\n \"\n @uploadSuccess=\"uploadSpecSuccess($event, scope.$index)\"\n ></UploadQiniu>\n </template>\n </el-table-column>\n <el-table-column label=\"商品条码\" min-width=\"200px\">\n <template slot-scope=\"scope\">\n <div\n v-for=\"(itemU, indexU) in scope.row.barCode\"\n :key=\"indexU\"\n style=\"padding-bottom: 5px\"\n >\n <span>{{ itemU.unitName }}:</span>\n <el-input\n v-model=\"itemU.barCode\"\n style=\"width: 160px\"\n size=\"small\"\n placeholder=\"请输入商品条码\"\n ></el-input>\n </div>\n </template>\n </el-table-column>\n <el-table-column label=\"商品重量\" min-width=\"200px\">\n <template slot-scope=\"scope\">\n <div\n v-for=\"(itemU, indexU) in scope.row.barCode\"\n :key=\"indexU\"\n style=\"padding-bottom: 5px\"\n >\n <span>{{ itemU.unitName }}:</span>\n <el-input\n v-model=\"itemU.weight\"\n style=\"width: 160px\"\n size=\"small\"\n placeholder=\"请输入商品重量 (g)\"\n >\n <el-button slot=\"append\">g</el-button>\n </el-input>\n </div>\n </template>\n </el-table-column>\n <el-table-column label=\"默认属性\" min-width=\"140px\">\n <template slot-scope=\"scope\">\n <div\n v-for=\"(itemU, indexU) in scope.row.barCode\"\n :key=\"indexU\"\n style=\"padding-bottom: 5px\"\n >\n <span>{{ itemU.unitName }}:</span>\n <el-switch\n v-model=\"itemU.isDefault\"\n active-color=\"#36B365\"\n inactive-color=\"#ff4949\"\n active-text=\"是\"\n inactive-text=\"否\"\n :inactive-value=\"4\"\n :active-value=\"5\"\n @change=\"isDefaultChange($event, indexU, scope.$index)\"\n ></el-switch>\n </div>\n </template>\n </el-table-column>\n <el-table-column\n v-if=\"!!base_goods_id\"\n prop=\"inventory\"\n min-width=\"120px\"\n label=\"库存\"\n >\n <template slot-scope=\"scope\">\n {{\n scope.row.isEditSpec === 5\n ? \"无记录\"\n : scope.row.inventory\n }}\n </template>\n </el-table-column>\n <el-table-column label=\"操作\" min-width=\"80px\">\n <template slot-scope=\"scope\">\n <el-button\n :disabled=\"scope.row.isEditSpec === 4\"\n type=\"text\"\n @click=\"specDetailDel(scope.row, scope.$index)\"\n >\n 删除\n </el-button>\n </template>\n </el-table-column>\n </el-table>\n </div>\n </div>\n </el-form>\n </div>\n </div>\n <el-dialog\n :close-on-press-escape=\"false\"\n :close-on-click-modal=\"false\"\n :title=\"edit_assist_model ? '修改辅助单位' : '新增辅助单位'\"\n :visible.sync=\"assist_model\"\n width=\"40%\"\n >\n <el-form\n style=\"text-align: center\"\n :model=\"assist_form\"\n size=\"small\"\n inline\n >\n <div v-if=\"isNew === 4\">\n <el-form-item prop=\"conversion\">\n 1\n {{ base_form.masterUnit.unitName }}\n =\n </el-form-item>\n <el-form-item prop=\"unitName\">\n <el-input-number\n v-model=\"assist_form.conversion\"\n :controls=\"false\"\n ></el-input-number>\n <el-select\n v-model=\"assist_form.unitId\"\n placeholder=\"请选择辅助单位\"\n @change=\"branchUnitChange\"\n >\n <el-option\n v-for=\"(item, index) in unit_options\"\n :key=\"index\"\n :label=\"item.unitName\"\n :value=\"item.id\"\n :disabled=\"item.unitName === base_form.masterUnit.unitName\"\n ></el-option>\n </el-select>\n </el-form-item>\n </div>\n <div v-else>\n <el-form-item prop=\"conversion\">\n 1\n <el-select\n v-model=\"assist_form.unitId\"\n placeholder=\"请选择辅助单位\"\n @change=\"branchUnitChange\"\n >\n <template v-for=\"(item, index) in unit_options\">\n <el-option\n :key=\"index\"\n :label=\"item.unitName\"\n :value=\"item.id\"\n :disabled=\"item.unitName === base_form.masterUnit.unitName\"\n ></el-option>\n </template>\n </el-select>\n =\n </el-form-item>\n <el-form-item prop=\"unitName\">\n <el-input-number\n v-model=\"assist_form.conversion\"\n :controls=\"false\"\n ></el-input-number>\n {{ base_form.masterUnit.unitName }}\n </el-form-item>\n </div>\n </el-form>\n <span slot=\"footer\" class=\"dialog-footer\">\n <el-button @click=\"assist_model = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"subAssist\">确 定</el-button>\n </span>\n </el-dialog>\n <!-- 属性值 -->\n <el-dialog title=\"属性值\" :visible.sync=\"spec_model\" width=\"40%\">\n <el-checkbox\n v-model=\"spec_check_all\"\n :indeterminate=\"is_indeterminate_spec\"\n @change=\"checkAllSpecChange\"\n >\n 全选\n </el-checkbox>\n <div style=\"margin: 15px 0\"></div>\n <el-checkbox-group v-model=\"spec_item_check\" @change=\"specItemChange\">\n <el-checkbox\n v-for=\"(item, index) in spec_data_child\"\n :key=\"index\"\n :label=\"item.id\"\n >\n {{ item.specName }}\n </el-checkbox>\n </el-checkbox-group>\n <span slot=\"footer\" class=\"dialog-footer\">\n <el-button @click=\"spec_model = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"selSpecVal\">确 定</el-button>\n </span>\n </el-dialog>\n <BrandSelModel\n v-if=\"sel_brand\"\n :is-check=\"false\"\n :is-show-add=\"true\"\n :dialog-visible=\"sel_brand\"\n :enable=\"true\"\n @close=\"sel_brand = false\"\n @confirm=\"brandConfirm\"\n />\n <!----------------- 添加分类 ----------->\n <AddCate\n v-if=\"add_model\"\n :dialog-title=\"dialogTitle\"\n :is-show=\"add_model\"\n :pid-path=\"pid_arr\"\n @confirm=\"subCategory\"\n @cancel=\"modelClose\"\n />\n <!-- 新建品牌-->\n <el-drawer\n class=\"edit-drawer\"\n size=\"50%\"\n :visible.sync=\"add_Brand\"\n direction=\"rtl\"\n >\n <AddBrand v-if=\"add_Brand\" @submitBrand=\"submitBrand\" />\n </el-drawer>\n </ContainerTit>\n</template>\n\n<script>\n import GoodsCategory from \"@/component/common/GoodsCategory.vue\";\n import BrandSelModel from \"@/component/goods/BrandSelModel.vue\";\n import Tinymce from \"@/component/Tinymce\";\n import UploadQiniu from \"@/component/common/UploadQiniu.vue\";\n // 新增分类\n import AddCate from \"@/component/goods/AddCate.vue\";\n import AddBrand from \"./AddBrand\";\n import SelectShop from \"@/component/goods/SelectShop.vue\";\n import {\n getAllUnit,\n defineSpec,\n SpecManagegetAll,\n getGoodsBasicInfoById,\n editGoodsBasic,\n addGoodsBasic,\n getAllCategoryPost,\n } from \"@/api/goods\";\n import { addPauseSave, delPauseSave, getPauseSave } from \"@/api/common\";\n import { getAllMerchantList } from \"@/api/Merchants\";\n export default {\n name: \"AddBaseData\",\n components: {\n // GoodsCategory,\n BrandSelModel,\n Tinymce,\n UploadQiniu,\n AddCate,\n AddBrand,\n SelectShop,\n },\n data() {\n const validateUnit = (rule, value, callback) => {\n if (value.unitName === \"\") {\n callback(new Error(\"请设置基本单位\"));\n } else {\n callback();\n }\n };\n return {\n // 计量单位\n self_spec_val: \"\", // 自定义属性值输入框\n spec_name_index: 0, // 属性名index\n self_spec_input: false, // 显示自定义属性值输入框\n spec_model: false, // 选择属性值弹窗\n spec_item_check: [], // 属性值弹窗单选value\n is_indeterminate_spec: false, // 批量选择属性值 全选选择框状态\n spec_check_all: false, // 属性值 全选选择框value\n spec_data: [], // 属性列表\n spec_data_child: [], // 属性值列表\n spec_table_Data: [], // 规格明细\n sku_list: [\n // 商品属性列表\n {\n spec_data_child: [],\n groupSpecId: \"\",\n self_spec_val: \"\",\n self_spec_input: false,\n groupSpecName: \"\",\n params: [],\n },\n ],\n add_model: false, // 新建分类\n dialogTitle: \"新建分类\",\n pid_arr: [],\n add_Brand: false, // 新增品牌\n pageName: \"\", // 暂存数据参数\n loading: false,\n img_list: [],\n // 关键词\n dynamicTags: [],\n inputVisible: false,\n inputValue: \"\",\n // 关键词 END\n assist_model: false,\n edit_assist_model: false,\n assist_index: 0,\n unit_options: [],\n // 计量单位弹窗\n assist_form: {\n unitName: \"\",\n isMaster: 4,\n isDefault: 4,\n weight: \"\",\n unitId: \"\",\n barCode: \"\",\n conversion: \"\",\n },\n sel_brand: false, // 打开品牌选择弹窗\n sel_shop: false, // 打开店铺选择弹窗\n master_unit_name: \"\",\n base_form: {\n // 基本信息\n specType: 1, // 是否多规格\n delUnitIds: [], // 辅助单位删除delUnitIds (unitId)\n delSpecSkuIds: [], // 属性删除delSpecSkuIds(这个用id)\n branchUnit: [],\n brandName: \"\",\n categoryPath: [], // 分类选择\n assistCategoryPath: [], //副分类\n noSalesShop: [],\n unitData: [],\n isEq: 4, //是否是抄码商品\n masterUnit: {\n isDefault: 5,\n isMaster: 5,\n weight: \"\",\n unitName: \"\",\n unitId: \"\",\n barCode: \"\",\n },\n describe: \"\",\n storage: \"\",\n title: \"\",\n code: \"\",\n barCode: \"\", // 商品条码\n categoryId: \"\",\n assistCategoryId: \"\",\n expireTime: \"\",\n brandId: \"\",\n tag: \"\",\n description: \"\",\n salesShop: \"\",\n images: [],\n merchantId: \"\", //商户ID\n },\n base_rules: {\n // 基本信息验证\n title: [\n { required: true, message: \"请输入商品名称\", trigger: \"blur\" },\n ],\n categoryId: [\n { required: true, message: \"请选择商品分类\", trigger: \"change\" },\n ],\n expireTime: [\n { required: true, message: \"请输入商品保质期\", trigger: \"blur\" },\n ],\n masterUnit: [{ validator: validateUnit, trigger: \"change\" }],\n },\n\n images_rules: {\n images: [\n {\n type: \"array\",\n required: true,\n message: \"请上传商品图片\",\n trigger: \"change\",\n },\n ],\n },\n base_goods_id: 0,\n isEditSpec: 5, // 5 表示此商品从未采购过,允许用户随意编辑单位和属性;4 表示商品已经采购过,隐藏添加属性按钮,避免skuid重组\n isNew: 5, // 5 标示这是一个最近新增的商品,基本单位为最小单位,4标示这是之前的老数据,基本单位为最大单位3\n sel_merchant: false,\n sel_cities: [],\n category_data: [], //商品分类列表\n cate_props: {\n label: \"title\",\n value: \"id\",\n checkStrictly: true,\n },\n assist_cate: [\n {\n assistCategoryPath: [],\n },\n ],\n page_tabs: \"1\",\n step_active: 1,\n };\n },\n async created() {\n // this.getAllGoodsSupport();\n // 商品分类列表\n await this.getAllCategoryPost();\n this.pageName = this.$route.name;\n\n // 商户管理\n await this.getAllMerchantList();\n // 属性管理\n await this.SpecManagegetAll();\n await this.getAllUnit();\n if (this.$route.params.id) {\n this.base_goods_id = this.$route.params.id;\n await this.getGoodsBasicInfoById();\n } else {\n // 获取暂存信息\n await this.getPauseSave();\n }\n },\n async activated() {\n if (this.$_isInit()) return;\n this.pageName = this.$route.name;\n this.step_active = 1;\n this.page_tabs = \"1\";\n if (this.$route.params.id) {\n this.base_goods_id = this.$route.params.id;\n await this.getGoodsBasicInfoById();\n } else {\n // 获取暂存信息\n await this.getPauseSave();\n }\n },\n methods: {\n // 默认单位change\n isDefaultChange(val, index, sIndex) {\n // 多规格数据\n if (this.spec_table_Data.length > 0) {\n if (val === 5) {\n const target = this.$_common.deepClone(this.spec_table_Data);\n target.forEach((item, indexS) => {\n item.barCode.forEach((itemB, indexB) => {\n if (indexS !== sIndex) {\n itemB.isDefault = 4;\n } else {\n if (indexB !== index) {\n itemB.isDefault = 4;\n }\n }\n });\n });\n this.spec_table_Data = target;\n }\n } else {\n if (val === 5) {\n if (index === \"masterUnit\") {\n this.base_form.branchUnit.forEach((item) => {\n item.isDefault = 4;\n });\n } else {\n this.base_form.masterUnit.isDefault = 4;\n this.base_form.branchUnit.forEach((item, indexU) => {\n if (indexU !== index) {\n item.isDefault = 4;\n }\n });\n }\n }\n }\n },\n // 请求基本单位数据\n async getAllUnit() {\n const { data } = await getAllUnit({\n page: 1,\n pageSize: 99,\n source: 4,\n });\n\n this.unit_options = data;\n },\n modelClose() {\n this.add_model = false;\n },\n // 打开新增弹窗\n openModel(title, row) {\n this.add_model = true;\n this.dialogTitle = title;\n if (title === \"新建子分类\") {\n let link = row.link\n ? row.link.split(\",\").map((item) => {\n return parseInt(item);\n })\n : [];\n link.push(row.id);\n this.pid_arr = link;\n }\n },\n // 新增/编辑分类\n async subCategory() {\n await this.getAllCategoryPost();\n },\n // 新建品牌\n submitBrand() {\n this.add_Brand = false;\n },\n // 添加暂存\n async AddTem() {\n const params = {\n ...this.base_form,\n specGroup: this.sku_list,\n specMultiple: this.spec_table_Data,\n tag: this.dynamicTags,\n assist_cate: this.assist_cate,\n };\n const data = await addPauseSave({\n key: this.pageName,\n data: params,\n });\n this.$message({\n type: \"success\",\n message: \"暂存成功\",\n });\n this.$closeCurrentGoEdit(\"/goods/manageG/BaseDataList\");\n },\n // 删除暂存信息\n async delPauseSave(type) {\n const data = delPauseSave({\n key: this.pageName,\n });\n\n if (type) {\n this.$message({\n type: \"success\",\n message: \"清除暂存成功\",\n });\n this.$closeCurrentGoEdit(\"/goods/manageG/AddBaseData\");\n }\n },\n // 获取暂存信息\n async getPauseSave() {\n const { data } = await getPauseSave({\n key: this.pageName,\n });\n\n if (JSON.stringify(data) === \"{}\") return;\n this.base_form = {\n ...data,\n categoryPath: Array.isArray(data.categoryPath)\n ? data.categoryPath\n : [],\n };\n this.assist_cate = data.assist_cate || [{ assistCategoryPath: [] }];\n this.sku_list = data.specGroup || [];\n this.spec_table_Data = data.specMultiple || [];\n this.dynamicTags = data.tag || [];\n if (data.images) {\n this.img_list = data.images.map((item) => {\n return {\n name: \"\",\n url: item,\n };\n });\n }\n },\n\n // 规格明细删除\n specDetailDel(row, index) {\n if (\n row.specGroupHash &&\n this.base_form.delSpecSkuIds.indexOf(row.specGroupHash) === -1\n ) {\n this.base_form.delSpecSkuIds.push(row.specGroupHash);\n }\n this.spec_table_Data.splice(index, 1);\n const specNameArr = row.specName.indexOf(\"_\")\n ? row.specName.split(\"_\")\n : row.specName;\n // console.log('specNameArr', row.specName)\n // console.log('this.spec_table_Data', this.spec_table_Data)\n let isFalseVal = \"\";\n for (let i in specNameArr) {\n let itemS = specNameArr[i];\n // console.log(itemS)\n // console.log(this.spec_table_Data.find(item => item.specName.indexOf(itemS) > -1))\n if (\n !this.spec_table_Data.find(\n (item) => item.specName.indexOf(itemS) > -1\n )\n ) {\n isFalseVal = itemS;\n break;\n }\n }\n // console.log('isStay,', isFalseVal)\n // console.log(this.sku_list)\n if (isFalseVal) {\n this.sku_list.forEach((item) => {\n const indexP = item.params.findIndex(\n (itemP) => itemP.specName === isFalseVal\n );\n if (indexP > -1) {\n item.params.splice(indexP, 1);\n }\n });\n }\n },\n // ddel(val) {\n // this.from.categoryPath = val;\n // },\n // 规格图片\n uploadSpecSuccess(val, index) {\n let target = this.$_common.deepClone(this.spec_table_Data);\n target[index].specImage = {\n name: \"\",\n url: val,\n };\n this.spec_table_Data = target;\n },\n // 添加规格项目\n addSkuP() {\n if (this.isEditSpec === 5) {\n this.sku_list.push({\n spec_data_child: [],\n self_spec_input: false,\n self_spec_val: \"\",\n groupSpecId: \"\",\n groupSpecName: \"\",\n params: [],\n });\n } else {\n this.$confirm(\n \"新增规格会导致原有库存重置,请谨慎操作! 是否继续?\",\n \"提示\",\n {\n confirmButtonText: \"继续新增\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }\n )\n .then(() => {\n this.sku_list.push({\n spec_data_child: [],\n self_spec_input: false,\n self_spec_val: \"\",\n groupSpecId: \"\",\n groupSpecName: \"\",\n params: [],\n });\n })\n .catch(() => {});\n }\n },\n // 规格明切换\n groupSpecIdChange(val, indexS) {\n let target = this.$_common.deepClone(this.sku_list);\n const specDataItem = this.spec_data.find((item) => item.id === val);\n const isHave = target.find(\n (item) => item.groupSpecName === specDataItem.specName\n );\n if (isHave) {\n target[indexS].groupSpecId = \"\";\n this.sku_list = target;\n this.$message.warning(`属性:【${specDataItem.specName}】已存在`);\n return;\n }\n target[indexS].groupSpecName = specDataItem.specName;\n target[indexS].spec_data_child = specDataItem.child || [];\n target[indexS].params = [];\n this.sku_list = target;\n // 重排规格组合\n // this.specGroupRest()\n // console.log(this.sku_list)\n // console.log(this.spec_table_Data)\n },\n // 重排规格组合\n specGroupRest() {\n // 编辑页面存储详情接口返回规格组合id\n this.spec_table_Data.forEach((item) => {\n if (\n item.specGroupHash &&\n this.base_form.delSpecSkuIds.indexOf(item.specGroupHash) === -1\n ) {\n this.base_form.delSpecSkuIds.push(item.specGroupHash);\n }\n });\n // 备份一份规格明细,用来填充重排规格组之前的数据\n const cloneSpecGroup = this.$_common.deepClone(this.spec_table_Data);\n const skuArr = this.sku_list.map((item) => {\n item.params = item.params.map((itemP) => {\n return {\n ...itemP,\n groupSpecName: item.groupSpecName,\n };\n });\n return item.params;\n });\n // console.log('skuArr::', skuArr)\n this.spec_table_Data = this.doExchange(skuArr);\n // console.log(this.spec_table_Data)\n\n this.spec_table_Data.forEach((item) => {\n const index = cloneSpecGroup.findIndex(\n (itemC) => itemC.id === item.id\n );\n if (index > -1) {\n item.barCode = cloneSpecGroup[index].barCode;\n item.specImage = cloneSpecGroup[index].specImage;\n item.inventory = cloneSpecGroup[index].inventory;\n item.isEditSpec = cloneSpecGroup[index].isEditSpec || 5;\n }\n });\n },\n // 规格组合\n doExchange(doubleArrays) {\n const len = doubleArrays.length;\n let unitData = this.$_common.deepClone(this.base_form.branchUnit);\n unitData.unshift(this.base_form.masterUnit);\n const barCodeArr = unitData.map((item) => {\n return {\n ...item,\n barCode: \"\",\n weight: \"\",\n isDefault: 4,\n };\n });\n if (len >= 2) {\n const len1 = doubleArrays[0].length;\n const len2 = doubleArrays[1].length;\n const newlen = len1 * len2;\n const temp = new Array(newlen);\n let index = 0;\n for (let i = 0; i < len1; i++) {\n for (let j = 0; j < len2; j++) {\n temp[index] = {\n groupSpecId:\n doubleArrays[0][i].groupSpecId +\n \"_\" +\n doubleArrays[1][j].groupSpecId,\n groupSpecName:\n doubleArrays[0][i].groupSpecName +\n \"_\" +\n doubleArrays[1][j].groupSpecName,\n id: doubleArrays[0][i].id + \"_\" + doubleArrays[1][j].id,\n specName:\n doubleArrays[0][i].specName +\n \"_\" +\n doubleArrays[1][j].specName,\n specImage: {\n name: \"\",\n url: \"\",\n },\n barCode: this.$_common.deepClone(barCodeArr),\n };\n index++;\n }\n }\n let newArray = new Array(len - 1);\n newArray[0] = temp;\n if (len > 2) {\n let _count = 1;\n for (let i = 2; i < len; i++) {\n newArray[_count] = doubleArrays[i];\n _count++;\n }\n }\n return this.doExchange(newArray);\n } else if (len > 0) {\n return doubleArrays[0].map((item) => {\n return {\n ...item,\n barCode: this.$_common.deepClone(barCodeArr),\n specImage: {\n name: \"\",\n url: \"\",\n },\n };\n });\n } else {\n return [];\n }\n },\n // 自定义属性值输入框确定 添加自定义属性\n async selfSpecConfirm(index) {\n const target = this.$_common.deepClone(this.sku_list);\n\n if (!target[index].self_spec_val) {\n target[index].self_spec_input = false;\n this.sku_list = target;\n return;\n }\n // 检查当前属性值是否已被选择\n const isHave = target[index].params.find(\n (item) => item.specName === target[index].self_spec_val\n );\n if (isHave) {\n this.$message.warning(\n `属性值:【${target[index].self_spec_val}】已存在`\n );\n target[index].self_spec_val = \"\";\n target[index].self_spec_input = false;\n this.sku_list = target;\n return;\n }\n // 属性值未被选择 做接口请求\n const { data } = await defineSpec({\n specName: target[index].self_spec_val,\n pid: target[index].groupSpecId,\n hidden: 4,\n });\n target[index].self_spec_input = false;\n target[index].params.push({\n specName: data.specName,\n id: data.id,\n groupSpecId: target[index].groupSpecId,\n });\n target[index].self_spec_val = \"\";\n this.sku_list = target;\n // 重排规格组合\n this.specGroupRest();\n },\n // 新增规格值\n addSpecVal(indexS) {\n this.spec_model = true;\n this.spec_data_child = this.sku_list[indexS].spec_data_child;\n this.spec_name_index = indexS;\n this.spec_item_check = this.sku_list[indexS].params.map(\n (item) => item.id\n );\n // 使用属性值单选方法,为了设置全选选择框状态\n this.specItemChange(this.spec_item_check);\n },\n // 选择属性值\n selSpecVal() {\n const target = this.$_common.deepClone(this.sku_list);\n const specval = this.spec_data_child\n .filter((item) => {\n return (\n this.spec_item_check.findIndex((itemS) => itemS === item.id) > -1\n );\n })\n .map((item) => {\n return {\n specName: item.specName,\n id: item.id,\n groupSpecId: item.pid,\n };\n });\n target[this.spec_name_index].params = this.$_common.unique(\n target[this.spec_name_index].params.concat(specval),\n [\"id\"]\n );\n this.sku_list = target;\n this.spec_model = false;\n // 重排规格组合\n this.specGroupRest();\n },\n // 属性值全选\n checkAllSpecChange(val) {\n this.is_indeterminate_spec = false;\n if (val) {\n this.spec_item_check = this.spec_data_child.map((item) => {\n return item.id;\n });\n } else {\n this.spec_item_check = [];\n }\n },\n // 属性值单选\n specItemChange(val) {\n let checkedCount = val.length;\n this.spec_check_all = checkedCount === this.spec_data_child.length;\n this.is_indeterminate_spec =\n checkedCount > 0 && checkedCount < this.spec_data_child.length;\n },\n // 删除规格值\n delSpecVal(indexC, indexS, itemC) {\n this.$confirm(\"确定要删除该规格值吗?\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n if (this.base_goods_id) {\n this.base_form.delSpecSkuIds = this.spec_table_Data\n .filter((item) => item.specName.indexOf(itemC.specName) > -1)\n .map((itemM) => {\n return itemM.specGroupHash;\n });\n }\n this.spec_table_Data = this.spec_table_Data.filter(\n (item) => item.specName.indexOf(itemC.specName) === -1\n );\n const target = this.$_common.deepClone(this.sku_list);\n target[indexS].params.splice(indexC, 1);\n this.sku_list = target;\n });\n },\n // 删除规格组\n delGroupSpecId(indexS) {\n this.$confirm(\"确定要删除该规格组吗?\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n this.sku_list.splice(indexS, 1);\n // 重排规格组合\n this.specGroupRest();\n });\n },\n\n // 获取属性列表\n async SpecManagegetAll() {\n const { data, pageTotal } = await SpecManagegetAll({\n page: 1,\n pageSize: 100,\n });\n\n this.spec_data = data.filter((item) => item.specName !== \"计量单位\");\n // this.unit_options = data.find(item => item.specName === '计量单位').child\n },\n // 选择图片\n uploadSuccess(val, res, file, fileList) {\n const imgArr = fileList.map((item) => {\n return item.content;\n });\n if (this.base_form.images.length) {\n this.base_form.images = this.base_form.images.concat(imgArr);\n } else {\n this.base_form.images = imgArr;\n }\n this.img_list = this.base_form.images.map((item) => {\n return {\n name: \"\",\n content: item,\n };\n });\n if (this.img_list.length > 10) {\n this.$message.warning(\"图片最多只能选择十张\");\n this.img_list = this.img_list.slice(0, 10);\n }\n },\n // 图片拖拽排序\n imgSortChange(list) {\n this.base_form.images = list.map((item) => {\n return item.content;\n });\n },\n uploadRemove(file, fileList) {\n this.base_form.images = fileList.map((item) => {\n return item.content;\n });\n },\n // 关键词删除\n handleClose(tag) {\n this.dynamicTags.splice(this.dynamicTags.indexOf(tag), 1);\n },\n // 关键词显示输入框\n showInput() {\n this.inputVisible = true;\n this.$nextTick(() => {\n this.$refs.saveTagInput.$refs.input.focus();\n });\n },\n // 关键词显示输入确定\n handleInputConfirm() {\n let inputValue = this.inputValue;\n if (inputValue) {\n this.dynamicTags.push(inputValue);\n }\n this.inputVisible = false;\n this.inputValue = \"\";\n },\n // 关键词END\n // 设置计量单位\n // 删除辅助单位\n delFuUnit(row, it) {\n if (\n row.unitId &&\n this.base_form.delUnitIds.indexOf(row.unitId) === -1\n ) {\n this.base_form.delUnitIds.push(row.unitId);\n }\n this.spec_table_Data = this.spec_table_Data.map((item) => {\n return {\n ...item,\n barCode: item.barCode.filter((item) => item.unitId !== row.unitId),\n };\n });\n this.base_form.branchUnit.splice(it, 1);\n },\n // 新增辅助单位\n addFuUnit() {\n this.assist_model = true;\n this.edit_assist_model = false;\n this.assist_form = {\n unitName: \"\",\n isMaster: 4,\n unitId: \"\",\n conversion: \"\",\n };\n },\n // 修改附单位\n EditFuUnit(it) {\n this.assist_model = true;\n this.edit_assist_model = true;\n this.assist_form = this.base_form.branchUnit[it];\n this.assist_index = it;\n },\n // 弹窗提交\n subAssist() {\n if (!this.assist_form.conversion) {\n this.$message.warning(\"请输入单位件换算关系\");\n return;\n }\n if (!this.assist_form.unitName) {\n this.$message.warning(\"请选择辅助单位\");\n return;\n }\n if (!this.edit_assist_model) {\n this.assist_form.weight =\n this.base_form.masterUnit.weight * this.assist_form.conversion;\n this.base_form.branchUnit.push(this.assist_form);\n } else {\n this.base_form.branchUnit[this.assist_index] = this.assist_form;\n }\n this.assist_model = false;\n this.spec_table_Data = this.spec_table_Data.map((item) => {\n item.barCode.push(this.$_common.deepClone(this.assist_form));\n return {\n ...item,\n };\n });\n },\n changeWeight() {\n const target = this.$_common.deepClone(this.base_form.branchUnit);\n target.forEach((item) => {\n item.weight = this.base_form.masterUnit.weight * item.conversion;\n });\n this.base_form.branchUnit = target;\n },\n // 基本单位切换\n masterUnitChange({ value, $event }) {\n // 编辑页面把删除 的单位ID存储下来\n if (!!this.base_goods_id) {\n const unitData = this.$_common.deepClone(this.base_form.unitData);\n\n this.base_form.delUnitIds = unitData.map((item) => item.unitId);\n if (this.base_form.specType === 1) {\n const specMultiple = this.$_common.deepClone(\n this.base_form.specMultiple\n );\n this.base_form.delSpecSkuIds = specMultiple.map((item) => item.id);\n }\n\n //把所有的单位删除,重新设置一个新的主单位\n if (this.base_form.masterUnit.id) {\n delete this.base_form.masterUnit.id;\n }\n }\n\n const val = value;\n this.base_form.masterUnit.unitName = this.unit_options.find(\n (item) => item.id === val\n ).unitName;\n // 重置辅助单位\n this.base_form.branchUnit = [];\n this.spec_table_Data = this.spec_table_Data.map((item) => {\n const index = item.barCode.findIndex((itemF) => itemF.isMaster === 5);\n const barObj = {\n ...this.$_common.deepClone(this.base_form.masterUnit),\n barCode: item.barCode[index].barCode || \"\",\n };\n this.$set(item.barCode, index, barObj);\n return item;\n });\n },\n // 辅助单位切换\n branchUnitChange(val) {\n this.assist_form.unitName = this.unit_options.find(\n (item) => item.id === val\n ).unitName;\n },\n // 获取详情\n async getGoodsBasicInfoById() {\n const { data } = await getGoodsBasicInfoById(this.base_goods_id);\n\n this.isEditSpec = data.isEditSpec;\n const unitData = this.$_common.deepClone(data.unitData);\n const masterUnit = unitData.find((item) => item.isMaster === 5) || {};\n const branchUnit = unitData.filter((item) => item.isMaster === 4);\n this.isNew = masterUnit.isNew || 4;\n this.base_form = {\n ...data,\n noSalesShop: data.noSalesShop\n ? data.noSalesShop.split(\",\").map((item) => parseInt(item))\n : [],\n masterUnit: masterUnit,\n delUnitIds: [],\n delSpecSkuIds: [],\n specType: data.specType,\n branchUnit: branchUnit,\n categoryPath: data.categoryPath\n ? data.categoryPath.split(\",\").map((item) => {\n return parseInt(item);\n })\n : [],\n assistCategoryPath: data.assistCategoryPath || [],\n };\n if (data.assistCategoryPath && data.assistCategoryPath.length) {\n this.assist_cate = data.assistCategoryPath.map((item) => {\n return {\n assistCategoryPath: item.split(\",\").map((iteme) => {\n return parseInt(iteme);\n }),\n };\n });\n } else {\n this.assist_cate = [\n {\n assistCategoryPath: [],\n },\n ];\n }\n\n this.img_list = data.images.map((item) => {\n return {\n name: \"\",\n url: item,\n };\n });\n this.dynamicTags = data.tag ? data.tag.split(\",\") : [];\n this.base_form.brandName = data.brandTitle;\n // 多规格数据\n if (parseInt(this.base_form.specType) === 2) {\n this.sku_list = data.specGroup.map((item) => {\n const specData = this.spec_data.find(\n (itemF) => itemF.id === item.groupSpec.specId\n );\n return {\n spec_data_child: specData ? specData.child : [],\n groupSpecId: item.groupSpec.specId,\n groupSpecName: item.groupSpec.specName,\n self_spec_val: \"\",\n self_spec_input: false,\n params: item.params.map((itemC) => {\n return {\n id: itemC.specValueId,\n specName: itemC.specValueName,\n groupSpecId: item.groupSpec.specId,\n };\n }),\n };\n });\n this.spec_table_Data = data.specMultiple.map((item) => {\n let barCodeA = [];\n for (let b in item.barCode) {\n let unitB = data.unitData.find(\n (itemF) => parseInt(itemF.unitId) === parseInt(b)\n );\n if (unitB) {\n barCodeA.push({\n ...unitB,\n barCode: item.barCode[b],\n weight: item.weight[b],\n isDefault: item.isDefault[b],\n });\n }\n }\n return {\n barCode: barCodeA,\n isEditSpec: item.isEditSpec,\n inventory: item.inventory - 0,\n specGroupHash: item.specGroupHash,\n id_D: item.id,\n unitId: item.unitId,\n specName: item.specGroup\n .map((itemP) => {\n return itemP.specValueName;\n })\n .join(\"_\"),\n id: item.specGroup\n .map((itemP) => {\n return itemP.specValueId;\n })\n .join(\"_\"),\n groupSpecId: item.specGroup\n .map((itemP) => {\n return itemP.specId;\n })\n .join(\"_\"),\n groupSpecName: item.specGroup\n .map((itemP) => {\n return itemP.specName;\n })\n .join(\"_\"),\n specImage: {\n name: \"\",\n url: item.specImage,\n },\n };\n });\n }\n },\n // 发布商品\n async submitGoods() {\n if (!this.base_form.title.trim()) {\n this.$message.warning(\"商品名称不能为空\");\n return;\n }\n if (!this.base_form.categoryPath.length) {\n this.$message.warning(\"商品分类不能为空\");\n return;\n }\n if (!this.base_form.masterUnit.unitId) {\n this.$message.warning(\"请选择基本单位\");\n return;\n }\n this.$refs[\"base_form\"].validate(async (valid) => {\n if (valid) {\n let specGroup = [];\n let specMultiple = [];\n\n if (!this.base_form.images.length) {\n this.$message.warning(\"请上传商品图片\");\n return;\n }\n if (this.base_form.masterUnit.weight < 0) {\n this.$message.warning(\"商品重量不能为负数\");\n return;\n }\n if (this.spec_table_Data.length > 0) {\n // 多规格\n this.base_form.specType = 2;\n specGroup = this.sku_list.map((item) => {\n return {\n groupSpec: {\n specName: item.groupSpecName,\n specId: item.groupSpecId,\n },\n params: item.params.map((item) => {\n return {\n specValueId: item.id,\n specValueName: item.specName,\n };\n }),\n };\n });\n specMultiple = this.spec_table_Data.map((item, index) => {\n let specVal = []; // 属性id\n let specId = []; // 属性组id\n let specName = []; // 属性组名\n let specValueName = []; // 属性名\n if ((item.id + \"\").indexOf(\"_\") > -1) {\n specVal = item.id.split(\"_\");\n specId = item.groupSpecId.split(\"_\");\n specValueName = item.specName.split(\"_\");\n specName = item.groupSpecName.split(\"_\");\n } else {\n specVal = [item.id];\n specId = [item.groupSpecId];\n specName = [item.groupSpecName];\n specValueName = [item.specName];\n }\n // 条码\n let barCodeO = {};\n let isDefaultO = {};\n let weightO = {};\n item.barCode.forEach((itemB) => {\n barCodeO[itemB.unitId] = itemB.barCode;\n isDefaultO[itemB.unitId] = itemB.isDefault;\n weightO[itemB.unitId] = itemB.weight;\n });\n let returnParams = {\n specImage: item.specImage.url,\n specGroup: specVal.map((itemV, indexV) => {\n return {\n specId: specId[indexV],\n specName: specName[indexV],\n specValueName: specValueName[indexV],\n specValueId: itemV,\n };\n }),\n barCode: barCodeO,\n isDefault: isDefaultO,\n weight: weightO,\n };\n if (this.$route.params.id) {\n returnParams.specGroupHash = item.specGroupHash;\n returnParams.id = item.id_D;\n }\n return returnParams;\n });\n } else {\n this.base_form.specType = 1;\n }\n let unitDataD = this.$_common.deepClone(this.base_form.branchUnit);\n unitDataD.unshift(this.base_form.masterUnit);\n const unitDataA = unitDataD.map((item) => {\n if (this.base_form.specType === 2) {\n item.barCode = \"\";\n item.isDefault = 4;\n item.weight = \"\";\n }\n if (\n this.base_form.delSpecSkuIds.indexOf(item.specGroupHash) !==\n -1 &&\n this.base_form.specType === 1\n ) {\n delete item.id;\n }\n return item;\n });\n // 副分类数据组装\n let assistCategoryPath = [];\n let assistCategoryId = [];\n // 过滤只有选择分类的数据\n const assistCate = this.assist_cate.filter(\n (item) => !!item.assistCategoryPath.length\n );\n assistCate.forEach((item) => {\n assistCategoryPath.push(item.assistCategoryPath.join(\",\"));\n assistCategoryId.push(\n item.assistCategoryPath[item.assistCategoryPath.length - 1]\n );\n });\n const params = {\n merchantId: this.base_form.merchantId,\n categoryPath: this.base_form.categoryPath.join(\",\"),\n assistCategoryPath: assistCategoryPath,\n categoryId: this.base_form.categoryId,\n assistCategoryId: assistCategoryId.join(\",\"),\n title: this.base_form.title,\n storage: this.base_form.storage,\n delUnitIds: this.base_form.delUnitIds,\n delSpecSkuIds: this.base_form.delSpecSkuIds,\n specType: this.base_form.specType,\n specGroup: specGroup,\n specMultiple: specMultiple,\n unitData: unitDataA,\n describe: this.base_form.describe,\n code: this.base_form.code,\n barCode: this.base_form.barCode,\n expireTime: this.base_form.expireTime,\n isEq: this.base_form.isEq,\n brandId: this.base_form.brandId,\n tag: this.dynamicTags.join(\",\"),\n description: this.base_form.description,\n noSalesShop: this.base_form.noSalesShop.join(\",\"),\n images: this.base_form.images,\n };\n this.loading = true;\n let target = {};\n try {\n if (this.$route.params.id) {\n target = await editGoodsBasic(this.base_goods_id, params);\n } else {\n target = await addGoodsBasic(params);\n }\n const data = target;\n this.loading = false;\n\n this.$message({\n type: \"success\",\n message: \"提交成功\",\n });\n await this.delPauseSave();\n this.$closeCurrentGoEdit(`/goods/manageG/BaseDataList`);\n } catch {\n this.loading = false;\n }\n }\n });\n },\n // 商品分类选择\n categoryChange(val, row) {\n // this.base_form.categoryPath = row;\n this.base_form.categoryId = val[val.length - 1];\n // this.base_form.categoryPath.push(this.$_common.deepClone(goodsItem));\n },\n // 品牌选择\n brandConfirm(val) {\n if (val.length > 1) {\n this.$message({\n type: \"error\",\n message: \"请选择一个品牌!\",\n });\n return;\n }\n this.base_form.brandName = val[0].title;\n this.base_form.brandId = val[0].id;\n },\n async getAllMerchantList() {\n const { data } = await getAllMerchantList();\n this.sel_cities = data;\n },\n // 商品分类列表\n async getAllCategoryPost() {\n const { data } = await getAllCategoryPost({\n enableStatus: 5,\n });\n\n if (JSON.stringify(data) === \"{}\") {\n this.category_data = [];\n } else {\n this.category_data = data;\n }\n },\n // 自定义选择即改变\n clickChange(event) {\n event.target.parentElement.parentElement.firstChild.click();\n },\n delAssistCate(index) {\n this.assist_cate.splice(index, 1);\n },\n addAssistCate() {\n this.assist_cate.push({\n assistCategoryPath: [],\n });\n },\n // 下一步\n tagNext() {\n if (this.page_tabs === \"1\") {\n this.$refs[\"base_form\"].validate((valid) => {\n if (valid) {\n if (!this.base_form.masterUnit.unitId) {\n this.$message.warning(\"请选择基本单位\");\n return;\n }\n this.page_tabs = \"2\";\n this.step_active = 2;\n }\n });\n } else if (this.page_tabs === \"2\") {\n if (!this.base_form.images.length) {\n this.$message.warning(\"请上传商品图片\");\n return;\n }\n this.page_tabs = \"3\";\n this.step_active = 3;\n }\n },\n // 上一步\n tagLast() {\n if (this.page_tabs === \"3\") {\n this.step_active = 2;\n this.page_tabs = \"2\";\n } else if (this.page_tabs === \"2\") {\n this.page_tabs = \"1\";\n this.step_active = 1;\n }\n },\n tabClick() {\n if (this.page_tabs === \"1\") {\n this.step_active = 1;\n } else if (this.page_tabs === \"2\") {\n this.step_active = 2;\n } else if (this.page_tabs === \"3\") {\n this.step_active = 3;\n }\n },\n // 抄码商品切换\n isEqChange(val) {\n if (this.isEditSpec !== 4 && val === 5) {\n this.base_form.masterUnit = {\n isDefault: 5,\n isMaster: 5,\n weight: \"\",\n unitName: \"\",\n unitId: \"\",\n barCode: \"\",\n };\n this.base_form.branchUnit = [];\n }\n },\n },\n };\n</script>\n<style lang=\"scss\">\n .goods-tab-view {\n .el-tabs__nav {\n padding-left: 28px !important;\n }\n .el-tabs__active-bar {\n left: 28px !important;\n }\n }\n</style>\n<style scoped lang=\"scss\">\n .goods-tab-view {\n height: 64px;\n overflow: hidden;\n position: relative;\n .btn-view {\n z-index: 99;\n position: absolute;\n right: 36px;\n top: 50%;\n transform: translateY(-50%);\n }\n }\n .goodsCate {\n position: relative;\n margin-bottom: 2px;\n }\n .addCate {\n position: absolute;\n left: 290px;\n top: 7px;\n }\n .creat-shop {\n color: #1890ff;\n font-size: 12px;\n }\n .sku-name-item {\n background-color: #f4f4f4;\n padding: 5px 0;\n }\n ::v-deep .el-tabs__item {\n height: 64px;\n line-height: 64px;\n font-size: 16px;\n font-weight: bold;\n color: #4f5e7b;\n }\n ::v-deep .is-active {\n color: #2153d4;\n }\n .order_top {\n width: 100%;\n background-color: #ffffff;\n border-radius: 3px;\n .order_top_content {\n padding: 20px 0 16px;\n }\n }\n .order_midden {\n margin-top: 16px;\n width: 100%;\n min-height: 600px;\n //height: 480px;\n background-color: #ffffff;\n border-radius: 3px;\n position: relative;\n .order_midden_top {\n position: absolute;\n top: 12px;\n right: 32px;\n z-index: 99;\n .salf-code {\n line-height: 32px;\n display: inline-block;\n font-size: 16px;\n font-weight: 500;\n color: #36b365;\n margin-right: 32px;\n vertical-align: middle;\n }\n .confirm {\n text-align: center;\n display: inline-block;\n width: 70px;\n height: 20px;\n //line-height: 20px;\n background-color: $base-color-blue;\n color: #ffffff;\n margin-right: 1px;\n margin-left: 10px;\n border-top-left-radius: 5px;\n border-bottom-left-radius: 5px;\n }\n .con {\n width: 20px;\n text-align: center;\n display: inline-block;\n line-height: 20px;\n background-color: $base-color-blue;\n color: #ffffff;\n border-top-right-radius: 5px;\n border-bottom-right-radius: 5px;\n }\n }\n .order_midden_left {\n margin-top: 16px;\n width: 95%;\n height: 350px;\n border-right: 1px solid #dee2ee;\n }\n .order_midden_m {\n margin-top: 16px;\n width: 95%;\n height: 350px;\n border-right: 1px solid #dee2ee;\n }\n .order_midden_right {\n margin-top: 16px;\n }\n }\n .order_midden_left_text {\n font-weight: bold;\n font-size: 16px;\n padding: 24px 20px 32px;\n .el-icon-arrow-right {\n font-weight: bold;\n margin-right: 4px;\n font-size: 14px;\n }\n .desc-span {\n font-size: 12px;\n font-weight: normal;\n color: #f57931;\n }\n }\n /* ::v-deep .el-tag {\n min-width: 80px;\n border-radius: 3px;\n font-size: 14px;\n margin-right: 12px;\n position: relative;\n }\n ::v-deep .el-tag__close {\n position: absolute;\n right: 5px;\n top: 5px;\n }*/\n .detail-edit-view {\n padding: 27px 30px;\n }\n .bottom-btn {\n width: 140px;\n height: 36px;\n border-radius: 4px;\n font-size: 14px;\n }\n</style>\n"]}]}