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\\PublishGoods.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\qianger\\7\\jindouyunNewFront\\src\\views\\goods\\sale\\PublishGoods.vue","mtime":1658126511010},{"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 GoodsCategory from "@/component/common/GoodsCategory.vue";
import BrandSelModel from "@/component/goods/BrandSelModel.vue"; // import EditGoods from "./AddGoods";

import SelectShop from "@/component/goods/SelectShop.vue";
import { setSalesNum, getGoodsInfo, BatchUnloading, getAllGoods, exportGetAllGoods, exportGetAllGoodsList, searchGood, exportSearchGood, delGoods, setTop, GoodsUpdateEnableStatus, batchGoodsExpress, setSalesNumBatch, setBrand, updateCategory, batchSetDistribution, setSort, getAllGoodsList } from "@/api/goods";
import { getAllExpressRule } from "@/api/System";
import { mapGetters } from "vuex";
export default {
  name: "PublishGoods",
  components: {
    GoodsCategory,
    // EditGoods,
    BrandSelModel,
    SelectShop
  },

  data() {
    return {
      virtual_sales_num: 0,
      set_goods_id: 0,
      sale_num_form: {
        ids: [],
        minVal: "",
        maxVal: ""
      },
      activeName: "all",
      goods_sku_list: [],
      checkedAll: false,
      isIndeterminate: false,
      is_price: false,
      sku_visible: false,
      sku_goods_name: "",
      goods_name: "",
      keyword: "",
      brandId: "",
      categoryId: "",
      enableStatus: "",
      shopId: "",
      sel_brand: false,
      transferShow: false,
      total: 0,
      page: 1,
      pageSize: 10,
      goods_data: [],
      // table 数据
      choose_data: [],
      form: {
        categoryPath: [],
        search_key: "",
        brand: "",
        shop: "",
        enableStatus: ""
      },
      price_goods_detail: {},
      inSales: 0,
      inStock: 0,
      spec_loading: false,
      set_form: {
        masterUnitId: "",
        shopName: "",
        brandName: "",
        brandId: "",
        category: [],
        branchUnit: [],
        deliverySupIds: ["1", "2"],
        // 物流支持 固定值 1 快递 2 自提 传参格式：1,2
        expressType: 1,
        // 快递运费 1 包邮 2 运费模版 3 固定费用
        expressFee: "",
        // 固定费用
        showExpress: 5,
        // 是否展示快递 5展示 4不展示
        ruleId: "" // 运费模版id

      },
      express_list: [],
      assistForm: {},
      more_sub_btn: false,
      unit_show: false,
      is_set: false,
      set_tit: "",
      checkList: ["商品分类", "规格", "基本单位", "总库存", // "虚拟销量",
      "真实销量", "当前状态", "销售店铺", "创建时间"],
      columns: [{
        label: "商品分类"
      }, {
        label: "规格"
      }, {
        label: "基本单位"
      }, {
        label: "总库存"
      }, // {
      //   label: "虚拟销量",
      // },
      {
        label: "真实销量"
      }, {
        label: "当前状态"
      }, {
        label: "销售店铺"
      }, {
        label: "创建时间"
      }],
      classifyFlag: true,
      specificationFlag: true,
      unitFlag: true,
      inventoryFlag: true,
      virtualFlag: true,
      trueFlag: true,
      stateFlag: true,
      shopFlag: true,
      timeFlag: true,
      member_sort: 0 //排序

    };
  },

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

  created() {
    if (this.$route.name === "GoodsSale") {
      this.inSales = 5;
    } else if (this.$route.name === "SoldOut") {
      this.inStock = 4;
    } else if (this.$route.name === "InWarehouse") {
      this.inStock = 5;
    }

    this.getAllGoodsList();
    this.getAllExpressRule();
  },

  activated() {
    if (this.$_isInit()) return;
    this.getData();
  },

  methods: {
    showTooltipMethod({
      type,
      column,
      row,
      items,
      _columnIndex
    }) {
      if (column.property === "shopName") {
        if (type === "body") {
          return column.shopName;
        }
      }
    },

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

    async setSalesNum(index, tag) {
      if (tag === -1) {
        this.goods_data[index].sale_false_visible = false;
        return;
      }

      if (this.virtual_sales_num < 0) {
        this.$message.warning("请输入大于0的值");
        return;
      }

      const data = await setSalesNum({
        id: this.goods_data[index].id,
        val: this.virtual_sales_num
      });
      this.goods_data[index].sale_false_visible = false;
      this.getData();
    },

    showSetSaleNum(index) {
      this.virtual_sales_num = this.goods_data[index].virtualSalesNum;
      this.goods_data[index].sale_false_visible = true;
    },

    openAddGoods() {
      if (parseInt(this.$store.getters["MUser/enterpriseScope"]) === 4) {
        this.$router.push("/goods/sale/AddGoodsOneStore");
      } else {
        this.$router.push("/goods/sale/AddGoods");
      }
    },

    tabChange() {
      switch (this.activeName) {
        case "all":
          this.inSales = 1;
          this.inStock = 0;
          break;

        case "GoodsSale":
          this.inSales = 2;
          this.inStock = 0;
          break;

        case "SoldOut":
          this.inSales = 3;
          this.inStock = 4;
          break;

        case "InWarehouse":
          this.inSales = 4;
          this.inStock = 5;
          break;
      }

      this.pageChange(1);
    },

    // 用于可展开表格与树形表格，切换某一行的展开状态，如果使用了第二个参数，则是设置这一行展开与否（expanded 为 true 则展开）
    async showSpec({
      row
    }) {
      return new Promise(async resolve => {
        const index = this.goods_data.findIndex(item => item.id === row.id);

        if (!this.goods_data[index].goods_sku_list.length) {
          const {
            data
          } = await getGoodsInfo(row.id);

          if (data.specType === 2) {
            this.$nextTick(() => {
              this.goods_data[index].goods_sku_list = data.specMultiple.map(item => {
                const specValueName = item.specGroup.map(itemS => {
                  return itemS.specValueName;
                }).join(";");
                return { ...item,
                  specValueName: specValueName
                };
              });
            });
          } else if (data.specType === 1) {
            this.$nextTick(() => {
              this.goods_data[index].goods_sku_list = data.specMultiple.map(item => {
                return { ...item,
                  specValueName: ""
                };
              });
            });
          }
        }

        resolve();
      }); // this.goods_data = target
    },

    toggleRowExpansion(index) {
      this.$refs.goodsTable.toggleRowExpand(this.goods_data[index]);
    },

    delBrand() {
      this.form.brand = "";
      this.brandId = "";
      this.pageChange(1);
    },

    delShop() {
      this.form.shop = "";
      this.shopId = "";
      this.pageChange(1);
    },

    // 批量选择
    selectionChange({
      records
    }) {
      this.checkedAll = this.$refs.goodsTable.isAllCheckboxChecked();
      this.isIndeterminate = this.$refs.goodsTable.isAllCheckboxChecked();
      this.choose_data = records;
    },

    // 编辑完成回调
    editsubData() {
      this.getData();
    },

    // 调整价格 编辑查看
    openPriceModel(row) {
      if (parseInt(this.$store.getters["MUser/enterpriseScope"]) === 5) {
        // this.is_price = true;
        // this.goods_name = row.title;
        // this.price_goods_detail = row;
        this.$router.push(`/goods/sale/EditGoods/${row.id}`);
      } else {
        this.$router.push(`/goods/sale/EditGoodsOneStore/${row.id}`);
      }
    },

    //  批量上下架
    async BatchUnloading(enableStatus) {
      let title = enableStatus === 4 ? "确定要批量下架这些商品吗？" : "确定要批量上架这些商品吗？";

      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      this.$confirm(title, "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        if (!this.choose_data.length) {
          this.$message.warning("请选择要操作的商品");
          return;
        }

        const idData = this.choose_data.map(item => {
          return item.id;
        });
        const data = await BatchUnloading({
          id: idData,
          enableStatus: enableStatus
        });
        this.$message({
          type: "success",
          message: "操作成功!"
        });
        this.getData();
      });
    },

    // 批量删除
    async deleteBatchUnloading(deleteStatus) {
      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      this.$confirm("确定要批量删除这些商品吗", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        if (!this.choose_data.length) {
          this.$message.warning("请选择要操作的商品");
          return;
        }

        const idData = this.choose_data.map(item => {
          return item.id;
        });
        const data = await BatchUnloading({
          id: idData,
          deleteStatus: deleteStatus
        });
        this.$message({
          type: "success",
          message: "操作成功!"
        });
        this.getData();
      });
    },

    // 获取列表
    async getAllGoods(exports) {
      let params = {
        page: this.page,
        pageSize: this.pageSize,
        ifMerchant: this.ifMerchant,
        merchantId: this.merchantId
      };

      if (this.inSales) {
        params.inSales = this.inSales;
      }

      if (this.inStock) {
        params.inStock = this.inStock;
      }

      if (exports) {
        const data = await exportGetAllGoods({ ...params,
          export: 1
        });
      } else {
        const data = await getAllGoods(params);
        this.goods_data = data.data.map(item => {
          return { ...item,
            sale_false_visible: false,
            goods_sku_list: [],
            address: item.shopName,
            sort_flag: false
          };
        });
        this.total = data.pageTotal;
      }
    },

    async getAllGoodsList(exports) {
      let params = {
        page: this.page,
        pageSize: this.pageSize,
        keywordType: this.inSales,
        keyword: this.keyword,
        categoryPath: this.form.categoryPath.join(","),
        brandId: this.brandId,
        enableStatus: this.enableStatus,
        shopId: this.shopId
      };

      if (exports) {
        const data = await exportGetAllGoodsList({ ...params,
          export: 1
        });
      } else {
        const data = await getAllGoodsList(params);
        this.goods_data = data.data.map(item => {
          return { ...item,
            sale_false_visible: false,
            goods_sku_list: [],
            address: item.shopName,
            sort_flag: false
          };
        });
        this.total = data.pageTotal;
      }
    },

    //  搜索商品 searchGood
    // async searchGood(exports) {
    //   if (this.activeName !== "all") {
    //     this.enableStatus = "";
    //   }
    //   let params = {
    //     keyword: this.keyword,
    //     brandId: this.brandId,
    //     categoryPath: this.form.categoryPath.join(","),
    //     enableStatus: this.enableStatus,
    //     shopId: this.shopId,
    //     page: this.page,
    //     pageSize: this.pageSize,
    //   };
    //   if (this.inSales) {
    //     params.inSales = this.inSales;
    //   }
    //   if (this.inStock) {
    //     params.inStock = this.inStock;
    //   }
    //   if (exports) {
    //     const data = await exportSearchGood({
    //       ...params,
    //       export: 1,
    //     });
    //   } else {
    //     const data = await searchGood(params);
    //
    //     this.goods_data = data.data.map((item) => {
    //       return {
    //         ...item,
    //         sale_false_visible: false,
    //         goods_sku_list: [],
    //       };
    //     });
    //     this.total = data.pageTotal;
    //   }
    // },
    // 判断当前使用方法为列表接口还是搜索引擎接口 获取列表数据
    getData(exports) {
      if (this.activeName !== "all") {
        this.enableStatus = "";
      } // 搜索参数规整


      const obj = {
        keyword: this.keyword,
        brandId: this.brandId,
        categoryPath: this.form.categoryPath.join(","),
        enableStatus: this.enableStatus,
        shopId: this.shopId
      };
      const isKey = this.$_common.isSerch(obj);

      if (isKey) {
        this.searchGood(exports);
      } else {
        this.getAllGoods(exports);
      }
    },

    // 分类搜索
    goodsChane(val) {
      this.pageChange(1);
    },

    // 品牌搜索
    brandConfirm(row) {
      this.form.brand = row[0].title;
      this.brandId = row[0].id;
      this.pageChange(1);
    },

    //转移品牌
    transferBrandConfirm(row) {
      this.set_form.brandName = row[0].title;
      this.set_form.brandId = row[0].id;
    },

    // 商铺搜索
    shopConfirm(val, row) {
      this.shopId = row[0].id;
      this.form.shop = row[0].name;
      this.pageChange(1);
    },

    // 删除商品
    async delData(id) {
      this.$confirm("确定要删除该条商品吗?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        const data = await delGoods(id);
        this.$message({
          type: "success",
          message: "删除成功!"
        });
        this.getData();
      });
    },

    // 删除商品
    async setTop(id) {
      this.$confirm("是否要将该商品置顶?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        const data = await setTop(id);
        this.$message({
          type: "success",
          message: "操作成功!"
        });
        this.getData();
      });
    },

    // 商品上下架
    async changeGoodsStatus(val, row) {
      try {
        const data = await GoodsUpdateEnableStatus({
          id: row.id,
          enableStatus: val
        });
        this.$message({
          type: "success",
          message: "操作成功!"
        });
      } catch (e) {
        this.getData();
      }
    },

    // 切页
    pageChange(val) {
      this.page = val;
      this.getAllGoodsList();
    },

    // 每页数据大小改变
    sizeChange(val) {
      this.pageSize = val;
      this.pageChange(1);
    },

    checkAllChange() {
      this.$refs.goodsTable.setAllCheckboxRow(this.checkedAll);
      this.isIndeterminate = this.$refs.goodsTable.isAllCheckboxChecked();
      this.choose_data = this.$refs.goodsTable.getCheckboxRecords();
    },

    // 打开批量设置弹窗
    openSet(tit, row) {
      this.is_set = true;
      this.set_tit = tit;

      if (row) {
        this.choose_data = [row];
      }
    },

    // 批量提交
    moreSubData() {
      this.checkedAll = false;
      this.isIndeterminate = false;

      if (this.set_tit === "转移分类") {
        this.updateCategory();
      }

      if (this.set_tit === "设置品牌") {
        this.setBrand();
      }

      if (this.set_tit === "虚拟销量") {
        this.setSalesNumBatch();
      }

      if (this.set_tit === "物流设置") {
        this.batchGoodsExpress();
      }
    },

    // 批量设置运费
    async batchGoodsExpress() {
      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      const idData = this.choose_data.map(item => {
        return item.id;
      });
      this.more_sub_btn = true;

      try {
        const data = await batchGoodsExpress({
          expressType: this.set_form.expressType,
          ruleId: this.set_form.ruleId,
          expressFee: this.set_form.expressFee,
          ids: idData
        });
        this.more_sub_btn = false;
        this.is_set = false;
        this.$message.success("操作成功");
        this.getData();
      } catch {
        this.more_sub_btn = false;
      }
    },

    // 设置虚拟销量
    async setSalesNumBatch() {
      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      if (!this.sale_num_form.minVal) {
        this.$message.warning("虚拟销量区间最小值不能为0");
        return;
      }

      if (!this.sale_num_form.maxVal) {
        this.$message.warning("虚拟销量区间最大值不能为0");
        return;
      }

      if (this.sale_num_form.maxVal <= this.sale_num_form.minVal) {
        this.$message.warning("虚拟销量区间最大值必须大于最小值");
        return;
      }

      this.more_sub_btn = true;

      try {
        const idData = this.choose_data.map(item => {
          return item.id;
        });
        const data = await setSalesNumBatch({ ...this.sale_num_form,
          ids: idData
        });
        this.more_sub_btn = false;
        this.is_set = false;
        this.$message.success("操作成功");
        this.getData();
      } catch {
        this.more_sub_btn = false;
      }
    },

    //  设置品牌
    async setBrand() {
      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      if (!this.set_form.brandId) {
        this.$message.warning("请选择要操作的品牌");
        return;
      }

      const idData = this.choose_data.map(item => {
        return item.basicGoodsId;
      });
      this.more_sub_btn = true;

      try {
        const data = await setBrand({
          id: idData,
          brandId: this.set_form.brandId
        });
        this.more_sub_btn = false;
        this.is_set = false;
        this.$message.success("操作成功");
        this.getData();
      } catch {
        this.more_sub_btn = false;
      }
    },

    // 转移分类
    async updateCategory() {
      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      if (!this.set_form.category) {
        this.$message.warning("请选择要转移的分类");
        return;
      }

      this.more_sub_btn = true;

      try {
        const idData = this.choose_data.map(item => {
          return item.basicGoodsId;
        });
        const data = await updateCategory({
          id: idData,
          // 要移动的基础商品id
          categoryId: this.set_form.category[this.set_form.category.length - 1],
          // 移动至商品分类id
          categoryPath: this.set_form.category.join(",") // 新的商品分类路径

        });
        this.more_sub_btn = false;
        this.is_set = false;
        this.$message.success("操作成功");
        this.set_form.category = [];
        this.getData();
      } catch {
        this.more_sub_btn = false;
      }
    },

    change() {
      this.classifyFlag = this.checkList.some(item => item === "商品分类");
      this.specificationFlag = this.checkList.some(item => item === "规格");
      this.unitFlag = this.checkList.some(item => item === "基本单位");
      this.inventoryFlag = this.checkList.some(item => item === "总库存");
      this.virtualFlag = this.checkList.some(item => item === "虚拟销量");
      this.trueFlag = this.checkList.some(item => item === "真实销量");
      this.stateFlag = this.checkList.some(item => item === "当前状态");
      this.shopFlag = this.checkList.some(item => item === "销售店铺");
      this.timeFlag = this.checkList.some(item => item === "创建时间");
    },

    batchSetDistribution(enableStatus) {
      let title = enableStatus === 4 ? "确定要批量禁用库存销售？" : "确定要批量启用这些商品为负库存销售吗？";

      if (!this.choose_data.length) {
        this.$message.warning("请选择要操作的商品");
        return;
      }

      this.$confirm(title, "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(async () => {
        this.checkedAll = false;
        this.isIndeterminate = false;

        if (!this.choose_data.length) {
          this.$message.warning("请选择要操作的商品");
          return;
        }

        const idData = this.choose_data.map(item => {
          return item.id;
        });
        const data = await batchSetDistribution({
          ids: idData,
          isDistribution: enableStatus
        });
        this.$message({
          type: "success",
          message: "操作成功!"
        });
        this.getData();
      });
    },

    showSort(index) {
      this.goods_data.forEach(item => item.sort_flag = false);
      this.member_sort = this.goods_data[index].sort;
      this.goods_data[index].sort_flag = true;
    },

    async setSort(index) {
      const {
        data
      } = await setSort({
        id: this.goods_data[index].id,
        sort: this.member_sort
      });
      this.$message.success("修改成功");
      this.goods_data[index].sort_flag = false;
      await this.getAllGoodsList();
    }

  }
};"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2pBA;AACA,gE,CACA;;AACA;AAEA,SACAA,WADA,EAEAC,YAFA,EAGAC,cAHA,EAIAC,WAJA,EAKAC,iBALA,EAMAC,qBANA,EAOAC,UAPA,EAQAC,gBARA,EASAC,QATA,EAUAC,MAVA,EAWAC,uBAXA,EAYAC,iBAZA,EAaAC,gBAbA,EAcAC,QAdA,EAeAC,cAfA,EAgBAC,oBAhBA,EAiBAC,OAjBA,EAkBAC,eAlBA,QAmBA,aAnBA;AAoBA;AACA;AACA;EACAC,oBADA;EAEAC;IACAC,aADA;IAEA;IACAC,aAHA;IAIAC;EAJA,CAFA;;EAQAC;IACA;MACAC,oBADA;MAEAC,eAFA;MAGAC;QACAC,OADA;QAEAC,UAFA;QAGAC;MAHA,CAHA;MAQAC,iBARA;MASAC,kBATA;MAUAC,iBAVA;MAWAC,sBAXA;MAYAC,eAZA;MAaAC,kBAbA;MAcAC,kBAdA;MAeAC,cAfA;MAgBAC,WAhBA;MAiBAC,WAjBA;MAkBAC,cAlBA;MAmBAC,gBAnBA;MAoBAC,UApBA;MAqBAC,gBArBA;MAsBAC,mBAtBA;MAuBAC,QAvBA;MAwBAC,OAxBA;MAyBAC,YAzBA;MA0BAC,cA1BA;MA0BA;MACAC,eA3BA;MA4BAC;QACAC,gBADA;QAEAC,cAFA;QAGAC,SAHA;QAIAC,QAJA;QAKAb;MALA,CA5BA;MAmCAc,sBAnCA;MAoCAC,UApCA;MAqCAC,UArCA;MAsCAC,mBAtCA;MAuCAC;QACAC,gBADA;QAEAC,YAFA;QAGAC,aAHA;QAIAvB,WAJA;QAKAwB,YALA;QAMAC,cANA;QAOAC,0BAPA;QAOA;QACAC,cARA;QAQA;QACAC,cATA;QASA;QACAC,cAVA;QAUA;QACAC,UAXA,CAWA;;MAXA,CAvCA;MAoDAC,gBApDA;MAqDAC,cArDA;MAsDAC,mBAtDA;MAuDAC,gBAvDA;MAwDAC,aAxDA;MAyDAC,WAzDA;MA0DAC,YACA,MADA,EAEA,IAFA,EAGA,MAHA,EAIA,KAJA,EAKA;MACA,MANA,EAOA,MAPA,EAQA,MARA,EASA,MATA,CA1DA;MAqEAC,UACA;QACAC;MADA,CADA,EAIA;QACAA;MADA,CAJA,EAOA;QACAA;MADA,CAPA,EAUA;QACAA;MADA,CAVA,EAaA;MACA;MACA;MACA;QACAA;MADA,CAhBA,EAmBA;QACAA;MADA,CAnBA,EAsBA;QACAA;MADA,CAtBA,EAyBA;QACAA;MADA,CAzBA,CArEA;MAkGAC,kBAlGA;MAmGAC,uBAnGA;MAoGAC,cApGA;MAqGAC,mBArGA;MAsGAC,iBAtGA;MAuGAC,cAvGA;MAwGAC,eAxGA;MAyGAC,cAzGA;MA0GAC,cA1GA;MA2GAC,cA3GA,CA2GA;;IA3GA;EA6GA,CAtHA;;EAuHAC,YACA;MACAC;IADA;EADA,CAvHA;;EA4HAC;IACA;MACA;IACA,CAFA,MAEA;MACA;IACA,CAFA,MAEA;MACA;IACA;;IACA;IACA;EACA,CAtIA;;EAuIAC;IACA;IACA;EACA,CA1IA;;EA2IAC;IACAC;MAAAC;MAAAC;MAAAC;MAAAC;MAAAC;IAAA;MACA;QACA;UACA;QACA;MACA;IACA,CAPA;;IAQA;IACA;MACA;QAAA5E;MAAA;MACA;IACA,CAZA;;IAaA;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA6E,6BADA;QAEAC;MAFA;MAKA;MACA;IACA,CA7BA;;IA8BAC;MACA;MACA;IACA,CAjCA;;IAkCAC;MACA;QACA;MACA,CAFA,MAEA;QACA;MACA;IACA,CAxCA;;IAyCAC;MACA;QACA;UACA;UACA;UACA;;QACA;UACA;UACA;UACA;;QACA;UACA;UACA;UACA;;QACA;UACA;UACA;UACA;MAhBA;;MAkBA;IACA,CA7DA;;IA8DA;IACA;MAAAP;IAAA;MACA;QACA;;QACA;UACA;YAAA1E;UAAA;;UACA;YACA;cACA,8DACAkF;gBACA,qCACAC,GADA,CACAC;kBACA;gBACA,CAHA,EAIAC,IAJA,CAIA,GAJA;gBAKA,SACA,OADA;kBAEAC;gBAFA;cAIA,CAXA;YAaA,CAdA;UAeA,CAhBA,MAgBA;YACA;cACA,8DACAJ;gBACA,SACA,OADA;kBAEAI;gBAFA;cAIA,CANA;YAQA,CATA;UAUA;QACA;;QACAC;MACA,CAlCA,EADA,CAoCA;IACA,CApGA;;IAqGAC;MACA;IACA,CAvGA;;IAwGAC;MACA;MACA;MACA;IACA,CA5GA;;IA6GAC;MACA;MACA;MACA;IACA,CAjHA;;IAkHA;IACAC;MAAAC;IAAA;MACA;MACA;MACA;IACA,CAvHA;;IAwHA;IACAC;MACA;IACA,CA3HA;;IA4HA;IACAC;MACA;QACA;QACA;QACA;QACA;MACA,CALA,MAKA;QACA;MACA;IACA,CAtIA;;IAwIA;IACA;MACA,YACA5E,qBACA,eADA,GAEA,eAHA;;MAIA;QACA;QACA;MACA;;MACA;QACA6E,uBADA;QAEAC,sBAFA;QAGAxB;MAHA,GAIAyB,IAJA,CAIA;QACA;UACA;UACA;QACA;;QACA;UACA;QACA,CAFA;QAGA;UACApB,UADA;UAEA3D;QAFA;QAIA;UACAsD,eADA;UAEA0B;QAFA;QAIA;MACA,CArBA;IAsBA,CAxKA;;IAyKA;IACA;MACA;QACA;QACA;MACA;;MACA;QACAH,uBADA;QAEAC,sBAFA;QAGAxB;MAHA,GAIAyB,IAJA,CAIA;QACA;UACA;UACA;QACA;;QACA;UACA;QACA,CAFA;QAGA;UACApB,UADA;UAEAsB;QAFA;QAIA;UACA3B,eADA;UAEA0B;QAFA;QAIA;MACA,CArBA;IAsBA,CArMA;;IAsMA;IACA;MACA;QACA3E,eADA;QAEAC,uBAFA;QAGA4E,2BAHA;QAIAC;MAJA;;MAMA;QACAC;MACA;;MACA;QACAA;MACA;;MACA;QACA,uCACA,SADA;UAEAC;QAFA;MAIA,CALA,MAKA;QACA;QACA;UACA,SACA,OADA;YAEAC,yBAFA;YAGAhG,kBAHA;YAIAiG,sBAJA;YAKAC;UALA;QAOA,CARA;QASA;MACA;IACA,CAtOA;;IAuOA;MACA;QACAnF,eADA;QAEAC,uBAFA;QAGAmF,yBAHA;QAIA5F,qBAJA;QAKAa,8CALA;QAMAZ,qBANA;QAOAE,+BAPA;QAQAC;MARA;;MAUA;QACA,2CACA,SADA;UAEAoF;QAFA;MAIA,CALA,MAKA;QACA;QACA;UACA,SACA,OADA;YAEAC,yBAFA;YAGAhG,kBAHA;YAIAiG,sBAJA;YAKAC;UALA;QAOA,CARA;QASA;MACA;IACA,CApQA;;IAqQA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACAE;MACA;QACA;MACA,CAHA,CAIA;;;MACA;QACA7F,qBADA;QAEAC,qBAFA;QAGAY,8CAHA;QAIAV,+BAJA;QAKAC;MALA;MAOA;;MACA;QACA;MACA,CAFA,MAEA;QACA;MACA;IACA,CA9TA;;IA+TA;IACA0F;MACA;IACA,CAlUA;;IAmUA;IACAC;MACA;MACA;MACA;IACA,CAxUA;;IAyUA;IACAC;MACA;MACA;IACA,CA7UA;;IA8UA;IACAC;MACA;MACA;MACA;IACA,CAnVA;;IAoVA;IACA;MACA;QACAjB,uBADA;QAEAC,sBAFA;QAGAxB;MAHA,GAIAyB,IAJA,CAIA;QACA;QAEA;UACAzB,eADA;UAEA0B;QAFA;QAIA;MACA,CAZA;IAaA,CAnWA;;IAoWA;IACA;MACA;QACAH,uBADA;QAEAC,sBAFA;QAGAxB;MAHA,GAIAyB,IAJA,CAIA;QACA;QAEA;UACAzB,eADA;UAEA0B;QAFA;QAIA;MACA,CAZA;IAaA,CAnXA;;IAoXA;IACA;MACA;QACA;UACArB,UADA;UAEA3D;QAFA;QAIA;UACAsD,eADA;UAEA0B;QAFA;MAIA,CATA,CASA;QACA;MACA;IACA,CAlYA;;IAmYA;IACAe;MACA;MACA;IACA,CAvYA;;IAwYA;IACAC;MACA;MACA;IACA,CA5YA;;IA6YAC;MACA;MACA;MACA;IACA,CAjZA;;IAkZA;IACAC;MACA;MACA;;MACA;QACA;MACA;IACA,CAzZA;;IA0ZA;IACAC;MACA;MACA;;MACA;QACA;MACA;;MACA;QACA;MACA;;MACA;QACA;MACA;;MACA;QACA;MACA;IACA,CA1aA;;IA2aA;IACA;MACA;QACA;QACA;MACA;;MACA;QACA;MACA,CAFA;MAGA;;MACA;QACA;UACA1E,sCADA;UAEAG,4BAFA;UAGAF,oCAHA;UAIAxC;QAJA;QAMA;QAEA;QACA;QACA;MACA,CAZA,CAYA;QACA;MACA;IACA,CApcA;;IAqcA;IACA;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;;MACA;QACA;UACA;QACA,CAFA;QAGA,sCACA,qBADA;UAEAA;QAFA;QAIA;QAEA;QACA;QACA;MACA,CAbA,CAaA;QACA;MACA;IACA,CAxeA;;IAyeA;IACA;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;QACA;MACA,CAFA;MAGA;;MACA;QACA;UACAyE,UADA;UAEA7D;QAFA;QAIA;QAEA;QACA;QACA;MACA,CAVA,CAUA;QACA;MACA;IACA,CApgBA;;IAsgBA;IACA;MACA;QACA;QACA;MACA;;MACA;QACA;QACA;MACA;;MACA;;MACA;QACA;UACA;QACA,CAFA;QAGA;UACA6D,UADA;UACA;UACA5D,mCACA,iCADA,CAFA;UAIA;UACAW,8CALA,CAKA;;QALA;QAOA;QACA;QACA;QACA;QACA;MACA,CAhBA,CAgBA;QACA;MACA;IACA,CApiBA;;IAqiBA0F;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IACA,CA/iBA;;IAgjBA9H;MACA,YACA0B,qBACA,cADA,GAEA,qBAHA;;MAIA;QACA;QACA;MACA;;MACA;QACA6E,uBADA;QAEAC,sBAFA;QAGAxB;MAHA,GAIAyB,IAJA,CAIA;QACA;QACA;;QACA;UACA;UACA;QACA;;QACA;UACA;QACA,CAFA;QAGA;UACA7F,WADA;UAEAmH;QAFA;QAIA;UACA/C,eADA;UAEA0B;QAFA;QAIA;MACA,CAvBA;IAwBA,CAjlBA;;IAklBAsB;MACA;MACA;MACA;IACA,CAtlBA;;IAulBA;MACA;QAAAxH;MAAA;QACA6E,6BADA;QAEA4C;MAFA;MAIA;MACA;MACA;IACA;;EA/lBA;AA3IA","names":["setSalesNum","getGoodsInfo","BatchUnloading","getAllGoods","exportGetAllGoods","exportGetAllGoodsList","searchGood","exportSearchGood","delGoods","setTop","GoodsUpdateEnableStatus","batchGoodsExpress","setSalesNumBatch","setBrand","updateCategory","batchSetDistribution","setSort","getAllGoodsList","name","components","GoodsCategory","BrandSelModel","SelectShop","data","virtual_sales_num","set_goods_id","sale_num_form","ids","minVal","maxVal","activeName","goods_sku_list","checkedAll","isIndeterminate","is_price","sku_visible","sku_goods_name","goods_name","keyword","brandId","categoryId","enableStatus","shopId","sel_brand","transferShow","total","page","pageSize","goods_data","choose_data","form","categoryPath","search_key","brand","shop","price_goods_detail","inSales","inStock","spec_loading","set_form","masterUnitId","shopName","brandName","category","branchUnit","deliverySupIds","expressType","expressFee","showExpress","ruleId","express_list","assistForm","more_sub_btn","unit_show","is_set","set_tit","checkList","columns","label","classifyFlag","specificationFlag","unitFlag","inventoryFlag","virtualFlag","trueFlag","stateFlag","shopFlag","timeFlag","member_sort","computed","enterpriseScope","created","activated","methods","showTooltipMethod","type","column","row","items","_columnIndex","id","val","showSetSaleNum","openAddGoods","tabChange","item","map","itemS","join","specValueName","resolve","toggleRowExpansion","delBrand","delShop","selectionChange","records","editsubData","openPriceModel","confirmButtonText","cancelButtonText","then","message","deleteStatus","ifMerchant","merchantId","params","export","sale_false_visible","address","sort_flag","keywordType","getData","goodsChane","brandConfirm","transferBrandConfirm","shopConfirm","pageChange","sizeChange","checkAllChange","openSet","moreSubData","change","isDistribution","showSort","sort"],"sourceRoot":"src/views/goods/sale","sources":["PublishGoods.vue"],"sourcesContent":["<template>\n <ContainerQuery>\n <div slot=\"left\">\n <el-dropdown\n v-if=\"\n $accessCheck($Access.PublishGoodsAddGoods) ||\n $accessCheck($Access.PublishGoodsAddBasicAndPublishGoods)\n \"\n split-button\n type=\"primary\"\n @click=\"openAddGoods\"\n >\n 发布商品\n <el-dropdown-menu slot=\"dropdown\">\n <el-dropdown-item>\n <div class=\"dropdown-div\" @click=\"getAllGoodsList(1)\">导出</div>\n </el-dropdown-item>\n <el-dropdown-item v-if=\"enterpriseScope == '4'\">\n <div @click=\"$router.push('/goods/manageG/SingleGoodsImport')\">\n 导入\n </div>\n </el-dropdown-item>\n </el-dropdown-menu>\n </el-dropdown>\n <el-button v-else size=\"small\" type=\"primary\" @click=\"getData(1)\">\n 导出\n </el-button>\n </div>\n <div v-if=\"$accessCheck($Access.PublishGoodsSearch)\" slot=\"more\">\n <el-form :inline=\"true\" size=\"small\">\n <el-form-item>\n <el-input\n v-model=\"keyword\"\n style=\"width: 220px\"\n placeholder=\"商品名称/商品编码\"\n clearable\n @keyup.enter.native=\"pageChange(1)\"\n @clear=\"pageChange(1)\"\n >\n <el-button slot=\"append\" @click=\"pageChange(1)\">\n <i class=\"el-icon-search\"></i>\n </el-button>\n </el-input>\n </el-form-item>\n <el-form-item>\n <GoodsCategory\n v-model=\"form.categoryPath\"\n :width=\"160\"\n check-strictly\n clearable\n size=\"small\"\n @change=\"goodsChane\"\n />\n </el-form-item>\n <el-form-item>\n <el-input\n v-model=\"form.brand\"\n style=\"width: 150px\"\n placeholder=\"商品品牌\"\n clearable\n @clear=\"delBrand\"\n >\n <i\n slot=\"suffix\"\n class=\"el-input__icon el-icon-search\"\n @click=\"sel_brand = true\"\n ></i>\n </el-input>\n </el-form-item>\n <el-form-item>\n <el-select\n v-model=\"enableStatus\"\n placeholder=\"销售状态\"\n style=\"width: 150px\"\n clearable\n @change=\"pageChange(1)\"\n >\n <el-option label=\"上架\" :value=\"5\"></el-option>\n <el-option label=\"下架\" :value=\"4\"></el-option>\n </el-select>\n </el-form-item>\n <el-form-item>\n <SelectShop\n v-model=\"shopId\"\n width=\"150\"\n placeholder=\"销售店铺\"\n @change=\"shopConfirm\"\n @clear=\"delShop\"\n />\n </el-form-item>\n </el-form>\n </div>\n <el-tabs v-model=\"activeName\" type=\"card\" @tab-click=\"tabChange\">\n <el-tab-pane label=\"全部\" name=\"all\"></el-tab-pane>\n <el-tab-pane label=\"销售中\" name=\"GoodsSale\"></el-tab-pane>\n <el-tab-pane label=\"已售罄\" name=\"SoldOut\"></el-tab-pane>\n <el-tab-pane label=\"仓库中\" name=\"InWarehouse\"></el-tab-pane>\n </el-tabs>\n <vxe-table\n ref=\"goodsTable\"\n show-overflow\n border=\"inner\"\n :data=\"goods_data\"\n :expand-config=\"{\n accordion: true,\n lazy: true,\n loadMethod: showSpec,\n }\"\n :tooltip-config=\"{ contentMethod: showTooltipMethod, enterable: true }\"\n @checkbox-all=\"selectionChange\"\n @checkbox-change=\"selectionChange\"\n >\n <vxe-table-column type=\"checkbox\" width=\"60\"></vxe-table-column>\n <vxe-table-column\n field=\"code\"\n width=\"140\"\n title=\"编码\"\n ></vxe-table-column>\n <vxe-table-column field=\"materialName\" title=\"商品\" min-width=\"300\">\n <template #default=\"scope\">\n <div class=\"clearfix\">\n <div class=\"float_left\">\n <el-image fit=\"cover\" :src=\"scope.row.images[0]\"></el-image>\n </div>\n <div class=\"float_left goods-name-view\">\n {{ scope.row.title }}\n </div>\n </div>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"classifyFlag\"\n field=\"categoryName\"\n title=\"商品分类\"\n min-width=\"120\"\n >\n <template #default=\"scope\">\n {{ scope.row.categoryName || \"未设置\" }}\n <el-button\n v-if=\"$accessCheck($Access.BaseDataListUpdateCategory)\"\n type=\"text\"\n icon=\"el-icon-edit\"\n @click=\"openSet('转移分类', scope.row)\"\n ></el-button>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"specificationFlag\"\n type=\"expand\"\n title=\"规格\"\n width=\"140\"\n >\n <template #default=\"scope\">\n <div class=\"sku-btn\" @click=\"toggleRowExpansion(scope.rowIndex)\">\n {{ scope.row.specTotal }}种规格\n </div>\n </template>\n <template #content=\"scope\">\n <ul class=\"sku-ul\">\n <li\n v-for=\"(item, index) in scope.row.goods_sku_list\"\n :key=\"index\"\n class=\"sku-li\"\n >\n <div class=\"clearfix\">\n <div class=\"float_left\">\n <img\n class=\"sku-img\"\n :src=\"item.specImage || scope.row.images[0]\"\n alt=\"\"\n />\n </div>\n <div class=\"sku-info float_left\">\n <p>\n <span class=\"label\">规格:</span>\n {{ item.unitName }};{{ item.specValueName }}\n </p>\n <p>\n <span class=\"label\">库存:</span>\n {{ $_common.formatNub(item.inventory) }};\n <span class=\"label\">销量:</span>\n {{ $_common.formatNub(item.salesNum) }}\n </p>\n <p>\n <span class=\"label\">起订量:</span>\n {{ $_common.formatNub(item.setNum) }};\n <span class=\"label\">市场价:</span>\n {{ $_common.formattedNumber(item.marketPrice) }}\n </p>\n <p>\n <span class=\"label\">阶梯价:</span>\n {{ item.enabledLadder === 1 ? \"是\" : \"否\" }};\n <span v-if=\"!item.enabledLadder\">\n <span class=\"label\">销售价:</span>\n {{ $_common.formattedNumber(item.salePrice) }}\n </span>\n </p>\n </div>\n </div>\n <div v-if=\"item.enabledLadder\" class=\"clearfix\">\n <div class=\"float_left\" style=\"width: 50px; margin-right: 10px\">\n 销售价:\n </div>\n <div class=\"float_left\">\n <p v-for=\"(price, indexP) in item.ladderPrice\" :key=\"indexP\">\n <span>\n 数量:\n <span style=\"color: #ff4040\">\n {{ price.from }}-{{\n indexP === item.ladderPrice.length - 1\n ? \"∞\"\n : price.to\n }}\n </span>\n ,\n </span>\n <span>\n 价格:\n <span style=\"color: #ff4040\">\n {{ $_common.formattedNumber(price.price) }}\n </span>\n ;\n </span>\n </p>\n </div>\n </div>\n </li>\n </ul>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"unitFlag\"\n field=\"unitNameMaster\"\n title=\"基本单位\"\n min-width=\"100\"\n ></vxe-table-column>\n <vxe-table-column field=\"sort\" title=\"排序\" min-width=\"130\">\n <template #default=\"{ row, $rowIndex }\">\n <div v-if=\"row.sort_flag\">\n <el-input-number\n v-model=\"member_sort\"\n style=\"width: calc(100% - 30px)\"\n :controls=\"false\"\n size=\"mini\"\n @keyup.enter.native=\"setSort($rowIndex)\"\n ></el-input-number>\n <div class=\"virtualSalesNum-btn\" @click=\"setSort($rowIndex)\">\n <i class=\"el-icon-check\"></i>\n </div>\n </div>\n\n <div v-else @click=\"showSort($rowIndex)\">\n {{ row.sort }}\n <el-button type=\"text\" icon=\"el-icon-edit\"></el-button>\n </div>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"inventoryFlag\"\n field=\"masterInventory\"\n title=\"总库存\"\n min-width=\"100\"\n >\n <template #default=\"scope\">\n <span\n :class=\"\n Number(scope.row.inventorTotal) <= 0\n ? 'danger-status'\n : 'success-status'\n \"\n class=\"\"\n >\n {{ $_common.formatNub(scope.row.inventorTotal) }}\n </span>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"false\"\n field=\"virtualSalesNum\"\n title=\"虚拟销量\"\n min-width=\"100\"\n >\n <template #default=\"scope\">\n <div v-if=\"scope.row.sale_false_visible\">\n <el-input-number\n v-model=\"virtual_sales_num\"\n style=\"width: calc(100% - 28px)\"\n :controls=\"false\"\n size=\"mini\"\n @keyup.enter.native=\"setSalesNum(scope.$index)\"\n @blur=\"setSalesNum(scope.$index, -1)\"\n ></el-input-number>\n <div class=\"virtualSalesNum-btn\" @click=\"setSalesNum(scope.$index)\">\n <i class=\"el-icon-check\"></i>\n </div>\n </div>\n\n <div v-else @click=\"showSetSaleNum(scope.$index)\">\n {{ scope.row.virtualSalesNum }}\n <el-button\n v-if=\"$accessCheck($Access.PublishGoodssetSalesNum)\"\n type=\"text\"\n icon=\"el-icon-edit\"\n ></el-button>\n </div>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"trueFlag\"\n field=\"salesNum\"\n title=\"真实销量\"\n min-width=\"100\"\n >\n <template #default=\"scope\">\n {{ $_common.formatNub(scope.row.salesNum) }}\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"stateFlag\"\n field=\"enableStatus\"\n title=\"销售状态\"\n width=\"100\"\n >\n <template #default=\"scope\">\n <el-switch\n v-if=\"$accessCheck($Access.PublishGoodsUpdateEnableStatus)\"\n v-model=\"scope.row.enableStatus\"\n class=\"switchStyle\"\n active-color=\"#36B365\"\n :active-value=\"5\"\n :inactive-value=\"4\"\n active-text=\"上架\"\n inactive-text=\"下架\"\n @change=\"changeGoodsStatus($event, scope.row)\"\n ></el-switch>\n <div v-else>\n <span v-if=\"scope.row.enableStatus === 5\" class=\"success-status\">\n 上架\n </span>\n <span v-else class=\"info-status\">下架</span>\n </div>\n </template>\n </vxe-table-column>\n <vxe-table-column\n v-if=\"shopFlag\"\n field=\"shopName\"\n title=\"销售店铺\"\n min-width=\"200\"\n ></vxe-table-column>\n <vxe-table-column\n v-if=\"timeFlag\"\n field=\"createTime\"\n title=\"创建时间\"\n width=\"150\"\n >\n <template #default=\"scope\">\n {{ $_common.formatDate(scope.row.createTime) }}\n </template>\n </vxe-table-column>\n <vxe-table-column title=\"操作\" fixed=\"right\" width=\"160\">\n <!-- <template slot=\"header\" #default=\"scope\">-->\n <!-- <!– <span v-if=\"false\">{{ scope.$index }}</span>–>-->\n <!-- <span class=\"operation\">操作</span>-->\n <!-- <el-popover popper-class=\"custom-table-checkbox\" trigger=\"click\">-->\n <!-- <el-checkbox-group v-model=\"checkList\">-->\n <!-- <el-checkbox-->\n <!-- v-for=\"(item, index) in columns\"-->\n <!-- :key=\"index\"-->\n <!-- :label=\"item.label\"-->\n <!-- @change=\"change\"-->\n <!-- ></el-checkbox>-->\n <!-- </el-checkbox-group>-->\n <!-- <el-button-->\n <!-- slot=\"reference\"-->\n <!-- icon=\"el-icon-setting\"-->\n <!-- type=\"text\"-->\n <!-- ></el-button>-->\n <!-- </el-popover>-->\n <!-- </template>-->\n <template #default=\"scope\">\n <div style=\"height: 34px; line-height: 34px\">\n <el-button\n v-if=\"\n ($accessCheck($Access.PublishGoodsEditGoods) &&\n $accessCheck($Access.PublishGoodsGetGoodsInfo) &&\n $route.name === 'PublishGoods') ||\n ($accessCheck($Access.PublishGoodsEditQuickGoods) &&\n $accessCheck($Access.PublishGoodsGetQuickGoodsInfo) &&\n $route.name === 'PublishGoods')\n \"\n type=\"text\"\n @click=\"openPriceModel(scope.row)\"\n >\n 编辑\n </el-button>\n <el-button\n v-if=\"\n $accessCheck($Access.PublishGoodsDelGoods) &&\n $route.name === 'PublishGoods'\n \"\n type=\"text\"\n @click=\"delData(scope.row.id)\"\n >\n 删除\n </el-button>\n <el-button\n v-if=\"$accessCheck($Access.PublishGoodssetTop)\"\n type=\"text\"\n @click=\"setTop(scope.row.id)\"\n >\n {{ scope.row.topTime !== 0 ? \"取消置顶\" : \"置顶\" }}\n </el-button>\n </div>\n </template>\n </vxe-table-column>\n </vxe-table>\n <!-- <el-drawer-->\n <!-- class=\"edit-drawer\"-->\n <!-- :title=\"goods_name\"-->\n <!-- :visible.sync=\"is_price\"-->\n <!-- direction=\"rtl\"-->\n <!-- size=\"50%\"-->\n <!-- >-->\n <!-- <EditGoods-->\n <!-- v-if=\"is_price\"-->\n <!-- :goods-id=\"price_goods_detail.id\"-->\n <!-- @subData=\"editsubData\"-->\n <!-- />-->\n <!-- </el-drawer>-->\n <FooterPage\n :page-size=\"pageSize\"\n :total-page.sync=\"total\"\n :current-page.sync=\"page\"\n @pageChange=\"pageChange\"\n @sizeChange=\"sizeChange\"\n >\n <div slot=\"btn-div\" class=\"foot-btn-div\">\n <span class=\"batch-checkbox\">\n <vxe-checkbox\n v-model=\"checkedAll\"\n :indeterminate=\"isIndeterminate\"\n @change=\"checkAllChange\"\n ></vxe-checkbox>\n </span>\n <el-dropdown\n v-if=\"\n $accessCheck($Access.PublishGoodsUpdateEnableStatus) &&\n ['PublishGoods', 'InWarehouse'].includes($route.name)\n \"\n >\n <el-button size=\"mini\">\n 批量上下架\n <i class=\"el-icon-caret-top\"></i>\n </el-button>\n <el-dropdown-menu slot=\"dropdown\">\n <el-dropdown-item>\n <div class=\"dropdown-div\" @click=\"BatchUnloading(5)\">\n 批量上架\n </div>\n </el-dropdown-item>\n <el-dropdown-item>\n <div class=\"dropdown-div\" @click=\"BatchUnloading(4)\">\n 批量下架\n </div>\n </el-dropdown-item>\n </el-dropdown-menu>\n </el-dropdown>\n <el-dropdown\n v-if=\"\n $accessCheck($Access.PublishGoodssetSalesNumBatch) ||\n $accessCheck($Access.PublishGoodsbatchGoodsExpress)\n \"\n >\n <el-button size=\"mini\">\n 批量设置\n <i class=\"el-icon-caret-top\"></i>\n </el-button>\n <el-dropdown-menu slot=\"dropdown\">\n <el-dropdown-item\n v-if=\"$accessCheck($Access.PublishGoodssetSalesNumBatch)\"\n >\n <div class=\"dropdown-div\" @click=\"openSet('虚拟销量')\">\n 设置虚拟销量\n </div>\n </el-dropdown-item>\n <el-dropdown-item\n v-if=\"$accessCheck($Access.PublishGoodsbatchGoodsExpress)\"\n >\n <div class=\"dropdown-div\" @click=\"openSet('物流设置')\">\n 批量设置物流\n </div>\n </el-dropdown-item>\n </el-dropdown-menu>\n </el-dropdown>\n <el-dropdown\n v-if=\"\n $accessCheck($Access.BaseDataListUpdateCategory) ||\n $accessCheck($Access.BaseDataListSetBrand)\n \"\n >\n <el-button size=\"mini\">\n 批量转移\n <i class=\"el-icon-caret-top\"></i>\n </el-button>\n <el-dropdown-menu slot=\"dropdown\">\n <el-dropdown-item>\n <div\n v-if=\"$accessCheck($Access.BaseDataListUpdateCategory)\"\n class=\"dropdown-div\"\n @click=\"openSet('转移分类')\"\n >\n 转移分类\n </div>\n </el-dropdown-item>\n <el-dropdown-item>\n <div\n v-if=\"$accessCheck($Access.BaseDataListSetBrand)\"\n class=\"dropdown-div\"\n @click=\"openSet('设置品牌')\"\n >\n 转移品牌\n </div>\n </el-dropdown-item>\n </el-dropdown-menu>\n </el-dropdown>\n <el-dropdown\n v-if=\"\n $accessCheck($Access.PublishGoodsUpdateEnableStatus) &&\n ['PublishGoods', 'InWarehouse'].includes($route.name)\n \"\n >\n <el-button size=\"mini\">\n 批量负库存销售\n <i class=\"el-icon-caret-top\"></i>\n </el-button>\n <el-dropdown-menu slot=\"dropdown\">\n <el-dropdown-item>\n <div class=\"dropdown-div\" @click=\"batchSetDistribution(5)\">\n 批量启用\n </div>\n </el-dropdown-item>\n <el-dropdown-item>\n <div class=\"dropdown-div\" @click=\"batchSetDistribution(4)\">\n 批量禁用\n </div>\n </el-dropdown-item>\n </el-dropdown-menu>\n </el-dropdown>\n <el-dropdown\n v-if=\"\n $accessCheck($Access.PublishGoodsUpdateEnableStatus) &&\n ['PublishGoods', 'InWarehouse'].includes($route.name)\n \"\n >\n <el-button size=\"mini\" @click=\"deleteBatchUnloading(4)\">\n 批量删除\n </el-button>\n </el-dropdown>\n </div>\n </FooterPage>\n <BrandSelModel\n v-if=\"sel_brand\"\n :is-check=\"false\"\n :dialog-visible=\"sel_brand\"\n @close=\"sel_brand = false\"\n @confirm=\"brandConfirm\"\n />\n <BrandSelModel\n v-if=\"transferShow\"\n :is-check=\"false\"\n :dialog-visible=\"transferShow\"\n @close=\"transferShow = false\"\n @confirm=\"transferBrandConfirm\"\n />\n <el-dialog\n :close-on-press-escape=\"false\"\n :close-on-click-modal=\"false\"\n :title=\"set_tit\"\n :visible.sync=\"is_set\"\n width=\"30%\"\n >\n <el-form ref=\"set_form\" :model=\"set_form\" label-width=\"100px\">\n <el-form-item v-if=\"set_tit === '虚拟销量'\" label=\"销量区间:\">\n <el-input-number\n v-model=\"sale_num_form.minVal\"\n :controls=\"false\"\n ></el-input-number>\n -\n <el-input-number\n v-model=\"sale_num_form.maxVal\"\n :controls=\"false\"\n ></el-input-number>\n <p class=\"form-tip\">虚拟总销量等于销量区间内产生的随机数</p>\n </el-form-item>\n <el-form-item v-if=\"set_tit === '转移分类'\" label=\"转移分类:\">\n <GoodsCategory v-model=\"set_form.category\" check-strictly />\n </el-form-item>\n <el-form-item v-if=\"set_tit === '设置品牌'\" label=\"设置品牌:\">\n <el-input\n v-model=\"set_form.brandName\"\n readonly\n style=\"width: 240px\"\n placeholder=\"请选择品牌\"\n >\n <i\n slot=\"suffix\"\n class=\"el-input__icon el-icon-search\"\n @click=\"transferShow = true\"\n ></i>\n </el-input>\n </el-form-item>\n <div v-if=\"set_tit === '物流设置'\">\n <el-form-item v-if=\"false\" label=\"物流支持:\" prop=\"deliverySupIds\">\n <el-checkbox-group v-model=\"set_form.deliverySupIds\">\n <el-checkbox label=\"1\">快递</el-checkbox>\n <el-checkbox label=\"2\">自提</el-checkbox>\n </el-checkbox-group>\n </el-form-item>\n <br />\n <el-form-item label=\"快递运费:\">\n <el-radio-group v-model=\"set_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 <br />\n <div v-if=\"set_form.expressType === 2\">\n <el-form-item label=\"运费模板:\" prop=\"ruleId\">\n <el-select v-model=\"set_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=\"set_form.expressType === 3\">\n <el-form-item label=\"统一运费:\" prop=\"expressFee\">\n <el-input-number\n v-model=\"set_form.expressFee\"\n :controls=\"false\"\n ></el-input-number>\n <span>元</span>\n </el-form-item>\n </div>\n <el-form-item v-if=\"false\" label=\"是否展示快递:\">\n <el-radio-group v-model=\"set_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 </el-form>\n <span slot=\"footer\" class=\"dialog-footer\">\n <el-button @click=\"is_set = false\">取 消</el-button>\n <el-button :loading=\"more_sub_btn\" type=\"primary\" @click=\"moreSubData\">\n 确 定\n </el-button>\n </span>\n </el-dialog>\n </ContainerQuery>\n</template>\n\n<script>\n import GoodsCategory from \"@/component/common/GoodsCategory.vue\";\n import BrandSelModel from \"@/component/goods/BrandSelModel.vue\";\n // import EditGoods from \"./AddGoods\";\n import SelectShop from \"@/component/goods/SelectShop.vue\";\n\n import {\n setSalesNum,\n getGoodsInfo,\n BatchUnloading,\n getAllGoods,\n exportGetAllGoods,\n exportGetAllGoodsList,\n searchGood,\n exportSearchGood,\n delGoods,\n setTop,\n GoodsUpdateEnableStatus,\n batchGoodsExpress,\n setSalesNumBatch,\n setBrand,\n updateCategory,\n batchSetDistribution,\n setSort,\n getAllGoodsList,\n } from \"@/api/goods\";\n import { getAllExpressRule } from \"@/api/System\";\n import { mapGetters } from \"vuex\";\n export default {\n name: \"PublishGoods\",\n components: {\n GoodsCategory,\n // EditGoods,\n BrandSelModel,\n SelectShop,\n },\n data() {\n return {\n virtual_sales_num: 0,\n set_goods_id: 0,\n sale_num_form: {\n ids: [],\n minVal: \"\",\n maxVal: \"\",\n },\n activeName: \"all\",\n goods_sku_list: [],\n checkedAll: false,\n isIndeterminate: false,\n is_price: false,\n sku_visible: false,\n sku_goods_name: \"\",\n goods_name: \"\",\n keyword: \"\",\n brandId: \"\",\n categoryId: \"\",\n enableStatus: \"\",\n shopId: \"\",\n sel_brand: false,\n transferShow: false,\n total: 0,\n page: 1,\n pageSize: 10,\n goods_data: [], // table 数据\n choose_data: [],\n form: {\n categoryPath: [],\n search_key: \"\",\n brand: \"\",\n shop: \"\",\n enableStatus: \"\",\n },\n price_goods_detail: {},\n inSales: 0,\n inStock: 0,\n spec_loading: false,\n set_form: {\n masterUnitId: \"\",\n shopName: \"\",\n brandName: \"\",\n brandId: \"\",\n category: [],\n branchUnit: [],\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 },\n express_list: [],\n assistForm: {},\n more_sub_btn: false,\n unit_show: false,\n is_set: false,\n set_tit: \"\",\n checkList: [\n \"商品分类\",\n \"规格\",\n \"基本单位\",\n \"总库存\",\n // \"虚拟销量\",\n \"真实销量\",\n \"当前状态\",\n \"销售店铺\",\n \"创建时间\",\n ],\n columns: [\n {\n label: \"商品分类\",\n },\n {\n label: \"规格\",\n },\n {\n label: \"基本单位\",\n },\n {\n label: \"总库存\",\n },\n // {\n // label: \"虚拟销量\",\n // },\n {\n label: \"真实销量\",\n },\n {\n label: \"当前状态\",\n },\n {\n label: \"销售店铺\",\n },\n {\n label: \"创建时间\",\n },\n ],\n classifyFlag: true,\n specificationFlag: true,\n unitFlag: true,\n inventoryFlag: true,\n virtualFlag: true,\n trueFlag: true,\n stateFlag: true,\n shopFlag: true,\n timeFlag: true,\n member_sort: 0, //排序\n };\n },\n computed: {\n ...mapGetters({\n enterpriseScope: \"MUser/enterpriseScope\",\n }),\n },\n created() {\n if (this.$route.name === \"GoodsSale\") {\n this.inSales = 5;\n } else if (this.$route.name === \"SoldOut\") {\n this.inStock = 4;\n } else if (this.$route.name === \"InWarehouse\") {\n this.inStock = 5;\n }\n this.getAllGoodsList();\n this.getAllExpressRule();\n },\n activated() {\n if (this.$_isInit()) return;\n this.getData();\n },\n methods: {\n showTooltipMethod({ type, column, row, items, _columnIndex }) {\n if (column.property === \"shopName\") {\n if (type === \"body\") {\n return column.shopName;\n }\n }\n },\n // 获取运费模版\n async getAllExpressRule() {\n const { data } = await getAllExpressRule();\n this.express_list = data;\n },\n async setSalesNum(index, tag) {\n if (tag === -1) {\n this.goods_data[index].sale_false_visible = false;\n return;\n }\n if (this.virtual_sales_num < 0) {\n this.$message.warning(\"请输入大于0的值\");\n return;\n }\n const data = await setSalesNum({\n id: this.goods_data[index].id,\n val: this.virtual_sales_num,\n });\n\n this.goods_data[index].sale_false_visible = false;\n this.getData();\n },\n showSetSaleNum(index) {\n this.virtual_sales_num = this.goods_data[index].virtualSalesNum;\n this.goods_data[index].sale_false_visible = true;\n },\n openAddGoods() {\n if (parseInt(this.$store.getters[\"MUser/enterpriseScope\"]) === 4) {\n this.$router.push(\"/goods/sale/AddGoodsOneStore\");\n } else {\n this.$router.push(\"/goods/sale/AddGoods\");\n }\n },\n tabChange() {\n switch (this.activeName) {\n case \"all\":\n this.inSales = 1;\n this.inStock = 0;\n break;\n case \"GoodsSale\":\n this.inSales = 2;\n this.inStock = 0;\n break;\n case \"SoldOut\":\n this.inSales = 3;\n this.inStock = 4;\n break;\n case \"InWarehouse\":\n this.inSales = 4;\n this.inStock = 5;\n break;\n }\n this.pageChange(1);\n },\n // 用于可展开表格与树形表格,切换某一行的展开状态,如果使用了第二个参数,则是设置这一行展开与否(expanded 为 true 则展开)\n async showSpec({ row }) {\n return new Promise(async (resolve) => {\n const index = this.goods_data.findIndex((item) => item.id === row.id);\n if (!this.goods_data[index].goods_sku_list.length) {\n const { data } = await getGoodsInfo(row.id);\n if (data.specType === 2) {\n this.$nextTick(() => {\n this.goods_data[index].goods_sku_list = data.specMultiple.map(\n (item) => {\n const specValueName = item.specGroup\n .map((itemS) => {\n return itemS.specValueName;\n })\n .join(\";\");\n return {\n ...item,\n specValueName: specValueName,\n };\n }\n );\n });\n } else if (data.specType === 1) {\n this.$nextTick(() => {\n this.goods_data[index].goods_sku_list = data.specMultiple.map(\n (item) => {\n return {\n ...item,\n specValueName: \"\",\n };\n }\n );\n });\n }\n }\n resolve();\n });\n // this.goods_data = target\n },\n toggleRowExpansion(index) {\n this.$refs.goodsTable.toggleRowExpand(this.goods_data[index]);\n },\n delBrand() {\n this.form.brand = \"\";\n this.brandId = \"\";\n this.pageChange(1);\n },\n delShop() {\n this.form.shop = \"\";\n this.shopId = \"\";\n this.pageChange(1);\n },\n // 批量选择\n selectionChange({ records }) {\n this.checkedAll = this.$refs.goodsTable.isAllCheckboxChecked();\n this.isIndeterminate = this.$refs.goodsTable.isAllCheckboxChecked();\n this.choose_data = records;\n },\n // 编辑完成回调\n editsubData() {\n this.getData();\n },\n // 调整价格 编辑查看\n openPriceModel(row) {\n if (parseInt(this.$store.getters[\"MUser/enterpriseScope\"]) === 5) {\n // this.is_price = true;\n // this.goods_name = row.title;\n // this.price_goods_detail = row;\n this.$router.push(`/goods/sale/EditGoods/${row.id}`);\n } else {\n this.$router.push(`/goods/sale/EditGoodsOneStore/${row.id}`);\n }\n },\n\n // 批量上下架\n async BatchUnloading(enableStatus) {\n let title =\n enableStatus === 4\n ? \"确定要批量下架这些商品吗?\"\n : \"确定要批量上架这些商品吗?\";\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n this.$confirm(title, \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n const idData = this.choose_data.map((item) => {\n return item.id;\n });\n const data = await BatchUnloading({\n id: idData,\n enableStatus: enableStatus,\n });\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.getData();\n });\n },\n // 批量删除\n async deleteBatchUnloading(deleteStatus) {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n this.$confirm(\"确定要批量删除这些商品吗\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n const idData = this.choose_data.map((item) => {\n return item.id;\n });\n const data = await BatchUnloading({\n id: idData,\n deleteStatus: deleteStatus,\n });\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.getData();\n });\n },\n // 获取列表\n async getAllGoods(exports) {\n let params = {\n page: this.page,\n pageSize: this.pageSize,\n ifMerchant: this.ifMerchant,\n merchantId: this.merchantId,\n };\n if (this.inSales) {\n params.inSales = this.inSales;\n }\n if (this.inStock) {\n params.inStock = this.inStock;\n }\n if (exports) {\n const data = await exportGetAllGoods({\n ...params,\n export: 1,\n });\n } else {\n const data = await getAllGoods(params);\n this.goods_data = data.data.map((item) => {\n return {\n ...item,\n sale_false_visible: false,\n goods_sku_list: [],\n address: item.shopName,\n sort_flag: false,\n };\n });\n this.total = data.pageTotal;\n }\n },\n async getAllGoodsList(exports) {\n let params = {\n page: this.page,\n pageSize: this.pageSize,\n keywordType: this.inSales,\n keyword: this.keyword,\n categoryPath: this.form.categoryPath.join(\",\"),\n brandId: this.brandId,\n enableStatus: this.enableStatus,\n shopId: this.shopId,\n };\n if (exports) {\n const data = await exportGetAllGoodsList({\n ...params,\n export: 1,\n });\n } else {\n const data = await getAllGoodsList(params);\n this.goods_data = data.data.map((item) => {\n return {\n ...item,\n sale_false_visible: false,\n goods_sku_list: [],\n address: item.shopName,\n sort_flag: false,\n };\n });\n this.total = data.pageTotal;\n }\n },\n // 搜索商品 searchGood\n // async searchGood(exports) {\n // if (this.activeName !== \"all\") {\n // this.enableStatus = \"\";\n // }\n // let params = {\n // keyword: this.keyword,\n // brandId: this.brandId,\n // categoryPath: this.form.categoryPath.join(\",\"),\n // enableStatus: this.enableStatus,\n // shopId: this.shopId,\n // page: this.page,\n // pageSize: this.pageSize,\n // };\n // if (this.inSales) {\n // params.inSales = this.inSales;\n // }\n // if (this.inStock) {\n // params.inStock = this.inStock;\n // }\n // if (exports) {\n // const data = await exportSearchGood({\n // ...params,\n // export: 1,\n // });\n // } else {\n // const data = await searchGood(params);\n //\n // this.goods_data = data.data.map((item) => {\n // return {\n // ...item,\n // sale_false_visible: false,\n // goods_sku_list: [],\n // };\n // });\n // this.total = data.pageTotal;\n // }\n // },\n // 判断当前使用方法为列表接口还是搜索引擎接口 获取列表数据\n getData(exports) {\n if (this.activeName !== \"all\") {\n this.enableStatus = \"\";\n }\n // 搜索参数规整\n const obj = {\n keyword: this.keyword,\n brandId: this.brandId,\n categoryPath: this.form.categoryPath.join(\",\"),\n enableStatus: this.enableStatus,\n shopId: this.shopId,\n };\n const isKey = this.$_common.isSerch(obj);\n if (isKey) {\n this.searchGood(exports);\n } else {\n this.getAllGoods(exports);\n }\n },\n // 分类搜索\n goodsChane(val) {\n this.pageChange(1);\n },\n // 品牌搜索\n brandConfirm(row) {\n this.form.brand = row[0].title;\n this.brandId = row[0].id;\n this.pageChange(1);\n },\n //转移品牌\n transferBrandConfirm(row) {\n this.set_form.brandName = row[0].title;\n this.set_form.brandId = row[0].id;\n },\n // 商铺搜索\n shopConfirm(val, row) {\n this.shopId = row[0].id;\n this.form.shop = row[0].name;\n this.pageChange(1);\n },\n // 删除商品\n async delData(id) {\n this.$confirm(\"确定要删除该条商品吗?\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n const data = await delGoods(id);\n\n this.$message({\n type: \"success\",\n message: \"删除成功!\",\n });\n this.getData();\n });\n },\n // 删除商品\n async setTop(id) {\n this.$confirm(\"是否要将该商品置顶?\", \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n const data = await setTop(id);\n\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.getData();\n });\n },\n // 商品上下架\n async changeGoodsStatus(val, row) {\n try {\n const data = await GoodsUpdateEnableStatus({\n id: row.id,\n enableStatus: val,\n });\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n } catch (e) {\n this.getData();\n }\n },\n // 切页\n pageChange(val) {\n this.page = val;\n this.getAllGoodsList();\n },\n // 每页数据大小改变\n sizeChange(val) {\n this.pageSize = val;\n this.pageChange(1);\n },\n checkAllChange() {\n this.$refs.goodsTable.setAllCheckboxRow(this.checkedAll);\n this.isIndeterminate = this.$refs.goodsTable.isAllCheckboxChecked();\n this.choose_data = this.$refs.goodsTable.getCheckboxRecords();\n },\n // 打开批量设置弹窗\n openSet(tit, row) {\n this.is_set = true;\n this.set_tit = tit;\n if (row) {\n this.choose_data = [row];\n }\n },\n // 批量提交\n moreSubData() {\n this.checkedAll = false;\n this.isIndeterminate = false;\n if (this.set_tit === \"转移分类\") {\n this.updateCategory();\n }\n if (this.set_tit === \"设置品牌\") {\n this.setBrand();\n }\n if (this.set_tit === \"虚拟销量\") {\n this.setSalesNumBatch();\n }\n if (this.set_tit === \"物流设置\") {\n this.batchGoodsExpress();\n }\n },\n // 批量设置运费\n async batchGoodsExpress() {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n const idData = this.choose_data.map((item) => {\n return item.id;\n });\n this.more_sub_btn = true;\n try {\n const data = await batchGoodsExpress({\n expressType: this.set_form.expressType,\n ruleId: this.set_form.ruleId,\n expressFee: this.set_form.expressFee,\n ids: idData,\n });\n this.more_sub_btn = false;\n\n this.is_set = false;\n this.$message.success(\"操作成功\");\n this.getData();\n } catch {\n this.more_sub_btn = false;\n }\n },\n // 设置虚拟销量\n async setSalesNumBatch() {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n if (!this.sale_num_form.minVal) {\n this.$message.warning(\"虚拟销量区间最小值不能为0\");\n return;\n }\n if (!this.sale_num_form.maxVal) {\n this.$message.warning(\"虚拟销量区间最大值不能为0\");\n return;\n }\n if (this.sale_num_form.maxVal <= this.sale_num_form.minVal) {\n this.$message.warning(\"虚拟销量区间最大值必须大于最小值\");\n return;\n }\n this.more_sub_btn = true;\n try {\n const idData = this.choose_data.map((item) => {\n return item.id;\n });\n const data = await setSalesNumBatch({\n ...this.sale_num_form,\n ids: idData,\n });\n this.more_sub_btn = false;\n\n this.is_set = false;\n this.$message.success(\"操作成功\");\n this.getData();\n } catch {\n this.more_sub_btn = false;\n }\n },\n // 设置品牌\n async setBrand() {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n if (!this.set_form.brandId) {\n this.$message.warning(\"请选择要操作的品牌\");\n return;\n }\n const idData = this.choose_data.map((item) => {\n return item.basicGoodsId;\n });\n this.more_sub_btn = true;\n try {\n const data = await setBrand({\n id: idData,\n brandId: this.set_form.brandId,\n });\n this.more_sub_btn = false;\n\n this.is_set = false;\n this.$message.success(\"操作成功\");\n this.getData();\n } catch {\n this.more_sub_btn = false;\n }\n },\n\n // 转移分类\n async updateCategory() {\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n if (!this.set_form.category) {\n this.$message.warning(\"请选择要转移的分类\");\n return;\n }\n this.more_sub_btn = true;\n try {\n const idData = this.choose_data.map((item) => {\n return item.basicGoodsId;\n });\n const data = await updateCategory({\n id: idData, // 要移动的基础商品id\n categoryId: this.set_form.category[\n this.set_form.category.length - 1\n ], // 移动至商品分类id\n categoryPath: this.set_form.category.join(\",\"), // 新的商品分类路径\n });\n this.more_sub_btn = false;\n this.is_set = false;\n this.$message.success(\"操作成功\");\n this.set_form.category = [];\n this.getData();\n } catch {\n this.more_sub_btn = false;\n }\n },\n change() {\n this.classifyFlag = this.checkList.some((item) => item === \"商品分类\");\n this.specificationFlag = this.checkList.some((item) => item === \"规格\");\n this.unitFlag = this.checkList.some((item) => item === \"基本单位\");\n this.inventoryFlag = this.checkList.some((item) => item === \"总库存\");\n this.virtualFlag = this.checkList.some((item) => item === \"虚拟销量\");\n this.trueFlag = this.checkList.some((item) => item === \"真实销量\");\n this.stateFlag = this.checkList.some((item) => item === \"当前状态\");\n this.shopFlag = this.checkList.some((item) => item === \"销售店铺\");\n this.timeFlag = this.checkList.some((item) => item === \"创建时间\");\n },\n batchSetDistribution(enableStatus) {\n let title =\n enableStatus === 4\n ? \"确定要批量禁用库存销售?\"\n : \"确定要批量启用这些商品为负库存销售吗?\";\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n this.$confirm(title, \"提示\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\",\n }).then(async () => {\n this.checkedAll = false;\n this.isIndeterminate = false;\n if (!this.choose_data.length) {\n this.$message.warning(\"请选择要操作的商品\");\n return;\n }\n const idData = this.choose_data.map((item) => {\n return item.id;\n });\n const data = await batchSetDistribution({\n ids: idData,\n isDistribution: enableStatus,\n });\n this.$message({\n type: \"success\",\n message: \"操作成功!\",\n });\n this.getData();\n });\n },\n showSort(index) {\n this.goods_data.forEach((item) => (item.sort_flag = false));\n this.member_sort = this.goods_data[index].sort;\n this.goods_data[index].sort_flag = true;\n },\n async setSort(index) {\n const { data } = await setSort({\n id: this.goods_data[index].id,\n sort: this.member_sort,\n });\n this.$message.success(\"修改成功\");\n this.goods_data[index].sort_flag = false;\n await this.getAllGoodsList();\n },\n },\n };\n</script>\n<style scoped lang=\"scss\">\n .sku-btn {\n width: 71px;\n height: 22px;\n line-height: 22px;\n background: #f5f5f5;\n border-radius: 4px;\n border: 1px solid #cad0d7;\n text-align: center;\n font-size: 12px;\n cursor: pointer;\n display: inline-block;\n }\n .goods-name-view {\n width: calc(100% - 76px);\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n margin-left: 10px;\n }\n .demo-table-expand {\n font-size: 0;\n }\n .demo-table-expand label {\n width: 90px;\n color: #99a9bf;\n }\n .demo-table-expand .el-form-item {\n margin-right: 0;\n margin-bottom: 0;\n width: 50%;\n }\n .custom-table-checkbox {\n .el-checkbox {\n display: block !important;\n margin: 0 05px 0;\n }\n }\n .virtualSalesNum-btn {\n width: 26px;\n text-align: center;\n line-height: 28px;\n height: 28px;\n vertical-align: middle;\n font-size: 12px;\n background: #f5f5f5;\n border: 1px solid #cad0d7;\n display: inline-block;\n cursor: pointer;\n border-left: 0;\n }\n .sku-ul {\n display: flex;\n flex-wrap: wrap;\n .sku-li {\n display: inline-block;\n margin-right: 10px;\n margin-bottom: 10px;\n border: 1px solid #ebeef5;\n padding: 10px;\n width: 294px;\n vertical-align: middle;\n .sku-img {\n width: 50px;\n margin-right: 8px;\n }\n .sku-info {\n line-height: 23px;\n color: #111111;\n .label {\n display: inline-block;\n width: 50px;\n color: #666666;\n text-align: right;\n }\n }\n }\n }\n</style>\n"]}]}
|