e200287d4b47f44c5e086d9c8fa90cde.json 31 KB

1
  1. {"remainingRequest":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\component\\common\\ConditionSelGoods.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\src\\component\\common\\ConditionSelGoods.vue","mtime":1655374732000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\babel.config.js","mtime":1655374732000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\千鸟\\千鸟云商前端源代码\\源点计划\\jindouyunNewFront\\node_modules\\vue-loader\\lib\\index.js","mtime":1655715099000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { getGoodsByCondition, getGoodsInfo, getGoodsBasicInfoById } from "@/api/goods";
import SaleGoodsSel from "@/component/goods/SaleGoodsSel.vue";
export default {
  name: "ConditionSelGoods",
  components: {
    SaleGoodsSel
  },
  model: {
    prop: "value",
    event: "change"
  },
  props: {
    // 商户id
    merchantId: {
      type: [Number, String],
      default: ""
    },
    type: {
      type: Boolean,
      // false 查询商品。true 查询商品资料
      default: false
    },
    // 当前使用组件的页面是否是采购页面
    isPurchase: {
      type: Boolean,
      default: false
    },
    // 当前使用组件的页面是否可以选择主单位
    isEqMaster: {
      type: Boolean,
      default: true
    },
    isAddGoods: {
      type: [Number, String],
      default: 5
    },
    userCenterId: {
      type: [Number, String],
      default: ""
    },
    shopId: {
      type: [Number, String, Array],
      default: ""
    },
    enableStatus: {
      type: [Number, String],
      default: ""
    },
    value: {
      type: String,
      default: ""
    },
    disabled: {
      type: Boolean,
      default: false
    },
    specCheck: {
      type: Array,
      default: () => {
        return [];
      }
    },
    // 5 只显示基本单位 4:主辅助单位都显示
    isRevealSku: {
      type: [Number, String],
      default: 4
    },
    // 5 只显示基本单位 4:主辅助单位都显示
    size: {
      type: String,
      default: "small"
    }
  },

  data() {
    return {
      goodsName: "",
      goods_options: [],
      show_goods: false,
      select_loading: false,
      // 弹窗
      spec_model: false,
      check_all_spec: false,
      is_spec_indeterminate: false,
      spec_check: [],
      spec_check_list: [],
      now_goods_data: {}
    };
  },

  watch: {
    specCheck(Nval) {
      this.spec_check = Nval;
    }

  },

  mounted() {
    console.log(this.isPurchase);
  },

  methods: {
    openGoodsModel() {
      if (this.disabled) return;
      this.show_goods = true;
    },

    async remoteMethod(keyword) {
      if (!keyword) {
        this.goods_options = [];
        return;
      }

      let params = {
        condition: keyword,
        type: this.type,
        enableStatus: this.enableStatus
      };

      if (this.shopId) {
        params.shopId = Array.isArray(this.shopId) ? this.shopId : [this.shopId];
      }

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

      this.select_loading = true;
      const {
        data
      } = await getGoodsByCondition(params);
      this.select_loading = false;

      if (JSON.stringify(data) === "{}") {
        this.goods_options = [];
      } else {
        this.goods_options = data;
      }
    },

    goodsVisibleChange(val) {
      this.$emit("goodsVisibleChange", val);
    },

    selectSelGoods(val) {
      this.$emit("selectSelGoods", val);
      this.check_all_spec = false;

      if (!this.type) {
        this.getGoodsInfo(val);
      } else {
        this.getGoodsBasicInfoById(val);
      }
    },

    // 商品详情
    async getGoodsInfo(val) {
      // userCenterId: this.userCenterId
      const {
        data
      } = await getGoodsInfo(val, {
        userCenterId: this.userCenterId
      });
      this.now_goods_data = data;
      this.spec_model = true;

      if (data.specType === 2) {
        this.spec_check_list = data.unitData.map(item => {
          return { ...item,
            is_spec_indeterminate: false,
            check_unit_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 {
        this.spec_check_list = data.specMultiple.map(itemF => {
          return { ...itemF,
            is_spec_indeterminate: false,
            check_unit_spec: false,
            spec_check: []
          };
        });
      }

      if (this.spec_check_list.length === 1 && !this.spec_check_list[0].children) {
        this.spec_model = false;
        this.$emit("specSelConfirm", {
          goodsD: [{
            skuId: this.spec_check_list[0].id,
            spec: this.spec_check_list[0]
          }],
          spec_check_list: this.spec_check_list,
          now_goods_data: this.now_goods_data
        });
      } else if (this.spec_check_list.length === 1 && this.spec_check_list[0].children.length === 1) {
        this.spec_model = false;
        this.$emit("specSelConfirm", {
          goodsD: [{
            skuId: this.spec_check_list[0].children[0].id,
            spec: this.spec_check_list[0].children[0]
          }],
          spec_check_list: this.spec_check_list,
          now_goods_data: this.now_goods_data
        });
      }
    },

    // 商品基础资料详情
    async getGoodsBasicInfoById(val) {
      const {
        data
      } = await getGoodsBasicInfoById(val, {
        isAddGoods: this.isAddGoods
      });
      this.now_goods_data = data;
      this.spec_model = true;

      if (data.specType === 2) {
        this.spec_check_list = data.unitData.map(item => {
          return { ...item,
            is_spec_indeterminate: false,
            check_unit_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 {
        this.spec_check_list = data.specMultiple.map(itemF => {
          return { ...itemF,
            is_spec_indeterminate: false,
            check_unit_spec: false,
            spec_check: []
          };
        });
      } // 抄码商品 不允许采购辅助单位


      if (this.isPurchase && data.isEq === 5) {
        this.spec_check_list = this.spec_check_list.filter(item => item.isMaster === 5);
      }
    },

    specSelConfirm() {
      let specCheck = [];
      let goodsD = [];

      if (this.now_goods_data.specType === 2) {
        this.spec_check_list.forEach(item => {
          if (item.spec_check && item.spec_check.length) {
            specCheck.push(item.spec_check.join(","));
          }
        });
        this.spec_check = specCheck.join(",").split(",").map(item => {
          return parseInt(item);
        });
        goodsD = this.spec_check.map(item => {
          let spec = {};

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

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

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

      this.$emit("specSelConfirm", {
        goodsD: goodsD,
        spec_check_list: this.spec_check_list,
        now_goods_data: this.now_goods_data
      });
      this.spec_model = false;
    },

    specCheckChange(val, index) {
      const target = this.$_common.deepClone(this.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;
      this.spec_check_list = target;
      this.check_all_spec = this.spec_check_list.every(item => item.check_unit_spec);
    },

    checkAllSpecChange(val) {
      this.spec_check_list.forEach(item => {
        item.check_unit_spec = val;
        item.is_spec_indeterminate = false;
        item.spec_check = val ? item.children && item.children.length ? item.children.map(itemC => itemC.id) : [] : [];
      });
      this.is_spec_indeterminate = false;
    },

    checkUnitSpecChange(val, index) {
      const target = this.$_common.deepClone(this.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;
      this.spec_check_list = target;
      this.check_all_spec = this.spec_check_list.every(item => item.check_unit_spec);
    },

    selGoods(val) {
      console.log(val);
      this.$emit("selGoods", val);
    }

  }
};"},{"version":3,"mappings":"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MAH;UACA;;UACA;YACA;YACA,cACAF,0CACAA,+CADA,GAEA,EAHA;;YAIA;cACAI;cACA;YACA;UACA;;UACA;YACAD,WADA;YAEAC;UAFA;QAIA,CAjBA;MAkBA,CA9BA,MA8BA;QACAF,8BACAP,MADA,CACAU,4BADA,EAEAR,GAFA,CAEAW;UACA;YACAL,eADA;YAEAC;UAFA;QAIA,CAPA;MAQA;;MACA;QACAF,cADA;QAEApB,qCAFA;QAGAC;MAHA;MAKA;IACA,CAnNA;;IAoNA0B;MACA;MACA;MACAC,gCACAC,8CADA;MAEAD,sCACAC,gEADA;MAEA;MACA,iDACAN,4BADA;IAGA,CA/NA;;IAgOAO;MACA;QACAP;QACAA;QACAA,wBACAA,wCACAA,oCADA,GAEA,EAHA,GAIA,EAJA;MAKA,CARA;MASA;IACA,CA3OA;;IA4OAQ;MACA;MACAH,iCACAA,0DACAA,2CADA,GAEA,EAHA,GAIA,EAJA;MAKAA;MACA;MACA,iDACAL,4BADA;IAGA,CAxPA;;IAyPAS;MACA5B;MACA;IACA;;EA5PA;AA9FA","names":["getGoodsByCondition","getGoodsInfo","getGoodsBasicInfoById","name","components","SaleGoodsSel","model","prop","event","props","merchantId","type","default","isPurchase","isEqMaster","isAddGoods","userCenterId","shopId","enableStatus","value","disabled","specCheck","isRevealSku","size","data","goodsName","goods_options","show_goods","select_loading","spec_model","check_all_spec","is_spec_indeterminate","spec_check","spec_check_list","now_goods_data","watch","mounted","console","methods","openGoodsModel","condition","params","goodsVisibleChange","selectSelGoods","check_unit_spec","children","filter","itemF","map","itemP","specGropName","itemS","join","goodsD","skuId","spec","item","specSelConfirm","split","itemM","specCheckChange","target","checkedCount","checkAllSpecChange","checkUnitSpecChange","selGoods"],"sourceRoot":"src/component/common","sources":["ConditionSelGoods.vue"],"sourcesContent":["<!--拼音筛选-->\n<template>\n <div class=\"out-div\">\n <el-select\n :size=\"size\"\n style=\"width: 100%\"\n :value=\"value\"\n filterable\n remote\n reserve-keyword\n :disabled=\"disabled\"\n placeholder=\"请输入关键词首字母\"\n :remote-method=\"remoteMethod\"\n :loading=\"select_loading\"\n @change=\"selectSelGoods\"\n @visible-change=\"goodsVisibleChange\"\n >\n <el-option\n v-for=\"(item, index) in goods_options\"\n :key=\"index\"\n :label=\"item.title\"\n :value=\"item.id\"\n ></el-option>\n </el-select>\n <span class=\"el-icon-search sel-icon\" @click=\"openGoodsModel\"></span>\n <el-dialog\n :close-on-press-escape=\"false\"\n :close-on-click-modal=\"false\"\n style=\"text-align: left\"\n title=\"选择属性\"\n :visible.sync=\"spec_model\"\n width=\"40%\"\n >\n <!-- :indeterminate=\"is_spec_indeterminate\"-->\n <el-checkbox v-model=\"check_all_spec\" @change=\"checkAllSpecChange\">\n 全选\n </el-checkbox>\n <div\n v-for=\"(item, index) in 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)\"\n >\n {{ item.unitName }}\n </el-checkbox>\n <div style=\"padding: 10px 15px 0\">\n <el-checkbox-group\n v-model=\"item.spec_check\"\n @change=\"specCheckChange($event, 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\">{{ itemC.specGropName }}</span>\n </el-checkbox>\n </el-checkbox-group>\n </div>\n </div>\n <span slot=\"footer\" class=\"dialog-footer\">\n <el-button @click=\"spec_model = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"specSelConfirm\">确 定</el-button>\n </span>\n </el-dialog>\n <SaleGoodsSel\n v-if=\"show_goods\"\n :merchant-id=\"merchantId\"\n :base-goods=\"type\"\n :is-show=\"show_goods\"\n :user-center-id=\"userCenterId\"\n :is-reveal-sku=\"4\"\n :is-eq-master=\"isEqMaster\"\n :is-purchase=\"isPurchase\"\n :shop-id=\"shopId\"\n @cancel=\"show_goods = false\"\n @confirm=\"selGoods\"\n ></SaleGoodsSel>\n </div>\n</template>\n\n<script>\n import {\n getGoodsByCondition,\n getGoodsInfo,\n getGoodsBasicInfoById,\n } from \"@/api/goods\";\n import SaleGoodsSel from \"@/component/goods/SaleGoodsSel.vue\";\n export default {\n name: \"ConditionSelGoods\",\n components: {\n SaleGoodsSel,\n },\n model: {\n prop: \"value\",\n event: \"change\",\n },\n props: {\n // 商户id\n merchantId: {\n type: [Number, String],\n default: \"\",\n },\n type: {\n type: Boolean,\n // false 查询商品。true 查询商品资料\n default: false,\n },\n // 当前使用组件的页面是否是采购页面\n isPurchase: {\n type: Boolean,\n default: false,\n },\n // 当前使用组件的页面是否可以选择主单位\n isEqMaster: {\n type: Boolean,\n default: true,\n },\n isAddGoods: {\n type: [Number, String],\n default: 5,\n },\n userCenterId: {\n type: [Number, String],\n default: \"\",\n },\n shopId: {\n type: [Number, String, Array],\n default: \"\",\n },\n enableStatus: {\n type: [Number, String],\n default: \"\",\n },\n value: {\n type: String,\n default: \"\",\n },\n disabled: {\n type: Boolean,\n default: false,\n },\n specCheck: {\n type: Array,\n default: () => {\n return [];\n },\n },\n // 5 只显示基本单位 4:主辅助单位都显示\n isRevealSku: {\n type: [Number, String],\n default: 4,\n },\n // 5 只显示基本单位 4:主辅助单位都显示\n size: {\n type: String,\n default: \"small\",\n },\n },\n data() {\n return {\n goodsName: \"\",\n goods_options: [],\n show_goods: false,\n select_loading: false,\n // 弹窗\n spec_model: false,\n check_all_spec: false,\n is_spec_indeterminate: false,\n spec_check: [],\n spec_check_list: [],\n now_goods_data: {},\n };\n },\n watch: {\n specCheck(Nval) {\n this.spec_check = Nval;\n },\n },\n mounted() {\n console.log(this.isPurchase);\n },\n methods: {\n openGoodsModel() {\n if (this.disabled) return;\n this.show_goods = true;\n },\n async remoteMethod(keyword) {\n if (!keyword) {\n this.goods_options = [];\n return;\n }\n let params = {\n condition: keyword,\n type: this.type,\n enableStatus: this.enableStatus,\n };\n if (this.shopId) {\n params.shopId = Array.isArray(this.shopId)\n ? this.shopId\n : [this.shopId];\n }\n if (this.merchantId) {\n params.merchantId = this.merchantId;\n }\n this.select_loading = true;\n const { data } = await getGoodsByCondition(params);\n this.select_loading = false;\n if (JSON.stringify(data) === \"{}\") {\n this.goods_options = [];\n } else {\n this.goods_options = data;\n }\n },\n goodsVisibleChange(val) {\n this.$emit(\"goodsVisibleChange\", val);\n },\n selectSelGoods(val) {\n this.$emit(\"selectSelGoods\", val);\n this.check_all_spec = false;\n if (!this.type) {\n this.getGoodsInfo(val);\n } else {\n this.getGoodsBasicInfoById(val);\n }\n },\n // 商品详情\n async getGoodsInfo(val) {\n // userCenterId: this.userCenterId\n const { data } = await getGoodsInfo(val, {\n userCenterId: this.userCenterId,\n });\n\n this.now_goods_data = data;\n this.spec_model = true;\n if (data.specType === 2) {\n this.spec_check_list = data.unitData.map((item) => {\n return {\n ...item,\n is_spec_indeterminate: false,\n check_unit_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 this.spec_check_list = data.specMultiple.map((itemF) => {\n return {\n ...itemF,\n is_spec_indeterminate: false,\n check_unit_spec: false,\n spec_check: [],\n };\n });\n }\n if (\n this.spec_check_list.length === 1 &&\n !this.spec_check_list[0].children\n ) {\n this.spec_model = false;\n this.$emit(\"specSelConfirm\", {\n goodsD: [\n {\n skuId: this.spec_check_list[0].id,\n spec: this.spec_check_list[0],\n },\n ],\n spec_check_list: this.spec_check_list,\n now_goods_data: this.now_goods_data,\n });\n } else if (\n this.spec_check_list.length === 1 &&\n this.spec_check_list[0].children.length === 1\n ) {\n this.spec_model = false;\n this.$emit(\"specSelConfirm\", {\n goodsD: [\n {\n skuId: this.spec_check_list[0].children[0].id,\n spec: this.spec_check_list[0].children[0],\n },\n ],\n spec_check_list: this.spec_check_list,\n now_goods_data: this.now_goods_data,\n });\n }\n },\n // 商品基础资料详情\n async getGoodsBasicInfoById(val) {\n const { data } = await getGoodsBasicInfoById(val, {\n isAddGoods: this.isAddGoods,\n });\n\n this.now_goods_data = data;\n this.spec_model = true;\n if (data.specType === 2) {\n this.spec_check_list = data.unitData.map((item) => {\n return {\n ...item,\n is_spec_indeterminate: false,\n check_unit_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 this.spec_check_list = data.specMultiple.map((itemF) => {\n return {\n ...itemF,\n is_spec_indeterminate: false,\n check_unit_spec: false,\n spec_check: [],\n };\n });\n }\n // 抄码商品 不允许采购辅助单位\n if (this.isPurchase && data.isEq === 5) {\n this.spec_check_list = this.spec_check_list.filter(\n (item) => item.isMaster === 5\n );\n }\n },\n specSelConfirm() {\n let specCheck = [];\n let goodsD = [];\n if (this.now_goods_data.specType === 2) {\n this.spec_check_list.forEach((item) => {\n if (item.spec_check && item.spec_check.length) {\n specCheck.push(item.spec_check.join(\",\"));\n }\n });\n this.spec_check = specCheck\n .join(\",\")\n .split(\",\")\n .map((item) => {\n return parseInt(item);\n });\n goodsD = this.spec_check.map((item) => {\n let spec = {};\n for (let i in this.spec_check_list) {\n let itemS = this.spec_check_list[i];\n const specD =\n itemS.children && itemS.children.length\n ? itemS.children.find((itemC) => itemC.id === item)\n : \"\";\n if (specD) {\n spec = specD;\n break;\n }\n }\n return {\n skuId: item,\n spec: spec,\n };\n });\n } else {\n goodsD = this.spec_check_list\n .filter((item) => item.check_unit_spec)\n .map((itemM) => {\n return {\n skuId: itemM.id,\n spec: itemM,\n };\n });\n }\n this.$emit(\"specSelConfirm\", {\n goodsD: goodsD,\n spec_check_list: this.spec_check_list,\n now_goods_data: this.now_goods_data,\n });\n this.spec_model = false;\n },\n specCheckChange(val, index) {\n const target = this.$_common.deepClone(this.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 this.spec_check_list = target;\n this.check_all_spec = this.spec_check_list.every(\n (item) => item.check_unit_spec\n );\n },\n checkAllSpecChange(val) {\n this.spec_check_list.forEach((item) => {\n item.check_unit_spec = val;\n item.is_spec_indeterminate = false;\n item.spec_check = val\n ? item.children && item.children.length\n ? item.children.map((itemC) => itemC.id)\n : []\n : [];\n });\n this.is_spec_indeterminate = false;\n },\n checkUnitSpecChange(val, index) {\n const target = this.$_common.deepClone(this.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 this.spec_check_list = target;\n this.check_all_spec = this.spec_check_list.every(\n (item) => item.check_unit_spec\n );\n },\n selGoods(val) {\n console.log(val);\n this.$emit(\"selGoods\", val);\n },\n },\n };\n</script>\n\n<style scoped lang=\"scss\">\n .out-div {\n position: relative;\n .sel-icon {\n position: absolute;\n display: block;\n right: 5px;\n top: 50%;\n width: 25px;\n text-align: center;\n transform: translateY(-50%);\n color: #c0c4cc;\n font-size: 13px;\n cursor: pointer;\n }\n }\n</style>\n"]}]}