a8a643f4c57e855058cfab322c7eb17a.json 48 KB

1
  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\\storeIntegralOrder\\components\\tableFrom.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\newItem\\admin\\src\\pages\\marketing\\storeIntegralOrder\\components\\tableFrom.vue","mtime":1677828270217},{"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 _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 "regenerator-runtime/runtime.js";
import "core-js/modules/es.error.cause.js";
import "core-js/modules/es.number.is-integer.js";
import "core-js/modules/es.number.constructor.js";
import "core-js/modules/es.regexp.exec.js";
import "core-js/modules/es.regexp.test.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/es.regexp.to-string.js";
import "core-js/modules/es.json.stringify.js";
import "core-js/modules/es.array.concat.js";
import "core-js/modules/es.array.join.js";
import "core-js/modules/es.array.filter.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { mapState, mapMutations } from 'vuex';
import { integralGetOrdes as _integralGetOrdes } from '@/api/marketing';
import { putWrite, storeOrderApi, handBatchDelivery, otherBatchDelivery, exportExpressList, storeIntegralOrder } from '@/api/order';
import autoSend from '../handle/autoSend';
import queueList from '../handle/queueList';
import Setting from '@/setting'; // import util from "@/libs/util";

import QueueList from '../handle/queueList.vue'; // import exportExcel from "@/utils/newToExcel.js";
// import XLSX from 'xlsx';
// const make_cols = refstr => Array(XLSX.utils.decode_range(refstr).e.c + 1).fill(0).map((x,i) => ({name:XLSX.utils.encode_col(i), key:i}));

export default {
  name: 'table_from',
  components: {
    autoSend: autoSend,
    queueList: queueList
  },
  props: ['formSelection', 'autoDisabled', 'isAll'],
  data: function data() {
    var codeNum = function codeNum(rule, value, callback) {
      if (!value) {
        return callback(new Error('请填写核销码'));
      } // 模拟异步验证效果


      if (!Number.isInteger(value)) {
        callback(new Error('请填写12位数字'));
      } else {
        // const reg = /[0-9]{12}/;
        var reg = /\b\d{12}\b/;

        if (!reg.test(value)) {
          callback(new Error('请填写12位数字'));
        } else {
          callback();
        }
      }
    };

    return {
      grid: {
        xl: 7,
        lg: 7,
        md: 12,
        sm: 24,
        xs: 24
      },
      fromList: {
        title: '选择时间',
        custom: true,
        fromTxt: [{
          text: '全部',
          val: ''
        }, {
          text: '今天',
          val: 'today'
        }, {
          text: '昨天',
          val: 'yesterday'
        }, {
          text: '最近7天',
          val: 'lately7'
        }, {
          text: '最近30天',
          val: 'lately30'
        }, {
          text: '本月',
          val: 'month'
        }, {
          text: '本年',
          val: 'year'
        }]
      },
      currentTab: '',
      // 搜索条件
      orderData: {
        status: '',
        data: '',
        real_name: '',
        field_key: 'all',
        pay_type: ''
      },
      modalTitleSs: '',
      statusType: '',
      time: '',
      value2: [],
      isDelIdList: [],
      modals2: false,
      timeVal: [],
      options: {
        shortcuts: [{
          text: '今天',
          value: function value() {
            var end = new Date();
            var start = new Date();
            start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate()));
            return [start, end];
          }
        }, {
          text: '昨天',
          value: function value() {
            var end = new Date();
            var start = new Date();
            start.setTime(start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 1)));
            end.setTime(end.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 1)));
            return [start, end];
          }
        }, {
          text: '最近7天',
          value: function value() {
            var end = new Date();
            var start = new Date();
            start.setTime(start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 6)));
            return [start, end];
          }
        }, {
          text: '最近30天',
          value: function value() {
            var end = new Date();
            var start = new Date();
            start.setTime(start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 29)));
            return [start, end];
          }
        }, {
          text: '本月',
          value: function value() {
            var end = new Date();
            var start = new Date();
            start.setTime(start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), 1)));
            return [start, end];
          }
        }, {
          text: '本年',
          value: function value() {
            var end = new Date();
            var start = new Date();
            start.setTime(start.setTime(new Date(new Date().getFullYear(), 0, 1)));
            return [start, end];
          }
        }]
      },
      payList: [{
        label: '全部',
        val: ''
      }, {
        label: '微信支付',
        val: '1'
      }, {
        label: '支付宝支付',
        val: '4'
      }, {
        label: '余额支付',
        val: '2'
      }, {
        label: '线下支付',
        val: '3'
      }],
      manualModal: false,
      uploadAction: "".concat(Setting.apiBaseURL, "/file/upload/1"),
      uploadHeaders: {},
      file: '',
      autoModal: false,
      isShow: false,
      recordModal: false,
      sendOutValue: '',
      exportList: [{
        name: '1',
        label: '导出发货单'
      }, {
        name: '0',
        label: '导出订单'
      }],
      exportListOn: 0,
      fileList: [],
      orderChartType: {} // modal5: false,
      // data5: [],
      // cols5: []
      // orderStatus: false,
      // orderInfo:''

    };
  },
  computed: _objectSpread(_objectSpread(_objectSpread({}, mapState('media', ['isMobile'])), mapState('integralOrder', ['isDels', 'delIdList'])), {}, {
    labelWidth: function labelWidth() {
      return this.isMobile ? undefined : 80;
    },
    labelPosition: function labelPosition() {
      return this.isMobile ? 'top' : 'right';
    },
    today: function today() {
      var end = new Date();
      var start = new Date();
      var datetimeStart = start.getFullYear() + '/' + (start.getMonth() + 1) + '/' + start.getDate();
      var datetimeEnd = end.getFullYear() + '/' + (end.getMonth() + 1) + '/' + end.getDate();
      return [datetimeStart, datetimeEnd];
    }
  }),
  watch: {
    $route: function $route() {
      if (this.$route.fullPath === '/admin/order/list?status=1') {
        this.getPath();
      }
    }
  },
  created: function created() {
    // this.timeVal = this.today;
    // this.orderData.data = this.timeVal.join('-');
    if (this.$route.fullPath === '/admin/order/list?status=1') {
      this.getPath();
    } // this.getToken();


    this.$parent.$emit('add');
    var searchData = {
      status: this.orderData.status,
      product_id: this.$route.query.product_id || ''
    };
    this.integralGetOrdes(searchData);
  },
  methods: _objectSpread(_objectSpread({}, mapMutations('integralOrder', ['getOrderStatus', 'getOrderType', 'getOrderTime', 'getOrderNum', 'getfieldKey'])), {}, {
    integralGetOrdes: function integralGetOrdes(searchData) {
      var _this = this;

      _integralGetOrdes(searchData).then(function (res) {
        _this.$set(_this, 'orderChartType', res.data);
      }).catch(function (err) {});
    },
    getPath: function getPath() {
      this.orderData.status = this.$route.query.status.toString();
      this.getOrderStatus(this.orderData.status);
      this.$emit('getList', 1);
      this.$emit('order-data', this.orderData);
    },
    // 导出
    // exports(value) {
    //   this.exportListOn = this.exportList.findIndex(
    //     (item) => item.name === value
    //   );
    //   let formValidate = this.orderData;
    //   let data = {
    //     status: formValidate.status,
    //     data: formValidate.data,
    //     real_name: formValidate.real_name,
    //     type: value,
    //   };
    //   storeOrderApi(data)
    //     .then((res) => {
    //       location.href = res.data[0];
    //     })
    //     .catch((res) => {
    //       this.$Message.error(res.msg);
    //     });
    // },
    // 数据导出；
    exports: function exports() {
      var _this2 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var th, filekey, data, fileName, excelData, i, lebData;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                th = [], filekey = [], data = [], fileName = '';
                excelData = JSON.parse(JSON.stringify(_this2.orderData));
                excelData.page = 1;
                excelData.product_id = _this2.$route.query.product_id || '';
                i = 0;

              case 5:
                if (!(i < excelData.page + 1)) {
                  _context.next = 16;
                  break;
                }

                _context.next = 8;
                return _this2.getExcelData(excelData);

              case 8:
                lebData = _context.sent;
                if (!fileName) fileName = lebData.filename;

                if (!filekey.length) {
                  filekey = lebData.filekey;
                }

                if (!th.length) th = lebData.header;

                if (lebData.export.length) {
                  data = data.concat(lebData.export);
                  excelData.page++;
                }

              case 13:
                i++;
                _context.next = 5;
                break;

              case 16:
                exportExcel(th, filekey, fileName, data);

              case 17:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }))();
    },
    getExcelData: function getExcelData(excelData) {
      return new Promise(function (resolve, reject) {
        storeIntegralOrder(excelData).then(function (res) {
          return resolve(res.data);
        });
      });
    },
    // 具体日期
    onchangeTime: function onchangeTime(e) {
      this.timeVal = e;
      this.orderData.data = this.timeVal[0] ? this.timeVal.join('-') : '';
      this.$store.dispatch('integralOrder/getOrderTabs', {
        data: this.orderData.data
      });
      this.getOrderTime(this.orderData.data);
      this.$emit('getList', 1);
      this.$emit('order-data', this.orderData);
    },
    // 选择时间
    selectChange: function selectChange(tab) {
      this.$store.dispatch('integralOrder/getOrderTabs', {
        data: tab
      });
      this.orderData.data = tab;
      this.getOrderTime(this.orderData.data);
      this.timeVal = [];
      this.$emit('getList');
      this.$emit('order-data', this.orderData);
    },
    // 订单选择状态
    selectChange2: function selectChange2(tab) {
      this.getOrderStatus(tab);
      this.$emit('getList', 1);
    },
    userSearchs: function userSearchs(type) {
      this.getOrderType(type);
      this.$emit('getList', 1);
    },
    // 时间状态
    timeChange: function timeChange(time) {
      this.getOrderTime(time);
      this.$emit('getList');
    },
    // 订单号搜索
    orderSearch: function orderSearch(num) {
      this.getOrderNum(num);
      this.getfieldKey(this.orderData.field_key);
      this.$emit('getList', 1);
    },
    // 点击订单类型
    onClickTab: function onClickTab() {
      this.$emit('onChangeType', this.currentTab);
    },
    // 批量删除
    delAll: function delAll() {
      var _this3 = this;

      if (this.delIdList.length === 0) {
        this.$Message.error('请先选择删除的订单！');
      } else {
        if (this.isDels) {
          this.delIdList.filter(function (item) {
            _this3.isDelIdList.push(item.id);
          });
          var idss = {
            ids: this.isDelIdList,
            all: this.isAll,
            where: this.orderData
          };
          var delfromData = {
            title: '删除订单',
            url: "/order/dels",
            method: 'post',
            ids: idss
          };
          this.$modalSure(delfromData).then(function (res) {
            _this3.$Message.success(res.msg);

            _this3.tabList();
          }).catch(function (res) {
            _this3.$Message.error(res.msg);
          });
        } else {
          var title = '错误！';
          var content = '<p>您选择的的订单存在用户未删除的订单，无法删除用户未删除的订单！</p>';
          this.$Modal.error({
            title: title,
            content: content
          });
        }
      }
    },
    del: function del(name) {
      // this.orderInfo = ''
      this.modals2 = false;
      this.writeOffFrom.confirm = 0;
      this.$refs[name].resetFields();
    },
    handleSubmit: function handleSubmit() {
      this.$emit('on-submit', this.data);
    },
    // 刷新
    Refresh: function Refresh() {
      this.$emit('getList');
    },
    //
    handleReset: function handleReset() {
      this.$refs.form.resetFields();
      this.$emit('on-reset');
    },
    // 上传头部token
    // getToken() {
    //   this.uploadHeaders["Authori-zation"] =
    //     "Bearer " + util.cookies.get("token");
    // },
    // beforeUpload(file){
    //     /* Boilerplate to set up FileReader */
    // 	const reader = new FileReader();
    // 	reader.onload = (e) => {
    // 		/* Parse data */
    // 		const bstr = e.target.result;
    // 		const wb = XLSX.read(bstr, {type:'binary'});
    // 		/* Get first worksheet */
    // 		const wsname = wb.SheetNames[0];
    // 		const ws = wb.Sheets[wsname];
    // 		/* Convert array of arrays */
    // 		const data = XLSX.utils.sheet_to_json(ws, {header:1});
    // 		/* Update state */
    // 		this.data5 = data;
    //         this.cols5 = make_cols(ws['!ref']);
    //         this.modal5 = true;
    // 	};
    // 	reader.readAsBinaryString(file);
    // },
    // 上传成功
    uploadSuccess: function uploadSuccess(res, file, fileList) {
      if (res.status === 200) {
        this.$Message.success(res.msg);
        this.file = res.data.src;
        this.fileList = fileList;
      } else {
        this.$Message.error(res.msg);
      }
    },
    //移除文件
    removeFile: function removeFile(file, fileList) {
      this.file = '';
      this.fileList = fileList;
    },
    // 手动批量发货-确定
    manualModalOk: function manualModalOk() {
      var _this4 = this;

      this.$refs.upload.clearFiles();
      handBatchDelivery({
        file: this.file
      }).then(function (res) {
        _this4.$Message.success(res.msg);

        _this4.fileList = [];
      }).catch(function (err) {
        _this4.$Message.error(err.msg);

        _this4.fileList = [];
      });
    },
    // 手动批量发货-取消
    manualModalCancel: function manualModalCancel() {
      this.fileList = [];
      this.$refs.upload.clearFiles();
    },
    // 自动批量发货-取消
    autoModalOk: function autoModalOk() {
      if (this.isAll == '全部' || this.formSelection.length) {
        this.$refs.send.modals = true;
        this.$refs.send.getList();
        this.$refs.send.getDeliveryList();
      } else {
        this.$Message.error('请选择本页订单');
      }
    },
    // 自动批量发货-取消
    autolModalCancel: function autolModalCancel() {},
    submitFail: function submitFail() {
      otherBatchDelivery();
    },
    queuemModal: function queuemModal() {
      // this.$router.push({ path: 'queue/list' });
      this.$refs.queue.modal = true;
    },
    onAuto: function onAuto() {
      this.$refs.sends.modals = true;
      this.$refs.sends.getList();
      this.$refs.sends.getDeliveryList();
    },
    // 下载物流公司对照表
    getExpressList: function getExpressList() {
      var _this5 = this;

      exportExpressList().then(function (res) {
        window.open(res.data[0]);
      }).catch(function (err) {
        _this5.$Message.error(err.msg);
      });
    }
  })
};"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoEA;AACA;AAEA,SACAA,QADA,EAEAC,aAFA,EAGAC,iBAHA,EAIAC,kBAJA,EAKAC,iBALA,EAMAC,kBANA,QAOA,aAPA;AAQA;AACA;AACA,gC,CACA;;AACA,gD,CACA;AACA;AACA;;AACA;EACAC,kBADA;EAEAC;IACAC,kBADA;IAEAC;EAFA,CAFA;EAMAC,iDANA;EAOAC,IAPA,kBAOA;IACA;MACA;QACA;MACA,CAHA,CAIA;;;MACA;QACAC;MACA,CAFA,MAEA;QACA;QACA;;QACA;UACAA;QACA,CAFA,MAEA;UACAA;QACA;MACA;IACA,CAhBA;;IAiBA;MACAC;QACAC,KADA;QAEAC,KAFA;QAGAC,MAHA;QAIAC,MAJA;QAKAC;MALA,CADA;MAQAC;QACAC,aADA;QAEAC,YAFA;QAGAC,UACA;UAAAC;UAAAC;QAAA,CADA,EAEA;UAAAD;UAAAC;QAAA,CAFA,EAGA;UAAAD;UAAAC;QAAA,CAHA,EAIA;UAAAD;UAAAC;QAAA,CAJA,EAKA;UAAAD;UAAAC;QAAA,CALA,EAMA;UAAAD;UAAAC;QAAA,CANA,EAOA;UAAAD;UAAAC;QAAA,CAPA;MAHA,CARA;MAqBAC,cArBA;MAsBA;MACAC;QACAC,UADA;QAEAhB,QAFA;QAGAiB,aAHA;QAIAC,gBAJA;QAKAC;MALA,CAvBA;MA8BAC,gBA9BA;MA+BAC,cA/BA;MAgCAC,QAhCA;MAiCAC,UAjCA;MAkCAC,eAlCA;MAmCAC,cAnCA;MAoCAC,WApCA;MAqCAC;QACAC,YACA;UACAhB,UADA;UAEAiB,KAFA,mBAEA;YACA;YACA;YACAC;YACA;UACA;QAPA,CADA,EAUA;UACAlB,UADA;UAEAiB,KAFA,mBAEA;YACA;YACA;YACAC,cACAA,kGADA;YAGAC,YACAA,gGADA;YAGA;UACA;QAZA,CAVA,EAwBA;UACAnB,YADA;UAEAiB,KAFA,mBAEA;YACA;YACA;YACAC,cACAA,kGADA;YAGA;UACA;QATA,CAxBA,EAmCA;UACAlB,aADA;UAEAiB,KAFA,mBAEA;YACA;YACA;YACAC,cACAA,mGADA;YAGA;UACA;QATA,CAnCA,EA8CA;UACAlB,UADA;UAEAiB,KAFA,mBAEA;YACA;YACA;YACAC;YACA;UACA;QAPA,CA9CA,EAuDA;UACAlB,UADA;UAEAiB,KAFA,mBAEA;YACA;YACA;YACAC;YACA;UACA;QAPA,CAvDA;MADA,CArCA;MAwGAE,UACA;QAAAC;QAAApB;MAAA,CADA,EAEA;QAAAoB;QAAApB;MAAA,CAFA,EAGA;QAAAoB;QAAApB;MAAA,CAHA,EAIA;QAAAoB;QAAApB;MAAA,CAJA,EAKA;QAAAoB;QAAApB;MAAA,CALA,CAxGA;MA+GAqB,kBA/GA;MAgHAC,6DAhHA;MAiHAC,iBAjHA;MAkHAC,QAlHA;MAmHAC,gBAnHA;MAoHAC,aApHA;MAqHAC,kBArHA;MAsHAC,gBAtHA;MAuHAC,aACA;QACA/C,SADA;QAEAsC;MAFA,CADA,EAKA;QACAtC,SADA;QAEAsC;MAFA,CALA,CAvHA;MAiIAU,eAjIA;MAkIAC,YAlIA;MAmIAC,kBAnIA,CAoIA;MACA;MACA;MACA;MACA;;IAxIA;EA0IA,CAnKA;EAoKAC,wDACAC,+BADA,GAEAA,kDAFA;IAGAC,UAHA,wBAGA;MACA;IACA,CALA;IAMAC,aANA,2BAMA;MACA;IACA,CARA;IASAC,KATA,mBASA;MACA;MACA;MACA;MACA;MACA;IACA;EAfA,EApKA;EAqLAC;IACAC,MADA,oBACA;MACA;QACA;MACA;IACA;EALA,CArLA;EA4LAC,OA5LA,qBA4LA;IACA;IACA;IACA;MACA;IACA,CALA,CAMA;;;IACA;IACA;MACArC,6BADA;MAEAsC;IAFA;IAIA;EACA,CAzMA;EA0MAC,yCACAC,+GADA;IAEAC,gBAFA,4BAEAC,UAFA,EAEA;MAAA;;MACAD,8BACAE,IADA,CACA;QACA;MACA,CAHA,EAIAC,KAJA,CAIA,iBAJA;IAKA,CARA;IASAC,OATA,qBASA;MACA;MACA;MACA;MACA;IACA,CAdA;IAeA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACAC,OApCA,qBAoCA;MAAA;;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBACAC,EADA,GACA,EADA,EACAC,OADA,GACA,EADA,EACAhE,IADA,GACA,EADA,EACAiE,QADA,GACA,EADA;gBAEAC,SAFA,GAEAC,4CAFA;gBAGAD;gBACAA;gBACAE,CALA,GAKA,CALA;;cAAA;gBAAA,MAKAA,sBALA;kBAAA;kBAAA;gBAAA;;gBAAA;gBAAA,OAMA,8BANA;;cAAA;gBAMAC,OANA;gBAOA;;gBACA;kBACAL;gBACA;;gBACA;;gBACA;kBACAhE;kBACAkE;gBACA;;cAfA;gBAKAE,GALA;gBAAA;gBAAA;;cAAA;gBAiBAE;;cAjBA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IAkBA,CAtDA;IAuDAC,YAvDA,wBAuDAL,SAvDA,EAuDA;MACA;QACAxE;UACA;QACA,CAFA;MAGA,CAJA;IAKA,CA7DA;IA8DA;IACA8E,YA/DA,wBA+DAC,CA/DA,EA+DA;MACA;MACA;MACA;QACAzE;MADA;MAGA;MACA;MACA;IACA,CAxEA;IAyEA;IACA0E,YA1EA,wBA0EAC,GA1EA,EA0EA;MACA;QAAA3E;MAAA;MACA;MACA;MACA;MACA;MACA;IACA,CAjFA;IAkFA;IACA4E,aAnFA,yBAmFAD,GAnFA,EAmFA;MACA;MACA;IACA,CAtFA;IAuFAE,WAvFA,uBAuFAC,IAvFA,EAuFA;MACA;MACA;IACA,CA1FA;IA2FA;IACAC,UA5FA,sBA4FAzD,IA5FA,EA4FA;MACA;MACA;IACA,CA/FA;IAgGA;IACA0D,WAjGA,uBAiGAC,GAjGA,EAiGA;MACA;MACA;MACA;IACA,CArGA;IAsGA;IACAC,UAvGA,wBAuGA;MACA;IACA,CAzGA;IA0GA;IACAC,MA3GA,oBA2GA;MAAA;;MACA;QACA;MACA,CAFA,MAEA;QACA;UACA;YACA;UACA,CAFA;UAGA;YACAC,qBADA;YAEAC,eAFA;YAGAC;UAHA;UAKA;YACA7E,aADA;YAEA8E,kBAFA;YAGAC,cAHA;YAIAJ;UAJA;UAMA,6BACAzB,IADA,CACA;YACA;;YACA;UACA,CAJA,EAKAC,KALA,CAKA;YACA;UACA,CAPA;QAQA,CAvBA,MAuBA;UACA;UACA;UACA;YACAnD,YADA;YAEAgF;UAFA;QAIA;MACA;IACA,CA/IA;IAgJAC,GAhJA,eAgJA/F,IAhJA,EAgJA;MACA;MACA;MACA;MACA;IACA,CArJA;IAsJAgG,YAtJA,0BAsJA;MACA;IACA,CAxJA;IAyJA;IACAC,OA1JA,qBA0JA;MACA;IACA,CA5JA;IA6JA;IACAC,WA9JA,yBA8JA;MACA;MACA;IACA,CAjKA;IAkKA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACAC,aA3LA,yBA2LAC,GA3LA,EA2LA1D,IA3LA,EA2LAO,QA3LA,EA2LA;MACA;QACA;QACA;QACA;MACA,CAJA,MAIA;QACA;MACA;IACA,CAnMA;IAoMA;IACAoD,UArMA,sBAqMA3D,IArMA,EAqMAO,QArMA,EAqMA;MACA;MACA;IACA,CAxMA;IAyMA;IACAqD,aA1MA,2BA0MA;MAAA;;MACA;MACA1G;QACA8C;MADA,GAGAsB,IAHA,CAGA;QACA;;QACA;MACA,CANA,EAOAC,KAPA,CAOA;QACA;;QACA;MACA,CAVA;IAWA,CAvNA;IAwNA;IACAsC,iBAzNA,+BAyNA;MACA;MACA;IACA,CA5NA;IA6NA;IACAC,WA9NA,yBA8NA;MACA;QACA;QACA;QACA;MACA,CAJA,MAIA;QACA;MACA;IACA,CAtOA;IAuOA;IACAC,gBAxOA,8BAwOA,EAxOA;IAyOAC,UAzOA,wBAyOA;MACA7G;IACA,CA3OA;IA4OA8G,WA5OA,yBA4OA;MACA;MACA;IACA,CA/OA;IAgPAC,MAhPA,oBAgPA;MACA;MACA;MACA;IACA,CApPA;IAqPA;IACAC,cAtPA,4BAsPA;MAAA;;MACA/G,oBACAkE,IADA,CACA;QACA8C;MACA,CAHA,EAIA7C,KAJA,CAIA;QACA;MACA,CANA;IAOA;EA9PA;AA1MA","names":["putWrite","storeOrderApi","handBatchDelivery","otherBatchDelivery","exportExpressList","storeIntegralOrder","name","components","autoSend","queueList","props","data","callback","grid","xl","lg","md","sm","xs","fromList","title","custom","fromTxt","text","val","currentTab","orderData","status","real_name","field_key","pay_type","modalTitleSs","statusType","time","value2","isDelIdList","modals2","timeVal","options","shortcuts","value","start","end","payList","label","manualModal","uploadAction","uploadHeaders","file","autoModal","isShow","recordModal","sendOutValue","exportList","exportListOn","fileList","orderChartType","computed","mapState","labelWidth","labelPosition","today","watch","$route","created","product_id","methods","mapMutations","integralGetOrdes","searchData","then","catch","getPath","exports","th","filekey","fileName","excelData","JSON","i","lebData","exportExcel","getExcelData","onchangeTime","e","selectChange","tab","selectChange2","userSearchs","type","timeChange","orderSearch","num","onClickTab","delAll","ids","all","where","url","method","content","del","handleSubmit","Refresh","handleReset","uploadSuccess","res","removeFile","manualModalOk","manualModalCancel","autoModalOk","autolModalCancel","submitFail","queuemModal","onAuto","getExpressList","window"],"sourceRoot":"src/pages/marketing/storeIntegralOrder/components","sources":["tableFrom.vue"],"sourcesContent":["<template>\r\n <div class=\"table_box\">\r\n <Form\r\n ref=\"orderData\"\r\n :model=\"orderData\"\r\n :label-width=\"labelWidth\"\r\n :label-position=\"labelPosition\"\r\n class=\"tabform\"\r\n @submit.native.prevent\r\n >\r\n <Row :gutter=\"24\" type=\"flex\" justify=\"end\">\r\n <Col span=\"8\" class=\"ivu-text-left\">\r\n <FormItem label=\"订单状态:\">\r\n <RadioGroup v-model=\"orderData.status\" type=\"button\" @on-change=\"selectChange2(orderData.status)\">\r\n <Radio label=\"\">全部 {{ '(' + orderChartType.statusAll ? orderChartType.statusAll : 0 + ')' }}</Radio>\r\n <Radio label=\"1\">未发货 {{ '(' + orderChartType.unshipped ? orderChartType.unshipped : 0 + ')' }}</Radio>\r\n <Radio label=\"2\">待收货 {{ '(' + orderChartType.untake ? orderChartType.untake : 0 + ')' }}</Radio>\r\n <Radio label=\"3\">交易完成 {{ '(' + orderChartType.complete ? orderChartType.complete : 0 + ')' }}</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"8\" class=\"ivu-text-left\">\r\n <FormItem label=\"创建时间:\">\r\n <DatePicker\r\n :editable=\"false\"\r\n @on-change=\"onchangeTime\"\r\n :value=\"timeVal\"\r\n format=\"yyyy/MM/dd HH:mm:ss\"\r\n type=\"datetimerange\"\r\n placement=\"bottom-start\"\r\n placeholder=\"自定义时间\"\r\n style=\"width: 300px\"\r\n class=\"mr20\"\r\n :options=\"options\"\r\n ></DatePicker>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"8\">\r\n <div class=\"df\">\r\n <FormItem label=\"搜索:\" prop=\"real_name\" label-for=\"real_name\">\r\n <Input\r\n v-model=\"orderData.real_name\"\r\n search\r\n enter-button\r\n placeholder=\"请输入\"\r\n element-id=\"name\"\r\n style=\"width: 300px\"\r\n @on-search=\"orderSearch(orderData.real_name)\"\r\n >\r\n <Select v-model=\"orderData.field_key\" slot=\"prepend\" style=\"width: 80px\">\r\n <Option value=\"all\">全部</Option>\r\n <Option value=\"order_id\">订单号</Option>\r\n <Option value=\"uid\">UID</Option>\r\n <Option value=\"real_name\">用户姓名</Option>\r\n <Option value=\"user_phone\">用户电话</Option>\r\n <Option value=\"store_name\">商品名称(模糊)</Option>\r\n </Select>\r\n </Input>\r\n </FormItem>\r\n <!-- <Button class=\"ml10\" @click=\"exports\">导出</Button> -->\r\n </div>\r\n </Col>\r\n </Row>\r\n </Form>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport { mapState, mapMutations } from 'vuex';\r\nimport { integralGetOrdes } from '@/api/marketing';\r\n\r\nimport {\r\n putWrite,\r\n storeOrderApi,\r\n handBatchDelivery,\r\n otherBatchDelivery,\r\n exportExpressList,\r\n storeIntegralOrder,\r\n} from '@/api/order';\r\nimport autoSend from '../handle/autoSend';\r\nimport queueList from '../handle/queueList';\r\nimport Setting from '@/setting';\r\n// import util from \"@/libs/util\";\r\nimport QueueList from '../handle/queueList.vue';\r\n// import exportExcel from \"@/utils/newToExcel.js\";\r\n// import XLSX from 'xlsx';\r\n// const make_cols = refstr => Array(XLSX.utils.decode_range(refstr).e.c + 1).fill(0).map((x,i) => ({name:XLSX.utils.encode_col(i), key:i}));\r\nexport default {\r\n name: 'table_from',\r\n components: {\r\n autoSend,\r\n queueList,\r\n },\r\n props: ['formSelection', 'autoDisabled', 'isAll'],\r\n data() {\r\n const codeNum = (rule, value, callback) => {\r\n if (!value) {\r\n return callback(new Error('请填写核销码'));\r\n }\r\n // 模拟异步验证效果\r\n if (!Number.isInteger(value)) {\r\n callback(new Error('请填写12位数字'));\r\n } else {\r\n // const reg = /[0-9]{12}/;\r\n const reg = /\\b\\d{12}\\b/;\r\n if (!reg.test(value)) {\r\n callback(new Error('请填写12位数字'));\r\n } else {\r\n callback();\r\n }\r\n }\r\n };\r\n return {\r\n grid: {\r\n xl: 7,\r\n lg: 7,\r\n md: 12,\r\n sm: 24,\r\n xs: 24,\r\n },\r\n fromList: {\r\n title: '选择时间',\r\n custom: true,\r\n fromTxt: [\r\n { text: '全部', val: '' },\r\n { text: '今天', val: 'today' },\r\n { text: '昨天', val: 'yesterday' },\r\n { text: '最近7天', val: 'lately7' },\r\n { text: '最近30天', val: 'lately30' },\r\n { text: '本月', val: 'month' },\r\n { text: '本年', val: 'year' },\r\n ],\r\n },\r\n currentTab: '',\r\n // 搜索条件\r\n orderData: {\r\n status: '',\r\n data: '',\r\n real_name: '',\r\n field_key: 'all',\r\n pay_type: '',\r\n },\r\n modalTitleSs: '',\r\n statusType: '',\r\n time: '',\r\n value2: [],\r\n isDelIdList: [],\r\n modals2: false,\r\n timeVal: [],\r\n options: {\r\n shortcuts: [\r\n {\r\n text: '今天',\r\n value() {\r\n const end = new Date();\r\n const start = new Date();\r\n start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate()));\r\n return [start, end];\r\n },\r\n },\r\n {\r\n text: '昨天',\r\n value() {\r\n const end = new Date();\r\n const start = new Date();\r\n start.setTime(\r\n start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 1)),\r\n );\r\n end.setTime(\r\n end.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 1)),\r\n );\r\n return [start, end];\r\n },\r\n },\r\n {\r\n text: '最近7天',\r\n value() {\r\n const end = new Date();\r\n const start = new Date();\r\n start.setTime(\r\n start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 6)),\r\n );\r\n return [start, end];\r\n },\r\n },\r\n {\r\n text: '最近30天',\r\n value() {\r\n const end = new Date();\r\n const start = new Date();\r\n start.setTime(\r\n start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), new Date().getDate() - 29)),\r\n );\r\n return [start, end];\r\n },\r\n },\r\n {\r\n text: '本月',\r\n value() {\r\n const end = new Date();\r\n const start = new Date();\r\n start.setTime(start.setTime(new Date(new Date().getFullYear(), new Date().getMonth(), 1)));\r\n return [start, end];\r\n },\r\n },\r\n {\r\n text: '本年',\r\n value() {\r\n const end = new Date();\r\n const start = new Date();\r\n start.setTime(start.setTime(new Date(new Date().getFullYear(), 0, 1)));\r\n return [start, end];\r\n },\r\n },\r\n ],\r\n },\r\n payList: [\r\n { label: '全部', val: '' },\r\n { label: '微信支付', val: '1' },\r\n { label: '支付宝支付', val: '4' },\r\n { label: '余额支付', val: '2' },\r\n { label: '线下支付', val: '3' },\r\n ],\r\n manualModal: false,\r\n uploadAction: `${Setting.apiBaseURL}/file/upload/1`,\r\n uploadHeaders: {},\r\n file: '',\r\n autoModal: false,\r\n isShow: false,\r\n recordModal: false,\r\n sendOutValue: '',\r\n exportList: [\r\n {\r\n name: '1',\r\n label: '导出发货单',\r\n },\r\n {\r\n name: '0',\r\n label: '导出订单',\r\n },\r\n ],\r\n exportListOn: 0,\r\n fileList: [],\r\n orderChartType: {},\r\n // modal5: false,\r\n // data5: [],\r\n // cols5: []\r\n // orderStatus: false,\r\n // orderInfo:''\r\n };\r\n },\r\n computed: {\r\n ...mapState('media', ['isMobile']),\r\n ...mapState('integralOrder', ['isDels', 'delIdList']),\r\n labelWidth() {\r\n return this.isMobile ? undefined : 80;\r\n },\r\n labelPosition() {\r\n return this.isMobile ? 'top' : 'right';\r\n },\r\n today() {\r\n const end = new Date();\r\n const start = new Date();\r\n var datetimeStart = start.getFullYear() + '/' + (start.getMonth() + 1) + '/' + start.getDate();\r\n var datetimeEnd = end.getFullYear() + '/' + (end.getMonth() + 1) + '/' + end.getDate();\r\n return [datetimeStart, datetimeEnd];\r\n },\r\n },\r\n watch: {\r\n $route() {\r\n if (this.$route.fullPath === '/admin/order/list?status=1') {\r\n this.getPath();\r\n }\r\n },\r\n },\r\n created() {\r\n // this.timeVal = this.today;\r\n // this.orderData.data = this.timeVal.join('-');\r\n if (this.$route.fullPath === '/admin/order/list?status=1') {\r\n this.getPath();\r\n }\r\n // this.getToken();\r\n this.$parent.$emit('add');\r\n let searchData = {\r\n status: this.orderData.status,\r\n product_id: this.$route.query.product_id || '',\r\n };\r\n this.integralGetOrdes(searchData);\r\n },\r\n methods: {\r\n ...mapMutations('integralOrder', ['getOrderStatus', 'getOrderType', 'getOrderTime', 'getOrderNum', 'getfieldKey']),\r\n integralGetOrdes(searchData) {\r\n integralGetOrdes(searchData)\r\n .then((res) => {\r\n this.$set(this, 'orderChartType', res.data);\r\n })\r\n .catch((err) => {});\r\n },\r\n getPath() {\r\n this.orderData.status = this.$route.query.status.toString();\r\n this.getOrderStatus(this.orderData.status);\r\n this.$emit('getList', 1);\r\n this.$emit('order-data', this.orderData);\r\n },\r\n // 导出\r\n // exports(value) {\r\n // this.exportListOn = this.exportList.findIndex(\r\n // (item) => item.name === value\r\n // );\r\n // let formValidate = this.orderData;\r\n // let data = {\r\n // status: formValidate.status,\r\n // data: formValidate.data,\r\n // real_name: formValidate.real_name,\r\n // type: value,\r\n // };\r\n // storeOrderApi(data)\r\n // .then((res) => {\r\n // location.href = res.data[0];\r\n // })\r\n // .catch((res) => {\r\n // this.$Message.error(res.msg);\r\n // });\r\n // },\r\n // 数据导出;\r\n async exports() {\r\n let [th, filekey, data, fileName] = [[], [], [], ''];\r\n let excelData = JSON.parse(JSON.stringify(this.orderData));\r\n excelData.page = 1;\r\n excelData.product_id = this.$route.query.product_id || '';\r\n for (let i = 0; i < excelData.page + 1; i++) {\r\n let lebData = await this.getExcelData(excelData);\r\n if (!fileName) fileName = lebData.filename;\r\n if (!filekey.length) {\r\n filekey = lebData.filekey;\r\n }\r\n if (!th.length) th = lebData.header;\r\n if (lebData.export.length) {\r\n data = data.concat(lebData.export);\r\n excelData.page++;\r\n }\r\n }\r\n exportExcel(th, filekey, fileName, data);\r\n },\r\n getExcelData(excelData) {\r\n return new Promise((resolve, reject) => {\r\n storeIntegralOrder(excelData).then((res) => {\r\n return resolve(res.data);\r\n });\r\n });\r\n },\r\n // 具体日期\r\n onchangeTime(e) {\r\n this.timeVal = e;\r\n this.orderData.data = this.timeVal[0] ? this.timeVal.join('-') : '';\r\n this.$store.dispatch('integralOrder/getOrderTabs', {\r\n data: this.orderData.data,\r\n });\r\n this.getOrderTime(this.orderData.data);\r\n this.$emit('getList', 1);\r\n this.$emit('order-data', this.orderData);\r\n },\r\n // 选择时间\r\n selectChange(tab) {\r\n this.$store.dispatch('integralOrder/getOrderTabs', { data: tab });\r\n this.orderData.data = tab;\r\n this.getOrderTime(this.orderData.data);\r\n this.timeVal = [];\r\n this.$emit('getList');\r\n this.$emit('order-data', this.orderData);\r\n },\r\n // 订单选择状态\r\n selectChange2(tab) {\r\n this.getOrderStatus(tab);\r\n this.$emit('getList', 1);\r\n },\r\n userSearchs(type) {\r\n this.getOrderType(type);\r\n this.$emit('getList', 1);\r\n },\r\n // 时间状态\r\n timeChange(time) {\r\n this.getOrderTime(time);\r\n this.$emit('getList');\r\n },\r\n // 订单号搜索\r\n orderSearch(num) {\r\n this.getOrderNum(num);\r\n this.getfieldKey(this.orderData.field_key);\r\n this.$emit('getList', 1);\r\n },\r\n // 点击订单类型\r\n onClickTab() {\r\n this.$emit('onChangeType', this.currentTab);\r\n },\r\n // 批量删除\r\n delAll() {\r\n if (this.delIdList.length === 0) {\r\n this.$Message.error('请先选择删除的订单!');\r\n } else {\r\n if (this.isDels) {\r\n this.delIdList.filter((item) => {\r\n this.isDelIdList.push(item.id);\r\n });\r\n let idss = {\r\n ids: this.isDelIdList,\r\n all: this.isAll,\r\n where: this.orderData,\r\n };\r\n let delfromData = {\r\n title: '删除订单',\r\n url: `/order/dels`,\r\n method: 'post',\r\n ids: idss,\r\n };\r\n this.$modalSure(delfromData)\r\n .then((res) => {\r\n this.$Message.success(res.msg);\r\n this.tabList();\r\n })\r\n .catch((res) => {\r\n this.$Message.error(res.msg);\r\n });\r\n } else {\r\n const title = '错误!';\r\n const content = '<p>您选择的的订单存在用户未删除的订单,无法删除用户未删除的订单!</p>';\r\n this.$Modal.error({\r\n title: title,\r\n content: content,\r\n });\r\n }\r\n }\r\n },\r\n del(name) {\r\n // this.orderInfo = ''\r\n this.modals2 = false;\r\n this.writeOffFrom.confirm = 0;\r\n this.$refs[name].resetFields();\r\n },\r\n handleSubmit() {\r\n this.$emit('on-submit', this.data);\r\n },\r\n // 刷新\r\n Refresh() {\r\n this.$emit('getList');\r\n },\r\n //\r\n handleReset() {\r\n this.$refs.form.resetFields();\r\n this.$emit('on-reset');\r\n },\r\n // 上传头部token\r\n // getToken() {\r\n // this.uploadHeaders[\"Authori-zation\"] =\r\n // \"Bearer \" + util.cookies.get(\"token\");\r\n // },\r\n // beforeUpload(file){\r\n // /* Boilerplate to set up FileReader */\r\n // \tconst reader = new FileReader();\r\n // \treader.onload = (e) => {\r\n // \t\t/* Parse data */\r\n // \t\tconst bstr = e.target.result;\r\n // \t\tconst wb = XLSX.read(bstr, {type:'binary'});\r\n // \t\t/* Get first worksheet */\r\n // \t\tconst wsname = wb.SheetNames[0];\r\n // \t\tconst ws = wb.Sheets[wsname];\r\n // \t\t/* Convert array of arrays */\r\n // \t\tconst data = XLSX.utils.sheet_to_json(ws, {header:1});\r\n // \t\t/* Update state */\r\n // \t\tthis.data5 = data;\r\n // this.cols5 = make_cols(ws['!ref']);\r\n // this.modal5 = true;\r\n // \t};\r\n // \treader.readAsBinaryString(file);\r\n // },\r\n // 上传成功\r\n uploadSuccess(res, file, fileList) {\r\n if (res.status === 200) {\r\n this.$Message.success(res.msg);\r\n this.file = res.data.src;\r\n this.fileList = fileList;\r\n } else {\r\n this.$Message.error(res.msg);\r\n }\r\n },\r\n //移除文件\r\n removeFile(file, fileList) {\r\n this.file = '';\r\n this.fileList = fileList;\r\n },\r\n // 手动批量发货-确定\r\n manualModalOk() {\r\n this.$refs.upload.clearFiles();\r\n handBatchDelivery({\r\n file: this.file,\r\n })\r\n .then((res) => {\r\n this.$Message.success(res.msg);\r\n this.fileList = [];\r\n })\r\n .catch((err) => {\r\n this.$Message.error(err.msg);\r\n this.fileList = [];\r\n });\r\n },\r\n // 手动批量发货-取消\r\n manualModalCancel() {\r\n this.fileList = [];\r\n this.$refs.upload.clearFiles();\r\n },\r\n // 自动批量发货-取消\r\n autoModalOk() {\r\n if (this.isAll == '全部' || this.formSelection.length) {\r\n this.$refs.send.modals = true;\r\n this.$refs.send.getList();\r\n this.$refs.send.getDeliveryList();\r\n } else {\r\n this.$Message.error('请选择本页订单');\r\n }\r\n },\r\n // 自动批量发货-取消\r\n autolModalCancel() {},\r\n submitFail() {\r\n otherBatchDelivery();\r\n },\r\n queuemModal() {\r\n // this.$router.push({ path: 'queue/list' });\r\n this.$refs.queue.modal = true;\r\n },\r\n onAuto() {\r\n this.$refs.sends.modals = true;\r\n this.$refs.sends.getList();\r\n this.$refs.sends.getDeliveryList();\r\n },\r\n // 下载物流公司对照表\r\n getExpressList() {\r\n exportExpressList()\r\n .then((res) => {\r\n window.open(res.data[0]);\r\n })\r\n .catch((err) => {\r\n this.$Message.error(err.msg);\r\n });\r\n },\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped lang=\"stylus\">\r\n.tab_data >>> .ivu-form-item-content {\r\n margin-left: 0 !important;\r\n}\r\n\r\n.table_box >>> .ivu-divider-horizontal {\r\n margin-top: 0px !important;\r\n}\r\n\r\n.table_box >>> .ivu-form-item {\r\n margin-bottom: 15px !important;\r\n}\r\n\r\n.tabform {\r\n margin-bottom: 10px;\r\n}\r\n\r\n.Refresh {\r\n font-size: 12px;\r\n color: #1890FF;\r\n cursor: pointer;\r\n}\r\n\r\n.order-wrapper {\r\n margin-top: 10px;\r\n padding: 10px;\r\n border: 1px solid #ddd;\r\n\r\n .title {\r\n font-size: 16px;\r\n }\r\n\r\n .order-box {\r\n margin-top: 10px;\r\n border: 1px solid #ddd;\r\n\r\n .item {\r\n display: flex;\r\n align-items: center;\r\n border-bottom: 1px solid #ddd;\r\n\r\n &:last-child {\r\n border-bottom: 0;\r\n }\r\n\r\n .label {\r\n width: 100px;\r\n padding: 10px 0 10px 10px;\r\n border-right: 1px solid #ddd;\r\n }\r\n\r\n .con {\r\n flex: 1;\r\n padding: 10px 0 10px 10px;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.manual-modal {\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n.df {\r\n display: flex;\r\n}\r\n</style>\r\n"]}]}