1 |
- {"remainingRequest":"D:\\qianger\\7\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js!D:\\qianger\\7\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\qianger\\7\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\qianger\\7\\jindouyunNewFront\\src\\views\\goods\\sale\\AddGoodsAdjustPrice.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\qianger\\7\\jindouyunNewFront\\src\\views\\goods\\sale\\AddGoodsAdjustPrice.vue","mtime":1655374732000},{"path":"D:\\qianger\\7\\jindouyunNewFront\\babel.config.js","mtime":1655374732000},{"path":"D:\\qianger\\7\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\qianger\\7\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"D:\\qianger\\7\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\qianger\\7\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js","mtime":1655715099000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.array.includes.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import GoodsChooseShop from "@/component/goods/GoodsChooseShop.vue";
import ConditionSelGoods from "@/component/common/ConditionSelGoods";
import SelectShop from "@/component/goods/SelectShop.vue";
import { getGoodsInfo } from "@/api/goods";
import { addPauseSave, getPauseSave, delPauseSave } from "@/api/common";
import { addAndEffective, PriceAdjustmentAdd } from "@/api/Price";
import { mapGetters } from "vuex";
import { getSupplierOfferPrice } from "@/api/Supplier";
import { getRelMap } from "@/api/goods";
const ladderPriceData = [{
  from: 1,
  price: 0.01,
  to: 2
}, {
  from: 3,
  price: 0.01,
  to: 4
}, {
  from: 5,
  price: 0.01,
  to: 999999999
}];
const goodsItem = {
  createUserName: "",
  goodsName: "",
  goodsId: "",
  saleType: "1",
  salePriceType: "1",
  salePriceAreaType: 1,
  salePrice: "",
  nowPrice: "",
  unitName: "",
  skuId: "",
  shopId: "",
  shopName: "",
  ladderPrice: ladderPriceData,
  enabledLadder: 0
};
export default {
  name: "AddGoodsAdjustPrice",
  components: {
    ConditionSelGoods,
    SelectShop
  },
  props: {
    goodId: {
      type: [Number, String],
      default: 0
    }
  },

  data() {
    return {
      show_goods: false,
      loading: false,
      shop_name: "",
      isDraw: false,
      show_shop: false,
      m_index: "",
      tableData: [],
      materialName: "",
      materialData: {},
      shop_id: "",
      user_power: {},
      pageName: "",
      goods_index: 0,
      goods_options: [],
      select_loading: false,
      spec_check: [],
      goodsItem: {},
      modify_list: [],
      price_id: 0
    };
  },

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

  created() {
    this.pageName = this.$route.name; // 商品列表进行商品调价

    this.isDraw = this.goodId > 0;

    if (this.isDraw) {
      this.getGoodsDetail();
    } else {
      // 报价单
      if (this.$route.query.price_id) {
        this.price_id = this.$route.query.price_id; // this.getSupplierOfferPrice();

        return;
      }

      for (let i = 1; i <= 1; i++) {
        this.tableData.push(this.$_common.deepClone(goodsItem));
      }

      this.getPauseSave();
    }
  },

  mounted() {
    if ([2, 3].includes(this.systemType)) {
      this.shop_id = this.storeData.id;
      this.shop_name = this.storeData.name;
    }
  },

  methods: {
    priceChange(index) {
      let target = this.$_common.deepClone(this.tableData);
      let salePrice = target[index].salePrice;

      if (salePrice < 0) {
        target[index].salePrice = 0;
      }

      this.tableData = target;
    },

    shopDefault(val, obj) {
      this.shop_id = val;
      this.shop_name = obj.name;

      if (this.$route.query.price_id) {
        this.getSupplierOfferPrice();
      }
    },

    async getRelMap(materielId) {
      const {
        data
      } = await getRelMap({
        shopId: this.shop_id,
        materielIds: materielId
      });
      this.tableData = this.tableData.map(item => {
        return { ...item,
          goodsId: data[item.id] || 0
        };
      });
    },

    async getSupplierOfferPrice() {
      const data = await getSupplierOfferPrice(this.price_id);
      let details_list = [];
      data.data.details.forEach(item => {
        for (let i in item.offerPrice) {
          details_list.push({
            goodsName: item.materielName,
            code: item.materielCode,
            id: item.materielId,
            skuId: i,
            ...item.offerPrice[i]
          });
        }
      });
      let goods_list = details_list.map(itemP => {
        const specGropName = itemP.specGroup.map(itemP => {
          return itemP.specGropName;
        });
        return {
          id: itemP.id,
          goodsName: itemP.goodsName,
          unitName: itemP.unitName,
          specGropName: specGropName,
          skuId: itemP.skuId,
          nowPrice: itemP.costPrice,
          enabledLadder: 0,
          createUserName: this.userName,
          goodsId: 0,
          saleType: "1",
          salePriceType: "1",
          salePriceAreaType: 1,
          salePrice: itemP.costPrice,
          shopId: this.shop_id,
          shopName: this.shop_name,
          ladderPrice: []
        };
      });
      this.tableData = goods_list;
      const materielId = details_list.map(itemG => {
        return itemG.id;
      });
      await this.getRelMap(this.$_common.unique(materielId));
    },

    async getGoodsDetail() {
      const {
        data
      } = await getGoodsInfo(this.goodId);
      this.shop_name = data.title;
      this.goodsItem = data; // 多商户只展示主单位

      let specMultiple = [];

      if (this.systemType === 3) {
        specMultiple = data.specMultiple.filter(item => item.isMaster === 5);
      } else {
        specMultiple = data.specMultiple;
      }

      console.log(specMultiple);

      if (data.specType === 2) {
        this.tableData = specMultiple.map(item => {
          const specValueName = item.specGroup.map(itemS => {
            return itemS.specValueName;
          }).join("_");
          return { ...item,
            goodsId: data.id,
            skuId: item.id,
            specGropName: specValueName
          };
        });
      } else if (data.specType === 1) {
        this.tableData = specMultiple.map(item => {
          return { ...item,
            goodsId: data.id,
            skuId: item.id,
            specGropName: "无"
          };
        });
      }
    },

    addListGoods() {
      this.tableData.push(this.$_common.deepClone(goodsItem));
    },

    selectSelGoods(id) {
      this.spec_check = this.tableData.filter(item => item.goodsId === id).map(item => {
        return item.skuId;
      });
    },

    specSelConfirm(params) {
      let target = this.$_common.deepClone(this.tableData);
      const goodsD = params.goodsD.map(item => {
        return {
          // spec_check_list: params.spec_check_list,
          createUserName: this.userName,
          goodsName: params.now_goods_data.title,
          goodsId: params.now_goods_data.id,
          saleType: "1",
          salePriceType: "1",
          salePriceAreaType: 1,
          salePrice: item.spec.salePrice,
          nowPrice: item.spec.salePrice,
          unitName: item.spec.unitName,
          specGropName: item.spec.specGropName,
          skuId: item.skuId,
          shopId: params.now_goods_data.shopId,
          shopName: params.now_goods_data.shopName,
          ladderPrice: item.spec.ladderPrice,
          enabledLadder: item.spec.enabledLadder
        };
      });

      if (!target[this.goods_index].skuId) {
        target.splice(this.goods_index, 1);
      }

      goodsD.forEach(item => {
        const targetD = target.find(itemG => itemG.skuId === item.skuId);

        if (!targetD) {
          target.push(item);
        }
      });
      this.tableData = target;
    },

    selGoods(list) {
      const goodsD = list.map(item => {
        let specGropName = item.specGroup.map(itemS => {
          return itemS.specValueName;
        }).join("_");
        return {
          createUserName: this.userName,
          goodsName: item.title,
          goodsId: item.id,
          saleType: "1",
          salePriceType: "1",
          salePriceAreaType: 1,
          salePrice: item.salePrice,
          nowPrice: item.salePrice,
          unitName: item.unitName,
          specGropName: specGropName,
          skuId: item.skuId,
          shopId: item.shopId,
          shopName: item.shopName,
          ladderPrice: item.ladderPrice,
          enabledLadder: item.enabledLadder
        };
      });

      if (!this.tableData.length) {
        this.tableData = goodsD;
      } else {
        const arr = this.$_common.unique(this.tableData.concat(goodsD), ["goodsId", "skuId"]).filter(item => item.goodsId);
        arr.push(this.$_common.deepClone(goodsItem));
        this.tableData = arr;
      } // this.tableData = target;

    },

    goodsVisibleChange(visible, index) {
      if (visible) {
        this.goods_index = index;
      }
    },

    enabledLadderChange(index) {
      const target = this.$_common.deepClone(this.tableData);

      if (target[index].enabledLadder && target[index].ladderPrice.length === 0) {
        target[index].ladderPrice = this.$_common.deepClone(ladderPriceData);
      }

      this.tableData = target;
    },

    // 双击选择店铺
    selShop(row) {
      this.shop_name = row[0].name;
      this.shop_id = row[0].id;
    },

    ladderPriceBlur(val, index, rindex) {
      const target = this.$_common.deepClone(this.tableData);
      target[rindex].ladderPrice[index + 1].from = val + 1;

      if (index === 0) {
        target[rindex].ladderPrice[index + 1].to = val + 2;

        if (target[rindex].ladderPrice[index + 2]) {
          target[rindex].ladderPrice[index + 2].from = val + 3;
        }
      }

      this.tableData = target;
    },

    // 删除阶梯价
    delLadderPrice(index, rIndex) {
      const target = this.$_common.deepClone(this.tableData);
      target[rIndex].ladderPrice.splice(index, 1);
      target[rIndex].ladderPrice[0].from = 1;
      target[rIndex].ladderPrice[target[rIndex].ladderPrice.length - 1].from = target[rIndex].ladderPrice[0].to + 1;
      this.tableData = target;
    },

    // 新增一条阶梯价
    addLadderPrice(rIndex) {
      const target = this.$_common.deepClone(this.tableData);

      if (!target[rIndex].ladderPrice.length) {
        target[rIndex].ladderPrice.push({
          from: 1,
          price: "",
          to: 2
        });
      } else {
        const upL = target[rIndex].ladderPrice[0];
        target[rIndex].ladderPrice.splice(1, "", {
          from: upL.to + 1,
          price: "",
          to: upL.to + 2
        });

        if (target[rIndex].ladderPrice.length === 3) {
          target[rIndex].ladderPrice[target[rIndex].ladderPrice.length - 1].from = upL.to + 3;
        }
      }

      this.tableData = target;
    },

    // 删除
    delData(index) {
      this.tableData.splice(index, 1);
    },

    // 选择大区确定
    regionConfirm(price) {},

    // 调整全国销售价
    standardConfirm(price) {
      const target = this.$_common.deepClone(this.tableData);
      target[this.m_index].salePrice[target[this.m_index].skuId] = { ...price,
        unitName: target[this.m_index].unitName
      };
      this.tableData = target;
    },

    // 新增暂存
    async AddTem() {
      this.loading = true;
      const {
        data
      } = await addPauseSave({
        key: this.pageName,
        data: {
          shopId: this.shop_id,
          shopName: this.shop_name,
          params: this.tableData
        }
      });
      this.loading = false;
      this.$message({
        type: "success",
        message: "暂存成功"
      });

      if (!this.isDraw) {
        if (this.systemType === 2) {
          this.$closeCurrentGoEdit("/SingleStore/goods/priceAdjust");
        } else {
          this.$closeCurrentGoEdit("/goods/sale/AdjustPrice");
        }
      } else {
        this.$emit("handelSuccess");
      }
    },

    // 获取暂存信息
    async getPauseSave() {
      const {
        data
      } = await getPauseSave({
        key: this.pageName
      });
      if (JSON.stringify(data) === "{}") return;
      this.tableData = data.params || [];
      this.shop_name = data.shopName || "";
      this.shop_id = data.shopId || "";
    },

    // 检查提交
    checkSub() {
      if (!this.isDraw && !this.shop_id) {
        this.$message.warning("请选择商铺");
        return;
      }

      if (!this.tableData[0].goodsId) {
        this.$message.warning("第一项商品不能为空");
        return;
      }

      const price = this.tableData.filter(item => item.goodsId).map(item => {
        return { ...item,
          ladderPrice: item.enabledLadder === 0 ? [] : item.ladderPrice,
          salePrice: item.enabledLadder === 1 ? 0 : item.salePrice,
          shopName: this.shop_name
        };
      });
      let ladderPriceLength = true;
      let isLadderPrice = true;

      for (let i in price) {
        const item = price[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.submitData();
    },

    // 保存
    async submitData() {
      let params = []; // 商品列表调价

      if (this.isDraw) {
        // 价格管理调价
        let salePrice = {};
        let min = 0;

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

        for (let i in this.tableData) {
          const itemS = this.tableData[i];

          if (itemS.ladderPrice.length) {
            itemS.ladderPrice[itemS.ladderPrice.length - 1].to = 9999999999;
          }

          salePrice[itemS.id] = {
            marketPrice: itemS.salePrice,
            salePrice: itemS.enabledLadder === 0 ? itemS.salePrice : min,
            unitName: itemS.unitName,
            ladderPrice: itemS.enabledLadder === 0 ? [] : itemS.ladderPrice,
            enabledLadder: itemS.enabledLadder
          };
        }

        params = [{
          createUserName: this.userName,
          goodsName: this.goodsItem.title,
          goodsId: this.goodsItem.id,
          saleType: 1,
          // 1，实物销售，2，虚物销售
          salePriceType: 1,
          // 1 销售价 2，秒杀价
          salePriceAreaType: 1,
          // 销售价格为区域价还是全国价
          salePrice: salePrice,
          shopId: this.goodsItem.shopId,
          shopName: this.shop_name
        }];
      } else {
        // 新增调价单
        const tableData = this.tableData.filter(item => item.goodsId);
        params = tableData.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 {
            createUserName: item.createUserName || this.userName,
            goodsName: item.goodsName,
            goodsId: item.goodsId,
            saleType: item.saleType,
            // 1，实物销售，2，虚物销售
            salePriceType: item.salePriceType,
            // 1 销售价 2，秒杀价
            salePriceAreaType: item.salePriceAreaType,
            salePrice: {
              [item.skuId]: {
                salePrice: item.enabledLadder === 0 ? item.salePrice : min,
                unitName: item.specGropName,
                ladderPrice: item.enabledLadder === 0 ? [] : item.ladderPrice,
                marketPrice: item.nowPrice,
                enabledLadder: item.enabledLadder
              }
            },
            shopId: item.shopId,
            shopName: this.shop_name
          };
        });
      }

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

      if (this.isDraw) {
        // 自动创建调价单且自动生效接口
        target = await addAndEffective(JSON.stringify(params));
      } else {
        target = await PriceAdjustmentAdd(JSON.stringify(params));
      }

      const data = target;
      this.loading = false;
      this.$message({
        type: "success",
        message: "操作成功"
      });
      await this.delPauseSave();

      if (!this.isDraw) {
        if (this.systemType === 2) {
          this.$closeCurrentGoEdit("/SingleStore/goods/priceAdjust");
        } else {
          this.$closeCurrentGoEdit("/goods/sale/AdjustPrice");
        }
      } else {
        this.$emit("handelSuccess");
      }
    },

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

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

  }
};"},{"version":3,"mappings":"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CA,CAFA,MAEA;UACA;QACA;MACA,CANA,MAMA;QACA;MACA;IACA,CA3SA;;IA4SA;IACA;MACA;QAAA3D;MAAA;QACAyD;MADA;MAIA;MACA;MACA;MACA;IACA,CAtTA;;IAuTA;IACAG;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA,6BACAnB,MADA,CACAP,oBADA,EAEAE,GAFA,CAEAF;QACA,SACA,OADA;UAEA5C,6DAFA;UAGAN,wDAHA;UAIAK;QAJA;MAMA,CATA;MAUA;MACA;;MACA;QACA;;QACA;UACA;YACAwE;YACA;UACA,CAHA,MAGA;YACAC;YACA;UACA;QACA,CARA,MAQA;UACA;YACAA;YACA;UACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;IACA,CAvWA;;IAyWA;IACA;MACA,gBADA,CAEA;;MACA;QACA;QACA;QACA;;QACA;UACA;YACA;UACA,CAFA;UAGAC;QACA;;QACA;UACA;;UACA;YACA1B;UACA;;UACArD;YACAgF,4BADA;YAEAhF,4DAFA;YAGAE,wBAHA;YAIAI,+DAJA;YAKAC;UALA;QAOA;;QACAmE,UACA;UACAhF,6BADA;UAEAC,+BAFA;UAGAC,0BAHA;UAIAC,WAJA;UAIA;UACAC,gBALA;UAKA;UACAC,oBANA;UAMA;UACAC,oBAPA;UAQAI,6BARA;UASAC;QATA,CADA;MAaA,CApCA,MAoCA;QACA;QACA;QACAqE;UACA;YACAxB;UACA,CAHA,CAIA;;;UACA;;UACA;YACA;cACA;YACA,CAFA;YAGA6B;UACA;;UACA;YACArF,oDADA;YAEAC,yBAFA;YAGAC,qBAHA;YAIAC,uBAJA;YAIA;YACAC,iCALA;YAKA;YACAC,yCANA;YAOAC;cACA;gBACAA,0DADA;gBAEAE,2BAFA;gBAGAI,6DAHA;gBAIA0E,0BAJA;gBAKAzE;cALA;YADA,CAPA;YAgBAH,mBAhBA;YAiBAC;UAjBA;QAmBA,CA/BA;MAgCA;;MAEA;MACA;;MACA;QACA;QACAqC;MACA,CAHA,MAGA;QACAA;MACA;;MACA;MACA;MAEA;QACA5B,eADA;QAEA6D;MAFA;MAIA;;MACA;QACA;UACA;QACA,CAFA,MAEA;UACA;QACA;MACA,CANA,MAMA;QACA;MACA;IACA,CA/cA;;IAgdA;IACA;MACA;QACAF;MADA;;MAIA;QACA;UACA3D,eADA;UAEA6D;QAFA;QAIA;MACA;IACA;;EA7dA;AAjEA","names":["from","price","to","createUserName","goodsName","goodsId","saleType","salePriceType","salePriceAreaType","salePrice","nowPrice","unitName","skuId","shopId","shopName","ladderPrice","enabledLadder","name","components","ConditionSelGoods","SelectShop","props","goodId","type","default","data","show_goods","loading","shop_name","isDraw","show_shop","m_index","tableData","materialName","materialData","shop_id","user_power","pageName","goods_index","goods_options","select_loading","spec_check","goodsItem","modify_list","price_id","computed","storeData","created","mounted","methods","priceChange","target","shopDefault","materielIds","details_list","code","id","specGropName","specMultiple","item","console","map","itemS","join","addListGoods","selectSelGoods","filter","specSelConfirm","goodsD","selGoods","unique","arr","goodsVisibleChange","enabledLadderChange","selShop","ladderPriceBlur","delLadderPrice","addLadderPrice","upL","delData","regionConfirm","standardConfirm","key","params","message","checkSub","ladderPriceLength","isLadderPrice","min","marketPrice"],"sourceRoot":"src/views/goods/sale","sources":["AddGoodsAdjustPrice.vue"],"sourcesContent":["<!--新建商品调价单-->\n<template>\n <ContainerTit>\n <span v-if=\"isDraw\" slot=\"pagetit\">商品调价</span>\n <div slot=\"headr\">\n <el-button v-if=\"!isDraw\" :loding=\"loading\" @click=\"delPauseSave(1)\">\n 清除暂存\n </el-button>\n <el-button v-if=\"!isDraw\" :loding=\"loading\" @click=\"AddTem\">\n 暂存\n </el-button>\n <el-button type=\"primary\" :loading=\"loading\" @click=\"checkSub\">\n 保存\n </el-button>\n </div>\n\n <div class=\"detail-tab-main\" style=\"background-color: #fff; padding: 20px\">\n <div v-if=\"!isDraw && systemType === 1\">\n <SelectShop\n v-model=\"shop_id\"\n size=\"small\"\n :is-default=\"true\"\n :clearable=\"false\"\n @change=\"selShop\"\n @default=\"shopDefault\"\n />\n <el-button\n size=\"mini\"\n type=\"text\"\n @click=\"$router.push('/SystemSettings/liansuoguanli/AddShop')\"\n >\n 【新建商铺】\n </el-button>\n </div>\n\n <div style=\"padding-top: 10px\">\n <el-table :data=\"tableData\">\n <el-table-column\n prop=\"skuId\"\n label=\"ID\"\n min-width=\"60\"\n align=\"center\"\n ></el-table-column>\n <el-table-column\n v-if=\"!isDraw\"\n prop=\"goodsName\"\n label=\"商品名称\"\n min-width=\"140\"\n align=\"center\"\n >\n <template slot-scope=\"scope\">\n <ConditionSelGoods\n v-if=\"!!shop_id\"\n v-model=\"scope.row.goodsName\"\n :shop-id=\"shop_id\"\n :spec-check=\"spec_check\"\n @goodsVisibleChange=\"goodsVisibleChange($event, scope.$index)\"\n @specSelConfirm=\"specSelConfirm\"\n @selectSelGoods=\"selectSelGoods\"\n @selGoods=\"selGoods\"\n />\n </template>\n </el-table-column>\n <el-table-column\n prop=\"unitName\"\n label=\"单位\"\n align=\"center\"\n min-width=\"60\"\n ></el-table-column>\n <el-table-column\n prop=\"specGropName\"\n label=\"属性\"\n align=\"center\"\n min-width=\"120\"\n ></el-table-column>\n <el-table-column\n v-if=\"!isDraw\"\n prop=\"nowPrice\"\n label=\"当前价格\"\n align=\"center\"\n min-width=\"80\"\n ></el-table-column>\n <el-table-column\n v-if=\"systemType !== 3\"\n prop=\"enabledLadder\"\n align=\"center\"\n label=\"启用阶梯价\"\n min-width=\"80\"\n >\n <template slot-scope=\"scope\">\n <el-switch\n v-if=\"!!scope.row.goodsId\"\n v-model=\"scope.row.enabledLadder\"\n :inactive-value=\"0\"\n :active-value=\"1\"\n active-color=\"#36B365\"\n inactive-color=\"#ff4949\"\n @change=\"enabledLadderChange(scope.$index)\"\n ></el-switch>\n </template>\n </el-table-column>\n <el-table-column\n prop=\"salePriceAreaType\"\n label=\"调整价格\"\n align=\"center\"\n min-width=\"240\"\n >\n <template slot-scope=\"scope\">\n <div v-if=\"!scope.row.goodsId\">未发布</div>\n <div v-else>\n <el-input-number\n v-if=\"parseInt(scope.row.enabledLadder) === 0\"\n v-model=\"scope.row.salePrice\"\n size=\"mini\"\n :min=\"0.01\"\n ></el-input-number>\n <el-button slot=\"append\" style=\"margin-left: 10px\" size=\"mini\">\n 元\n </el-button>\n <ul v-if=\"parseInt(scope.row.enabledLadder) === 1\">\n <li\n v-for=\"(item, index) in scope.row.ladderPrice\"\n :key=\"index\"\n style=\"padding-bottom: 5px; text-align: left\"\n >\n <el-input-number\n :controls=\"false\"\n size=\"mini\"\n disabled\n :value=\"item.from\"\n style=\"width: 60px\"\n :min=\"0\"\n ></el-input-number>\n --\n <el-input-number\n v-if=\"!(index === scope.row.ladderPrice.length - 1)\"\n v-model=\"item.to\"\n :controls=\"false\"\n size=\"mini\"\n :min=\"item.from + 1\"\n style=\"width: 60px\"\n @blur=\"ladderPriceBlur(item.to, index, scope.$index)\"\n ></el-input-number>\n <el-input-number\n v-else\n size=\"mini\"\n disabled\n value=\"∞\"\n style=\"width: 60px\"\n :min=\"1\"\n ></el-input-number>\n {{ scope.row.unitName }}\n ¥\n <el-input-number\n v-model=\"item.price\"\n :controls=\"false\"\n size=\"mini\"\n style=\"width: 80px\"\n :min=\"0\"\n ></el-input-number>\n <el-button\n v-if=\"!(index === scope.row.ladderPrice.length - 1)\"\n :disabled=\"scope.row.ladderPrice.length === 2\"\n style=\"color: #f56c6c\"\n size=\"mini\"\n icon=\"el-icon-remove\"\n type=\"text\"\n @click=\"delLadderPrice(index, scope.$index)\"\n ></el-button>\n </li>\n <el-button\n :disabled=\"scope.row.ladderPrice.length === 3\"\n size=\"mini\"\n icon=\"el-icon-circle-plus\"\n type=\"text\"\n @click=\"addLadderPrice(scope.$index)\"\n >\n 新增\n </el-button>\n </ul>\n </div>\n </template>\n </el-table-column>\n <el-table-column\n v-if=\"!isDraw\"\n label=\"管理\"\n align=\"center\"\n min-width=\"120\"\n >\n <template slot-scope=\"scope\">\n <el-button\n type=\"text\"\n size=\"mini\"\n :disabled=\"tableData.length === 1\"\n @click=\"delData(scope.$index)\"\n >\n 删除\n </el-button>\n <el-button type=\"text\" size=\"mini\" @click=\"addListGoods\">\n 新增\n </el-button>\n </template>\n </el-table-column>\n </el-table>\n <div\n v-if=\"!!shop_id\"\n style=\"text-align: center; padding-top: 10px\"\n class=\"clearfix\"\n >\n <el-button\n type=\"text\"\n icon=\"el-icon-circle-plus\"\n @click=\"addListGoods\"\n >\n 新增一条\n </el-button>\n </div>\n </div>\n </div>\n <!-- 选择商铺-->\n <!-- <GoodsChooseShop-->\n <!-- v-if=\"show_shop\"-->\n <!-- :dialog-visible=\"show_shop\"-->\n <!-- :is-default=\"true\"-->\n <!-- :is-show-add=\"true\"-->\n <!-- @close=\"show_shop = false\"-->\n <!-- @confirm=\"selShop\"-->\n <!-- ></GoodsChooseShop>-->\n </ContainerTit>\n</template>\n\n<script>\n import GoodsChooseShop from \"@/component/goods/GoodsChooseShop.vue\";\n import ConditionSelGoods from \"@/component/common/ConditionSelGoods\";\n import SelectShop from \"@/component/goods/SelectShop.vue\";\n import { getGoodsInfo } from \"@/api/goods\";\n import { addPauseSave, getPauseSave, delPauseSave } from \"@/api/common\";\n import { addAndEffective, PriceAdjustmentAdd } from \"@/api/Price\";\n import { mapGetters } from \"vuex\";\n import { getSupplierOfferPrice } from \"@/api/Supplier\";\n import { getRelMap } from \"@/api/goods\";\n const ladderPriceData = [\n {\n from: 1,\n price: 0.01,\n to: 2,\n },\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 const goodsItem = {\n createUserName: \"\",\n goodsName: \"\",\n goodsId: \"\",\n saleType: \"1\",\n salePriceType: \"1\",\n salePriceAreaType: 1,\n salePrice: \"\",\n nowPrice: \"\",\n unitName: \"\",\n skuId: \"\",\n shopId: \"\",\n shopName: \"\",\n ladderPrice: ladderPriceData,\n enabledLadder: 0,\n };\n export default {\n name: \"AddGoodsAdjustPrice\",\n components: {\n ConditionSelGoods,\n SelectShop,\n },\n props: {\n goodId: {\n type: [Number, String],\n default: 0,\n },\n },\n data() {\n return {\n show_goods: false,\n loading: false,\n shop_name: \"\",\n isDraw: false,\n show_shop: false,\n m_index: \"\",\n tableData: [],\n materialName: \"\",\n materialData: {},\n shop_id: \"\",\n user_power: {},\n pageName: \"\",\n goods_index: 0,\n goods_options: [],\n select_loading: false,\n spec_check: [],\n goodsItem: {},\n modify_list: [],\n price_id: 0,\n };\n },\n computed: {\n ...mapGetters({\n storeData: \"MUser/storeData\",\n }),\n },\n created() {\n this.pageName = this.$route.name;\n // 商品列表进行商品调价\n this.isDraw = this.goodId > 0;\n if (this.isDraw) {\n this.getGoodsDetail();\n } else {\n // 报价单\n if (this.$route.query.price_id) {\n this.price_id = this.$route.query.price_id;\n // this.getSupplierOfferPrice();\n return;\n }\n for (let i = 1; i <= 1; i++) {\n this.tableData.push(this.$_common.deepClone(goodsItem));\n }\n this.getPauseSave();\n }\n },\n mounted() {\n if ([2, 3].includes(this.systemType)) {\n this.shop_id = this.storeData.id;\n this.shop_name = this.storeData.name;\n }\n },\n methods: {\n priceChange(index) {\n let target = this.$_common.deepClone(this.tableData);\n let salePrice = target[index].salePrice;\n if (salePrice < 0) {\n target[index].salePrice = 0;\n }\n this.tableData = target;\n },\n shopDefault(val, obj) {\n this.shop_id = val;\n this.shop_name = obj.name;\n if (this.$route.query.price_id) {\n this.getSupplierOfferPrice();\n }\n },\n async getRelMap(materielId) {\n const { data } = await getRelMap({\n shopId: this.shop_id,\n materielIds: materielId,\n });\n this.tableData = this.tableData.map((item) => {\n return {\n ...item,\n goodsId: data[item.id] || 0,\n };\n });\n },\n async getSupplierOfferPrice() {\n const data = await getSupplierOfferPrice(this.price_id);\n let details_list = [];\n data.data.details.forEach((item) => {\n for (let i in item.offerPrice) {\n details_list.push({\n goodsName: item.materielName,\n code: item.materielCode,\n id: item.materielId,\n skuId: i,\n ...item.offerPrice[i],\n });\n }\n });\n let goods_list = details_list.map((itemP) => {\n const specGropName = itemP.specGroup.map((itemP) => {\n return itemP.specGropName;\n });\n return {\n id: itemP.id,\n goodsName: itemP.goodsName,\n unitName: itemP.unitName,\n specGropName: specGropName,\n skuId: itemP.skuId,\n nowPrice: itemP.costPrice,\n enabledLadder: 0,\n createUserName: this.userName,\n goodsId: 0,\n saleType: \"1\",\n salePriceType: \"1\",\n salePriceAreaType: 1,\n salePrice: itemP.costPrice,\n shopId: this.shop_id,\n shopName: this.shop_name,\n ladderPrice: [],\n };\n });\n\n this.tableData = goods_list;\n const materielId = details_list.map((itemG) => {\n return itemG.id;\n });\n await this.getRelMap(this.$_common.unique(materielId));\n },\n async getGoodsDetail() {\n const { data } = await getGoodsInfo(this.goodId);\n this.shop_name = data.title;\n this.goodsItem = data;\n // 多商户只展示主单位\n let specMultiple = [];\n if (this.systemType === 3) {\n specMultiple = data.specMultiple.filter(\n (item) => item.isMaster === 5\n );\n } else {\n specMultiple = data.specMultiple;\n }\n console.log(specMultiple);\n if (data.specType === 2) {\n this.tableData = specMultiple.map((item) => {\n const specValueName = item.specGroup\n .map((itemS) => {\n return itemS.specValueName;\n })\n .join(\"_\");\n return {\n ...item,\n goodsId: data.id,\n skuId: item.id,\n specGropName: specValueName,\n };\n });\n } else if (data.specType === 1) {\n this.tableData = specMultiple.map((item) => {\n return {\n ...item,\n goodsId: data.id,\n skuId: item.id,\n specGropName: \"无\",\n };\n });\n }\n },\n addListGoods() {\n this.tableData.push(this.$_common.deepClone(goodsItem));\n },\n selectSelGoods(id) {\n this.spec_check = this.tableData\n .filter((item) => item.goodsId === id)\n .map((item) => {\n return item.skuId;\n });\n },\n specSelConfirm(params) {\n let target = this.$_common.deepClone(this.tableData);\n const goodsD = params.goodsD.map((item) => {\n return {\n // spec_check_list: params.spec_check_list,\n createUserName: this.userName,\n goodsName: params.now_goods_data.title,\n goodsId: params.now_goods_data.id,\n saleType: \"1\",\n salePriceType: \"1\",\n salePriceAreaType: 1,\n salePrice: item.spec.salePrice,\n nowPrice: item.spec.salePrice,\n unitName: item.spec.unitName,\n specGropName: item.spec.specGropName,\n skuId: item.skuId,\n shopId: params.now_goods_data.shopId,\n shopName: params.now_goods_data.shopName,\n ladderPrice: item.spec.ladderPrice,\n enabledLadder: item.spec.enabledLadder,\n };\n });\n if (!target[this.goods_index].skuId) {\n target.splice(this.goods_index, 1);\n }\n\n goodsD.forEach((item) => {\n const targetD = target.find((itemG) => itemG.skuId === item.skuId);\n if (!targetD) {\n target.push(item);\n }\n });\n\n this.tableData = target;\n },\n selGoods(list) {\n const goodsD = list.map((item) => {\n let specGropName = item.specGroup\n .map((itemS) => {\n return itemS.specValueName;\n })\n .join(\"_\");\n return {\n createUserName: this.userName,\n goodsName: item.title,\n goodsId: item.id,\n saleType: \"1\",\n salePriceType: \"1\",\n salePriceAreaType: 1,\n salePrice: item.salePrice,\n nowPrice: item.salePrice,\n unitName: item.unitName,\n specGropName: specGropName,\n skuId: item.skuId,\n shopId: item.shopId,\n shopName: item.shopName,\n ladderPrice: item.ladderPrice,\n enabledLadder: item.enabledLadder,\n };\n });\n\n if (!this.tableData.length) {\n this.tableData = goodsD;\n } else {\n const arr = this.$_common\n .unique(this.tableData.concat(goodsD), [\"goodsId\", \"skuId\"])\n .filter((item) => item.goodsId);\n arr.push(this.$_common.deepClone(goodsItem));\n this.tableData = arr;\n }\n\n // this.tableData = target;\n },\n goodsVisibleChange(visible, index) {\n if (visible) {\n this.goods_index = index;\n }\n },\n enabledLadderChange(index) {\n const target = this.$_common.deepClone(this.tableData);\n if (\n target[index].enabledLadder &&\n target[index].ladderPrice.length === 0\n ) {\n target[index].ladderPrice = this.$_common.deepClone(ladderPriceData);\n }\n this.tableData = target;\n },\n // 双击选择店铺\n selShop(row) {\n this.shop_name = row[0].name;\n this.shop_id = row[0].id;\n },\n ladderPriceBlur(val, index, rindex) {\n const target = this.$_common.deepClone(this.tableData);\n target[rindex].ladderPrice[index + 1].from = val + 1;\n if (index === 0) {\n target[rindex].ladderPrice[index + 1].to = val + 2;\n if (target[rindex].ladderPrice[index + 2]) {\n target[rindex].ladderPrice[index + 2].from = val + 3;\n }\n }\n this.tableData = target;\n },\n // 删除阶梯价\n delLadderPrice(index, rIndex) {\n const target = this.$_common.deepClone(this.tableData);\n target[rIndex].ladderPrice.splice(index, 1);\n target[rIndex].ladderPrice[0].from = 1;\n target[rIndex].ladderPrice[target[rIndex].ladderPrice.length - 1].from =\n target[rIndex].ladderPrice[0].to + 1;\n this.tableData = target;\n },\n // 新增一条阶梯价\n addLadderPrice(rIndex) {\n const target = this.$_common.deepClone(this.tableData);\n if (!target[rIndex].ladderPrice.length) {\n target[rIndex].ladderPrice.push({\n from: 1,\n price: \"\",\n to: 2,\n });\n } else {\n const upL = target[rIndex].ladderPrice[0];\n target[rIndex].ladderPrice.splice(1, \"\", {\n from: upL.to + 1,\n price: \"\",\n to: upL.to + 2,\n });\n if (target[rIndex].ladderPrice.length === 3) {\n target[rIndex].ladderPrice[\n target[rIndex].ladderPrice.length - 1\n ].from = upL.to + 3;\n }\n }\n this.tableData = target;\n },\n // 删除\n delData(index) {\n this.tableData.splice(index, 1);\n },\n // 选择大区确定\n regionConfirm(price) {},\n // 调整全国销售价\n standardConfirm(price) {\n const target = this.$_common.deepClone(this.tableData);\n target[this.m_index].salePrice[target[this.m_index].skuId] = {\n ...price,\n unitName: target[this.m_index].unitName,\n };\n this.tableData = target;\n },\n // 新增暂存\n async AddTem() {\n this.loading = true;\n const { data } = await addPauseSave({\n key: this.pageName,\n data: {\n shopId: this.shop_id,\n shopName: this.shop_name,\n params: this.tableData,\n },\n });\n this.loading = false;\n\n this.$message({\n type: \"success\",\n message: \"暂存成功\",\n });\n if (!this.isDraw) {\n if (this.systemType === 2) {\n this.$closeCurrentGoEdit(\"/SingleStore/goods/priceAdjust\");\n } else {\n this.$closeCurrentGoEdit(\"/goods/sale/AdjustPrice\");\n }\n } else {\n this.$emit(\"handelSuccess\");\n }\n },\n // 获取暂存信息\n async getPauseSave() {\n const { data } = await getPauseSave({\n key: this.pageName,\n });\n\n if (JSON.stringify(data) === \"{}\") return;\n this.tableData = data.params || [];\n this.shop_name = data.shopName || \"\";\n this.shop_id = data.shopId || \"\";\n },\n // 检查提交\n checkSub() {\n if (!this.isDraw && !this.shop_id) {\n this.$message.warning(\"请选择商铺\");\n return;\n }\n if (!this.tableData[0].goodsId) {\n this.$message.warning(\"第一项商品不能为空\");\n return;\n }\n const price = this.tableData\n .filter((item) => item.goodsId)\n .map((item) => {\n return {\n ...item,\n ladderPrice: item.enabledLadder === 0 ? [] : item.ladderPrice,\n salePrice: item.enabledLadder === 1 ? 0 : item.salePrice,\n shopName: this.shop_name,\n };\n });\n let ladderPriceLength = true;\n let isLadderPrice = true;\n for (let i in price) {\n const item = price[i];\n if (item.enabledLadder === 1) {\n if (item.ladderPrice.length < 2) {\n ladderPriceLength = false;\n break;\n } else if (!item.ladderPrice.every((itemP) => itemP.price > 0)) {\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.submitData();\n },\n\n // 保存\n async submitData() {\n let params = [];\n // 商品列表调价\n if (this.isDraw) {\n // 价格管理调价\n let salePrice = {};\n let min = 0;\n if (this.goodsItem.enabledLadder === 1) {\n const arr = this.goodsItem.ladderPrice.map((itemM) => {\n return itemM.price;\n });\n min = Math.min.apply(null, arr);\n }\n for (let i in this.tableData) {\n const itemS = this.tableData[i];\n if (itemS.ladderPrice.length) {\n itemS.ladderPrice[itemS.ladderPrice.length - 1].to = 9999999999;\n }\n salePrice[itemS.id] = {\n marketPrice: itemS.salePrice,\n salePrice: itemS.enabledLadder === 0 ? itemS.salePrice : min,\n unitName: itemS.unitName,\n ladderPrice: itemS.enabledLadder === 0 ? [] : itemS.ladderPrice,\n enabledLadder: itemS.enabledLadder,\n };\n }\n params = [\n {\n createUserName: this.userName,\n goodsName: this.goodsItem.title,\n goodsId: this.goodsItem.id,\n saleType: 1, // 1,实物销售,2,虚物销售\n salePriceType: 1, // 1 销售价 2,秒杀价\n salePriceAreaType: 1, // 销售价格为区域价还是全国价\n salePrice: salePrice,\n shopId: this.goodsItem.shopId,\n shopName: this.shop_name,\n },\n ];\n } else {\n // 新增调价单\n const tableData = this.tableData.filter((item) => item.goodsId);\n params = tableData.map((item) => {\n if (item.ladderPrice.length) {\n item.ladderPrice[item.ladderPrice.length - 1].to = 9999999999;\n }\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 createUserName: item.createUserName || this.userName,\n goodsName: item.goodsName,\n goodsId: item.goodsId,\n saleType: item.saleType, // 1,实物销售,2,虚物销售\n salePriceType: item.salePriceType, // 1 销售价 2,秒杀价\n salePriceAreaType: item.salePriceAreaType,\n salePrice: {\n [item.skuId]: {\n salePrice: item.enabledLadder === 0 ? item.salePrice : min,\n unitName: item.specGropName,\n ladderPrice: item.enabledLadder === 0 ? [] : item.ladderPrice,\n marketPrice: item.nowPrice,\n enabledLadder: item.enabledLadder,\n },\n },\n shopId: item.shopId,\n shopName: this.shop_name,\n };\n });\n }\n\n let target = {};\n this.loading = true;\n if (this.isDraw) {\n // 自动创建调价单且自动生效接口\n target = await addAndEffective(JSON.stringify(params));\n } else {\n target = await PriceAdjustmentAdd(JSON.stringify(params));\n }\n const data = target;\n this.loading = false;\n\n this.$message({\n type: \"success\",\n message: \"操作成功\",\n });\n await this.delPauseSave();\n if (!this.isDraw) {\n if (this.systemType === 2) {\n this.$closeCurrentGoEdit(\"/SingleStore/goods/priceAdjust\");\n } else {\n this.$closeCurrentGoEdit(\"/goods/sale/AdjustPrice\");\n }\n } else {\n this.$emit(\"handelSuccess\");\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/AddGoodsAdjustPrice\");\n }\n },\n },\n };\n</script>\n\n<style scoped lang=\"scss\">\n .creat-shop {\n color: #1890ff;\n font-size: 12px;\n margin: 5px 0 0 5px;\n }\n</style>\n"]}]}
|