1 |
- {"remainingRequest":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\babel-loader\\lib\\index.js!D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\wnmp\\www\\vue\\seaBlueAdmin\\src\\views\\goods\\sale\\AddGoods.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\src\\views\\goods\\sale\\AddGoods.vue","mtime":1678954023612},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\babel.config.js","mtime":1681371897685},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1681371913603},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\babel-loader\\lib\\index.js","mtime":1681371912860},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1681371913603},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\vue-loader\\lib\\index.js","mtime":1681371925849}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.array.includes.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import GoodsWarehouse from "@/component/goods/GoodsWarehouse";
import Chart1 from "../components/Chart1";
import SelectShop from "@/component/goods/SelectShop.vue";
import { getAllExpressRule, getAllCustomerSource } from "@/api/System";
import { addPauseSave, delPauseSave, getPauseSave } from "@/api/common";
import { getGoodsInfo, editGoods, addGoods, getGoodsBasicInfoById, getAllGoodsSupport, getAllGoodsGroups } from "@/api/goods";
import ClientListModal from "@/component/common/ClientListModal";
import CustomerPrice from "../components/CustomerPrice";
import LadderPrice from "../components/LadderPrice";
import CustomerTypePrice from "../components/CustomerTypePrice";
import RegionTree from "@/component/common/RegionTree";
import { mapGetters } from "vuex";
import { Enterprise } from "@/api/user";
import { CustomerPriceAdjustmentAdd, addCustomerTypePriceAdjustment, getCustomerPriceByGoodsIds, getCustomerTypePriceByGoodsIds } from "@/api/Price";
const priceDataLi = {
  enabledLadder: 0,
  marketPrice: "",
  memberPrice: "",
  costPrice: "",
  salePrice: "",
  setNum: 0,
  isSale: 5,
  salePriceAreaType: 1,
  ladderPrice: [
    /* {
      from: 1,
      price: 0.01,
      to: 2
    }, {
      from: 3,
      price: 0.01,
      to: 4
    },
    {
      from: 5,
      price: 0.01,
      to: 999999999
    } */
  ]
};
export default {
  name: "AddBaseData",
  components: {
    SelectShop,
    GoodsWarehouse,
    RegionTree,
    ClientListModal,
    Chart1,
    CustomerPrice,
    CustomerTypePrice,
    LadderPrice
  },
  props: {
    goodsId: {
      type: [Number, String],
      default: 0
    },
    basicGoodsId: {
      type: [Number, String],
      default: 0
    }
  },

  data() {
    return {
      // flagS: false,
      unitisMaster: 4,
      choose_support: [],
      unit_index: 0,
      sku_index: 0,
      ladderPrice: [],
      enabledLadder: 0,
      ladder_price_show: false,
      // 阶梯价弹窗
      type_price_show: false,
      // 客户类型价弹窗
      customerTypePriceOpen: false,
      // 客户类型价弹窗开关
      customerTypePrice: [],
      // 客户类型价弹窗数据
      customerPriceOpen: false,
      customerPrice: [],
      appoint_price_show: false,
      // 客户指定价弹窗
      customer_show: false,
      // 经营屏蔽->客户列表弹窗选择
      customer_list: [],
      // 经营屏蔽->客户列表
      customer_type_check: [],
      // 经营屏蔽->客户类型选择数组
      customer_type_list: [],
      // 经营屏蔽->客户类型列表
      region_arr: [],
      // 经营屏蔽->当前商品已选择过的区域
      page_tabs: "1",
      // 页面tab切换
      unit_name_tab: "",
      show_region: false,
      goods_data: {
        specType: 1
      },
      primary_unit: "",
      price_data: [// { marketPrice: '' }
      ],
      show_goods: false,
      show_chose: false,
      isModel: false,
      base_rules: {
        shopName: [{
          required: true,
          message: "请选择店铺",
          trigger: "change"
        }],
        goodsName: [{
          required: true,
          message: "请选择商品",
          trigger: "change"
        }],
        deliverySupIds: [{
          required: true,
          type: "array",
          message: "请选择物流支持",
          trigger: "change"
        }],
        ruleId: [{
          required: true,
          message: "请选择运费模板",
          trigger: "change"
        }],
        expressFee: [{
          required: true,
          message: "请输入运费",
          trigger: "blur"
        }]
      },
      price: "",
      express_list: [],
      // 运费模版列表
      base_form: {
        createUserName: "",
        goodsName: "",
        enableStatus: 5,
        isDistribution: 4,
        //负库存销售
        specType: "",
        goodsBasicId: 0,
        // 商品基础资料
        shopId: "",
        // 店铺
        shopName: "",
        // 店铺
        images: [],
        // 相册
        salesArea: [],
        // 销售区域
        serviceInfo: 1,
        price: [],
        // 区域价
        specification: [],
        // // 规格
        content: "",
        // 商品描述
        isRecommend: 5,
        // 5推荐 4不推荐
        sort: "999",
        // 排序
        deliverySupIds: ["1", "2"],
        // 物流支持 固定值 1 快递 2 自提 传参格式：1,2
        expressType: 1,
        // 快递运费 1 包邮 2 运费模版 3 固定费用
        expressFee: "",
        // 固定费用
        showExpress: 5,
        // 是否展示快递 5展示 4不展示
        ruleId: "",
        // 运费模版id
        isShield: 4,
        // 经营屏蔽 4关闭 5开启
        notArea: [],
        //经营屏蔽地区
        notCustomerType: "",
        //经营屏蔽 客户类型屏蔽
        notCustomer: "",
        //经营屏蔽 客户屏蔽
        showMinUnitPrice: 4 //最小单位

      },
      delivery_form: {},
      user_power: {},
      goods_id: 0,
      sub_load: false,
      pageName: "",
      time_data: [],
      goodsNum_data: [],
      orderMoney_data: [],
      orderNum_data: [],
      time: [],
      tableData: [],
      page: 1,
      pageSize: 20,
      total: 0,
      support: [],
      options_value: [],
      goods_groups: [],
      sku_id: ""
    };
  },

  computed: { ...mapGetters({
      salePriceTimes: "MUser/salePriceTimes",
      systemType: "MUser/systemType",
      storeData: "MUser/storeData"
    })
  },

  async created() {
    this.pageName = this.$route.name;

    if (this.basicGoodsId) {
      await this.selGoods([], this.basicGoodsId);
      return;
    }

    if (this.$route.params.id) {
      this.goods_id = this.$route.params.id;
      await this.getDetail();
    } else {
      await this.getPauseSave();

      if ([2, 3].includes(this.systemType)) {
        console.log(this.pageName);
        this.base_form.shopId = this.storeData.id; // 店铺

        this.base_form.shopName = this.storeData.name; // 店铺
      }
    } // 获取运费模版


    await this.getAllExpressRule(); // 获取客户类型

    await this.getAllCustomerSource(); // 获取商品服务

    await this.getAllGoodsSupport(); // 商品分组

    await this.getAllGoodsGroups();
  },

  methods: {
    getShop() {
      this.$emit("closeShop");
      this.$router.push("/SystemSettings/liansuoguanli/AddShop");
    },

    // 获取运费模版
    async getAllExpressRule() {
      const {
        data
      } = await getAllExpressRule();
      this.express_list = data;
      const data1 = await Enterprise({
        ranking: 1,
        // "1销量排行 2销额排行",
        businessOverviewShopId: "",
        // "经营概况按店铺筛选：为空则筛选全店",
        categoryRankingShopId: "",
        // "类目排行按店铺筛选：为空则筛选全店",
        goodsRankingShopId: "",
        // "商品排行按店铺筛选：为空则筛选全店",
        supplierRankingShopId: "" // 供应商排行按店铺筛选：为空则筛选全店"

      });

      if (data1.data.aggregateStatistics) {
        if (this.time_data.length) {
          this.time_data = [];
        }

        this.$nextTick(() => {
          data1.data.chartData.forEach(value => {
            this.time_data.push(value.date);
          });
        });
      }
    },

    // 计算市场价
    salePriceBlur(index, indexU) {
      if (this.goods_data.specType === 1) {
        // 根据比例自动换算销售价
        const target = this.$_common.deepClone(this.price_data);
        const marketPrice = this.$NP.times(target[index].salePrice, this.salePriceTimes);
        target[index] = { ...target[index],
          marketPrice: marketPrice
        }; // target.forEach((item) => {
        //   if (
        //     item.conversion &&
        //     item.isMaster === 4 &&
        //     this.goods_data.isEq === 5
        //   ) {
        //     item.salePrice = this.$NP.times(
        //       target[index].salePrice,
        //       item.conversion
        //     );
        //     item.marketPrice = this.$NP.times(marketPrice, item.conversion);
        //   }
        // });

        this.price_data = target;
      } else {
        this.goods_data.unitData[indexU].priceData[index].marketPrice = this.$NP.times(this.goods_data.unitData[indexU].priceData[index].salePrice, this.salePriceTimes);
      }
    },

    // 会员价失去焦点
    memberPriceBlur(index) {
      return; // 根据比例自动换算 会员价

      if (this.goods_data.specType === 1) {
        const target = this.$_common.deepClone(this.price_data);
        target.forEach(item => {
          if (item.conversion && item.isMaster === 4 && this.goods_data.isEq === 5) {
            item.memberPrice = this.$NP.times(target[index].memberPrice, item.conversion);
          }
        });
        this.price_data = target;
      }
    },

    shopDefault(val, row) {
      this.base_form.shopId = val;
      this.base_form.shopName = row.name;
    },

    otherSetPrice(row, index) {
      const target = this.$_common.deepClone(this.goods_data);
      target.unitData[index].priceData = target.unitData[index].priceData.map(item => {
        return { ...item,
          customerTypePrice: row.customerTypePrice,
          customerTypePriceOpen: row.customerTypePriceOpen,
          customerPrice: row.customerPrice,
          customerPriceOpen: row.customerPriceOpen,
          marketPrice: row.marketPrice,
          memberPrice: row.memberPrice,
          salePrice: row.salePrice,
          enabledLadder: row.enabledLadder,
          ladderPrice: row.ladderPrice,
          setNum: row.setNum,
          isSale: row.isSale || 5
        };
      });
      this.goods_data = target;
    },

    openShop() {
      if (this.goods_id) return;
      this.show_chose = true;
    },

    openGoodsModel() {
      if (!this.base_form.shopName || !!this.goods_id) return;
      this.show_goods = true;
    },

    // 获取商品详情
    async getDetail() {
      const {
        data
      } = await getGoodsInfo(this.goods_id);
      this.goods_data = data;
      this.choose_support = data.support;
      let arr = [];
      data.goodsGroups.forEach(item => {
        if (item) {
          arr.push(Number(item));
        }
      });
      this.options_value = arr;
      this.base_form = {
        createUserName: this.userName,
        goodsName: data.title,
        enableStatus: data.enableStatus,
        // 是否上架
        isDistribution: data.isDistribution,
        //是否负库存销售
        goodsBasicId: data.basicGoodsId,
        // 商品基础资料
        shopId: data.shopId,
        // 店铺
        shopName: data.shopName,
        // 店铺
        images: data.images,
        // 相册
        salesArea: data.salesArea,
        // 销售区域
        serviceInfo: data.serviceInfo,
        price: [],
        specification: data.specification,
        // // 规格
        content: data.content,
        // 商品描述
        isRecommend: data.isRecommend,
        // 5推荐 4不推荐
        sort: data.sort,
        // 排序
        specType: data.specType,
        // 2 多规格 1单规格
        deliverySupIds: data.deliverySupIds.split(","),
        // 物流支持 固定值 1 快递 2 自提 传参格式：1,2
        expressType: data.expressType,
        // 快递运费 1 包邮 2 运费模版 3 固定费用
        expressFee: data.expressFee,
        // 固定费用
        showExpress: data.showExpress,
        // 是否展示快递 5展示 4不展示
        ruleId: data.ruleId,
        // 运费模版id
        isShield: data.isShield,
        // 经营屏蔽
        notArea: data.notArea,
        notCustomerType: data.notCustomerType,
        notCustomer: data.notCustomer,
        showMinUnitPrice: data.showMinUnitPrice
      };
      this.region_arr = data.notArea;
      this.customer_type_check = data.notCustomerType ? data.notCustomerType.split(",").map(item => parseInt(item)) : [];
      this.customer_list = data.notCustomerLists || [];

      if (data.specType === 1) {
        this.price_data = data.specMultiple.map(item => {
          return { ...item,
            isSale: item.isSale || 5,
            // 客户类型和客户快速调价
            customerTypePrice: [],
            customerTypePriceOpen: false,
            customerPrice: [],
            customerPriceOpen: false
          };
        });
      } else if (data.specType === 2) {
        if (this.goods_data.unitData && this.goods_data.unitData.length) {
          this.unit_name_tab = this.goods_data.unitData[0].unitName;
          this.goods_data.unitData = this.goods_data.unitData.map(itemU => {
            const priceData = data.specMultiple.filter(itemF => itemF.unitId === itemU.unitId).map(item => {
              const skuName = item.specGroup.map(itemM => {
                return itemM.specValueName;
              }).join("_"); // item.specGroup.forEach((itemS) => {
              //   if (itemS.specId === 11) {
              //     this.flagS = true;
              //   }
              // });

              return { ...item,
                isSale: item.isSale || 5,
                skuName: skuName,
                // 客户类型和客户快速调价
                customerTypePrice: [],
                customerTypePriceOpen: false,
                customerPrice: [],
                customerPriceOpen: false,
                minUnitPriceConvert: item.minUnitPriceConvert || ""
              };
            });
            return { ...itemU,
              priceData: priceData
            };
          });
        }
      } // this.region_arr = data.salesArea


      if (data.basicGoodsId) {
        await this.selGoods([], data.basicGoodsId);
      }

      this.toggleSelection(); // 获取指定商品的最后生效的客户调价单数据

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

      await this.getCustomerTypePriceByGoodsIds();
    },

    // 检查提交
    checkSub() {
      this.$refs.base_form.validate(valid => {
        if (valid) {
          let priceData = [];

          if (this.goods_data.specType === 2) {
            // 多属性
            this.goods_data.unitData.forEach(item => {
              item.priceData.forEach(itemP => {
                priceData.push({
                  id: itemP.id,
                  conversion: itemP.conversion,
                  unitName: itemP.unitName,
                  unitId: itemP.unitId,
                  isMaster: itemP.isMaster,
                  deleteStatus: itemP.deleteStatus || 4,
                  enabledLadder: itemP.enabledLadder,
                  salePriceAreaType: itemP.salePriceAreaType,
                  salePrice: itemP.salePrice,
                  ladderPrice: itemP.ladderPrice,
                  marketPrice: itemP.marketPrice,
                  memberPrice: itemP.memberPrice,
                  setNum: itemP.setNum,
                  isSale: itemP.isSale || 5,
                  minUnitPriceConvert: itemP.minUnitPriceConvert
                });
              });
            });
          } else {
            priceData = this.$_common.deepClone(this.price_data).map(item => {
              delete item.customerTypePrice;
              delete item.customerTypePriceOpen;
              delete item.customerPrice;
              delete item.customerPriceOpen;
              return item;
            });
          }

          let ladderPriceLength = true;
          let isLadderPrice = true;

          for (let i in priceData) {
            const item = priceData[i];

            if (item.enabledLadder === 1) {
              if (item.ladderPrice.length < 2) {
                ladderPriceLength = false;
                break;
              } else if (!item.ladderPrice.every(itemP => itemP.price > 0)) {
                isLadderPrice = false;
                break;
              }
            } else {
              if (!item.salePrice) {
                isLadderPrice = false;
                break;
              }
            }
          }

          if (!ladderPriceLength) {
            this.$message.warning("请至少设置两条阶梯价");
            return;
          }

          if (!isLadderPrice) {
            this.$message.warning("请输入价格");
            return;
          }

          this.price = priceData.map(item => {
            if (item.ladderPrice.length) {
              item.ladderPrice[item.ladderPrice.length - 1].to = 9999999999;
            }

            let min = 0;

            if (item.enabledLadder === 1) {
              const arr = item.ladderPrice.map(itemM => {
                return itemM.price;
              });
              min = Math.min.apply(null, arr);
            }

            return { ...item,
              ladderPrice: item.enabledLadder === 0 ? [] : item.ladderPrice,
              salePrice: item.enabledLadder === 1 ? min : item.salePrice
            };
          });
          this.price = priceData;
          this.subData();
        }
      });
    },

    // 商品新建提交
    async subData() {
      let target = {};
      const notCustomer = this.customer_list.map(item => {
        return item.id;
      });
      const isFSale = this.price.every(item => item.isSale === 4);

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

      const params = { ...this.base_form,
        price: this.price,
        deliverySupIds: this.base_form.deliverySupIds.join(","),
        notCustomerType: this.customer_type_check.join(","),
        notCustomer: notCustomer.join(","),
        support: this.choose_support,
        goodsGroups: this.options_value
      };
      this.sub_load = true;

      try {
        if (this.goods_id) {
          target = await editGoods(this.goods_id, params);
          this.sub_load = false;
          await this.AdjustPrice(this.goods_id);
        } else {
          target = await addGoods({ ...params,
            createUserName: this.userName
          });
          this.sub_load = false;
          await this.AdjustPrice(target.data);
          await this.delPauseSave();
        }

        this.$message({
          type: "success",
          message: "提交成功"
        });

        if (this.basicGoodsId) {
          this.$emit("subData");
        } else {
          if (this.systemType === 2) {
            await this.$closeCurrentGoEdit("/SingleStore/goods/GoodsAdministration");
          } else {
            await this.$closeCurrentGoEdit("/goods/sale/PublishGoods");
          }
        }
      } finally {
        this.sub_load = false;
      }
    },

    // 请求快速调价接口
    async AdjustPrice(goodsId) {
      let typeParams = [];
      let customerParams = [];
      let typePrice = [];
      let customerPrice = [];

      if (this.goods_data.specType === 1) {
        this.price_data.forEach(item => {
          if (item.customerTypePriceOpen) {
            item.customerTypePrice.forEach(type => {
              // if (!type.priceId) {
              typeParams.push({
                createUserName: this.userName,
                goodsName: this.base_form.goodsName,
                goodsId: goodsId,
                shopId: this.base_form.shopId,
                shopName: this.base_form.shopName,
                customerName: type.name,
                customerType: type.id,
                effective: 5,
                //调价单立即生效effective 5立即生效 4需要手动生效
                salePrice: [{
                  price: type.price,
                  skuId: item.id,
                  unitName: item.unitName,
                  adjPricetag: type.adjPricetag,
                  ladderPrice: type.ladderPrice || []
                }]
              }); // }
            });
          }

          if (item.customerPriceOpen) {
            item.customerPrice.forEach(type => {
              // if (!type.priceId) {
              customerParams.push({
                createUserName: this.userName,
                goodsName: this.base_form.goodsName,
                goodsId: goodsId,
                shopId: this.base_form.shopId,
                shopName: this.base_form.shopName,
                customerName: type.name,
                customerId: type.id,
                effective: 5,
                //调价单立即生效effective 5立即生效 4需要手动生效
                salePrice: [{
                  price: type.price,
                  skuId: item.id,
                  unitName: item.unitName,
                  adjPricetag: type.adjPricetag,
                  ladderPrice: type.ladderPrice || []
                }]
              }); // }
            });
          }
        });
      } else {
        // 多属性
        this.goods_data.unitData.forEach(item => {
          item.priceData.forEach(itemP => {
            if (itemP.customerTypePriceOpen) {
              itemP.customerTypePrice.forEach(type => {
                // if (!type.priceId) {
                typeParams.push({
                  createUserName: this.userName,
                  goodsName: this.base_form.goodsName,
                  goodsId: goodsId,
                  shopId: this.base_form.shopId,
                  shopName: this.base_form.shopName,
                  customerName: type.name,
                  customerType: type.id,
                  effective: 5,
                  //调价单立即生效effective 5立即生效 4需要手动生效
                  salePrice: [{
                    price: type.price,
                    skuId: itemP.id,
                    unitName: itemP.unitName,
                    adjPricetag: type.adjPricetag,
                    ladderPrice: type.ladderPrice || []
                  }]
                }); // }
              });
            }

            if (itemP.customerPriceOpen) {
              itemP.customerPrice.forEach(type => {
                // if (!type.priceId) {
                customerParams.push({
                  createUserName: this.userName,
                  goodsName: this.base_form.goodsName,
                  goodsId: goodsId,
                  shopId: this.base_form.shopId,
                  shopName: this.base_form.shopName,
                  customerName: type.name,
                  customerId: type.id,
                  effective: 5,
                  //调价单立即生效effective 5立即生效 4需要手动生效
                  salePrice: [{
                    price: type.price,
                    skuId: itemP.id,
                    unitName: itemP.unitName,
                    adjPricetag: type.adjPricetag,
                    ladderPrice: type.ladderPrice || []
                  }]
                }); // }
              });
            }
          });
        });
      } //客户类型


      typeParams.forEach(item => {
        const index = typePrice.findIndex(price => price.customerType === item.customerType);

        if (index === -1) {
          typePrice.push({ ...item
          });
        } else {
          typePrice[index].salePrice = typePrice[index].salePrice.concat(item.salePrice);
        }
      }); //客户价格

      customerParams.forEach(item => {
        const index = customerPrice.findIndex(price => price.customerId === item.customerId);

        if (index === -1) {
          customerPrice.push({ ...item
          });
        } else {
          customerPrice[index].salePrice = customerPrice[index].salePrice.concat(item.salePrice);
        }
      }); // console.log("typePrice", typePrice);
      // console.log("customerPrice", customerPrice);

      await this.addCustomerTypePriceAdjustment(typePrice);
      await this.CustomerPriceAdjustmentAdd(customerPrice);
    },

    // 获取暂存信息
    async getPauseSave() {
      const {
        data
      } = await getPauseSave({
        key: this.pageName
      });
      if (JSON.stringify(data) === "{}") return;

      if (data.goods_data) {
        this.goods_data = data.goods_data;
      }

      if (data.base_form) {
        this.base_form = data.base_form;
        this.region_arr = this.base_form.notArea;
      }

      if (data.price) {
        this.price_data = data.price;
      }

      if (data.unit_name_tab) {
        this.unit_name_tab = data.unit_name_tab;
      }

      if (data.customer_list) {
        this.customer_list = data.customer_list;
      }
    },

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

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

    // 商品暂存
    async tempData() {
      this.sub_load = true;

      try {
        const data = await addPauseSave({
          key: this.pageName,
          data: {
            base_form: this.base_form,
            price: this.price,
            goods_data: this.goods_data,
            unit_name_tab: this.unit_name_tab,
            customer_list: this.customer_list
          }
        });
        this.sub_load = false;
        this.$message({
          type: "success",
          message: "暂存成功"
        });

        if (this.systemType === 2) {
          this.$closeCurrentGoEdit("/SingleStore/goods/GoodsAdministration");
        } else {
          this.$closeCurrentGoEdit("/goods/sale/PublishGoods");
        }
      } finally {
        this.sub_load = false;
      }
    },

    // 选择商品
    async selGoods(row, basicGoodsId) {
      const {
        data
      } = await getGoodsBasicInfoById(basicGoodsId || row[0].id, {
        isAddGoods: 5
      });

      if (this.goods_id) {
        this.goods_data = { ...this.goods_data,
          categoryTitle: data.categoryTitle,
          brandTitle: data.brandTitle,
          expireTime: data.expireTime,
          description: data.description,
          tag: data.tag,
          masterUnit: data.unitData.find(item => item.isMaster === 5),
          branchUnit: data.unitData.filter(item => item.isMaster === 4)
        };
        return;
      }

      this.goods_data = { ...data,
        masterUnit: data.unitData.find(item => item.isMaster === 5),
        branchUnit: data.unitData.filter(item => item.isMaster === 4)
      };
      this.base_form.goodsName = data.title;
      this.unit_name_tab = data.unitData[0].unitName;
      this.base_form.images = data.images;
      this.base_form.specType = data.specType;
      this.base_form.content = data.description;
      this.base_form.goodsBasicId = data.id;
      let priceData = [];
      const priceDataItem = this.$_common.deepClone(priceDataLi);

      if (data.specType === 1) {
        priceData = data.unitData.map(item => {
          return { ...item,
            ...priceDataItem,
            isSale: 5,
            // 客户类型和客户快速调价
            customerTypePrice: [],
            customerTypePriceOpen: false,
            customerPrice: [],
            customerPriceOpen: false
          };
        });
        this.price_data = priceData;
      } else if (data.specType === 2) {
        this.goods_data.unitData = this.goods_data.unitData.map(itemU => {
          const priceD = data.specMultiple.filter(itemF => itemF.unitId === itemU.unitId).map(item => {
            const skuName = item.specGroup.map(itemM => {
              return itemM.specValueName;
            }).join("_"); // item.specGroup.forEach((itemS) => {
            //   if (itemS.specId === 11) {
            //     this.flagS = true;
            //   }
            // });

            return { ...item,
              ...priceDataItem,
              isSale: 5,
              skuName: skuName,
              // 客户类型和客户快速调价
              customerTypePrice: [],
              customerTypePriceOpen: false,
              customerPrice: [],
              customerPriceOpen: false
            };
          });
          return { ...itemU,
            priceData: priceD
          };
        });
      }

      let specification = [];

      if (row[0]) {
        if (row[0].specType === 1) {
          specification = (row[0].branchUnit || []).concat(row[0].masterUnit);
        } else if (row[0].specType === 2) {
          specification = row[0].specMultiple;
        }
      }

      this.base_form.specification = specification;
      let arr = "";
      this.price_data.forEach(item => {
        if (item.isMaster === 5) {
          arr = item.unitName;
        }
      });
      this.primary_unit = arr;
    },

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

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

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

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

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

    // 价格波动图
    orderDate() {
      console.log(this.time);
    },

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

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

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

      this.sku_index = index;

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

      this[key] = true;
    },

    // 指定价数据确定
    appointPriceConfirm(customerPriceOpen, customerPrice) {
      if (this.goods_data.specType === 1) {
        // 单规格
        const target = this.$_common.deepClone(this.price_data);
        target[this.sku_index].customerPriceOpen = customerPriceOpen;
        target[this.sku_index].customerPrice = customerPriceOpen ? customerPrice : [];
        this.price_data = target;
      } else {
        // 多规格
        const target = this.$_common.deepClone(this.goods_data.unitData);
        target[this.unit_index].priceData[this.sku_index].customerPriceOpen = customerPriceOpen;
        target[this.unit_index].priceData[this.sku_index].customerPrice = customerPriceOpen ? customerPrice : [];
        this.goods_data.unitData = target;
      }
    },

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

      if (this.$route.params.id) {
        await this.appointPriceConfirm(customerPriceOpen, customerPrice);
      }
    },

    // 客户类型价设置
    typePriceConfirm(customerTypePriceOpen, customerTypePrice) {
      if (this.goods_data.specType === 1) {
        // 单规格
        const target = this.$_common.deepClone(this.price_data);
        target[this.sku_index].customerTypePriceOpen = customerTypePriceOpen;
        target[this.sku_index].customerTypePrice = customerTypePriceOpen ? customerTypePrice : [];
        this.price_data = target;
      } else {
        // 多规格
        const target = this.$_common.deepClone(this.goods_data.unitData);
        target[this.unit_index].priceData[this.sku_index].customerTypePriceOpen = customerTypePriceOpen;
        target[this.unit_index].priceData[this.sku_index].customerTypePrice = customerTypePriceOpen ? customerTypePrice : [];
        this.goods_data.unitData = target;
      }
    },

    // 客户类型价数据取消
    async typePriceCancel(customerTypePriceOpen, customerTypePrice) {
      this.type_price_show = false;

      if (this.$route.params.id) {
        //获取指定商品的最后生效的客户类型调价数据
        await this.typePriceConfirm(customerTypePriceOpen, customerTypePrice);
      }
    },

    // 阶梯价设置
    ladderPriceConfirm(enabledLadder, ladderPrice) {
      if (this.goods_data.specType === 1) {
        // 单规格
        const target = this.$_common.deepClone(this.price_data); // if (this.goods_data.isEq === 5) {
        //   // 抄码商品根据比例自动换算销售价
        //   target.forEach((item) => {
        //     item.enabledLadder = enabledLadder;
        //     if (enabledLadder) {
        //       if (item.conversion && item.isMaster === 4) {
        //         item.ladderPrice = ladderPrice.map((ladder) => {
        //           return {
        //             ...ladder,
        //             price: this.$NP.times(ladder.price, item.conversion),
        //           };
        //         });
        //       } else {
        //         item.ladderPrice = ladderPrice;
        //       }
        //     } else {
        //       item.ladderPrice = [];
        //     }
        //   });
        // } else {
        //   target[this.sku_index].enabledLadder = enabledLadder;
        //   target[this.sku_index].ladderPrice = enabledLadder
        //     ? ladderPrice
        //     : [];
        // }

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

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

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

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

    async getAllGoodsSupport() {
      const {
        data,
        pageTotal
      } = await getAllGoodsSupport({
        page: this.page,
        pageSize: this.pageSize
      });
      this.tableData = data;
      this.total = pageTotal;
    },

    toggleSelection() {
      let arr = [];
      this.goods_data.support.forEach(item => {
        arr.push(Number(item));
      });
      this.choose_support = arr;
    },

    // 商品组
    async getAllGoodsGroups() {
      const {
        data
      } = await getAllGoodsGroups({
        page: 1,
        pageSize: 999,
        name: ""
      });
      this.goods_groups = data;
    },

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

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

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

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

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

  }
};"},{"version":3,"mappings":"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A;QACA;UACA;UACA;YACA,oCACA0F,MADA,CACAC,sCADA,EAEAC,GAFA,CAEAR;cACA,+BACAQ,GADA,CACAC;gBACA;cACA,CAHA,EAIAC,IAJA,CAIA,GAJA,EADA,CAMA;cACA;cACA;cACA;cACA;;cACA,SACA,OADA;gBAEAzH,wBAFA;gBAGA0H,gBAHA;gBAIA;gBACAhG,qBALA;gBAMAD,4BANA;gBAOAG,iBAPA;gBAQAD,wBARA;gBASAgG;cATA;YAWA,CAxBA;YAyBA,SACA,QADA;cAEAC;YAFA;UAIA,CA9BA;QA+BA;MACA,CA3FA,CA4FA;;;MACA;QACA;MACA;;MACA,uBAhGA,CAiGA;;MACA,wCAlGA,CAmGA;;MACA;IACA,CA5NA;;IA6NA;IACAC;MACA;QACA;UACA;;UACA;YACA;YACA;cACAd;gBACAa;kBACAE,YADA;kBAEAC,4BAFA;kBAGAC,wBAHA;kBAIAC,oBAJA;kBAKAC,wBALA;kBAMAC,qCANA;kBAOAzI,kCAPA;kBAQAO,0CARA;kBASAH,0BATA;kBAUAI,8BAVA;kBAWAP,8BAXA;kBAYAC,8BAZA;kBAaAG,oBAbA;kBAcAC,yBAdA;kBAeA2H;gBAfA;cAiBA,CAlBA;YAmBA,CApBA;UAqBA,CAvBA,MAuBA;YACAC,0BACAQ,SADA,CACA,eADA,EAEAb,GAFA,CAEAR;cACA;cACA;cACA;cACA;cACA;YACA,CARA;UASA;;UAEA;UACA;;UACA;YACA;;YACA;cACA;gBACAsB;gBACA;cACA,CAHA,MAGA,IACA,iDADA,EAEA;gBACAC;gBACA;cACA;YACA,CAVA,MAUA;cACA;gBACAA;gBACA;cACA;YACA;UACA;;UACA;YACA;YACA;UACA;;UACA;YACA;YACA;UACA;;UACA;YACA;cACAvB;YACA;;YACA;;YACA;cACA;gBACA;cACA,CAFA;cAGAwB;YACA;;YACA,SACA,OADA;cAEArI,6DAFA;cAGAJ;YAHA;UAKA,CAhBA;UAiBA;UACA;QACA;MACA,CAvFA;IAwFA,CAvTA;;IAwTA;IACA;MACA;MACA;QACA;MACA,CAFA;MAGA;;MACA;QACA;QACA;MACA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;QARA;QAUA;MACA;;MACA,oBACA,OADA;QAEAD,2DAFA;QAGAC;MAHA;MAKA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;;MACA;QACAhC;UACA,SACA,OADA;YAEA,gBAFA;YAGA5H,SAHA;YAIA;YACA0B,qBALA;YAMAD,4BANA;YAOAG,iBAPA;YAQAD;UARA;QAUA,CAXA;QAYA;MACA,CAdA,MAcA;QACA;UACA,iCACA0F,MADA,CACAC,sCADA,EAEAC,GAFA,CAEAR;YACA,+BACAQ,GADA,CACAC;cACA;YACA,CAHA,EAIAC,IAJA,CAIA,GAJA,EADA,CAMA;YACA;YACA;YACA;YACA;;YACA,SACA,OADA;cAEA,gBAFA;cAGAzH,SAHA;cAIA0H,gBAJA;cAKA;cACAhG,qBANA;cAOAD,4BAPA;cAQAG,iBARA;cASAD;YATA;UAWA,CAxBA;UAyBA,SACA,QADA;YAEAiG;UAFA;QAIA,CA9BA;MA+BA;;MACA;;MACA;QACA;UACA3D;QACA,CAFA,MAEA;UACAA;QACA;MACA;;MACA;MACA;MACA;QACA;UACAmD;QACA;MACA,CAJA;MAKA;IACA,CA3qBA;;IA4qBA;IACAyC;MACA;MACA;IACA,CAhrBA;;IAirBA;IACAC;MACA;QACA;MACA,CAFA;IAGA,CAtrBA;;IAurBA;IACA;MACA;QACAvE,OADA;QAEAC;MAFA;MAKA;IACA,CA/rBA;;IAgsBA;IACAuE;MACA;IACA,CAnsBA;;IAosBA;IACAC;MACA;IACA,CAvsBA;;IAwsBA;IACAC;MACA/D;IACA,CA3sBA;;IA4sBA;IACAgE;MACA;MACA;QACA;QACA;QACA;QACA;;QACA;UACA;UACA;UACA;QACA;;QACA;UACA;UACA;UACA;QACA;MACA;;MACA;;MACA;QACA;MACA;;MACA;IACA,CApuBA;;IAquBA;IACAC;MACA;QACA;QACA;QACAvD;QACAA,2DACAhF,aADA,GAEA,EAFA;QAGA;MACA,CARA,MAQA;QACA;QACA;QACAgF,kCACA,cADA,EAEAjF,iBAFA,GAEAA,iBAFA;QAGAiF,kCACA,cADA,EAEAhF,aAFA,GAEAD,sCAFA;QAGA;MACA;IACA,CA1vBA;;IA2vBA;IACA;MACA;;MACA;QACA;MACA;IACA,CAjwBA;;IAkwBA;IACAyI;MACA;QACA;QACA;QACAxD;QACAA,mEACAlF,iBADA,GAEA,EAFA;QAGA;MACA,CARA,MAQA;QACA;QACA;QACAkF,kCACA,cADA,EAEAnF,qBAFA,GAEAA,qBAFA;QAGAmF,kCACA,cADA,EAEAlF,iBAFA,GAEAD,8CAFA;QAGA;MACA;IACA,CAvxBA;;IAwxBA;IACA;MACA;;MACA;QACA;QACA;MACA;IACA,CA/xBA;;IAgyBA;IACA4I;MACA;QACA;QACA,wDAFA,CAGA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QACAzD;QACAA;QACA;MACA,CA/BA,MA+BA;QACA;QACA;QACAA,kCACA,cADA,EAEAlH,aAFA,GAEAA,aAFA;QAGAkH,kCACA,cADA,EAEA1G,WAFA,GAEAR,gCAFA;QAGA;MACA;IACA,CA50BA;;IA60BA4K;MACA;IACA,CA/0BA;;IAg1BA;IACA;MACA;MACA;QAAApJ;MAAA;IACA,CAp1BA;;IAq1BA;IACA;MACA;MACA;QAAAA;MAAA;IACA,CAz1BA;;IA01BA;MACA;QAAAA;QAAAqJ;MAAA;QACAhF,eADA;QAEAC;MAFA;MAIA;MACA;IACA,CAj2BA;;IAk2BAgF;MACA;MACA;QACApD;MACA,CAFA;MAGA;IACA,CAx2BA;;IAy2BA;IACA;MACA;QAAAlG;MAAA;QACAqE,OADA;QAEAC,aAFA;QAGArF;MAHA;MAKA;IACA,CAj3BA;;IAk3BA;IACA;MACA;QAAAe;QAAAqJ;MAAA;QACAzJ,sBADA;QAEAyE,OAFA;QAGAC;MAHA;MAKA;IACA,CA13BA;;IA23BA;IACA;MACA;QAAAtE;MAAA;QACAJ,sBADA;QAEAyE,OAFA;QAGAC;MAHA;MAKA;MACA;IACA,CAp4BA;;IAq4BAiF;MACA;QACA;UACA;UACA;UACA;YACA;cACA1J;gBACA;kBACAW;oBACAoH,8BADA;oBAEA5I,8BAFA;oBAGAoD,kBAHA;oBAIAnD,2BAJA;oBAKA2H,qBALA;oBAMA4C;kBANA;gBAQA;cACA,CAXA;YAYA;UACA,CAfA,EAHA,CAmBA;;UACA;UACA;YACA;cACA3J;gBACA;kBACAa;oBACAkH,8BADA;oBAEA5I,8BAFA;oBAGAoD,kBAHA;oBAIAnD,uBAJA;oBAKA2H,mBALA;oBAMA4C;kBANA;gBAQA;cACA,CAXA;YAYA;UACA,CAfA;UAgBA,SACA,OADA;YAEA;YACAhJ,oCAHA;YAIAD,mDAJA;YAKAG,4BALA;YAMAD;UANA;QAQA,CA7CA;MA8CA,CA/CA,MA+CA;QACA;UACA,SACA,QADA;YAEAiG;cACA;cACA;cACA;gBACA;kBACA7G;oBACA;sBACAW;wBACAoH,8BADA;wBAEA5I,8BAFA;wBAGAoD,kBAHA;wBAIAnD,2BAJA;wBAKA2H,qBALA;wBAMA4C;sBANA;oBAQA;kBACA,CAXA;gBAYA;cACA,CAfA,EAHA,CAmBA;;cACA;cACA;gBACA;kBACA3J;oBACA;sBACAa;wBACAkH,8BADA;wBAEA5I,8BAFA;wBAGAoD,kBAHA;wBAIAnD,uBAJA;wBAKA2H,mBALA;wBAMA4C;sBANA;oBAQA;kBACA,CAXA;gBAYA;cACA,CAfA;cAgBA,SACA,OADA;gBAEAhJ,oCAFA;gBAGAD,mDAHA;gBAIAG,4BAJA;gBAKAD;cALA;YAOA,CA5CA;UAFA;QAgDA,CAjDA;MAkDA;IACA;;EAz+BA;AAlKA","names":["getGoodsInfo","editGoods","addGoods","getGoodsBasicInfoById","getAllGoodsSupport","getAllGoodsGroups","CustomerPriceAdjustmentAdd","addCustomerTypePriceAdjustment","getCustomerPriceByGoodsIds","getCustomerTypePriceByGoodsIds","enabledLadder","marketPrice","memberPrice","costPrice","salePrice","setNum","isSale","salePriceAreaType","ladderPrice","name","components","SelectShop","GoodsWarehouse","RegionTree","ClientListModal","Chart1","CustomerPrice","CustomerTypePrice","LadderPrice","props","goodsId","type","default","basicGoodsId","data","unitisMaster","choose_support","unit_index","sku_index","ladder_price_show","type_price_show","customerTypePriceOpen","customerTypePrice","customerPriceOpen","customerPrice","appoint_price_show","customer_show","customer_list","customer_type_check","customer_type_list","region_arr","page_tabs","unit_name_tab","show_region","goods_data","specType","primary_unit","price_data","show_goods","show_chose","isModel","base_rules","shopName","required","message","trigger","goodsName","deliverySupIds","ruleId","expressFee","price","express_list","base_form","createUserName","enableStatus","isDistribution","goodsBasicId","shopId","images","salesArea","serviceInfo","specification","content","isRecommend","sort","expressType","showExpress","isShield","notArea","notCustomerType","notCustomer","showMinUnitPrice","delivery_form","user_power","goods_id","sub_load","pageName","time_data","goodsNum_data","orderMoney_data","orderNum_data","time","tableData","page","pageSize","total","support","options_value","goods_groups","sku_id","computed","salePriceTimes","systemType","storeData","console","methods","getShop","ranking","businessOverviewShopId","categoryRankingShopId","goodsRankingShopId","supplierRankingShopId","data1","salePriceBlur","target","index","memberPriceBlur","item","shopDefault","otherSetPrice","openShop","openGoodsModel","arr","filter","itemF","map","itemM","join","skuName","minUnitPriceConvert","priceData","checkSub","id","conversion","unitName","unitId","isMaster","deleteStatus","deepClone","ladderPriceLength","isLadderPrice","min","goodsGroups","typeParams","customerName","customerType","effective","skuId","adjPricetag","customerParams","customerId","itemP","typePrice","concat","key","isAddGoods","categoryTitle","brandTitle","expireTime","description","tag","masterUnit","branchUnit","selChose","selRegion","customerSel","deleteCustomer","orderDate","openModal","appointPriceConfirm","typePriceConfirm","ladderPriceConfirm","ladderPriceCancel","pageTotal","toggleSelection","adjustmentData","priceId"],"sourceRoot":"src/views/goods/sale","sources":["AddGoods.vue"],"sourcesContent":["<!--添加基础资料-->\n<template>\n <ContainerTit>\n <span v-if=\"!!goods_id\" slot=\"pagetit\">商品详情</span>\n <span v-if=\"!!basicGoodsId\" slot=\"pagetit\">商品发布</span>\n <div\n v-if=\"\n (!!basicGoodsId || !!goods_id) &&\n $accessCheck($Access.PublishGoodsEditGoods)\n \"\n slot=\"headr\"\n >\n <el-button :loading=\"sub_load\" type=\"primary\" @click=\"checkSub\">\n 提交保存\n </el-button>\n </div>\n <div v-if=\"$route.name === 'AddGoods'\" slot=\"headr\">\n <el-button :loading=\"sub_load\" @click=\"delPauseSave(1)\">\n 清除暂存\n </el-button>\n <el-button :loading=\"sub_load\" @click=\"tempData\">暂存</el-button>\n <el-button :loading=\"sub_load\" type=\"primary\" @click=\"checkSub\">\n 提交保存\n </el-button>\n </div>\n <el-form\n ref=\"base_form\"\n label-position=\"right\"\n :model=\"base_form\"\n :rules=\"base_rules\"\n size=\"small\"\n label-width=\"130px\"\n >\n <div class=\"detail-tab-item\" style=\"padding: 0 20px\">\n <el-tabs v-model=\"page_tabs\">\n <el-tab-pane label=\"商品信息\" name=\"1\"></el-tab-pane>\n <el-tab-pane\n :disabled=\"base_form.isShield === 4\"\n label=\"经营屏蔽\"\n name=\"2\"\n ></el-tab-pane>\n <!-- <el-tab-pane label=\"商品服务\" name=\"4\"></el-tab-pane>-->\n <!--<el-tab-pane\n v-if=\"goods_id\"\n label=\"价格波动图\"\n name=\"3\"\n ></el-tab-pane>-->\n </el-tabs>\n </div>\n <!-- 商品信息-->\n <div v-if=\"page_tabs === '1'\">\n <el-row :gutter=\"10\">\n <el-col :span=\"12\">\n <div class=\"detail-tab-item\">\n <div class=\"detail-tab-title\">基础信息</div>\n <div class=\"detail-tab-main\" style=\"padding-bottom: 1px\">\n <el-form-item\n v-if=\"systemType === 1\"\n label=\"选择店铺:\"\n prop=\"shopName\"\n >\n <SelectShop\n v-model=\"base_form.shopId\"\n :is-default=\"true\"\n :clearable=\"false\"\n :action=\"1\"\n :materiel-id=\"basicGoodsId\"\n @change=\"selChose\"\n @default=\"shopDefault\"\n />\n <el-button size=\"mini\" type=\"text\" @click=\"getShop\">\n 【新建店铺】\n </el-button>\n </el-form-item>\n <el-form-item v-else label=\"当前店铺:\" prop=\"shopName\">\n {{ base_form.shopName }}\n </el-form-item>\n <el-form-item label=\"选择商品:\" prop=\"goodsName\">\n <el-input\n v-if=\"!basicGoodsId\"\n v-model=\"base_form.goodsName\"\n style=\"width: 200px\"\n :disabled=\"!base_form.shopName || !!goods_id\"\n readonly\n placeholder=\"请选择商品\"\n >\n <i\n slot=\"suffix\"\n class=\"el-input__icon el-icon-search\"\n @click=\"openGoodsModel\"\n ></i>\n </el-input>\n <span v-else>{{ base_form.goodsName || \"--\" }}</span>\n </el-form-item>\n <el-form-item label=\"商品分组:\">\n <el-select\n v-model=\"options_value\"\n multiple\n style=\"width: 200px\"\n placeholder=\"请选择\"\n >\n <el-option\n v-for=\"item in goods_groups\"\n :key=\"item.id\"\n :label=\"item.name\"\n :value=\"item.id\"\n ></el-option>\n </el-select>\n </el-form-item>\n <el-form-item label=\"是否上架:\">\n <el-switch\n v-model=\"base_form.enableStatus\"\n active-color=\"#36B365\"\n inactive-color=\"#ff4949\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n active-text=\"上架\"\n inactive-text=\"下架\"\n ></el-switch>\n </el-form-item>\n <el-form-item label=\"负库存销售:\">\n <el-switch\n v-model=\"base_form.isDistribution\"\n active-color=\"#36B365\"\n inactive-color=\"#ff4949\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n active-text=\"启用\"\n inactive-text=\"禁用\"\n ></el-switch>\n </el-form-item>\n <el-form-item label=\"经营屏蔽:\">\n <el-switch\n v-model=\"base_form.isShield\"\n active-color=\"#36B365\"\n inactive-color=\"#ff4949\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n active-text=\"启用\"\n inactive-text=\"禁用\"\n ></el-switch>\n </el-form-item>\n <el-form-item\n v-if=\"goods_data.specType === 2\"\n label=\"重量属性斤价:\"\n >\n <el-switch\n v-model=\"base_form.showMinUnitPrice\"\n active-color=\"#36B365\"\n inactive-color=\"#ff4949\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n active-text=\"显示\"\n inactive-text=\"不显示\"\n ></el-switch>\n <el-tooltip placement=\"right\">\n <div slot=\"content\">\n 根据最小单位换算比例换算当前重量属性每斤价钱\n <br />\n 例如:10公斤=50元换算后1斤=2.5元\n </div>\n <i\n style=\"\n position: absolute;\n top: 30%;\n left: 150px;\n color: rgb(192, 197, 207);\n \"\n class=\"el-icon-question\"\n ></i>\n </el-tooltip>\n </el-form-item>\n </div>\n </div>\n </el-col>\n <el-col :span=\"12\">\n <!-- 物流设置 -->\n <div class=\"detail-tab-item\" style=\"height: 330px\">\n <div class=\"detail-tab-title clearfix\">物流设置</div>\n <div class=\"detail-tab-main\">\n <el-form-item\n v-if=\"false\"\n label=\"物流支持:\"\n prop=\"deliverySupIds\"\n >\n <el-checkbox-group v-model=\"base_form.deliverySupIds\">\n <el-checkbox label=\"1\">快递</el-checkbox>\n <el-checkbox label=\"2\">自提</el-checkbox>\n </el-checkbox-group>\n <p\n v-if=\"!goods_id\"\n class=\"form-tip\"\n @click=\"$router.push('/SystemSettings/jiaoyiset/Delivery')\"\n >\n <el-button type=\"text\" size=\"small\">\n 【配送方式配置】\n </el-button>\n </p>\n </el-form-item>\n <el-form-item label=\"快递运费:\">\n <el-radio-group v-model=\"base_form.expressType\">\n <el-radio :label=\"1\">包邮</el-radio>\n <el-radio :label=\"2\">运费模版</el-radio>\n <el-radio :label=\"3\">统一运费</el-radio>\n </el-radio-group>\n </el-form-item>\n <div v-if=\"base_form.expressType === 2\">\n <el-form-item label=\"运费模板:\" prop=\"ruleId\">\n <el-select v-model=\"base_form.ruleId\" placeholder=\"请选择\">\n <el-option\n v-for=\"(item, index) in express_list\"\n :key=\"index\"\n :label=\"item.title\"\n :value=\"item.id\"\n ></el-option>\n </el-select>\n </el-form-item>\n </div>\n <div v-if=\"base_form.expressType === 3\">\n <el-form-item label=\"统一运费:\" prop=\"expressFee\">\n <el-input\n v-model=\"base_form.expressFee\"\n style=\"width: 200px\"\n type=\"number\"\n :controls=\"false\"\n >\n <el-button slot=\"append\">元</el-button>\n </el-input>\n </el-form-item>\n </div>\n <el-form-item v-if=\"false\" label=\"是否展示快递:\">\n <el-radio-group v-model=\"base_form.showExpress\">\n <el-radio :label=\"4\">不展示</el-radio>\n <el-radio :label=\"5\">展示</el-radio>\n </el-radio-group>\n </el-form-item>\n </div>\n <div class=\"detail-tab-title clearfix\">商品服务</div>\n <div class=\"detail-tab-main\">\n <el-checkbox-group\n v-model=\"choose_support\"\n style=\"margin-left: 25px\"\n >\n <el-checkbox\n v-for=\"(item, index) in tableData\"\n :key=\"index\"\n :label=\"item.id\"\n >\n {{ item.servicesName }}\n <el-tooltip\n class=\"item\"\n effect=\"dark\"\n :content=\"item.describe\"\n placement=\"top\"\n >\n <span\n class=\"el-icon-question\"\n style=\"color: rgb(96, 98, 102)\"\n ></span>\n </el-tooltip>\n </el-checkbox>\n </el-checkbox-group>\n </div>\n </div>\n </el-col>\n </el-row>\n\n <!-- 无属性价格管理-->\n <div v-if=\"goods_data.specType === 1\" class=\"detail-tab-item\">\n <div class=\"detail-tab-title clearfix\">价格管理</div>\n <div class=\"detail-tab-main\">\n <el-table border :data=\"price_data\">\n <el-table-column\n prop=\"unitName\"\n label=\"属性\"\n min-width=\"80\"\n ></el-table-column>\n <el-table-column label=\"换算比例\" min-width=\"80\">\n <template slot-scope=\"scope\">\n <span v-if=\"scope.row.isMaster === 4\">\n 1{{ scope.row.unitName }}={{ Number(scope.row.conversion)\n }}{{ primary_unit }}\n </span>\n <span v-else>主单位</span>\n </template>\n </el-table-column>\n <el-table-column\n v-if=\"goods_data.supplierId && !goods_id\"\n prop=\"costPrice\"\n label=\"成本价/元\"\n min-width=\"100\"\n >\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.costPrice\"\n style=\"width: 80px\"\n :controls=\"false\"\n placeholder=\"成本价\"\n size=\"small\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"销售价/元\" min-width=\"120\">\n <!-- 抄码商品不允许修改辅助单位的销售价-->\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.salePrice\"\n size=\"mini\"\n :controls=\"false\"\n :min=\"0\"\n style=\"width: 100%\"\n @blur=\"salePriceBlur(scope.$index)\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"会员价/元\" min-width=\"120\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.memberPrice\"\n size=\"mini\"\n :controls=\"false\"\n :min=\"0\"\n style=\"width: 100%\"\n @blur=\"memberPriceBlur(scope.$index)\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"marketPrice\"\n label=\"市场价/元\"\n min-width=\"100\"\n >\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.marketPrice\"\n style=\"width: 100%\"\n :controls=\"false\"\n placeholder=\"市场价\"\n size=\"small\"\n :min=\"0\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"起订数量\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.setNum\"\n style=\"width: 100%\"\n :controls=\"false\"\n placeholder=\"起订数量\"\n size=\"small\"\n :precision=\"0\"\n :min=\"1\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"是否销售\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-switch\n v-model=\"scope.row.isSale\"\n class=\"switchStyle\"\n active-text=\"启用\"\n inactive-text=\"禁用\"\n active-color=\"#2153D4\"\n inactive-color=\"#879BBA\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n ></el-switch>\n </template>\n </el-table-column>\n <el-table-column label=\"阶梯价\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-button\n v-if=\"\n scope.row.ladderPrice.length &&\n scope.row.enabledLadder === 1\n \"\n type=\"primary\"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'ladder_price_show', scope.row)\n \"\n >\n 已设置\n </el-button>\n <el-button\n v-else\n type=\"infCustomerTypePrice.vueo\"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'ladder_price_show', scope.row)\n \"\n >\n 去设置\n </el-button>\n </template>\n </el-table-column>\n <el-table-column label=\"客户类型价\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <div v-if=\"$route.name !== 'EditGoods'\">\n <el-button\n v-if=\"\n scope.row.customerTypePrice.length &&\n scope.row.customerTypePriceOpen\n \"\n type=\"primary\"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'type_price_show', scope.row)\n \"\n >\n 已设置\n </el-button>\n <el-button\n v-else\n type=\"info\"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'type_price_show', scope.row)\n \"\n >\n 去设置\n </el-button>\n </div>\n <div v-else>\n <el-button\n :type=\"\n scope.row.customerTypePriceOpen ? 'primary' : 'info'\n \"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'type_price_show', scope.row)\n \"\n >\n {{ scope.row.customerTypePriceOpen ? \"查看\" : \"未设置\" }}\n </el-button>\n </div>\n </template>\n </el-table-column>\n <el-table-column label=\"客户指定价\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-button\n v-if=\"\n scope.row.customerPrice.length &&\n scope.row.customerPriceOpen\n \"\n type=\"primary\"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'appoint_price_show', scope.row)\n \"\n >\n 已设置\n </el-button>\n <el-button\n v-else\n type=\"info\"\n size=\"mini\"\n @click=\"\n openModal(scope.$index, 'appoint_price_show', scope.row)\n \"\n >\n 去设置\n </el-button>\n </template>\n </el-table-column>\n </el-table>\n </div>\n </div>\n <!-- 多属性价格管理-->\n <div v-if=\"goods_data.specType === 2\" class=\"detail-tab-item\">\n <div class=\"detail-tab-title clearfix\">价格管理</div>\n <div class=\"detail-tab-main\">\n <el-form-item v-if=\"false\" label=\"商品推荐:\" prop=\"isRecommend\">\n <el-radio v-model=\"base_form.isRecommend\" :label=\"5\">是</el-radio>\n <el-radio v-model=\"base_form.isRecommend\" :label=\"4\">否</el-radio>\n </el-form-item>\n <el-tabs v-model=\"unit_name_tab\" type=\"card\">\n <el-tab-pane\n v-for=\"(itemU, indexU) in goods_data.unitData\"\n :key=\"indexU\"\n :label=\"itemU.unitName\"\n :name=\"itemU.unitName\"\n >\n <el-table\n :data=\"itemU.priceData\"\n border\n style=\"width: 100%\"\n size=\"mini\"\n >\n <el-table-column\n prop=\"skuName\"\n label=\"属性\"\n min-width=\"80\"\n ></el-table-column>\n <el-table-column\n v-if=\"base_form.showMinUnitPrice === 5\"\n prop=\"skuName\"\n label=\"换算比例\"\n min-width=\"100\"\n >\n <template slot=\"header\" slot-scope=\"scope\">\n <span v-if=\"false\">{{ scope.$index }}</span>\n {{ itemU.unitName }}/元换算比例\n </template>\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.minUnitPriceConvert\"\n size=\"mini\"\n :controls=\"false\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"销售价/元\" min-width=\"120\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.salePrice\"\n size=\"mini\"\n :controls=\"false\"\n @blur=\"salePriceBlur(scope.$index, indexU)\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"会员价/元\" min-width=\"120\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.memberPrice\"\n size=\"mini\"\n :controls=\"false\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"marketPrice\"\n label=\"市场价/元\"\n min-width=\"100\"\n >\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.marketPrice\"\n style=\"width: 80px\"\n :controls=\"false\"\n placeholder=\"市场价\"\n size=\"small\"\n :min=\"0\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"起订数量\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-input-number\n v-model=\"scope.row.setNum\"\n style=\"width: 80px\"\n :controls=\"false\"\n placeholder=\"起订数量\"\n size=\"small\"\n :precision=\"0\"\n :min=\"1\"\n ></el-input-number>\n </template>\n </el-table-column>\n <el-table-column label=\"是否销售\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-switch\n v-model=\"scope.row.isSale\"\n class=\"switchStyle\"\n active-text=\"启用\"\n inactive-text=\"禁用\"\n active-color=\"#2153D4\"\n inactive-color=\"#879BBA\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n ></el-switch>\n </template>\n </el-table-column>\n <el-table-column label=\"阶梯价\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-button\n v-if=\"\n scope.row.ladderPrice.length &&\n scope.row.enabledLadder === 1\n \"\n type=\"primary\"\n size=\"mini\"\n @click=\"\n openModal(\n scope.$index,\n 'ladder_price_show',\n scope.row,\n indexU\n )\n \"\n >\n 已设置\n </el-button>\n <el-button\n v-else\n type=\"info\"\n size=\"mini\"\n @click=\"\n openModal(\n scope.$index,\n 'ladder_price_show',\n scope.row,\n indexU\n )\n \"\n >\n 去设置\n </el-button>\n </template>\n </el-table-column>\n <el-table-column label=\"客户类型价\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-button\n v-if=\"\n scope.row.customerTypePrice.length &&\n scope.row.customerTypePriceOpen\n \"\n type=\"primary\"\n size=\"mini\"\n @click=\"\n openModal(\n scope.$index,\n 'type_price_show',\n scope.row,\n indexU\n )\n \"\n >\n 已设置\n </el-button>\n <el-button\n v-else\n type=\"info\"\n size=\"mini\"\n @click=\"\n openModal(\n scope.$index,\n 'type_price_show',\n scope.row,\n indexU\n )\n \"\n >\n 去设置\n </el-button>\n </template>\n </el-table-column>\n <el-table-column label=\"客户指定价\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-button\n v-if=\"\n scope.row.customerPrice.length &&\n scope.row.customerPriceOpen\n \"\n type=\"primary\"\n size=\"mini\"\n @click=\"\n openModal(\n scope.$index,\n 'appoint_price_show',\n scope.row,\n indexU\n )\n \"\n >\n 已设置\n </el-button>\n <el-button\n v-else\n type=\"info\"\n size=\"mini\"\n @click=\"\n openModal(\n scope.$index,\n 'appoint_price_show',\n scope.row,\n indexU\n )\n \"\n >\n 去设置\n </el-button>\n </template>\n </el-table-column>\n <el-table-column label=\"操作\" min-width=\"100\">\n <template slot-scope=\"scope\">\n <el-button\n type=\"text\"\n size=\"small\"\n @click=\"otherSetPrice(scope.row, indexU)\"\n >\n 同步\n </el-button>\n </template>\n </el-table-column>\n </el-table>\n </el-tab-pane>\n </el-tabs>\n </div>\n </div>\n </div>\n <!-- 经营屏蔽-->\n <div v-if=\"page_tabs === '2'\">\n <div class=\"page-tip-div\">\n <i class=\"el-icon-info\"></i>\n 符合以下条件的客户用将无法看到此商品\n </div>\n <el-row :gutter=\"10\">\n <el-col :span=\"8\">\n <div class=\"detail-tab-item\" style=\"margin-bottom: 0\">\n <div class=\"detail-tab-title\">地区屏蔽</div>\n <div\n class=\"detail-tab-main\"\n style=\"height: calc(100vh - 380px); overflow: auto\"\n >\n <RegionTree\n :checked-key=\"region_arr\"\n @checkChange=\"selRegion\"\n />\n </div>\n </div>\n </el-col>\n <el-col :span=\"16\">\n <div class=\"detail-tab-item\">\n <div class=\"detail-tab-title\">客户类型屏蔽</div>\n <div class=\"detail-tab-main\">\n <div\n v-if=\"!customer_type_list.length\"\n style=\"text-align: center\"\n >\n 暂无客户类型\n </div>\n <el-checkbox-group v-model=\"customer_type_check\">\n <el-checkbox\n v-for=\"(item, index) in customer_type_list\"\n :key=\"index\"\n :label=\"item.id\"\n >\n {{ item.name }}\n </el-checkbox>\n </el-checkbox-group>\n </div>\n </div>\n <div class=\"detail-tab-item\">\n <div class=\"detail-tab-title clearfix\">\n <span class=\"float_left\">客户屏蔽</span>\n <div class=\"float_right\">\n <el-button\n type=\"primary\"\n size=\"mini\"\n @click=\"customer_show = true\"\n >\n 选择客户\n </el-button>\n </div>\n </div>\n <div class=\"detail-tab-main\">\n <el-table border :data=\"customer_list\">\n <el-table-column\n show-overflow-tooltip\n prop=\"code\"\n label=\"编号\"\n ></el-table-column>\n <el-table-column\n show-overflow-tooltip\n prop=\"name\"\n label=\"姓名\"\n ></el-table-column>\n <el-table-column\n prop=\"customerType\"\n label=\"类型\"\n ></el-table-column>\n <el-table-column\n prop=\"shopName\"\n label=\"所属商铺\"\n show-overflow-tooltip\n ></el-table-column>\n <el-table-column label=\"管理\">\n <template slot-scope=\"scope\">\n <el-button\n type=\"text\"\n @click=\"deleteCustomer(scope.$index)\"\n >\n 删除\n </el-button>\n </template>\n </el-table-column>\n </el-table>\n </div>\n </div>\n </el-col>\n </el-row>\n </div>\n <!-- 价格波动图-->\n <div v-if=\"page_tabs === '3'\">\n <div class=\"ph\" style=\"height: 350px\">\n <div style=\"padding-bottom: 20px\">\n <el-date-picker\n v-model=\"time\"\n clearable\n type=\"daterange\"\n value-format=\"timestamp\"\n range-separator=\"-\"\n start-placeholder=\"开始日期\"\n end-placeholder=\"结束日期\"\n @change=\"orderDate\"\n ></el-date-picker>\n <chart1\n :time-data=\"time_data\"\n :goods-num=\"goodsNum_data\"\n :order-num=\"orderNum_data\"\n :order-money=\"orderMoney_data\"\n ></chart1>\n </div>\n </div>\n </div>\n <!-- 商品服务-->\n <!-- <div v-show=\"page_tabs === '4'\">-->\n <!-- <el-table-->\n <!-- ref=\"multipleTable\"-->\n <!-- :data=\"tableData\"-->\n <!-- tooltip-effect=\"dark\"-->\n <!-- @selection-change=\"handleSelectionChange\"-->\n <!-- >-->\n <!-- <el-table-column type=\"selection\"></el-table-column>-->\n <!-- <el-table-column-->\n <!-- prop=\"servicesName\"-->\n <!-- label=\"商品服务名称\"-->\n <!-- ></el-table-column>-->\n <!-- <el-table-column prop=\"describe\" label=\"描述\"></el-table-column>-->\n <!-- </el-table>-->\n <!-- <FooterPage-->\n <!-- :page-size=\"pageSize\"-->\n <!-- :total-page.sync=\"total\"-->\n <!-- :current-page.sync=\"page\"-->\n <!-- @pageChange=\"pageChange\"-->\n <!-- @sizeChange=\"sizeChange\"-->\n <!-- ></FooterPage>-->\n <!-- </div>-->\n </el-form>\n\n <!-- 商品列表-->\n <GoodsWarehouse\n v-if=\"show_goods\"\n :modal=\"!goodsId\"\n :shop-id=\"base_form.shopId\"\n goods-warehouse\n :is-check=\"false\"\n :is-show=\"show_goods\"\n :enable=\"true\"\n @cancel=\"show_goods = false\"\n @confirm=\"selGoods\"\n />\n <!-- 客户选择-->\n <ClientListModal\n v-if=\"customer_show\"\n :is-show=\"customer_show\"\n :is-check=\"true\"\n :modal=\"!basicGoodsId\"\n :is-show-add=\"true\"\n @cancel=\"customer_show = false\"\n @confirm=\"customerSel\"\n />\n <!-- 客户调价-->\n <CustomerPrice\n v-if=\"appoint_price_show\"\n :is-show=\"appoint_price_show\"\n :customer-price-open=\"customerPriceOpen\"\n :customer-price=\"customerPrice\"\n :modal=\"!basicGoodsId && !goodsId\"\n :ladder-price=\"ladderPrice\"\n :sku-id=\"sku_id\"\n :enabled-ladder=\"enabledLadder\"\n @confirm=\"appointPriceConfirm\"\n @cancel=\"appointPriceCancel\"\n />\n <!-- 客户类型调价-->\n <CustomerTypePrice\n v-if=\"type_price_show\"\n :is-show=\"type_price_show\"\n :customer-type-price-open=\"customerTypePriceOpen\"\n :customer-type-price=\"customerTypePrice\"\n :ladder-price=\"ladderPrice\"\n :enabled-ladder=\"enabledLadder\"\n :modal=\"!basicGoodsId && !goodsId\"\n :sku-id=\"sku_id\"\n @confirm=\"typePriceConfirm\"\n @cancel=\"typePriceCancel\"\n />\n <!-- 阶梯价弹窗-->\n <LadderPrice\n v-if=\"ladder_price_show\"\n :enabled-ladder=\"enabledLadder\"\n :ladder-price=\"ladderPrice\"\n :is-show=\"ladder_price_show\"\n :modal=\"!basicGoodsId && !goodsId\"\n @confirm=\"ladderPriceConfirm\"\n @cancel=\"ladderPriceCancel\"\n />\n <!-- :disabled=\"-->\n <!-- goods_data.isEq === 5 && unitisMaster === 4 && goods_data.specType === 1-->\n <!-- \"-->\n </ContainerTit>\n</template>\n\n<script>\n import GoodsWarehouse from \"@/component/goods/GoodsWarehouse\";\n import Chart1 from \"../components/Chart1\";\n import SelectShop from \"@/component/goods/SelectShop.vue\";\n import { getAllExpressRule, getAllCustomerSource } from \"@/api/System\";\n import { addPauseSave, delPauseSave, getPauseSave } from \"@/api/common\";\n import {\n getGoodsInfo,\n editGoods,\n addGoods,\n getGoodsBasicInfoById,\n getAllGoodsSupport,\n getAllGoodsGroups,\n } from \"@/api/goods\";\n import ClientListModal from \"@/component/common/ClientListModal\";\n import CustomerPrice from \"../components/CustomerPrice\";\n import LadderPrice from \"../components/LadderPrice\";\n import CustomerTypePrice from \"../components/CustomerTypePrice\";\n import RegionTree from \"@/component/common/RegionTree\";\n import { mapGetters } from \"vuex\";\n import { Enterprise } from \"@/api/user\";\n import {\n CustomerPriceAdjustmentAdd,\n addCustomerTypePriceAdjustment,\n getCustomerPriceByGoodsIds,\n getCustomerTypePriceByGoodsIds,\n } from \"@/api/Price\";\n const priceDataLi = {\n enabledLadder: 0,\n marketPrice: \"\",\n memberPrice: \"\",\n costPrice: \"\",\n salePrice: \"\",\n setNum: 0,\n isSale: 5,\n salePriceAreaType: 1,\n ladderPrice: [\n /* {\n from: 1,\n price: 0.01,\n to: 2\n }, {\n from: 3,\n price: 0.01,\n to: 4\n },\n {\n from: 5,\n price: 0.01,\n to: 999999999\n } */\n ],\n };\n export default {\n name: \"AddBaseData\",\n components: {\n SelectShop,\n GoodsWarehouse,\n RegionTree,\n ClientListModal,\n Chart1,\n CustomerPrice,\n CustomerTypePrice,\n LadderPrice,\n },\n props: {\n goodsId: {\n type: [Number, String],\n default: 0,\n },\n basicGoodsId: {\n type: [Number, String],\n default: 0,\n },\n },\n data() {\n return {\n // flagS: false,\n unitisMaster: 4,\n choose_support: [],\n unit_index: 0,\n sku_index: 0,\n ladderPrice: [],\n enabledLadder: 0,\n ladder_price_show: false, // 阶梯价弹窗\n type_price_show: false, // 客户类型价弹窗\n customerTypePriceOpen: false, // 客户类型价弹窗开关\n customerTypePrice: [], // 客户类型价弹窗数据\n customerPriceOpen: false,\n customerPrice: [],\n appoint_price_show: false, // 客户指定价弹窗\n customer_show: false, // 经营屏蔽->客户列表弹窗选择\n customer_list: [], // 经营屏蔽->客户列表\n customer_type_check: [], // 经营屏蔽->客户类型选择数组\n customer_type_list: [], // 经营屏蔽->客户类型列表\n region_arr: [], // 经营屏蔽->当前商品已选择过的区域\n page_tabs: \"1\", // 页面tab切换\n unit_name_tab: \"\",\n show_region: false,\n goods_data: {\n specType: 1,\n },\n primary_unit: \"\",\n price_data: [\n // { marketPrice: '' }\n ],\n show_goods: false,\n show_chose: false,\n isModel: false,\n base_rules: {\n shopName: [\n { required: true, message: \"请选择店铺\", trigger: \"change\" },\n ],\n goodsName: [\n { required: true, message: \"请选择商品\", trigger: \"change\" },\n ],\n deliverySupIds: [\n {\n required: true,\n type: \"array\",\n message: \"请选择物流支持\",\n trigger: \"change\",\n },\n ],\n ruleId: [\n { required: true, message: \"请选择运费模板\", trigger: \"change\" },\n ],\n expressFee: [\n { required: true, message: \"请输入运费\", trigger: \"blur\" },\n ],\n },\n price: \"\",\n express_list: [], // 运费模版列表\n base_form: {\n createUserName: \"\",\n goodsName: \"\",\n enableStatus: 5,\n isDistribution: 4, //负库存销售\n specType: \"\",\n goodsBasicId: 0, // 商品基础资料\n shopId: \"\", // 店铺\n shopName: \"\", // 店铺\n images: [], // 相册\n salesArea: [], // 销售区域\n serviceInfo: 1,\n price: [], // 区域价\n specification: [], // // 规格\n content: \"\", // 商品描述\n isRecommend: 5, // 5推荐 4不推荐\n sort: \"999\", // 排序\n deliverySupIds: [\"1\", \"2\"], // 物流支持 固定值 1 快递 2 自提 传参格式:1,2\n expressType: 1, // 快递运费 1 包邮 2 运费模版 3 固定费用\n expressFee: \"\", // 固定费用\n showExpress: 5, // 是否展示快递 5展示 4不展示\n ruleId: \"\", // 运费模版id\n isShield: 4, // 经营屏蔽 4关闭 5开启\n notArea: [], //经营屏蔽地区\n notCustomerType: \"\", //经营屏蔽 客户类型屏蔽\n notCustomer: \"\", //经营屏蔽 客户屏蔽\n showMinUnitPrice: 4, //最小单位\n },\n delivery_form: {},\n user_power: {},\n goods_id: 0,\n sub_load: false,\n pageName: \"\",\n time_data: [],\n goodsNum_data: [],\n orderMoney_data: [],\n orderNum_data: [],\n time: [],\n tableData: [],\n page: 1,\n pageSize: 20,\n total: 0,\n support: [],\n options_value: [],\n goods_groups: [],\n sku_id: \"\",\n };\n },\n computed: {\n ...mapGetters({\n salePriceTimes: \"MUser/salePriceTimes\",\n systemType: \"MUser/systemType\",\n storeData: \"MUser/storeData\",\n }),\n },\n async created() {\n this.pageName = this.$route.name;\n if (this.basicGoodsId) {\n await this.selGoods([], this.basicGoodsId);\n return;\n }\n if (this.$route.params.id) {\n this.goods_id = this.$route.params.id;\n await this.getDetail();\n } else {\n await this.getPauseSave();\n\t\t\n if ([2, 3].includes(this.systemType)) {\n\t\t\tconsole.log( this.pageName);\n this.base_form.shopId = this.storeData.id; // 店铺\n this.base_form.shopName = this.storeData.name; // 店铺\n }\n }\n // 获取运费模版\n await this.getAllExpressRule();\n // 获取客户类型\n await this.getAllCustomerSource();\n // 获取商品服务\n await this.getAllGoodsSupport();\n // 商品分组\n await this.getAllGoodsGroups();\n },\n methods: {\n getShop() {\n this.$emit(\"closeShop\");\n this.$router.push(\"/SystemSettings/liansuoguanli/AddShop\");\n },\n // 获取运费模版\n async getAllExpressRule() {\n const { data } = await getAllExpressRule();\n this.express_list = data;\n const data1 = await Enterprise({\n ranking: 1, // \"1销量排行 2销额排行\",\n businessOverviewShopId: \"\", // \"经营概况按店铺筛选:为空则筛选全店\",\n categoryRankingShopId: \"\", // \"类目排行按店铺筛选:为空则筛选全店\",\n goodsRankingShopId: \"\", // \"商品排行按店铺筛选:为空则筛选全店\",\n supplierRankingShopId: \"\", // 供应商排行按店铺筛选:为空则筛选全店\"\n });\n if (data1.data.aggregateStatistics) {\n if (this.time_data.length) {\n this.time_data = [];\n }\n this.$nextTick(() => {\n data1.data.chartData.forEach((value) => {\n this.time_data.push(value.date);\n });\n });\n }\n },\n // 计算市场价\n salePriceBlur(index, indexU) {\n if (this.goods_data.specType === 1) {\n // 根据比例自动换算销售价\n const target = this.$_common.deepClone(this.price_data);\n const marketPrice = this.$NP.times(\n target[index].salePrice,\n this.salePriceTimes\n );\n target[index] = {\n ...target[index],\n marketPrice: marketPrice,\n };\n // target.forEach((item) => {\n // if (\n // item.conversion &&\n // item.isMaster === 4 &&\n // this.goods_data.isEq === 5\n // ) {\n // item.salePrice = this.$NP.times(\n // target[index].salePrice,\n // item.conversion\n // );\n // item.marketPrice = this.$NP.times(marketPrice, item.conversion);\n // }\n // });\n this.price_data = target;\n } else {\n this.goods_data.unitData[indexU].priceData[\n index\n ].marketPrice = this.$NP.times(\n this.goods_data.unitData[indexU].priceData[index].salePrice,\n this.salePriceTimes\n );\n }\n },\n // 会员价失去焦点\n memberPriceBlur(index) {\n return;\n // 根据比例自动换算 会员价\n if (this.goods_data.specType === 1) {\n const target = this.$_common.deepClone(this.price_data);\n target.forEach((item) => {\n if (\n item.conversion &&\n item.isMaster === 4 &&\n this.goods_data.isEq === 5\n ) {\n item.memberPrice = this.$NP.times(\n target[index].memberPrice,\n item.conversion\n );\n }\n });\n this.price_data = target;\n }\n },\n shopDefault(val, row) {\n this.base_form.shopId = val;\n this.base_form.shopName = row.name;\n },\n otherSetPrice(row, index) {\n const target = this.$_common.deepClone(this.goods_data);\n target.unitData[index].priceData = target.unitData[index].priceData.map(\n (item) => {\n return {\n ...item,\n customerTypePrice: row.customerTypePrice,\n customerTypePriceOpen: row.customerTypePriceOpen,\n customerPrice: row.customerPrice,\n customerPriceOpen: row.customerPriceOpen,\n marketPrice: row.marketPrice,\n memberPrice: row.memberPrice,\n salePrice: row.salePrice,\n enabledLadder: row.enabledLadder,\n ladderPrice: row.ladderPrice,\n setNum: row.setNum,\n isSale: row.isSale || 5,\n };\n }\n );\n this.goods_data = target;\n },\n openShop() {\n if (this.goods_id) return;\n this.show_chose = true;\n },\n openGoodsModel() {\n if (!this.base_form.shopName || !!this.goods_id) return;\n this.show_goods = true;\n },\n // 获取商品详情\n async getDetail() {\n const { data } = await getGoodsInfo(this.goods_id);\n this.goods_data = data;\n this.choose_support = data.support;\n let arr = [];\n data.goodsGroups.forEach((item) => {\n if (item) {\n arr.push(Number(item));\n }\n });\n this.options_value = arr;\n this.base_form = {\n createUserName: this.userName,\n goodsName: data.title,\n enableStatus: data.enableStatus, // 是否上架\n isDistribution: data.isDistribution, //是否负库存销售\n goodsBasicId: data.basicGoodsId, // 商品基础资料\n shopId: data.shopId, // 店铺\n shopName: data.shopName, // 店铺\n images: data.images, // 相册\n salesArea: data.salesArea, // 销售区域\n serviceInfo: data.serviceInfo,\n price: [],\n specification: data.specification, // // 规格\n content: data.content, // 商品描述\n isRecommend: data.isRecommend, // 5推荐 4不推荐\n sort: data.sort, // 排序\n specType: data.specType, // 2 多规格 1单规格\n deliverySupIds: data.deliverySupIds.split(\",\"), // 物流支持 固定值 1 快递 2 自提 传参格式:1,2\n expressType: data.expressType, // 快递运费 1 包邮 2 运费模版 3 固定费用\n expressFee: data.expressFee, // 固定费用\n showExpress: data.showExpress, // 是否展示快递 5展示 4不展示\n ruleId: data.ruleId, // 运费模版id\n isShield: data.isShield, // 经营屏蔽\n notArea: data.notArea,\n notCustomerType: data.notCustomerType,\n notCustomer: data.notCustomer,\n showMinUnitPrice: data.showMinUnitPrice,\n };\n this.region_arr = data.notArea;\n this.customer_type_check = data.notCustomerType\n ? data.notCustomerType.split(\",\").map((item) => parseInt(item))\n : [];\n this.customer_list = data.notCustomerLists || [];\n if (data.specType === 1) {\n this.price_data = data.specMultiple.map((item) => {\n return {\n ...item,\n isSale: item.isSale || 5,\n // 客户类型和客户快速调价\n customerTypePrice: [],\n customerTypePriceOpen: false,\n customerPrice: [],\n customerPriceOpen: false,\n };\n });\n } else if (data.specType === 2) {\n if (this.goods_data.unitData && this.goods_data.unitData.length) {\n this.unit_name_tab = this.goods_data.unitData[0].unitName;\n this.goods_data.unitData = this.goods_data.unitData.map((itemU) => {\n const priceData = data.specMultiple\n .filter((itemF) => itemF.unitId === itemU.unitId)\n .map((item) => {\n const skuName = item.specGroup\n .map((itemM) => {\n return itemM.specValueName;\n })\n .join(\"_\");\n // item.specGroup.forEach((itemS) => {\n // if (itemS.specId === 11) {\n // this.flagS = true;\n // }\n // });\n return {\n ...item,\n isSale: item.isSale || 5,\n skuName: skuName,\n // 客户类型和客户快速调价\n customerTypePrice: [],\n customerTypePriceOpen: false,\n customerPrice: [],\n customerPriceOpen: false,\n minUnitPriceConvert: item.minUnitPriceConvert || \"\",\n };\n });\n return {\n ...itemU,\n priceData: priceData,\n };\n });\n }\n }\n // this.region_arr = data.salesArea\n if (data.basicGoodsId) {\n await this.selGoods([], data.basicGoodsId);\n }\n this.toggleSelection();\n // 获取指定商品的最后生效的客户调价单数据\n await this.getCustomerPriceByGoodsIds();\n //获取指定商品的最后生效的客户类型调价数据\n await this.getCustomerTypePriceByGoodsIds();\n },\n // 检查提交\n checkSub() {\n this.$refs.base_form.validate((valid) => {\n if (valid) {\n let priceData = [];\n if (this.goods_data.specType === 2) {\n // 多属性\n this.goods_data.unitData.forEach((item) => {\n item.priceData.forEach((itemP) => {\n priceData.push({\n id: itemP.id,\n conversion: itemP.conversion,\n unitName: itemP.unitName,\n unitId: itemP.unitId,\n isMaster: itemP.isMaster,\n deleteStatus: itemP.deleteStatus || 4,\n enabledLadder: itemP.enabledLadder,\n salePriceAreaType: itemP.salePriceAreaType,\n salePrice: itemP.salePrice,\n ladderPrice: itemP.ladderPrice,\n marketPrice: itemP.marketPrice,\n memberPrice: itemP.memberPrice,\n setNum: itemP.setNum,\n isSale: itemP.isSale || 5,\n minUnitPriceConvert: itemP.minUnitPriceConvert,\n });\n });\n });\n } else {\n priceData = this.$_common\n .deepClone(this.price_data)\n .map((item) => {\n delete item.customerTypePrice;\n delete item.customerTypePriceOpen;\n delete item.customerPrice;\n delete item.customerPriceOpen;\n return item;\n });\n }\n\n let ladderPriceLength = true;\n let isLadderPrice = true;\n for (let i in priceData) {\n const item = priceData[i];\n if (item.enabledLadder === 1) {\n if (item.ladderPrice.length < 2) {\n ladderPriceLength = false;\n break;\n } else if (\n !item.ladderPrice.every((itemP) => itemP.price > 0)\n ) {\n isLadderPrice = false;\n break;\n }\n } else {\n if (!item.salePrice) {\n isLadderPrice = false;\n break;\n }\n }\n }\n if (!ladderPriceLength) {\n this.$message.warning(\"请至少设置两条阶梯价\");\n return;\n }\n if (!isLadderPrice) {\n this.$message.warning(\"请输入价格\");\n return;\n }\n this.price = priceData.map((item) => {\n if (item.ladderPrice.length) {\n item.ladderPrice[item.ladderPrice.length - 1].to = 9999999999;\n }\n let min = 0;\n if (item.enabledLadder === 1) {\n const arr = item.ladderPrice.map((itemM) => {\n return itemM.price;\n });\n min = Math.min.apply(null, arr);\n }\n return {\n ...item,\n ladderPrice: item.enabledLadder === 0 ? [] : item.ladderPrice,\n salePrice: item.enabledLadder === 1 ? min : item.salePrice,\n };\n });\n this.price = priceData;\n this.subData();\n }\n });\n },\n // 商品新建提交\n async subData() {\n let target = {};\n const notCustomer = this.customer_list.map((item) => {\n return item.id;\n });\n const isFSale = this.price.every((item) => item.isSale === 4);\n if (isFSale) {\n this.$message.warning(\"至少保留一条规格的销售状态为【启用】\");\n return;\n }\n const params = {\n ...this.base_form,\n price: this.price,\n deliverySupIds: this.base_form.deliverySupIds.join(\",\"),\n notCustomerType: this.customer_type_check.join(\",\"),\n notCustomer: notCustomer.join(\",\"),\n support: this.choose_support,\n goodsGroups: this.options_value,\n };\n this.sub_load = true;\n try {\n if (this.goods_id) {\n target = await editGoods(this.goods_id, params);\n this.sub_load = false;\n await this.AdjustPrice(this.goods_id);\n } else {\n target = await addGoods({\n ...params,\n createUserName: this.userName,\n });\n this.sub_load = false;\n await this.AdjustPrice(target.data);\n await this.delPauseSave();\n }\n this.$message({\n type: \"success\",\n message: \"提交成功\",\n });\n if (this.basicGoodsId) {\n this.$emit(\"subData\");\n } else {\n if (this.systemType === 2) {\n await this.$closeCurrentGoEdit(\n \"/SingleStore/goods/GoodsAdministration\"\n );\n } else {\n await this.$closeCurrentGoEdit(\"/goods/sale/PublishGoods\");\n }\n }\n } finally {\n this.sub_load = false;\n }\n },\n // 请求快速调价接口\n async AdjustPrice(goodsId) {\n let typeParams = [];\n let customerParams = [];\n let typePrice = [];\n let customerPrice = [];\n if (this.goods_data.specType === 1) {\n this.price_data.forEach((item) => {\n if (item.customerTypePriceOpen) {\n item.customerTypePrice.forEach((type) => {\n // if (!type.priceId) {\n typeParams.push({\n createUserName: this.userName,\n goodsName: this.base_form.goodsName,\n goodsId: goodsId,\n shopId: this.base_form.shopId,\n shopName: this.base_form.shopName,\n customerName: type.name,\n customerType: type.id,\n effective: 5, //调价单立即生效effective 5立即生效 4需要手动生效\n salePrice: [\n {\n price: type.price,\n skuId: item.id,\n unitName: item.unitName,\n adjPricetag: type.adjPricetag,\n ladderPrice: type.ladderPrice || [],\n },\n ],\n });\n // }\n });\n }\n if (item.customerPriceOpen) {\n item.customerPrice.forEach((type) => {\n // if (!type.priceId) {\n customerParams.push({\n createUserName: this.userName,\n goodsName: this.base_form.goodsName,\n goodsId: goodsId,\n shopId: this.base_form.shopId,\n shopName: this.base_form.shopName,\n customerName: type.name,\n customerId: type.id,\n effective: 5, //调价单立即生效effective 5立即生效 4需要手动生效\n salePrice: [\n {\n price: type.price,\n skuId: item.id,\n unitName: item.unitName,\n adjPricetag: type.adjPricetag,\n ladderPrice: type.ladderPrice || [],\n },\n ],\n });\n // }\n });\n }\n });\n } else {\n // 多属性\n this.goods_data.unitData.forEach((item) => {\n item.priceData.forEach((itemP) => {\n if (itemP.customerTypePriceOpen) {\n itemP.customerTypePrice.forEach((type) => {\n // if (!type.priceId) {\n typeParams.push({\n createUserName: this.userName,\n goodsName: this.base_form.goodsName,\n goodsId: goodsId,\n shopId: this.base_form.shopId,\n shopName: this.base_form.shopName,\n customerName: type.name,\n customerType: type.id,\n effective: 5, //调价单立即生效effective 5立即生效 4需要手动生效\n salePrice: [\n {\n price: type.price,\n skuId: itemP.id,\n unitName: itemP.unitName,\n adjPricetag: type.adjPricetag,\n ladderPrice: type.ladderPrice || [],\n },\n ],\n });\n // }\n });\n }\n if (itemP.customerPriceOpen) {\n itemP.customerPrice.forEach((type) => {\n // if (!type.priceId) {\n customerParams.push({\n createUserName: this.userName,\n goodsName: this.base_form.goodsName,\n goodsId: goodsId,\n shopId: this.base_form.shopId,\n shopName: this.base_form.shopName,\n customerName: type.name,\n customerId: type.id,\n effective: 5, //调价单立即生效effective 5立即生效 4需要手动生效\n salePrice: [\n {\n price: type.price,\n skuId: itemP.id,\n unitName: itemP.unitName,\n adjPricetag: type.adjPricetag,\n ladderPrice: type.ladderPrice || [],\n },\n ],\n });\n // }\n });\n }\n });\n });\n }\n //客户类型\n typeParams.forEach((item) => {\n const index = typePrice.findIndex(\n (price) => price.customerType === item.customerType\n );\n if (index === -1) {\n typePrice.push({\n ...item,\n });\n } else {\n typePrice[index].salePrice = typePrice[index].salePrice.concat(\n item.salePrice\n );\n }\n });\n //客户价格\n customerParams.forEach((item) => {\n const index = customerPrice.findIndex(\n (price) => price.customerId === item.customerId\n );\n if (index === -1) {\n customerPrice.push({\n ...item,\n });\n } else {\n customerPrice[index].salePrice = customerPrice[\n index\n ].salePrice.concat(item.salePrice);\n }\n });\n\n // console.log(\"typePrice\", typePrice);\n // console.log(\"customerPrice\", customerPrice);\n await this.addCustomerTypePriceAdjustment(typePrice);\n await this.CustomerPriceAdjustmentAdd(customerPrice);\n },\n // 获取暂存信息\n async getPauseSave() {\n const { data } = await getPauseSave({\n key: this.pageName,\n });\n\n if (JSON.stringify(data) === \"{}\") return;\n if (data.goods_data) {\n this.goods_data = data.goods_data;\n }\n if (data.base_form) {\n this.base_form = data.base_form;\n this.region_arr = this.base_form.notArea;\n }\n if (data.price) {\n this.price_data = data.price;\n }\n if (data.unit_name_tab) {\n this.unit_name_tab = data.unit_name_tab;\n }\n if (data.customer_list) {\n this.customer_list = data.customer_list;\n }\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/sale/AddGoods\");\n }\n },\n // 商品暂存\n async tempData() {\n this.sub_load = true;\n try {\n const data = await addPauseSave({\n key: this.pageName,\n data: {\n base_form: this.base_form,\n price: this.price,\n goods_data: this.goods_data,\n unit_name_tab: this.unit_name_tab,\n customer_list: this.customer_list,\n },\n });\n this.sub_load = false;\n\n this.$message({\n type: \"success\",\n message: \"暂存成功\",\n });\n if (this.systemType === 2) {\n this.$closeCurrentGoEdit(\"/SingleStore/goods/GoodsAdministration\");\n } else {\n this.$closeCurrentGoEdit(\"/goods/sale/PublishGoods\");\n }\n } finally {\n this.sub_load = false;\n }\n },\n // 选择商品\n async selGoods(row, basicGoodsId) {\n const { data } = await getGoodsBasicInfoById(\n basicGoodsId || row[0].id,\n {\n isAddGoods: 5,\n }\n );\n\n if (this.goods_id) {\n this.goods_data = {\n ...this.goods_data,\n categoryTitle: data.categoryTitle,\n brandTitle: data.brandTitle,\n expireTime: data.expireTime,\n description: data.description,\n tag: data.tag,\n masterUnit: data.unitData.find((item) => item.isMaster === 5),\n branchUnit: data.unitData.filter((item) => item.isMaster === 4),\n };\n return;\n }\n this.goods_data = {\n ...data,\n masterUnit: data.unitData.find((item) => item.isMaster === 5),\n branchUnit: data.unitData.filter((item) => item.isMaster === 4),\n };\n this.base_form.goodsName = data.title;\n this.unit_name_tab = data.unitData[0].unitName;\n this.base_form.images = data.images;\n this.base_form.specType = data.specType;\n this.base_form.content = data.description;\n this.base_form.goodsBasicId = data.id;\n let priceData = [];\n const priceDataItem = this.$_common.deepClone(priceDataLi);\n if (data.specType === 1) {\n priceData = data.unitData.map((item) => {\n return {\n ...item,\n ...priceDataItem,\n isSale: 5,\n // 客户类型和客户快速调价\n customerTypePrice: [],\n customerTypePriceOpen: false,\n customerPrice: [],\n customerPriceOpen: false,\n };\n });\n this.price_data = priceData;\n } else if (data.specType === 2) {\n this.goods_data.unitData = this.goods_data.unitData.map((itemU) => {\n const priceD = data.specMultiple\n .filter((itemF) => itemF.unitId === itemU.unitId)\n .map((item) => {\n const skuName = item.specGroup\n .map((itemM) => {\n return itemM.specValueName;\n })\n .join(\"_\");\n // item.specGroup.forEach((itemS) => {\n // if (itemS.specId === 11) {\n // this.flagS = true;\n // }\n // });\n return {\n ...item,\n ...priceDataItem,\n isSale: 5,\n skuName: skuName,\n // 客户类型和客户快速调价\n customerTypePrice: [],\n customerTypePriceOpen: false,\n customerPrice: [],\n customerPriceOpen: false,\n };\n });\n return {\n ...itemU,\n priceData: priceD,\n };\n });\n }\n let specification = [];\n if (row[0]) {\n if (row[0].specType === 1) {\n specification = (row[0].branchUnit || []).concat(row[0].masterUnit);\n } else if (row[0].specType === 2) {\n specification = row[0].specMultiple;\n }\n }\n this.base_form.specification = specification;\n let arr = \"\";\n this.price_data.forEach((item) => {\n if (item.isMaster === 5) {\n arr = item.unitName;\n }\n });\n this.primary_unit = arr;\n },\n // 选择商铺\n selChose(val, row) {\n this.base_form.shopId = row[0].id;\n this.base_form.shopName = row[0].name;\n },\n // 地区选择\n selRegion(row) {\n this.base_form.notArea = row.map((item) => {\n return item.codePath;\n });\n },\n // 获取客户类型\n async getAllCustomerSource() {\n const data = await getAllCustomerSource({\n page: 1,\n pageSize: 50,\n });\n\n this.customer_type_list = data.data;\n },\n // 选择客户\n customerSel(val) {\n this.customer_list = val;\n },\n // 删除客户\n deleteCustomer(index) {\n this.customer_list.splice(index, 1);\n },\n // 价格波动图\n orderDate() {\n console.log(this.time);\n },\n // 打开指定价弹窗\n openModal(index, key, row, indexU) {\n // 获取阶梯价数据,做阶梯价调价\n if (row) {\n this.unitisMaster = row.isMaster;\n this.sku_id = row.id;\n this.ladderPrice = row.ladderPrice;\n this.enabledLadder = row.enabledLadder;\n if (key === \"type_price_show\") {\n // 客户类型指定价调价数据\n this.customerTypePriceOpen = row.customerTypePriceOpen;\n this.customerTypePrice = row.customerTypePrice;\n }\n if (key === \"appoint_price_show\") {\n // 客户指定价调价数据\n this.customerPriceOpen = row.customerPriceOpen;\n this.customerPrice = row.customerPrice;\n }\n }\n this.sku_index = index;\n if (indexU > -1) {\n this.unit_index = indexU;\n }\n this[key] = true;\n },\n // 指定价数据确定\n appointPriceConfirm(customerPriceOpen, customerPrice) {\n if (this.goods_data.specType === 1) {\n // 单规格\n const target = this.$_common.deepClone(this.price_data);\n target[this.sku_index].customerPriceOpen = customerPriceOpen;\n target[this.sku_index].customerPrice = customerPriceOpen\n ? customerPrice\n : [];\n this.price_data = target;\n } else {\n // 多规格\n const target = this.$_common.deepClone(this.goods_data.unitData);\n target[this.unit_index].priceData[\n this.sku_index\n ].customerPriceOpen = customerPriceOpen;\n target[this.unit_index].priceData[\n this.sku_index\n ].customerPrice = customerPriceOpen ? customerPrice : [];\n this.goods_data.unitData = target;\n }\n },\n // 指定价数据取消\n async appointPriceCancel(customerPriceOpen, customerPrice) {\n this.appoint_price_show = false;\n if (this.$route.params.id) {\n await this.appointPriceConfirm(customerPriceOpen, customerPrice);\n }\n },\n // 客户类型价设置\n typePriceConfirm(customerTypePriceOpen, customerTypePrice) {\n if (this.goods_data.specType === 1) {\n // 单规格\n const target = this.$_common.deepClone(this.price_data);\n target[this.sku_index].customerTypePriceOpen = customerTypePriceOpen;\n target[this.sku_index].customerTypePrice = customerTypePriceOpen\n ? customerTypePrice\n : [];\n this.price_data = target;\n } else {\n // 多规格\n const target = this.$_common.deepClone(this.goods_data.unitData);\n target[this.unit_index].priceData[\n this.sku_index\n ].customerTypePriceOpen = customerTypePriceOpen;\n target[this.unit_index].priceData[\n this.sku_index\n ].customerTypePrice = customerTypePriceOpen ? customerTypePrice : [];\n this.goods_data.unitData = target;\n }\n },\n // 客户类型价数据取消\n async typePriceCancel(customerTypePriceOpen, customerTypePrice) {\n this.type_price_show = false;\n if (this.$route.params.id) {\n //获取指定商品的最后生效的客户类型调价数据\n await this.typePriceConfirm(customerTypePriceOpen, customerTypePrice);\n }\n },\n // 阶梯价设置\n ladderPriceConfirm(enabledLadder, ladderPrice) {\n if (this.goods_data.specType === 1) {\n // 单规格\n const target = this.$_common.deepClone(this.price_data);\n // if (this.goods_data.isEq === 5) {\n // // 抄码商品根据比例自动换算销售价\n // target.forEach((item) => {\n // item.enabledLadder = enabledLadder;\n // if (enabledLadder) {\n // if (item.conversion && item.isMaster === 4) {\n // item.ladderPrice = ladderPrice.map((ladder) => {\n // return {\n // ...ladder,\n // price: this.$NP.times(ladder.price, item.conversion),\n // };\n // });\n // } else {\n // item.ladderPrice = ladderPrice;\n // }\n // } else {\n // item.ladderPrice = [];\n // }\n // });\n // } else {\n // target[this.sku_index].enabledLadder = enabledLadder;\n // target[this.sku_index].ladderPrice = enabledLadder\n // ? ladderPrice\n // : [];\n // }\n target[this.sku_index].enabledLadder = enabledLadder;\n target[this.sku_index].ladderPrice = enabledLadder ? ladderPrice : [];\n this.price_data = target;\n } else {\n // 多规格\n const target = this.$_common.deepClone(this.goods_data.unitData);\n target[this.unit_index].priceData[\n this.sku_index\n ].enabledLadder = enabledLadder;\n target[this.unit_index].priceData[\n this.sku_index\n ].ladderPrice = enabledLadder ? ladderPrice : [];\n this.goods_data.unitData = target;\n }\n },\n ladderPriceCancel() {\n this.ladder_price_show = false;\n },\n // 客户调价单\n async CustomerPriceAdjustmentAdd(params) {\n if (!params.length) return;\n const { data } = await CustomerPriceAdjustmentAdd(params);\n },\n // 客户类型调价单\n async addCustomerTypePriceAdjustment(params) {\n if (!params.length) return;\n const { data } = await addCustomerTypePriceAdjustment(params);\n },\n async getAllGoodsSupport() {\n const { data, pageTotal } = await getAllGoodsSupport({\n page: this.page,\n pageSize: this.pageSize,\n });\n this.tableData = data;\n this.total = pageTotal;\n },\n toggleSelection() {\n let arr = [];\n this.goods_data.support.forEach((item) => {\n arr.push(Number(item));\n });\n this.choose_support = arr;\n },\n // 商品组\n async getAllGoodsGroups() {\n const { data } = await getAllGoodsGroups({\n page: 1,\n pageSize: 999,\n name: \"\",\n });\n this.goods_groups = data;\n },\n // 获取指定商品的最后生效的客户调价单数据\n async getCustomerPriceByGoodsIds() {\n const { data, pageTotal } = await getCustomerPriceByGoodsIds({\n goodsId: this.goods_id,\n page: 1,\n pageSize: 200,\n });\n this.customerPrice = data;\n },\n // 获取指定商品的最后生效的客户类型调价数据\n async getCustomerTypePriceByGoodsIds() {\n const { data } = await getCustomerTypePriceByGoodsIds({\n goodsId: this.goods_id,\n page: 1,\n pageSize: 999,\n });\n this.customerTypePrice = data;\n this.adjustmentData();\n },\n adjustmentData() {\n if (this.base_form.specType === 1) {\n this.price_data = this.price_data.map((item) => {\n //客户类型价\n let customerTypePrice = [];\n this.customerTypePrice.forEach((type) => {\n if (type.salePrice && type.salePrice.length) {\n type.salePrice.forEach((pitem) => {\n if (pitem.skuId === item.id) {\n customerTypePrice.push({\n adjPricetag: pitem.adjPricetag,\n ladderPrice: pitem.ladderPrice,\n price: pitem.price,\n name: type.customerTypeName,\n id: type.customerType,\n priceId: type.id,\n });\n }\n });\n }\n });\n //客户价\n let customerPrice = [];\n this.customerPrice.forEach((type) => {\n if (type.salePrice && type.salePrice.length) {\n type.salePrice.forEach((pitem) => {\n if (pitem.skuId === item.id) {\n customerPrice.push({\n adjPricetag: pitem.adjPricetag,\n ladderPrice: pitem.ladderPrice,\n price: pitem.price,\n name: type.customerName,\n id: type.customerId,\n priceId: type.id,\n });\n }\n });\n }\n });\n return {\n ...item,\n // 客户类型和客户快速调价\n customerTypePrice: customerTypePrice,\n customerTypePriceOpen: customerTypePrice.length > 0,\n customerPrice: customerPrice,\n customerPriceOpen: customerPrice.length > 0,\n };\n });\n } else {\n this.goods_data.unitData = this.goods_data.unitData.map((itemU) => {\n return {\n ...itemU,\n priceData: itemU.priceData.map((item) => {\n //客户类型价\n let customerTypePrice = [];\n this.customerTypePrice.forEach((type) => {\n if (type.salePrice && type.salePrice.length) {\n type.salePrice.forEach((pitem) => {\n if (pitem.skuId === item.id) {\n customerTypePrice.push({\n adjPricetag: pitem.adjPricetag,\n ladderPrice: pitem.ladderPrice,\n price: pitem.price,\n name: type.customerTypeName,\n id: type.customerType,\n priceId: type.id,\n });\n }\n });\n }\n });\n //客户价\n let customerPrice = [];\n this.customerPrice.forEach((type) => {\n if (type.salePrice && type.salePrice.length) {\n type.salePrice.forEach((pitem) => {\n if (pitem.skuId === item.id) {\n customerPrice.push({\n adjPricetag: pitem.adjPricetag,\n ladderPrice: pitem.ladderPrice,\n price: pitem.price,\n name: type.customerName,\n id: type.customerId,\n priceId: type.id,\n });\n }\n });\n }\n });\n return {\n ...item,\n customerTypePrice: customerTypePrice,\n customerTypePriceOpen: customerTypePrice.length > 0,\n customerPrice: customerPrice,\n customerPriceOpen: customerPrice.length > 0,\n };\n }),\n };\n });\n }\n },\n },\n };\n</script>\n<style scoped lang=\"scss\">\n .ph {\n background-color: #fff;\n height: 240px;\n padding: 12px 17px 12px 17px;\n border-radius: 6px;\n box-shadow: 0 2px 6px 0 rgba(76, 80, 88, 0.16);\n position: relative;\n .ranking-sel {\n position: absolute;\n left: 130px;\n top: 14px;\n }\n h4 {\n display: inline-block;\n width: 120px;\n }\n .ph-num-text {\n font-size: 16px;\n font-weight: 600;\n color: #24365c;\n margin: -8px 0 0 10px;\n }\n }\n .switch-div {\n padding-bottom: 10px;\n }\n .td-label {\n display: inline-block;\n width: 80px;\n text-align: right;\n font-size: 13px;\n vertical-align: middle;\n }\n .ladder-price-ul {\n vertical-align: middle;\n display: inline-block;\n }\n</style>\n"]}]}
|