43883f4a5de78a7db4f842a85899da8a.json 42 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\\order\\orderList\\components\\tableFrom.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\newItem\\admin\\src\\pages\\order\\orderList\\components\\tableFrom.vue","mtime":1677828270224},{"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 { mapState, mapMutations } from 'vuex';
import { putWrite, storeOrderApi } from '@/api/order';
import { exportOrderList } from '@/api/export';
export default {
  name: 'table_from',
  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 {
        var reg = /\b\d{12}\b/;

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

    return {
      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: '',
      grid: {
        xl: 8,
        lg: 8,
        md: 8,
        sm: 24,
        xs: 24
      },
      // 搜索条件
      orderData: {
        status: '',
        data: '',
        real_name: '',
        field_key: 'all',
        pay_type: '',
        type: ''
      },
      modalTitleSs: '',
      statusType: '',
      time: '',
      value2: [],
      writeOffRules: {
        code: [{
          validator: codeNum,
          trigger: 'blur',
          required: true
        }]
      },
      writeOffFrom: {
        code: '',
        confirm: 0
      },
      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'
      }]
    };
  },
  computed: _objectSpread(_objectSpread({}, mapState('order', ['orderChartType', 'isDels', 'delIdList', 'orderType'])), {}, {
    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();
    }
  },
  methods: _objectSpread(_objectSpread({}, mapMutations('order', ['getOrderStatus', 'getOrderType', 'getOrderTime', 'getOrderNum', 'getfieldKey'])), {}, {
    getPath: function getPath() {
      this.orderData.status = this.$route.query.status.toString();
      this.getOrderStatus(this.orderData.status);
      this.$emit('getList', 1);
    },
    changeModal: function changeModal(status) {
      if (!status) this.writeOffFrom.code = '';
    },
    // 导出
    exportList: function exportList() {
      var _this = 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:
                _this.orderData.type = _this.orderType === 0 ? '' : _this.orderType;
                th = [], filekey = [], data = [], fileName = '';
                excelData = JSON.parse(JSON.stringify(_this.orderData));
                excelData.page = 1;
                excelData.limit = 200;
                i = 0;

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

                _context.next = 9;
                return _this.getExcelData(excelData);

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

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

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

                if (!lebData.export.length) {
                  _context.next = 18;
                  break;
                }

                data = data.concat(lebData.export);
                excelData.page++;
                _context.next = 20;
                break;

              case 18:
                _this.$exportExcel(th, filekey, fileName, data);

                return _context.abrupt("return");

              case 20:
                i++;
                _context.next = 6;
                break;

              case 23:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }))();
    },
    getExcelData: function getExcelData(excelData) {
      return new Promise(function (resolve, reject) {
        exportOrderList(excelData).then(function (res) {
          resolve(res.data);
        });
      });
    },
    // 具体日期
    onchangeTime: function onchangeTime(e) {
      this.timeVal = e;
      this.orderData.data = this.timeVal[0] ? this.timeVal.join('-') : '';
      this.$store.dispatch('order/getOrderTabs', {
        data: this.orderData.data
      });
      this.getOrderTime(this.orderData.data);
      this.$emit('getList', 1);
    },
    // 选择时间
    selectChange: function selectChange(tab) {
      this.$store.dispatch('order/getOrderTabs', {
        data: tab
      });
      this.orderData.data = tab;
      this.getOrderTime(this.orderData.data);
      this.timeVal = [];
      this.$emit('getList');
    },
    // 订单选择状态
    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 _this2 = this;

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

            _this2.$emit('getList');
          }).catch(function (res) {
            _this2.$Message.error(res.msg);
          });
        } else {
          var title = '错误！';
          var content = '<p>您选择的的订单存在用户未删除的订单，无法删除用户未删除的订单！</p>';
          this.$Modal.error({
            title: title,
            content: content
          });
        }
      }
    },
    // 订单核销
    writeOff: function writeOff() {
      this.modals2 = true;
    },
    // 验证
    search: function search(name) {
      var _this3 = this;

      this.$refs[name].validate(function (valid) {
        if (valid) {
          _this3.writeOffFrom.confirm = 0;
          putWrite(_this3.writeOffFrom).then( /*#__PURE__*/function () {
            var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(res) {
              return regeneratorRuntime.wrap(function _callee2$(_context2) {
                while (1) {
                  switch (_context2.prev = _context2.next) {
                    case 0:
                      if (res.status === 200) {
                        _this3.$Message.success(res.msg); // this.modals2 = false
                        // this.$refs[name].resetFields()
                        // this.$emit('getList')

                      } else {
                        _this3.$Message.error(res.msg);
                      }

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

            return function (_x) {
              return _ref.apply(this, arguments);
            };
          }()).catch(function (res) {
            _this3.$Message.error(res.msg);
          });
        } else {
          _this3.$Message.error('请填写正确的核销码');
        }
      });
    },
    // 订单核销
    ok: function ok(name) {
      var _this4 = this;

      if (!this.writeOffFrom.code) {
        this.$Message.warning('请先验证订单！');
      } else {
        this.writeOffFrom.confirm = 1;
        putWrite(this.writeOffFrom).then( /*#__PURE__*/function () {
          var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(res) {
            return regeneratorRuntime.wrap(function _callee3$(_context3) {
              while (1) {
                switch (_context3.prev = _context3.next) {
                  case 0:
                    if (res.status === 200) {
                      _this4.$Message.success(res.msg);

                      _this4.modals2 = false;

                      _this4.$refs[name].resetFields();

                      _this4.$emit('getList', 1);
                    } else {
                      _this4.$Message.error(res.msg);
                    }

                  case 1:
                  case "end":
                    return _context3.stop();
                }
              }
            }, _callee3);
          }));

          return function (_x2) {
            return _ref2.apply(this, arguments);
          };
        }()).catch(function (res) {
          _this4.$Message.error(res.msg);
        });
      }
    },
    del: function del(name) {
      this.modals2 = false;
      this.writeOffFrom.code = '';
      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');
    }
  })
};"},{"version":3,"mappings":"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","names":["name","data","callback","fromList","title","custom","fromTxt","text","val","currentTab","grid","xl","lg","md","sm","xs","orderData","status","real_name","field_key","pay_type","type","modalTitleSs","statusType","time","value2","writeOffRules","code","validator","trigger","required","writeOffFrom","confirm","modals2","timeVal","options","shortcuts","value","start","end","payList","label","computed","mapState","today","watch","$route","created","methods","mapMutations","getPath","changeModal","exportList","th","filekey","fileName","excelData","JSON","i","lebData","getExcelData","exportOrderList","resolve","onchangeTime","e","selectChange","tab","selectChange2","userSearchs","timeChange","orderSearch","num","onClickTab","delAll","ids","url","method","then","catch","content","writeOff","search","putWrite","ok","del","handleSubmit","Refresh","handleReset"],"sourceRoot":"src/pages/order/orderList/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=\"80\"\r\n label-position=\"right\"\r\n class=\"tabform\"\r\n @submit.native.prevent\r\n >\r\n <Row :gutter=\"24\" type=\"flex\" justify=\"end\">\r\n <Col span=\"24\" 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=\"\">全部</Radio>\r\n <Radio label=\"0\">未支付</Radio>\r\n <Radio label=\"1\">未发货</Radio>\r\n <Radio label=\"2\">待收货</Radio>\r\n <Radio label=\"3\">待评价</Radio>\r\n <Radio label=\"4\">交易完成</Radio>\r\n <Radio label=\"5\">待核销</Radio>\r\n <Radio label=\"6\">已核销</Radio>\r\n <!-- <Radio label=\"-1\">退款中 {{ '(' +orderChartType.refunding?orderChartType.refunding:0+ ')' }}</Radio>-->\r\n <!-- <Radio label=\"-2\">已退款 {{ '(' +orderChartType.refund?orderChartType.refund:0+ ')' }}</Radio>-->\r\n <Radio label=\"-2\">已退款</Radio>\r\n <Radio label=\"-4\">已删除</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n </Col>\r\n <Col span=\"24\" class=\"ivu-text-left\">\r\n <FormItem label=\"支付方式:\">\r\n <RadioGroup v-model=\"orderData.pay_type\" type=\"button\" @on-change=\"userSearchs\">\r\n <Radio v-for=\"item in payList\" :label=\"item.val\" :key=\"item.id\">{{ item.label }}</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=\"16\">\r\n <Col span=\"12\" class=\"mr\">\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 @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=\"title\">商品名称(模糊)</Option>\r\n </Select>\r\n </Input>\r\n </FormItem>\r\n </Col>\r\n <!--<Col v-bind=\"grid\">-->\r\n <!--<Button class=\"mr\">导出</Button>-->\r\n <!--<span class=\"Refresh\" @click=\"Refresh\">刷新</span><Icon type=\"ios-refresh\" />-->\r\n <!--</Col>-->\r\n </Col>\r\n <Col span=\"24\">\r\n <div class=\"ml20\">\r\n <Button v-auth=\"['order-dels']\" class=\"mr10\" type=\"primary\" @click=\"delAll\">批量删除订单</Button>\r\n <Button v-auth=\"['order-write']\" type=\"success\" class=\"mr10 greens\" size=\"default\" @click=\"writeOff\">\r\n <Icon type=\"md-list\"></Icon>\r\n 订单核销\r\n </Button>\r\n <Button v-auth=\"['export-storeOrder']\" class=\"export\" icon=\"ios-share-outline\" @click=\"exportList\"\r\n >导出</Button\r\n >\r\n </div>\r\n </Col>\r\n </Row>\r\n </Form>\r\n <!--订单核销模态框-->\r\n <Modal\r\n v-model=\"modals2\"\r\n title=\"订单核销\"\r\n class=\"paymentFooter\"\r\n :closable=\"false\"\r\n width=\"400\"\r\n @on-visible-change=\"changeModal\"\r\n >\r\n <Form\r\n ref=\"writeOffFrom\"\r\n :model=\"writeOffFrom\"\r\n :rules=\"writeOffRules\"\r\n label-position=\"right\"\r\n class=\"tabform\"\r\n @submit.native.prevent\r\n >\r\n <FormItem prop=\"code\" label-for=\"code\">\r\n <Input style=\"width: 100%\" type=\"text\" placeholder=\"请输入12位核销码\" v-model.number=\"writeOffFrom.code\" />\r\n </FormItem>\r\n </Form>\r\n <div slot=\"footer\">\r\n <Button type=\"primary\" @click=\"ok('writeOffFrom')\">立即核销</Button>\r\n <Button @click=\"del('writeOffFrom')\">取消</Button>\r\n </div>\r\n </Modal>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport { mapState, mapMutations } from 'vuex';\r\nimport { putWrite, storeOrderApi } from '@/api/order';\r\nimport { exportOrderList } from '@/api/export';\r\nexport default {\r\n name: 'table_from',\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 = /\\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 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 grid: {\r\n xl: 8,\r\n lg: 8,\r\n md: 8,\r\n sm: 24,\r\n xs: 24,\r\n },\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 type: '',\r\n },\r\n modalTitleSs: '',\r\n statusType: '',\r\n time: '',\r\n value2: [],\r\n writeOffRules: {\r\n code: [{ validator: codeNum, trigger: 'blur', required: true }],\r\n },\r\n writeOffFrom: {\r\n code: '',\r\n confirm: 0,\r\n },\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 };\r\n },\r\n computed: {\r\n ...mapState('order', ['orderChartType', 'isDels', 'delIdList', 'orderType']),\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 },\r\n methods: {\r\n ...mapMutations('order', ['getOrderStatus', 'getOrderType', 'getOrderTime', 'getOrderNum', 'getfieldKey']),\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 },\r\n changeModal(status) {\r\n if (!status) this.writeOffFrom.code = '';\r\n },\r\n // 导出\r\n async exportList() {\r\n this.orderData.type = this.orderType === 0 ? '' : this.orderType;\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.limit = 200;\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 } else {\r\n this.$exportExcel(th, filekey, fileName, data);\r\n return;\r\n }\r\n }\r\n },\r\n getExcelData(excelData) {\r\n return new Promise((resolve, reject) => {\r\n exportOrderList(excelData).then((res) => {\r\n 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('order/getOrderTabs', { data: this.orderData.data });\r\n this.getOrderTime(this.orderData.data);\r\n this.$emit('getList', 1);\r\n },\r\n // 选择时间\r\n selectChange(tab) {\r\n this.$store.dispatch('order/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 },\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 let idss = {\r\n ids: this.delIdList,\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.$emit('getList');\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 // 订单核销\r\n writeOff() {\r\n this.modals2 = true;\r\n },\r\n // 验证\r\n search(name) {\r\n this.$refs[name].validate((valid) => {\r\n if (valid) {\r\n this.writeOffFrom.confirm = 0;\r\n putWrite(this.writeOffFrom)\r\n .then(async (res) => {\r\n if (res.status === 200) {\r\n this.$Message.success(res.msg);\r\n // this.modals2 = false\r\n // this.$refs[name].resetFields()\r\n // this.$emit('getList')\r\n } else {\r\n this.$Message.error(res.msg);\r\n }\r\n })\r\n .catch((res) => {\r\n this.$Message.error(res.msg);\r\n });\r\n } else {\r\n this.$Message.error('请填写正确的核销码');\r\n }\r\n });\r\n },\r\n // 订单核销\r\n ok(name) {\r\n if (!this.writeOffFrom.code) {\r\n this.$Message.warning('请先验证订单!');\r\n } else {\r\n this.writeOffFrom.confirm = 1;\r\n putWrite(this.writeOffFrom)\r\n .then(async (res) => {\r\n if (res.status === 200) {\r\n this.$Message.success(res.msg);\r\n this.modals2 = false;\r\n this.$refs[name].resetFields();\r\n this.$emit('getList', 1);\r\n } else {\r\n this.$Message.error(res.msg);\r\n }\r\n })\r\n .catch((res) => {\r\n this.$Message.error(res.msg);\r\n });\r\n }\r\n },\r\n del(name) {\r\n this.modals2 = false;\r\n this.writeOffFrom.code = '';\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 },\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</style>\r\n"]}]}