cd25e23c97546226dac3d2edab19db9c.json 27 KB

1
  1. {"remainingRequest":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\babel-loader\\lib\\index.js!D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\wnmp\\www\\vue\\seaBlueAdmin\\src\\component\\goods\\SelBaseGoods.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\src\\component\\goods\\SelBaseGoods.vue","mtime":1678954023475},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\babel.config.js","mtime":1681371897685},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1681371913603},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\babel-loader\\lib\\index.js","mtime":1681371912860},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1681371913603},{"path":"D:\\wnmp\\www\\vue\\seaBlueAdmin\\node_modules\\vue-loader\\lib\\index.js","mtime":1681371925849}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { getGoodsBasicInfoById, getAllGoodsBasic, searchBasic } from "@/api/goods";
export default {
  name: "SelBaseGoods",
  props: {
    isShow: {
      type: Boolean,
      default: false
    }
  },

  data() {
    return {
      keyword: "",
      choose_data: [],
      spec_check_list: [],
      goods_list: [],
      loading: false,
      total: 0,
      pre_page: 10,
      page: 1,
      pageLayout: "total, prev, pager, next"
    };
  },

  created() {
    this.getList();
  },

  methods: {
    // 全选选中切换
    checkAllSpecChange(val, tindex) {
      // console.log(this.goods_list[tindex])
      this.goods_list[tindex].spec_check_list.forEach(item => {
        item.check_unit_spec = val;
        item.spec_check = val ? item.children && item.children.length ? item.children.map(itemC => itemC.id) : [] : [];
      });
    },

    // 单位选择切换
    checkUnitSpecChange(val, index, tindex) {
      const goodsList = this.$_common.deepClone(this.goods_list);
      const target = goodsList[tindex].spec_check_list;
      target[index].spec_check = val ? target[index].children && target[index].children.length ? target[index].children.map(item => item.id) : [] : [];
      target[index].is_spec_indeterminate = false;
      goodsList[tindex].check_all_spec = target.every(item => item.check_unit_spec);
      this.goods_list = goodsList;
      this.$refs.goodsTable.toggleRowSelection(this.goods_list[tindex], true);
    },

    // 属性单位切换
    specCheckChange(val, index, tindex) {
      const goodsList = this.$_common.deepClone(this.goods_list);
      const target = goodsList[tindex].spec_check_list;
      let checkedCount = val.length;
      target[index].check_unit_spec = checkedCount === target[index].children.length;
      target[index].is_spec_indeterminate = checkedCount > 0 && checkedCount < target[index].children.length;
      goodsList[tindex].check_all_spec = target.every(item => item.check_unit_spec);
      this.goods_list = goodsList;
      this.$refs.goodsTable.toggleRowSelection(this.goods_list[tindex], true);
    },

    getList() {
      if (this.keyword) {
        this.searchBasic();
      } else {
        this.getAllGoodsBasic();
      }
    },

    async showSkuChange(id, index) {
      if (this.goods_list[index].spec_check_list) {
        return;
      }

      const {
        data
      } = await getGoodsBasicInfoById(id, {
        isAddGoods: 5
      });
      let specCheckList = [];

      if (data.specType === 2) {
        specCheckList = data.unitData.map(item => {
          return { ...item,
            check_all_spec: false,
            spec_check: [],
            children: data.specMultiple.filter(itemF => itemF.unitId === item.unitId).map(itemP => {
              return { ...itemP,
                specGropName: itemP.specGroup.map(itemS => {
                  return itemS.specValueName;
                }).join("_")
              };
            })
          };
        });
      } else {
        specCheckList = data.specMultiple.map(itemF => {
          return { ...itemF,
            check_all_spec: false,
            spec_check: []
          };
        });
      }

      this.goods_list[index].spec_check_list = specCheckList;
      this.goods_list[index].specMultiple = data.specMultiple; // this.goods_list[index].spec_check = []

      if (this.choose_data.findIndex(item => item.id === data.id) > -1) {
        this.$refs.goodsTable.toggleRowSelection(this.goods_list[index], false);
        setTimeout(() => {
          this.$refs.goodsTable.toggleRowSelection(this.goods_list[index], true);
        }, 10);
      } else {
        this.$refs.goodsTable.toggleRowSelection(this.goods_list[index], true);
      }
    },

    // 获取列表
    async getAllGoodsBasic() {
      const {
        data,
        pageTotal
      } = await getAllGoodsBasic({
        page: this.page,
        pageSize: this.pageSize
      });

      for (let i = 0; i < data.length; i++) {
        const isTrue = this.choose_data.find(itemF => {
          return itemF.id === data[i].id;
        });

        if (isTrue) {
          this.$nextTick(() => {
            data[i] = isTrue;
            this.$refs.goodsTable.toggleRowSelection(data[i], true);
          });
        }
      }

      this.goods_list = data;
      this.total = pageTotal;
    },

    // 搜索引擎 列表
    async searchBasic() {
      const {
        data,
        pageTotal
      } = await searchBasic({
        keyword: this.keyword,
        page: this.page,
        pageSize: this.pageSize
      });

      for (let i = 0; i < data.length; i++) {
        const isTrue = this.choose_data.find(itemF => {
          return itemF.id === data[i].id;
        });

        if (isTrue) {
          this.$nextTick(() => {
            this.$refs.goodsTable.toggleRowSelection(data[i], true);
          });
        }
      }

      this.goods_list = data;
      this.total = pageTotal;
    },

    pageChange(page) {
      this.page = page;
      this.getList();
    },

    sizeChange(size) {
      this.pre_page = size;
      this.pageChange(1);
    },

    selectionChange(val) {
      if (!this.choose_data.length) {
        this.choose_data = val;
      } else {
        this.choose_data = this.$_common.unique(this.choose_data.concat(val), ["id"]);
      }
    },

    // 关闭弹窗
    cancel() {
      this.$emit("cancel");
    },

    // 关闭弹窗
    confirm() {
      let isReturn = true;

      for (let i = 0; i < this.choose_data.length; i++) {
        let item = this.choose_data[i];

        if (!item.spec_check_list) {
          this.$message.warning("【" + item.title + "】未选择规格");
          isReturn = false;
          break;
        }

        if (item.specType === 2) {
          let specCheck = [];
          item.spec_check_list.forEach(itemS => {
            if (itemS.spec_check && itemS.spec_check.length) {
              specCheck.push(itemS.spec_check.join(","));
            }
          });

          if (specCheck.length) {
            item.spec_check = specCheck.join(",").split(",").map(itemD => {
              return parseInt(itemD);
            });
          } else {
            item.spec_check = [];
          }

          item.skuD = item.spec_check.map(itemD => {
            let spec = {};

            for (let i in item.spec_check_list) {
              let itemS = item.spec_check_list[i];
              const specD = itemS.children && itemS.children.length ? itemS.children.find(itemC => itemC.id === itemD) : "";

              if (specD) {
                spec = specD;
                break;
              }
            }

            return {
              skuId: itemD,
              spec: spec
            };
          });
        } else {
          item.skuD = item.spec_check_list.filter(itemS => itemS.check_unit_spec).map(itemM => {
            return {
              skuId: itemM.id,
              spec: itemM
            };
          });
        }
      }

      if (!isReturn) {
        return;
      }

      this.cancel();
      this.$emit("confirm", this.choose_data);
    },

    selGoods(row) {
      this.cancel();
      this.$emit("confirm", [row]);
    }

  }
};"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyHA,SACAA,qBADA,EAEAC,gBAFA,EAGAC,WAHA,QAIA,aAJA;AAKA;EACAC,oBADA;EAEAC;IACAC;MACAC,aADA;MAEAC;IAFA;EADA,CAFA;;EAQAC;IACA;MACAC,WADA;MAEAC,eAFA;MAGAC,mBAHA;MAIAC,cAJA;MAKAC,cALA;MAMAC,QANA;MAOAC,YAPA;MAQAC,OARA;MASAC;IATA;EAWA,CApBA;;EAqBAC;IACA;EACA,CAvBA;;EAwBAC;IACA;IACAC;MACA;MACA;QACAC;QACAA,wBACAA,wCACAA,oCADA,GAEA,EAHA,GAIA,EAJA;MAKA,CAPA;IAQA,CAZA;;IAaA;IACAC;MACA;MACA;MACAC,iCACAA,0DACAA,2CADA,GAEA,EAHA,GAIA,EAJA;MAKAA;MACAC,gDACAH,4BADA;MAGA;MACA;IACA,CA5BA;;IA6BA;IACAI;MACA;MACA;MACA;MACAF,gCACAG,8CADA;MAEAH,sCACAG,gEADA;MAEAF,gDACAH,4BADA;MAGA;MACA;IACA,CA3CA;;IA4CAM;MACA;QACA;MACA,CAFA,MAEA;QACA;MACA;IACA,CAlDA;;IAmDA;MACA;QACA;MACA;;MACA;QAAAnB;MAAA;QACAoB;MADA;MAIA;;MACA;QACAC;UACA,SACA,OADA;YAEAC,qBAFA;YAGAC,cAHA;YAIAC,4BACAC,MADA,CACAC,qCADA,EAEAC,GAFA,CAEAC;cACA,SACA,QADA;gBAEAC,8BACAF,GADA,CACAG;kBACA;gBACA,CAHA,EAIAC,IAJA,CAIA,GAJA;cAFA;YAQA,CAXA;UAJA;QAiBA,CAlBA;MAmBA,CApBA,MAoBA;QACAV;UACA,SACA,QADA;YAEAC,qBAFA;YAGAC;UAHA;QAKA,CANA;MAOA;;MACA;MACA,wDAvCA,CAwCA;;MACA;QACA,yCACA,sBADA,EAEA,KAFA;QAIAS;UACA,yCACA,sBADA,EAEA,IAFA;QAIA,CALA,EAKA,EALA;MAMA,CAXA,MAWA;QACA,yCACA,sBADA,EAEA,IAFA;MAIA;IACA,CA7GA;;IA8GA;IACA;MACA;QAAAhC;QAAAiC;MAAA;QACAzB,eADA;QAEA0B;MAFA;;MAKA;QACA;UACA;QACA,CAFA;;QAGA;UACA;YACAlC;YACA;UACA,CAHA;QAIA;MACA;;MACA;MACA;IACA,CAlIA;;IAmIA;IACA;MACA;QAAAA;QAAAiC;MAAA;QACAhC,qBADA;QAEAO,eAFA;QAGA0B;MAHA;;MAMA;QACA;UACA;QACA,CAFA;;QAGA;UACA;YACA;UACA,CAFA;QAGA;MACA;;MACA;MACA;IACA,CAvJA;;IAwJAC;MACA;MACA;IACA,CA3JA;;IA4JAC;MACA;MACA;IACA,CA/JA;;IAgKAC;MACA;QACA;MACA,CAFA,MAEA;QACA,wCACA,4BADA,EAEA,MAFA;MAIA;IACA,CAzKA;;IA0KA;IACAC;MACA;IACA,CA7KA;;IA8KA;IACAC;MACA;;MACA;QACA;;QACA;UACA;UACAC;UACA;QACA;;QACA;UACA;UACA3B;YACA;cACA4B;YACA;UACA,CAJA;;UAKA;YACA5B,4BACAkB,IADA,CACA,GADA,EAEAW,KAFA,CAEA,GAFA,EAGAf,GAHA,CAGAgB;cACA;YACA,CALA;UAMA,CAPA,MAOA;YACA9B;UACA;;UAEAA;YACA;;YACA;cACA;cACA,cACAiB,0CACAA,gDADA,GAEA,EAHA;;cAIA;gBACAc;gBACA;cACA;YACA;;YACA;cACAC,YADA;cAEAD;YAFA;UAIA,CAjBA;QAkBA,CApCA,MAoCA;UACA/B,iCACAY,MADA,CACAK,8BADA,EAEAH,GAFA,CAEAmB;YACA;cACAD,eADA;cAEAD;YAFA;UAIA,CAPA;QAQA;MACA;;MACA;QACA;MACA;;MACA;MACA;IACA,CA5OA;;IA6OAG;MACA;MACA;IACA;;EAhPA;AAxBA","names":["getGoodsBasicInfoById","getAllGoodsBasic","searchBasic","name","props","isShow","type","default","data","keyword","choose_data","spec_check_list","goods_list","loading","total","pre_page","page","pageLayout","created","methods","checkAllSpecChange","item","checkUnitSpecChange","target","goodsList","specCheckChange","checkedCount","getList","isAddGoods","specCheckList","check_all_spec","spec_check","children","filter","itemF","map","itemP","specGropName","itemS","join","setTimeout","pageTotal","pageSize","pageChange","sizeChange","selectionChange","cancel","confirm","isReturn","specCheck","split","itemD","spec","skuId","itemM","selGoods"],"sourceRoot":"src/component/goods","sources":["SelBaseGoods.vue"],"sourcesContent":["<!--选择店铺商品-->\n<template>\n <div>\n <el-dialog\n :close-on-press-escape=\"false\"\n :close-on-click-modal=\"false\"\n title=\"商品列表\"\n :visible=\"isShow\"\n width=\"60%\"\n @close=\"cancel\"\n >\n <div class=\"clearfix\" style=\"padding-bottom: 10px\">\n <el-input\n v-model=\"keyword\"\n style=\"width: 240px\"\n size=\"mini\"\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 </div>\n <el-table\n ref=\"goodsTable\"\n border\n height=\"500\"\n :data=\"goods_list\"\n size=\"small\"\n @selection-change=\"selectionChange\"\n @row-dblclick=\"selGoods\"\n >\n <el-table-column type=\"selection\" width=\"55\"></el-table-column>\n <el-table-column prop=\"title\" label=\"商品名称\"></el-table-column>\n <el-table-column prop=\"code\" label=\"商品编码\"></el-table-column>\n <el-table-column\n prop=\"categoryTitle\"\n label=\"商品分类\"\n ></el-table-column>\n <el-table-column prop=\"categoryTitle\" label=\"规格\">\n <template slot-scope=\"scope\">\n <el-popover\n placement=\"right\"\n width=\"300\"\n trigger=\"click\"\n @show=\"showSkuChange(scope.row.id, scope.$index)\"\n >\n <div class=\"sku-view\">\n <el-checkbox\n v-model=\"scope.row.check_all_spec\"\n @change=\"checkAllSpecChange($event, scope.$index)\"\n >\n 全选\n </el-checkbox>\n <div\n v-for=\"(item, index) in scope.row.spec_check_list\"\n :key=\"index\"\n style=\"padding: 10px; border: 1px solid #eee; margin: 10px 0\"\n >\n <el-checkbox\n v-model=\"item.check_unit_spec\"\n :indeterminate=\"item.is_spec_indeterminate\"\n @change=\"checkUnitSpecChange($event, index, scope.$index)\"\n >\n {{ item.unitName }}\n </el-checkbox>\n <div v-if=\"item.children\" style=\"padding: 10px 15px 0\">\n <el-checkbox-group\n v-model=\"item.spec_check\"\n @change=\"specCheckChange($event, index, scope.$index)\"\n >\n <el-checkbox\n v-for=\"(itemC, indexC) in item.children\"\n :key=\"indexC\"\n style=\"padding-bottom: 5px\"\n :label=\"itemC.id\"\n >\n <span style=\"font-weight: 400\">\n {{ itemC.specGropName }}\n </span>\n </el-checkbox>\n </el-checkbox-group>\n </div>\n </div>\n </div>\n <el-button slot=\"reference\" size=\"mini\">选择规格</el-button>\n </el-popover>\n </template>\n </el-table-column>\n <el-table-column label=\"选择商品\">\n <template slot-scope=\"scope\">\n <el-button\n size=\"mini\"\n icon=\"el-icon-check\"\n @click=\"selGoods(scope.row)\"\n ></el-button>\n </template>\n </el-table-column>\n </el-table>\n <FooterPage\n :page-size=\"pre_page\"\n :total-page.sync=\"total\"\n :current-page.sync=\"page\"\n @pageChange=\"pageChange\"\n @sizeChange=\"sizeChange\"\n ></FooterPage>\n <div\n slot=\"footer\"\n style=\"width: 100%; border-top: 1px solid #eee; padding-top: 10px\"\n >\n <el-button size=\"small\" type=\"primary\" @click=\"confirm\">确定</el-button>\n <el-button size=\"small\" @click=\"cancel\">取消</el-button>\n </div>\n </el-dialog>\n </div>\n</template>\n\n<script>\n import {\n getGoodsBasicInfoById,\n getAllGoodsBasic,\n searchBasic,\n } from \"@/api/goods\";\n export default {\n name: \"SelBaseGoods\",\n props: {\n isShow: {\n type: Boolean,\n default: false,\n },\n },\n data() {\n return {\n keyword: \"\",\n choose_data: [],\n spec_check_list: [],\n goods_list: [],\n loading: false,\n total: 0,\n pre_page: 10,\n page: 1,\n pageLayout: \"total, prev, pager, next\",\n };\n },\n created() {\n this.getList();\n },\n methods: {\n // 全选选中切换\n checkAllSpecChange(val, tindex) {\n // console.log(this.goods_list[tindex])\n this.goods_list[tindex].spec_check_list.forEach((item) => {\n item.check_unit_spec = val;\n item.spec_check = val\n ? item.children && item.children.length\n ? item.children.map((itemC) => itemC.id)\n : []\n : [];\n });\n },\n // 单位选择切换\n checkUnitSpecChange(val, index, tindex) {\n const goodsList = this.$_common.deepClone(this.goods_list);\n const target = goodsList[tindex].spec_check_list;\n target[index].spec_check = val\n ? target[index].children && target[index].children.length\n ? target[index].children.map((item) => item.id)\n : []\n : [];\n target[index].is_spec_indeterminate = false;\n goodsList[tindex].check_all_spec = target.every(\n (item) => item.check_unit_spec\n );\n this.goods_list = goodsList;\n this.$refs.goodsTable.toggleRowSelection(this.goods_list[tindex], true);\n },\n // 属性单位切换\n specCheckChange(val, index, tindex) {\n const goodsList = this.$_common.deepClone(this.goods_list);\n const target = goodsList[tindex].spec_check_list;\n let checkedCount = val.length;\n target[index].check_unit_spec =\n checkedCount === target[index].children.length;\n target[index].is_spec_indeterminate =\n checkedCount > 0 && checkedCount < target[index].children.length;\n goodsList[tindex].check_all_spec = target.every(\n (item) => item.check_unit_spec\n );\n this.goods_list = goodsList;\n this.$refs.goodsTable.toggleRowSelection(this.goods_list[tindex], true);\n },\n getList() {\n if (this.keyword) {\n this.searchBasic();\n } else {\n this.getAllGoodsBasic();\n }\n },\n async showSkuChange(id, index) {\n if (this.goods_list[index].spec_check_list) {\n return;\n }\n const { data } = await getGoodsBasicInfoById(id, {\n isAddGoods: 5,\n });\n\n let specCheckList = [];\n if (data.specType === 2) {\n specCheckList = data.unitData.map((item) => {\n return {\n ...item,\n check_all_spec: false,\n spec_check: [],\n children: data.specMultiple\n .filter((itemF) => itemF.unitId === item.unitId)\n .map((itemP) => {\n return {\n ...itemP,\n specGropName: itemP.specGroup\n .map((itemS) => {\n return itemS.specValueName;\n })\n .join(\"_\"),\n };\n }),\n };\n });\n } else {\n specCheckList = data.specMultiple.map((itemF) => {\n return {\n ...itemF,\n check_all_spec: false,\n spec_check: [],\n };\n });\n }\n this.goods_list[index].spec_check_list = specCheckList;\n this.goods_list[index].specMultiple = data.specMultiple;\n // this.goods_list[index].spec_check = []\n if (this.choose_data.findIndex((item) => item.id === data.id) > -1) {\n this.$refs.goodsTable.toggleRowSelection(\n this.goods_list[index],\n false\n );\n setTimeout(() => {\n this.$refs.goodsTable.toggleRowSelection(\n this.goods_list[index],\n true\n );\n }, 10);\n } else {\n this.$refs.goodsTable.toggleRowSelection(\n this.goods_list[index],\n true\n );\n }\n },\n // 获取列表\n async getAllGoodsBasic() {\n const { data, pageTotal } = await getAllGoodsBasic({\n page: this.page,\n pageSize: this.pageSize,\n });\n\n for (let i = 0; i < data.length; i++) {\n const isTrue = this.choose_data.find((itemF) => {\n return itemF.id === data[i].id;\n });\n if (isTrue) {\n this.$nextTick(() => {\n data[i] = isTrue;\n this.$refs.goodsTable.toggleRowSelection(data[i], true);\n });\n }\n }\n this.goods_list = data;\n this.total = pageTotal;\n },\n // 搜索引擎 列表\n async searchBasic() {\n const { data, pageTotal } = await searchBasic({\n keyword: this.keyword,\n page: this.page,\n pageSize: this.pageSize,\n });\n\n for (let i = 0; i < data.length; i++) {\n const isTrue = this.choose_data.find((itemF) => {\n return itemF.id === data[i].id;\n });\n if (isTrue) {\n this.$nextTick(() => {\n this.$refs.goodsTable.toggleRowSelection(data[i], true);\n });\n }\n }\n this.goods_list = data;\n this.total = pageTotal;\n },\n pageChange(page) {\n this.page = page;\n this.getList();\n },\n sizeChange(size) {\n this.pre_page = size;\n this.pageChange(1);\n },\n selectionChange(val) {\n if (!this.choose_data.length) {\n this.choose_data = val;\n } else {\n this.choose_data = this.$_common.unique(\n this.choose_data.concat(val),\n [\"id\"]\n );\n }\n },\n // 关闭弹窗\n cancel() {\n this.$emit(\"cancel\");\n },\n // 关闭弹窗\n confirm() {\n let isReturn = true;\n for (let i = 0; i < this.choose_data.length; i++) {\n let item = this.choose_data[i];\n if (!item.spec_check_list) {\n this.$message.warning(\"【\" + item.title + \"】未选择规格\");\n isReturn = false;\n break;\n }\n if (item.specType === 2) {\n let specCheck = [];\n item.spec_check_list.forEach((itemS) => {\n if (itemS.spec_check && itemS.spec_check.length) {\n specCheck.push(itemS.spec_check.join(\",\"));\n }\n });\n if (specCheck.length) {\n item.spec_check = specCheck\n .join(\",\")\n .split(\",\")\n .map((itemD) => {\n return parseInt(itemD);\n });\n } else {\n item.spec_check = [];\n }\n\n item.skuD = item.spec_check.map((itemD) => {\n let spec = {};\n for (let i in item.spec_check_list) {\n let itemS = item.spec_check_list[i];\n const specD =\n itemS.children && itemS.children.length\n ? itemS.children.find((itemC) => itemC.id === itemD)\n : \"\";\n if (specD) {\n spec = specD;\n break;\n }\n }\n return {\n skuId: itemD,\n spec: spec,\n };\n });\n } else {\n item.skuD = item.spec_check_list\n .filter((itemS) => itemS.check_unit_spec)\n .map((itemM) => {\n return {\n skuId: itemM.id,\n spec: itemM,\n };\n });\n }\n }\n if (!isReturn) {\n return;\n }\n this.cancel();\n this.$emit(\"confirm\", this.choose_data);\n },\n selGoods(row) {\n this.cancel();\n this.$emit(\"confirm\", [row]);\n },\n },\n };\n</script>\n\n<style scoped></style>\n"]}]}