| 1 |
- {"remainingRequest":"E:\\item\\newItem\\admin\\node_modules\\babel-loader\\lib\\index.js!E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\item\\newItem\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\item\\newItem\\admin\\node_modules\\iview-loader\\index.js??ref--0-2!E:\\item\\newItem\\admin\\src\\pages\\marketing\\lottery\\create.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\newItem\\admin\\src\\pages\\marketing\\lottery\\create.vue","mtime":1677828270210},{"path":"E:\\item\\newItem\\admin\\babel.config.js","mtime":1677828270071},{"path":"E:\\item\\newItem\\admin\\.babelrc","mtime":1677828270070},{"path":"E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\iview-loader\\index.js","mtime":1570440814000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _toConsumableArray from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js";
import _asyncToGenerator from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js";
import _objectSpread from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/objectSpread2.js";
import _defineProperty from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/defineProperty.js";
import "regenerator-runtime/runtime.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/es.regexp.to-string.js";
import "core-js/modules/web.dom-collections.for-each.js";
import "core-js/modules/es.array.splice.js";
import "core-js/modules/es.array.join.js";
import "core-js/modules/es.number.to-fixed.js";
import "core-js/modules/es.array.concat.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { mapState } from 'vuex';
import goodsList from '@/components/goodsList/index';
import uploadPictures from '@/components/uploadPictures';
import userLabel from '@/components/userLabel';
import addGoods from './addGoods';
import { lotteryNewDetailApi, lotteryDetailApi, lotteryCreateApi, lotteryEditApi } from '@/api/lottery'; //详情 创建 编辑

import { lotteryFrom } from './formRule/lotteryFrom';
import { labelListApi as _labelListApi } from '@/api/product';
import { levelListApi as _levelListApi } from '@/api/user';
import WangEditor from '@/components/wangEditor/index.vue';
import { formatDate as _formatDate } from '@/utils/validate';
import { formatRichText } from '@/utils/editorImg';
export default {
  name: 'lotteryCreate',
  components: {
    goodsList: goodsList,
    uploadPictures: uploadPictures,
    addGoods: addGoods,
    WangEditor: WangEditor,
    userLabel: userLabel
  },
  data: function data() {
    return _defineProperty({
      selectDataLabel: [],
      selectLabelShow: false,
      content: '',
      tabs: [{
        name: '积分抽取',
        type: '1'
      }, {
        name: '订单支付',
        type: '3'
      }, {
        name: '订单评价',
        type: '4'
      }],
      title: '添加商品',
      loading: false,
      userLabelList: [],
      //用户标签列表
      userLevelListApi: [],
      //用户等级列表
      submitOpen: false,
      spinShow: false,
      addGoodsModel: false,
      editData: {},
      myConfig: {
        autoHeightEnabled: false,
        // 编辑器不自动被内容撑高
        initialFrameHeight: 500,
        // 初始容器高度
        initialFrameWidth: '100%',
        // 初始容器宽度
        UEDITOR_HOME_URL: '/admin/UEditor/',
        serverUrl: ''
      },
      isChoice: '单选',
      current: 0,
      modalPic: false,
      modal_loading: false,
      images: [],
      templateList: [{
        id: 0,
        name: '非付费会员'
      }, {
        id: 1,
        name: '付费会员'
      }],
      columns: [{
        title: '序号',
        type: 'index',
        width: 60,
        align: 'center'
      }, {
        title: '图片',
        slot: 'image',
        align: 'center',
        minWidth: 120
      }, {
        title: '名称',
        align: 'center',
        minWidth: 80,
        key: 'name'
      }, {
        title: '奖品',
        slot: 'type',
        align: 'center',
        minWidth: 80
      }, {
        title: '提示语',
        key: 'prompt',
        align: 'center',
        minWidth: 80
      }, {
        title: '数量',
        slot: 'total',
        align: 'center',
        minWidth: 80
      }, {
        title: '奖品权重',
        slot: 'chance',
        align: 'center',
        minWidth: 80
      }, {
        title: '奖品概率',
        key: 'probability',
        align: 'center',
        minWidth: 80
      }, {
        title: '操作',
        slot: 'setting',
        align: 'center',
        minWidth: 80
      }],
      specsData: [{
        type: 1,
        //类型 1：未中奖 2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 10,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }, {
        type: 1,
        //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
        name: '',
        //活动名称
        num: 0,
        //奖品数量
        image: '',
        //奖品图片
        chance: 0,
        //中奖权重
        total: 0,
        //奖品数量
        prompt: '' //提示语

      }],
      formValidate: {
        images: [],
        name: '',
        //活动名称
        desc: '',
        //活动描述
        image: '',
        //活动背景图
        factor: '1',
        //抽奖类型：1:积分 2:余额 3：下单支付成功 4:订单评价',5:关注
        factor_num: 1,
        //获取一次抽奖的条件数量
        attends_user: 1,
        //参与用户1：所有  2：部分
        user_level: [],
        //参与用户等级
        user_label: [],
        //参与用户标签
        is_svip: '-1',
        //参与用户是否付费会员
        prize_num: 0,
        //奖品数量
        period: [],
        //活动时间
        prize: [],
        //奖品数组
        lottery_num_term: 1,
        //抽奖次数限制：1：每天2：每人
        lottery_num: 1,
        //抽奖次数
        spread_num: 1,
        //关注推广获取抽奖次数
        is_all_record: 0,
        //中奖纪录展示
        is_personal_record: 0,
        //个人中奖纪录展示
        is_content: 0,
        //活动规格是否展示
        content: '',
        //富文本内容
        status: 0 //状态

      },
      ruleValidate: lotteryFrom,
      currentid: '',
      picTit: '',
      tableIndex: 0,
      copy: 0,
      editIndex: null,
      id: ''
    }, "copy", 0);
  },
  filters: {
    typeName: function typeName(type) {
      if (type == 1) {
        return '未中奖';
      } else if (type == 2) {
        return '积分';
      } else if (type == 3) {
        return '余额';
      } else if (type == 4) {
        return '红包';
      } else if (type == 5) {
        return '优惠券';
      } else if (type == 6) {
        return '商品';
      }
    }
  },
  computed: _objectSpread(_objectSpread({}, mapState('admin/layout', ['isMobile'])), {}, {
    labelWidth: function labelWidth() {
      return this.isMobile ? undefined : 135;
    },
    labelPosition: function labelPosition() {
      return this.isMobile ? 'top' : 'right';
    }
  }),
  mounted: function mounted() {
    this.getInfo();
    this.labelListApi();
    this.levelListApi();
  },
  methods: {
    changeUsers: function changeUsers(e) {
      if (e == 1) {
        this.formValidate.user_level = []; //参与用户等级

        this.formValidate.user_label = []; //参与用户标签

        this.formValidate.is_svip = '-1'; //参与用户是否付费会员

        this.selectDataLabel = []; //参与用户是否付费会员
      }
    },
    // 标签弹窗关闭
    labelClose: function labelClose() {
      this.selectLabelShow = false;
    },
    activeSelectData: function activeSelectData(data) {
      this.selectLabelShow = false;
      this.selectDataLabel = data;
    },
    onClickTab: function onClickTab(e) {
      this.formValidate.factor = e;
      this.getInfo(e);
    },
    getEditorContent: function getEditorContent(data) {
      this.content = data;
    },
    //用户标签列表
    labelListApi: function labelListApi() {
      var _this = this;

      _labelListApi().then(function (res) {
        _this.userLabelList = res.data.list;
      });
    },
    //用户等级列表
    levelListApi: function levelListApi() {
      var _this2 = this;

      _levelListApi().then(function (res) {
        _this2.userLevelListApi = res.data.list;
      });
    },
    // 具体日期
    onchangeTime: function onchangeTime(e) {
      var _this3 = this;

      this.$nextTick(function () {
        _this3.$set(_this3.formValidate, 'period', e);
      });
    },
    // 详情
    getInfo: function getInfo(e) {
      var _this4 = this;

      this.spinShow = true;
      lotteryNewDetailApi(this.formValidate.factor).then(function (res) {
        if (res.status == 200 && !Array.isArray(res.data)) {
          _this4.formValidate = res.data;
          _this4.formValidate.user_level = res.data.user_level || [];
          _this4.selectDataLabel = res.data.user_label || [];
          _this4.formValidate.is_svip = res.data.is_svip;
          _this4.content = res.data.is_content ? res.data.content : '';
          _this4.formValidate.factor = res.data.factor.toString();
          _this4.formValidate.period = [_this4.formatDate(res.data.start_time) || '', _this4.formatDate(res.data.end_time) || ''];
          _this4.specsData = res.data.prize;

          _this4.getProbability();
        } else {
          _this4.formValidate = {
            images: [],
            name: '',
            //活动名称
            desc: '',
            //活动描述
            image: '',
            //活动背景图
            factor: e.toString(),
            //抽奖类型：1:积分 2:余额 3：下单支付成功 4:订单评价',5:关注
            factor_num: 1,
            //获取一次抽奖的条件数量
            attends_user: 1,
            //参与用户1：所有  2：部分
            user_level: [],
            //参与用户等级
            user_label: [],
            //参与用户标签
            is_svip: '-1',
            //参与用户是否付费会员
            prize_num: 0,
            //奖品数量
            period: [],
            //活动时间
            prize: [],
            //奖品数组
            lottery_num_term: 1,
            //抽奖次数限制：1：每天2：每人
            lottery_num: 1,
            //抽奖次数
            spread_num: 1,
            //关注推广获取抽奖次数
            is_all_record: 0,
            //中奖纪录展示
            is_personal_record: 0,
            //个人中奖纪录展示
            is_content: 0,
            //活动规格是否展示
            content: '',
            //富文本内容
            status: 0 //状态

          };
          _this4.specsData = [{
            type: 1,
            //类型 1：未中奖 2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 10,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }, {
            type: 1,
            //类型 1：未中奖2：积分  3:余额  4：红包 5:优惠券 6：站内商品
            name: '',
            //活动名称
            num: 0,
            //奖品数量
            image: '',
            //奖品图片
            chance: 0,
            //中奖权重
            total: 0,
            //奖品数量
            prompt: '' //提示语

          }];
        }
      }).catch(function (err) {});
      this.spinShow = false;
    },
    // 下一步
    next: function next(name) {
      var _this5 = this;

      this.formValidate.prize = this.specsData;

      if (this.formValidate.is_content) {
        this.formValidate.content = formatRichText(this.content);
      }

      if (this.formValidate.attends_user == 2) {
        if (this.selectDataLabel.length) {
          var activeIds = [];
          this.selectDataLabel.forEach(function (item) {
            activeIds.push(item.id);
          });
          this.formValidate.user_label = activeIds;
        }
      }

      if (this.submitOpen) return false;
      this.$refs[name].validate(function (valid) {
        if (valid) {
          _this5.submitOpen = true;

          if (_this5.formValidate.id && !_this5.copy) {
            lotteryEditApi(_this5.formValidate.id, _this5.formValidate).then( /*#__PURE__*/function () {
              var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(res) {
                return regeneratorRuntime.wrap(function _callee$(_context) {
                  while (1) {
                    switch (_context.prev = _context.next) {
                      case 0:
                        _this5.$Message.success(res.msg);

                        _this5.submitOpen = false; // setTimeout(() => {
                        //   this.submitOpen = false;
                        //   this.$router.push({
                        //     path: "/admin/marketing/lottery/recording_list",
                        //   });
                        // }, 500);

                      case 2:
                      case "end":
                        return _context.stop();
                    }
                  }
                }, _callee);
              }));

              return function (_x) {
                return _ref2.apply(this, arguments);
              };
            }()).catch(function (res) {
              _this5.submitOpen = false;

              _this5.$Message.error(res.msg);
            });
          } else {
            lotteryCreateApi(_this5.formValidate).then( /*#__PURE__*/function () {
              var _ref3 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(res) {
                return regeneratorRuntime.wrap(function _callee2$(_context2) {
                  while (1) {
                    switch (_context2.prev = _context2.next) {
                      case 0:
                        _this5.submitOpen = false;

                        _this5.$Message.success(res.msg); // setTimeout(() => {
                        //   this.submitOpen = false;
                        //   this.$router.push({
                        //     path: "/admin/marketing/lottery/recording_list",
                        //   });
                        // }, 500);


                      case 2:
                      case "end":
                        return _context2.stop();
                    }
                  }
                }, _callee2);
              }));

              return function (_x2) {
                return _ref3.apply(this, arguments);
              };
            }()).catch(function (res) {
              _this5.submitOpen = false;

              _this5.$Message.error(res.msg);
            });
          }
        } else {
          return false;
        }
      });
    },
    // 上一步
    step: function step() {
      this.current--;
    },
    // 点击商品图
    modalPicTap: function modalPicTap(tit, picTit, index) {
      this.modalPic = true;
      this.isChoice = tit === 'dan' ? '单选' : '多选';
      this.picTit = picTit || '';
      this.tableIndex = index;
    },
    // 获取单张图片信息
    getPic: function getPic(pc) {
      switch (this.picTit) {
        case 'danFrom':
          this.formValidate.image = pc.att_dir;
          break;

        default:
          this.specsData[this.tableIndex].image = pc.att_dir;
      }

      this.modalPic = false;
    },
    handleRemove: function handleRemove() {
      this.formValidate.image = '';
    },
    // 表单验证
    validate: function validate(prop, status, error) {
      if (status === false) {
        this.$Message.error(error);
        return false;
      } else {
        return true;
      }
    },
    //新增商品
    addGoods: function addGoods() {
      this.addGoodsModel = true;
      this.title = '添加商品';
      this.editData = {};
    },
    //编辑商品
    editGoods: function editGoods(index) {
      this.addGoodsModel = true;
      this.title = '添加奖品';
      this.editData = this.specsData[index];
      this.editIndex = index;
    },
    //删除商品
    deleteGoods: function deleteGoods(index) {
      this.specsData.splice(index, 1);
    },
    //获取数组中某个字段之和
    sumArr: function sumArr(arr, name) {
      var arrData = [];

      for (var i = 0; i < arr.length; i++) {
        arrData.push(arr[i][name]);
      }

      return eval(arrData.join('+'));
    },
    addGoodsData: function addGoodsData(data) {
      this.editIndex != null ? this.$set(this.specsData, [this.editIndex], data) : this.specsData.length < 8 ? this.specsData.push(data) : this.$Message.warning('最多添加8个奖品');
      this.getProbability();
      this.addGoodsModel = false;
      this.editIndex = null;
    },
    changeChance: function changeChance(data, index) {
      var _this6 = this;

      this.$set(this.specsData[index], 'chance', data);
      this.$nextTick(function (e) {
        _this6.getProbability();
      });
    },
    changeTotal: function changeTotal(data, index) {
      this.$set(this.specsData[index], 'total', data);
    },
    //获取商品中奖概率
    getProbability: function getProbability() {
      var sum = 0;
      sum = this.sumArr(this.specsData, 'chance');

      for (var j = 0; j < this.specsData.length; j++) {
        if (sum == 0) {
          this.$set(this.specsData[j], 'probability', '0%');
        } else {
          this.$set(this.specsData[j], 'probability', (this.specsData[j].chance / sum * 100).toFixed(2) + '%');
        }
      }
    },
    //修改排序
    onDragDrop: function onDragDrop(a, b) {
      var _this$specsData;

      (_this$specsData = this.specsData).splice.apply(_this$specsData, [b, 1].concat(_toConsumableArray(this.specsData.splice(a, 1, this.specsData[b]))));
    },
    //时间格式转换
    formatDate: function formatDate(time) {
      if (time) {
        var date = new Date(time * 1000);
        return _formatDate(date, 'yyyy-MM-dd hh:mm');
      } else {
        return '';
      }
    }
  }
};"},{"version":3,"mappings":"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","names":["name","components","goodsList","uploadPictures","addGoods","WangEditor","userLabel","data","selectDataLabel","selectLabelShow","content","tabs","type","title","loading","userLabelList","userLevelListApi","submitOpen","spinShow","addGoodsModel","editData","myConfig","autoHeightEnabled","initialFrameHeight","initialFrameWidth","UEDITOR_HOME_URL","serverUrl","isChoice","current","modalPic","modal_loading","images","templateList","id","columns","width","align","slot","minWidth","key","specsData","num","image","chance","total","prompt","formValidate","desc","factor","factor_num","attends_user","user_level","user_label","is_svip","prize_num","period","prize","lottery_num_term","lottery_num","spread_num","is_all_record","is_personal_record","is_content","status","ruleValidate","currentid","picTit","tableIndex","copy","editIndex","filters","typeName","computed","mapState","labelWidth","labelPosition","mounted","methods","changeUsers","e","labelClose","activeSelectData","onClickTab","getEditorContent","labelListApi","levelListApi","onchangeTime","getInfo","lotteryNewDetailApi","then","catch","next","activeIds","lotteryEditApi","lotteryCreateApi","step","modalPicTap","tit","index","getPic","pc","handleRemove","validate","prop","error","editGoods","deleteGoods","sumArr","arr","arrData","addGoodsData","changeChance","changeTotal","getProbability","sum","onDragDrop","a","b","formatDate","time"],"sourceRoot":"src/pages/marketing/lottery","sources":["create.vue"],"sourcesContent":["<template>\r\n <div>\r\n <div class=\"i-layout-page-header header_top\">\r\n <div class=\"i-layout-page-header fl_header\">\r\n <!-- <router-link :to=\"{ path: '/admin/marketing/lottery/index' }\"\r\n ><Button icon=\"ios-arrow-back\" size=\"small\" type=\"text\"\r\n >返回</Button\r\n ></router-link\r\n > -->\r\n <!-- <Divider type=\"vertical\" /> -->\r\n <span\r\n class=\"ivu-page-header-title mr20\"\r\n style=\"padding: 0\"\r\n v-text=\"$route.params.id ? '编辑抽奖信息' : '添加抽奖信息'\"\r\n ></span>\r\n </div>\r\n </div>\r\n\r\n <Card :bordered=\"false\" dis-hover class=\"ivu-mt\">\r\n <div>\r\n <Tabs v-model=\"formValidate.factor\" @on-click=\"onClickTab\">\r\n <TabPane v-for=\"(item, index) in tabs\" :label=\"item.name\" :name=\"item.type\" :key=\"index\" />\r\n </Tabs>\r\n </div>\r\n <Row type=\"flex\" class=\"mt30 acea-row row-middle row-center\">\r\n <Col span=\"23\">\r\n <Form\r\n class=\"form mt30\"\r\n ref=\"formValidate\"\r\n :rules=\"ruleValidate\"\r\n :model=\"formValidate\"\r\n @on-validate=\"validate\"\r\n :label-width=\"labelWidth\"\r\n :label-position=\"labelPosition\"\r\n @submit.native.prevent\r\n >\r\n <Row type=\"flex\">\r\n <Col span=\"24\">\r\n <FormItem label=\"活动名称:\" prop=\"name\" label-for=\"name\">\r\n <Input class=\"perW30\" placeholder=\"请输入活动名称\" element-id=\"name\" v-model=\"formValidate.name\" />\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\">\r\n <FormItem label=\"活动时间:\">\r\n <div class=\"acea-row row-middle\">\r\n <DatePicker\r\n :editable=\"false\"\r\n type=\"datetimerange\"\r\n format=\"yyyy-MM-dd HH:mm\"\r\n placeholder=\"请选择活动时间\"\r\n @on-change=\"onchangeTime\"\r\n class=\"perW30\"\r\n v-model=\"formValidate.period\"\r\n ></DatePicker>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\">\r\n <FormItem label=\"参与用户:\" prop=\"attends_user\" label-for=\"attends_user\">\r\n <RadioGroup element-id=\"attends_user\" v-model=\"formValidate.attends_user\" @on-change=\"changeUsers\">\r\n <Radio :label=\"1\" class=\"radio\">全部用户</Radio>\r\n <Radio :label=\"2\">部分用户</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.attends_user == 2\">\r\n <FormItem label=\"\" :prop=\"formValidate.attends_user == 2 ? 'user_level' : ''\">\r\n <div class=\"acea-row row-middle\">\r\n <Select multiple v-model=\"formValidate.user_level\" class=\"perW30\" placeholder=\"请选择用户等级\">\r\n <Option v-for=\"item in userLevelListApi\" :value=\"item.id\" :key=\"item.id\">{{ item.name }}</Option>\r\n </Select>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.attends_user == 2\">\r\n <FormItem label=\"\" :prop=\"formValidate.attends_user == 2 ? 'is_svip' : ''\">\r\n <div class=\"acea-row row-middle\">\r\n <Select v-model=\"formValidate.is_svip\" class=\"perW30\" clearable placeholder=\"请选择是否是付费会员\">\r\n <Option v-for=\"item in templateList\" :value=\"item.id\" :key=\"item.id\">{{ item.name }}</Option>\r\n </Select>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.attends_user == 2\">\r\n <FormItem label=\"\" :prop=\"formValidate.attends_user == 2 ? 'user_label' : ''\">\r\n <div class=\"acea-row row-middle\">\r\n <!-- <Select\r\n multiple\r\n v-model=\"formValidate.user_label\"\r\n class=\"perW30\"\r\n placeholder=\"请选择用户标签\"\r\n >\r\n <Option\r\n v-for=\"item in userLabelList\"\r\n :value=\"String(item.id)\"\r\n :key=\"item.id\"\r\n >{{ item.label_name }}</Option\r\n >\r\n </Select> -->\r\n <div class=\"labelInput acea-row row-between-wrapper\" @click=\"selectLabelShow = true\">\r\n <div class=\"\">\r\n <div v-if=\"selectDataLabel.length\">\r\n <Tag\r\n :closable=\"false\"\r\n v-for=\"(item, index) in selectDataLabel\"\r\n @on-close=\"closeLabel(item)\"\r\n :key=\"index\"\r\n >{{ item.label_name }}</Tag\r\n >\r\n </div>\r\n <span class=\"span\" v-else>选择用户标签</span>\r\n </div>\r\n <div class=\"ivu-icon ivu-icon-ios-arrow-down\"></div>\r\n </div>\r\n </div>\r\n <div class=\"ml100 grey\">三个条件都设置后,必须这些条件都满足的用户才能参加抽奖</div>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.factor == 5\">\r\n <FormItem\r\n label=\"抽奖次数:\"\r\n :prop=\"formValidate.factor == 5 ? 'lottery_num_term' : ''\"\r\n label-for=\"status\"\r\n >\r\n <RadioGroup element-id=\"lottery_num_term\" v-model=\"formValidate.lottery_num_term\">\r\n <Radio :label=\"1\" class=\"radio\">每天N次</Radio>\r\n <Radio :label=\"2\">每人N次</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.factor == 5\">\r\n <FormItem\r\n label=\"邀请新用户最多可获得抽奖\"\r\n :prop=\"formValidate.factor == 5 ? 'lottery_num' : ''\"\r\n label-for=\"lottery_num\"\r\n >\r\n <div class=\"acea-row row-middle\">\r\n <div class=\"mr10 grey\"></div>\r\n <InputNumber\r\n placeholder=\"\"\r\n element-id=\"lottery_num\"\r\n :min=\"1\"\r\n :precision=\"0\"\r\n v-model=\"formValidate.lottery_num\"\r\n class=\"perW20\"\r\n />\r\n <div class=\"ml10 grey\">次</div>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.factor == 5\">\r\n <FormItem\r\n label=\"邀请一位新用户关注公众号可获得抽奖\"\r\n :prop=\"formValidate.factor == 5 ? 'spread_num' : ''\"\r\n label-for=\"spread_num\"\r\n >\r\n <div class=\"acea-row row-middle\">\r\n <div class=\"mr10 grey\"></div>\r\n <InputNumber\r\n placeholder=\"\"\r\n element-id=\"spread_num\"\r\n :min=\"1\"\r\n :precision=\"0\"\r\n v-model=\"formValidate.spread_num\"\r\n class=\"perW20\"\r\n />\r\n <div class=\"ml10 grey\">次</div>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" v-if=\"formValidate.factor == 1 || formValidate.factor == 3 || formValidate.factor == 4\">\r\n <FormItem\r\n :label=\"formValidate.factor == 1 ? '抽奖消耗积分:' : '抽奖次数:'\"\r\n :prop=\"\r\n formValidate.factor == 1 || formValidate.factor == 3 || formValidate.factor == 4 ? 'factor_num' : ''\r\n \"\r\n label-for=\"factor_num\"\r\n >\r\n <div class=\"acea-row row-middle\">\r\n <div class=\"mr10 grey\"></div>\r\n <InputNumber\r\n placeholder=\"\"\r\n element-id=\"factor_num\"\r\n :min=\"1\"\r\n :precision=\"0\"\r\n v-model=\"formValidate.factor_num\"\r\n class=\"perW20\"\r\n />\r\n <div class=\"ml10 grey\" v-if=\"formValidate.factor !== 1\">次</div>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n </Row>\r\n <Row>\r\n <Col span=\"24\">\r\n <FormItem label=\"规格选择:\" prop=\"prize\">\r\n <Table :data=\"specsData\" :columns=\"columns\" border :draggable=\"true\" @on-drag-drop=\"onDragDrop\">\r\n <template slot-scope=\"{ row, index }\" slot=\"image\">\r\n <div class=\"acea-row row-middle row-center-wrapper\" @click=\"modalPicTap('dan', 'goods', index)\">\r\n <div class=\"pictrue pictrueTab\" v-if=\"row.image\">\r\n <img v-lazy=\"row.image\" />\r\n </div>\r\n <div class=\"upLoad pictrueTab acea-row row-center-wrapper\" v-else>\r\n <Icon type=\"ios-camera-outline\" size=\"21\" class=\"iconfonts\" />\r\n </div>\r\n </div>\r\n </template>\r\n <template slot-scope=\"{ row, index }\" slot=\"total\">\r\n <InputNumber\r\n v-model=\"row.total\"\r\n :max=\"99999\"\r\n :min=\"0\"\r\n :precision=\"0\"\r\n class=\"priceBox\"\r\n @on-change=\"\r\n (data) => {\r\n changeTotal(data, index);\r\n }\r\n \"\r\n ></InputNumber>\r\n </template>\r\n <template slot-scope=\"{ row, index }\" slot=\"chance\">\r\n <InputNumber\r\n v-model=\"row.chance\"\r\n :max=\"100\"\r\n :min=\"0\"\r\n :precision=\"0\"\r\n class=\"priceBox\"\r\n @on-change=\"\r\n (data) => {\r\n changeChance(data, index);\r\n }\r\n \"\r\n ></InputNumber>\r\n </template>\r\n <template slot-scope=\"{ row, index }\" slot=\"type\">\r\n <div>{{ row.type | typeName }}</div>\r\n </template>\r\n <template slot-scope=\"{ row, index }\" slot=\"setting\">\r\n <Button class=\"submission mr15\" @click=\"editGoods(index)\">编辑</Button>\r\n <!-- <Button\r\n v-if=\"row.type !== 1\"\r\n class=\"submission mr15\"\r\n @click=\"deleteGoods(index)\"\r\n >删除</Button\r\n > -->\r\n </template>\r\n </Table>\r\n <Button v-if=\"specsData.length < 8\" type=\"primary\" class=\"submission mr15 mt20\" @click=\"addGoods\"\r\n >添加商品</Button\r\n >\r\n </FormItem>\r\n <FormItem>\r\n <div class=\"pl60 grey\">\r\n 奖品必须设置为8个,列表中拖拽可调整奖品在九宫中的位置\r\n <Poptip placement=\"bottom\" width=\"380\">\r\n <a>查看位置示例图</a>\r\n <div class=\"api\" slot=\"content\">\r\n <img src=\"../../../assets/images/lotteryTest.png\" alt=\"\" />\r\n </div>\r\n </Poptip>\r\n </div>\r\n </FormItem>\r\n </Col>\r\n </Row>\r\n <div>\r\n <FormItem\r\n v-if=\"formValidate.factor != 3 && formValidate.factor != 4\"\r\n :prop=\"formValidate.factor != 3 && formValidate.factor != 4 ? 'image' : ''\"\r\n >\r\n <div class=\"custom-label\" slot=\"label\">\r\n <div>\r\n <div>活动背景图</div>\r\n <div>(750*750)</div>\r\n </div>\r\n <div>:</div>\r\n </div>\r\n <div class=\"acea-row\">\r\n <div class=\"pictrue\" v-if=\"formValidate.image\">\r\n <img v-lazy=\"formValidate.image\" />\r\n <Button shape=\"circle\" icon=\"md-close\" @click.native=\"handleRemove()\" class=\"btndel\"></Button>\r\n </div>\r\n <div v-else class=\"upLoad acea-row row-center-wrapper\" @click=\"modalPicTap('dan', 'danFrom')\">\r\n <Icon type=\"ios-camera-outline\" size=\"26\" class=\"iconfonts\" />\r\n </div>\r\n </div>\r\n </FormItem>\r\n <FormItem\r\n v-if=\"formValidate.factor != 3 && formValidate.factor != 4\"\r\n label=\"中奖名单:\"\r\n :prop=\"formValidate.factor != 3 && formValidate.factor != 4 ? 'is_all_record' : ''\"\r\n label-for=\"is_all_record\"\r\n >\r\n <RadioGroup element-id=\"is_all_record\" v-model=\"formValidate.is_all_record\">\r\n <Radio :label=\"0\">关闭</Radio>\r\n <Radio :label=\"1\" class=\"radio\">开启</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n <FormItem\r\n v-if=\"formValidate.factor != 3 && formValidate.factor != 4\"\r\n label=\"个人中奖记录:\"\r\n :prop=\"formValidate.factor != 3 && formValidate.factor != 4 ? 'is_personal_record' : ''\"\r\n label-for=\"is_personal_record\"\r\n >\r\n <RadioGroup element-id=\"is_personal_record\" v-model=\"formValidate.is_personal_record\">\r\n <Radio :label=\"0\">关闭</Radio>\r\n <Radio :label=\"1\" class=\"radio\">开启</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n <FormItem\r\n v-if=\"formValidate.factor != 3 && formValidate.factor != 4\"\r\n label=\"活动规则:\"\r\n prop=\"is_content\"\r\n label-for=\"is_content\"\r\n >\r\n <RadioGroup element-id=\"is_content\" v-model=\"formValidate.is_content\">\r\n <Radio :label=\"0\">关闭</Radio>\r\n <Radio :label=\"1\" class=\"radio\">开启</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n <FormItem\r\n label=\"\"\r\n :prop=\"\r\n formValidate.factor != 3 && formValidate.factor != 4 && formValidate.is_content == 1 ? 'content' : ''\r\n \"\r\n v-show=\"formValidate.factor != 3 && formValidate.factor != 4 && formValidate.is_content == 1\"\r\n >\r\n <WangEditor\r\n style=\"width: 90%\"\r\n :content=\"formValidate.content\"\r\n @editorContent=\"getEditorContent\"\r\n ></WangEditor>\r\n </FormItem>\r\n <FormItem label=\"活动状态:\" prop=\"status\" label-for=\"status\">\r\n <RadioGroup element-id=\"status\" v-model=\"formValidate.status\">\r\n <Radio :label=\"0\">关闭</Radio>\r\n <Radio :label=\"1\" class=\"radio\">开启</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n </div>\r\n <FormItem>\r\n <Button type=\"primary\" class=\"submission\" :loading=\"submitOpen\" @click=\"next('formValidate')\">\r\n <div v-if=\"!submitOpen\">提交</div>\r\n <div v-else>提交中</div>\r\n </Button>\r\n </FormItem>\r\n <Spin size=\"large\" fix v-if=\"spinShow\"></Spin>\r\n </Form>\r\n </Col>\r\n </Row>\r\n </Card>\r\n\r\n <!-- 上传图片-->\r\n <Modal\r\n v-model=\"modalPic\"\r\n width=\"950px\"\r\n scrollable\r\n footer-hide\r\n closable\r\n title=\"上传商品图\"\r\n :mask-closable=\"false\"\r\n :z-index=\"1\"\r\n >\r\n <uploadPictures :isChoice=\"isChoice\" @getPic=\"getPic\" v-if=\"modalPic\"></uploadPictures>\r\n </Modal>\r\n <!-- 上传图片-->\r\n <Modal\r\n v-model=\"addGoodsModel\"\r\n width=\"60%\"\r\n scrollable\r\n footer-hide\r\n closable\r\n :title=\"title\"\r\n :mask-closable=\"false\"\r\n :z-index=\"1\"\r\n >\r\n <addGoods v-if=\"addGoodsModel\" @addGoodsData=\"addGoodsData\" :editData=\"editData\"></addGoods>\r\n </Modal>\r\n <!-- 用户标签 -->\r\n <Modal\r\n v-model=\"selectLabelShow\"\r\n scrollable\r\n title=\"请选择用户标签\"\r\n :closable=\"false\"\r\n width=\"500\"\r\n :footer-hide=\"true\"\r\n :mask-closable=\"false\"\r\n >\r\n <userLabel\r\n v-if=\"selectLabelShow\"\r\n :uid=\"0\"\r\n ref=\"userLabel\"\r\n :only_get=\"true\"\r\n :selectDataLabel=\"selectDataLabel\"\r\n @activeData=\"activeSelectData\"\r\n @close=\"labelClose\"\r\n ></userLabel>\r\n </Modal>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport { mapState } from 'vuex';\r\nimport goodsList from '@/components/goodsList/index';\r\nimport uploadPictures from '@/components/uploadPictures';\r\nimport userLabel from '@/components/userLabel';\r\nimport addGoods from './addGoods';\r\nimport { lotteryNewDetailApi, lotteryDetailApi, lotteryCreateApi, lotteryEditApi } from '@/api/lottery'; //详情 创建 编辑\r\nimport { lotteryFrom } from './formRule/lotteryFrom';\r\nimport { labelListApi } from '@/api/product';\r\nimport { levelListApi } from '@/api/user';\r\nimport WangEditor from '@/components/wangEditor/index.vue';\r\n\r\nimport { formatDate } from '@/utils/validate';\r\nimport { formatRichText } from '@/utils/editorImg';\r\n\r\nexport default {\r\n name: 'lotteryCreate',\r\n components: {\r\n goodsList,\r\n uploadPictures,\r\n addGoods,\r\n WangEditor,\r\n userLabel,\r\n },\r\n data() {\r\n return {\r\n selectDataLabel: [],\r\n selectLabelShow: false,\r\n content: '',\r\n tabs: [\r\n {\r\n name: '积分抽取',\r\n type: '1',\r\n },\r\n {\r\n name: '订单支付',\r\n type: '3',\r\n },\r\n {\r\n name: '订单评价',\r\n type: '4',\r\n },\r\n ],\r\n title: '添加商品',\r\n loading: false,\r\n userLabelList: [], //用户标签列表\r\n userLevelListApi: [], //用户等级列表\r\n submitOpen: false,\r\n spinShow: false,\r\n addGoodsModel: false,\r\n editData: {},\r\n myConfig: {\r\n autoHeightEnabled: false, // 编辑器不自动被内容撑高\r\n initialFrameHeight: 500, // 初始容器高度\r\n initialFrameWidth: '100%', // 初始容器宽度\r\n UEDITOR_HOME_URL: '/admin/UEditor/',\r\n serverUrl: '',\r\n },\r\n isChoice: '单选',\r\n current: 0,\r\n modalPic: false,\r\n modal_loading: false,\r\n images: [],\r\n templateList: [\r\n { id: 0, name: '非付费会员' },\r\n { id: 1, name: '付费会员' },\r\n ],\r\n columns: [\r\n {\r\n title: '序号',\r\n type: 'index',\r\n width: 60,\r\n align: 'center',\r\n },\r\n {\r\n title: '图片',\r\n slot: 'image',\r\n align: 'center',\r\n minWidth: 120,\r\n },\r\n {\r\n title: '名称',\r\n align: 'center',\r\n minWidth: 80,\r\n key: 'name',\r\n },\r\n {\r\n title: '奖品',\r\n slot: 'type',\r\n align: 'center',\r\n minWidth: 80,\r\n },\r\n {\r\n title: '提示语',\r\n key: 'prompt',\r\n align: 'center',\r\n minWidth: 80,\r\n },\r\n {\r\n title: '数量',\r\n slot: 'total',\r\n align: 'center',\r\n minWidth: 80,\r\n },\r\n {\r\n title: '奖品权重',\r\n slot: 'chance',\r\n align: 'center',\r\n minWidth: 80,\r\n },\r\n {\r\n title: '奖品概率',\r\n key: 'probability',\r\n align: 'center',\r\n minWidth: 80,\r\n },\r\n {\r\n title: '操作',\r\n slot: 'setting',\r\n align: 'center',\r\n minWidth: 80,\r\n },\r\n ],\r\n specsData: [\r\n {\r\n type: 1, //类型 1:未中奖 2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 10, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n ],\r\n formValidate: {\r\n images: [],\r\n name: '', //活动名称\r\n desc: '', //活动描述\r\n image: '', //活动背景图\r\n factor: '1', //抽奖类型:1:积分 2:余额 3:下单支付成功 4:订单评价',5:关注\r\n factor_num: 1, //获取一次抽奖的条件数量\r\n attends_user: 1, //参与用户1:所有 2:部分\r\n user_level: [], //参与用户等级\r\n user_label: [], //参与用户标签\r\n is_svip: '-1', //参与用户是否付费会员\r\n prize_num: 0, //奖品数量\r\n period: [], //活动时间\r\n prize: [], //奖品数组\r\n lottery_num_term: 1, //抽奖次数限制:1:每天2:每人\r\n lottery_num: 1, //抽奖次数\r\n spread_num: 1, //关注推广获取抽奖次数\r\n is_all_record: 0, //中奖纪录展示\r\n is_personal_record: 0, //个人中奖纪录展示\r\n is_content: 0, //活动规格是否展示\r\n content: '', //富文本内容\r\n status: 0, //状态\r\n },\r\n ruleValidate: lotteryFrom,\r\n currentid: '',\r\n picTit: '',\r\n tableIndex: 0,\r\n copy: 0,\r\n editIndex: null,\r\n id: '',\r\n copy: 0,\r\n };\r\n },\r\n filters: {\r\n typeName(type) {\r\n if (type == 1) {\r\n return '未中奖';\r\n } else if (type == 2) {\r\n return '积分';\r\n } else if (type == 3) {\r\n return '余额';\r\n } else if (type == 4) {\r\n return '红包';\r\n } else if (type == 5) {\r\n return '优惠券';\r\n } else if (type == 6) {\r\n return '商品';\r\n }\r\n },\r\n },\r\n computed: {\r\n ...mapState('admin/layout', ['isMobile']),\r\n labelWidth() {\r\n return this.isMobile ? undefined : 135;\r\n },\r\n labelPosition() {\r\n return this.isMobile ? 'top' : 'right';\r\n },\r\n },\r\n mounted() {\r\n this.getInfo();\r\n this.labelListApi();\r\n this.levelListApi();\r\n },\r\n methods: {\r\n changeUsers(e) {\r\n if (e == 1) {\r\n this.formValidate.user_level = []; //参与用户等级\r\n this.formValidate.user_label = []; //参与用户标签\r\n this.formValidate.is_svip = '-1'; //参与用户是否付费会员\r\n this.selectDataLabel = []; //参与用户是否付费会员\r\n }\r\n },\r\n // 标签弹窗关闭\r\n labelClose() {\r\n this.selectLabelShow = false;\r\n },\r\n activeSelectData(data) {\r\n this.selectLabelShow = false;\r\n this.selectDataLabel = data;\r\n },\r\n onClickTab(e) {\r\n this.formValidate.factor = e;\r\n this.getInfo(e);\r\n },\r\n getEditorContent(data) {\r\n this.content = data;\r\n },\r\n //用户标签列表\r\n labelListApi() {\r\n labelListApi().then((res) => {\r\n this.userLabelList = res.data.list;\r\n });\r\n },\r\n //用户等级列表\r\n levelListApi() {\r\n levelListApi().then((res) => {\r\n this.userLevelListApi = res.data.list;\r\n });\r\n },\r\n // 具体日期\r\n onchangeTime(e) {\r\n this.$nextTick(() => {\r\n this.$set(this.formValidate, 'period', e);\r\n });\r\n },\r\n // 详情\r\n getInfo(e) {\r\n this.spinShow = true;\r\n lotteryNewDetailApi(this.formValidate.factor)\r\n .then((res) => {\r\n if (res.status == 200 && !Array.isArray(res.data)) {\r\n this.formValidate = res.data;\r\n this.formValidate.user_level = res.data.user_level || [];\r\n this.selectDataLabel = res.data.user_label || [];\r\n this.formValidate.is_svip = res.data.is_svip;\r\n this.content = res.data.is_content ? res.data.content : '';\r\n this.formValidate.factor = res.data.factor.toString();\r\n this.formValidate.period = [\r\n this.formatDate(res.data.start_time) || '',\r\n this.formatDate(res.data.end_time) || '',\r\n ];\r\n\r\n this.specsData = res.data.prize;\r\n this.getProbability();\r\n } else {\r\n this.formValidate = {\r\n images: [],\r\n name: '', //活动名称\r\n desc: '', //活动描述\r\n image: '', //活动背景图\r\n factor: e.toString(), //抽奖类型:1:积分 2:余额 3:下单支付成功 4:订单评价',5:关注\r\n factor_num: 1, //获取一次抽奖的条件数量\r\n attends_user: 1, //参与用户1:所有 2:部分\r\n user_level: [], //参与用户等级\r\n user_label: [], //参与用户标签\r\n is_svip: '-1', //参与用户是否付费会员\r\n prize_num: 0, //奖品数量\r\n period: [], //活动时间\r\n prize: [], //奖品数组\r\n lottery_num_term: 1, //抽奖次数限制:1:每天2:每人\r\n lottery_num: 1, //抽奖次数\r\n spread_num: 1, //关注推广获取抽奖次数\r\n is_all_record: 0, //中奖纪录展示\r\n is_personal_record: 0, //个人中奖纪录展示\r\n is_content: 0, //活动规格是否展示\r\n content: '', //富文本内容\r\n status: 0, //状态\r\n };\r\n this.specsData = [\r\n {\r\n type: 1, //类型 1:未中奖 2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 10, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n {\r\n type: 1, //类型 1:未中奖2:积分 3:余额 4:红包 5:优惠券 6:站内商品\r\n name: '', //活动名称\r\n num: 0, //奖品数量\r\n image: '', //奖品图片\r\n chance: 0, //中奖权重\r\n total: 0, //奖品数量\r\n prompt: '', //提示语\r\n },\r\n ];\r\n }\r\n })\r\n .catch((err) => {});\r\n this.spinShow = false;\r\n },\r\n // 下一步\r\n next(name) {\r\n this.formValidate.prize = this.specsData;\r\n if (this.formValidate.is_content) {\r\n this.formValidate.content = formatRichText(this.content);\r\n }\r\n if (this.formValidate.attends_user == 2) {\r\n if (this.selectDataLabel.length) {\r\n let activeIds = [];\r\n this.selectDataLabel.forEach((item) => {\r\n activeIds.push(item.id);\r\n });\r\n this.formValidate.user_label = activeIds;\r\n }\r\n }\r\n if (this.submitOpen) return false;\r\n this.$refs[name].validate((valid) => {\r\n if (valid) {\r\n this.submitOpen = true;\r\n if (this.formValidate.id && !this.copy) {\r\n lotteryEditApi(this.formValidate.id, this.formValidate)\r\n .then(async (res) => {\r\n this.$Message.success(res.msg);\r\n this.submitOpen = false;\r\n // setTimeout(() => {\r\n // this.submitOpen = false;\r\n // this.$router.push({\r\n // path: \"/admin/marketing/lottery/recording_list\",\r\n // });\r\n // }, 500);\r\n })\r\n .catch((res) => {\r\n this.submitOpen = false;\r\n this.$Message.error(res.msg);\r\n });\r\n } else {\r\n lotteryCreateApi(this.formValidate)\r\n .then(async (res) => {\r\n this.submitOpen = false;\r\n this.$Message.success(res.msg);\r\n // setTimeout(() => {\r\n // this.submitOpen = false;\r\n // this.$router.push({\r\n // path: \"/admin/marketing/lottery/recording_list\",\r\n // });\r\n // }, 500);\r\n })\r\n .catch((res) => {\r\n this.submitOpen = false;\r\n this.$Message.error(res.msg);\r\n });\r\n }\r\n } else {\r\n return false;\r\n }\r\n });\r\n },\r\n // 上一步\r\n step() {\r\n this.current--;\r\n },\r\n // 点击商品图\r\n modalPicTap(tit, picTit, index) {\r\n this.modalPic = true;\r\n this.isChoice = tit === 'dan' ? '单选' : '多选';\r\n this.picTit = picTit || '';\r\n this.tableIndex = index;\r\n },\r\n // 获取单张图片信息\r\n getPic(pc) {\r\n switch (this.picTit) {\r\n case 'danFrom':\r\n this.formValidate.image = pc.att_dir;\r\n break;\r\n default:\r\n this.specsData[this.tableIndex].image = pc.att_dir;\r\n }\r\n this.modalPic = false;\r\n },\r\n handleRemove() {\r\n this.formValidate.image = '';\r\n },\r\n // 表单验证\r\n validate(prop, status, error) {\r\n if (status === false) {\r\n this.$Message.error(error);\r\n return false;\r\n } else {\r\n return true;\r\n }\r\n },\r\n //新增商品\r\n addGoods() {\r\n this.addGoodsModel = true;\r\n this.title = '添加商品';\r\n this.editData = {};\r\n },\r\n //编辑商品\r\n editGoods(index) {\r\n this.addGoodsModel = true;\r\n this.title = '添加奖品';\r\n this.editData = this.specsData[index];\r\n this.editIndex = index;\r\n },\r\n //删除商品\r\n deleteGoods(index) {\r\n this.specsData.splice(index, 1);\r\n },\r\n //获取数组中某个字段之和\r\n sumArr(arr, name) {\r\n let arrData = [];\r\n for (let i = 0; i < arr.length; i++) {\r\n arrData.push(arr[i][name]);\r\n }\r\n return eval(arrData.join('+'));\r\n },\r\n addGoodsData(data) {\r\n this.editIndex != null\r\n ? this.$set(this.specsData, [this.editIndex], data)\r\n : this.specsData.length < 8\r\n ? this.specsData.push(data)\r\n : this.$Message.warning('最多添加8个奖品');\r\n this.getProbability();\r\n this.addGoodsModel = false;\r\n this.editIndex = null;\r\n },\r\n changeChance(data, index) {\r\n this.$set(this.specsData[index], 'chance', data);\r\n this.$nextTick((e) => {\r\n this.getProbability();\r\n });\r\n },\r\n changeTotal(data, index) {\r\n this.$set(this.specsData[index], 'total', data);\r\n },\r\n //获取商品中奖概率\r\n getProbability() {\r\n let sum = 0;\r\n sum = this.sumArr(this.specsData, 'chance');\r\n for (let j = 0; j < this.specsData.length; j++) {\r\n if (sum == 0) {\r\n this.$set(this.specsData[j], 'probability', '0%');\r\n } else {\r\n this.$set(this.specsData[j], 'probability', ((this.specsData[j].chance / sum) * 100).toFixed(2) + '%');\r\n }\r\n }\r\n },\r\n //修改排序\r\n onDragDrop(a, b) {\r\n this.specsData.splice(b, 1, ...this.specsData.splice(a, 1, this.specsData[b]));\r\n },\r\n //时间格式转换\r\n formatDate(time) {\r\n if (time) {\r\n let date = new Date(time * 1000);\r\n return formatDate(date, 'yyyy-MM-dd hh:mm');\r\n } else {\r\n return '';\r\n }\r\n },\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped lang=\"stylus\">\r\n.custom-label {\r\n display: inline-flex;\r\n line-height: 1.5;\r\n}\r\n\r\n.grey {\r\n color: #999;\r\n}\r\n\r\n.maxW /deep/.ivu-select-dropdown {\r\n max-width: 600px;\r\n}\r\n\r\n.ivu-table-wrapper {\r\n border-left: 1px solid #dcdee2;\r\n border-top: 1px solid #dcdee2;\r\n}\r\n\r\n.tabBox_img {\r\n width: 50px;\r\n height: 50px;\r\n}\r\n\r\n.tabBox_img img {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.priceBox {\r\n width: 100%;\r\n}\r\n\r\n.form {\r\n .picBox {\r\n display: inline-block;\r\n cursor: pointer;\r\n }\r\n\r\n .pictrue {\r\n width: 58px;\r\n height: 58px;\r\n border: 1px dotted rgba(0, 0, 0, 0.1);\r\n margin-right: 0px;\r\n display: inline-block;\r\n position: relative;\r\n cursor: pointer;\r\n\r\n img {\r\n width: 100%;\r\n height: 100%;\r\n }\r\n\r\n .btndel {\r\n position: absolute;\r\n z-index: 9;\r\n width: 20px !important;\r\n height: 20px !important;\r\n left: 46px;\r\n top: -4px;\r\n }\r\n }\r\n\r\n .upLoad {\r\n width: 58px;\r\n height: 58px;\r\n line-height: 58px;\r\n border: 1px dotted rgba(0, 0, 0, 0.1);\r\n border-radius: 4px;\r\n background: rgba(0, 0, 0, 0.02);\r\n cursor: pointer;\r\n }\r\n}\r\n\r\n.labelInput {\r\n border: 1px solid #dcdee2;\r\n padding: 0 6px;\r\n width: 30%;\r\n border-radius: 5px;\r\n min-height: 30px;\r\n cursor: pointer;\r\n\r\n .span {\r\n color: #c5c8ce;\r\n }\r\n\r\n .ivu-icon-ios-arrow-down {\r\n font-size: 14px;\r\n color: #808695;\r\n }\r\n}\r\n</style>\r\n"]}]}
|