suyiScreen/node_modules/.cache/babel-loader/5a4ef7c0bc4f86995cfd6eee4d6...

1 line
33 KiB
JSON

{"remainingRequest":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\thread-loader\\dist\\cjs.js!C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\babel-loader\\lib\\index.js!C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\@jiaminghi\\data-view\\lib\\components\\scrollBoard\\src\\main.vue?vue&type=script&lang=js&","dependencies":[{"path":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\@jiaminghi\\data-view\\lib\\components\\scrollBoard\\src\\main.vue","mtime":1670640065295},{"path":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1670640066936},{"path":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\thread-loader\\dist\\cjs.js","mtime":1670640073542},{"path":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\babel-loader\\lib\\index.js","mtime":1670640065986},{"path":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1670640066936},{"path":"C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\vue-loader\\lib\\index.js","mtime":1670640074287}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.array.concat";
import "core-js/modules/es.array.fill";
import "core-js/modules/es.array.map";
import "core-js/modules/es.array.reduce";
import "core-js/modules/es.array.slice";
import "core-js/modules/es.array.splice";
import "core-js/modules/es.object.to-string";
import "regenerator-runtime/runtime";
import _asyncToGenerator from "C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/asyncToGenerator";
import _objectSpread from "C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/objectSpread2";
import _toConsumableArray from "C:\\hjmWeb\\suyiScreen\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/toConsumableArray";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import autoResize from '../../../mixin/autoResize';
import { deepMerge } from '@jiaminghi/charts/lib/util/index';
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util';
export default {
  name: 'DvScrollBoard',
  mixins: [autoResize],
  props: {
    config: {
      type: Object,
      default: function _default() {
        return {};
      }
    }
  },
  data: function data() {
    return {
      ref: 'scroll-board',
      defaultConfig: {
        /**
         * @description Board header
         * @type {Array<String>}
         * @default header = []
         * @example header = ['column1', 'column2', 'column3']
         */
        header: [],

        /**
         * @description Board data
         * @type {Array<Array>}
         * @default data = []
         */
        data: [],

        /**
         * @description Row num
         * @type {Number}
         * @default rowNum = 5
         */
        rowNum: 5,

        /**
         * @description Header background color
         * @type {String}
         * @default headerBGC = '#00BAFF'
         */
        headerBGC: '#00BAFF',

        /**
         * @description Odd row background color
         * @type {String}
         * @default oddRowBGC = '#003B51'
         */
        oddRowBGC: '#003B51',

        /**
         * @description Even row background color
         * @type {String}
         * @default evenRowBGC = '#003B51'
         */
        evenRowBGC: '#0A2732',

        /**
         * @description Scroll wait time
         * @type {Number}
         * @default waitTime = 2000
         */
        waitTime: 2000,

        /**
         * @description Header height
         * @type {Number}
         * @default headerHeight = 35
         */
        headerHeight: 35,

        /**
         * @description Column width
         * @type {Array<Number>}
         * @default columnWidth = []
         */
        columnWidth: [],

        /**
         * @description Column align
         * @type {Array<String>}
         * @default align = []
         * @example align = ['left', 'center', 'right']
         */
        align: [],

        /**
         * @description Show index
         * @type {Boolean}
         * @default index = false
         */
        index: false,

        /**
         * @description index Header
         * @type {String}
         * @default indexHeader = '#'
         */
        indexHeader: '#',

        /**
         * @description Carousel type
         * @type {String}
         * @default carousel = 'single'
         * @example carousel = 'single' | 'page'
         */
        carousel: 'single'
      },
      mergedConfig: null,
      header: [],
      rowsData: [],
      rows: [],
      widths: [],
      heights: [],
      avgHeight: 0,
      aligns: [],
      animationIndex: 0,
      animationHandler: '',
      updater: 0
    };
  },
  watch: {
    config: function config() {
      var stopAnimation = this.stopAnimation,
          calcData = this.calcData;
      stopAnimation();
      calcData();
    }
  },
  methods: {
    afterAutoResizeMixinInit: function afterAutoResizeMixinInit() {
      var calcData = this.calcData;
      calcData();
    },
    onResize: function onResize() {
      var mergedConfig = this.mergedConfig,
          calcWidths = this.calcWidths,
          calcHeights = this.calcHeights;
      if (!mergedConfig) return;
      calcWidths();
      calcHeights();
    },
    calcData: function calcData() {
      var mergeConfig = this.mergeConfig,
          calcHeaderData = this.calcHeaderData,
          calcRowsData = this.calcRowsData;
      mergeConfig();
      calcHeaderData();
      calcRowsData();
      var calcWidths = this.calcWidths,
          calcHeights = this.calcHeights,
          calcAligns = this.calcAligns;
      calcWidths();
      calcHeights();
      calcAligns();
      var animation = this.animation;
      animation(true);
    },
    mergeConfig: function mergeConfig() {
      var config = this.config,
          defaultConfig = this.defaultConfig;
      this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {});
    },
    calcHeaderData: function calcHeaderData() {
      var _this$mergedConfig = this.mergedConfig,
          header = _this$mergedConfig.header,
          index = _this$mergedConfig.index,
          indexHeader = _this$mergedConfig.indexHeader;

      if (!header.length) {
        this.header = [];
        return;
      }

      header = _toConsumableArray(header);
      if (index) header.unshift(indexHeader);
      this.header = header;
    },
    calcRowsData: function calcRowsData() {
      var _this$mergedConfig2 = this.mergedConfig,
          data = _this$mergedConfig2.data,
          index = _this$mergedConfig2.index,
          headerBGC = _this$mergedConfig2.headerBGC,
          rowNum = _this$mergedConfig2.rowNum;

      if (index) {
        data = data.map(function (row, i) {
          row = _toConsumableArray(row);
          var indexTag = "<span class=\"index\" style=\"background-color: ".concat(headerBGC, ";\">").concat(i + 1, "</span>");
          row.unshift(indexTag);
          return row;
        });
      }

      data = data.map(function (ceils, i) {
        return {
          ceils: ceils,
          rowIndex: i
        };
      });
      var rowLength = data.length;

      if (rowLength > rowNum && rowLength < 2 * rowNum) {
        data = [].concat(_toConsumableArray(data), _toConsumableArray(data));
      }

      data = data.map(function (d, i) {
        return _objectSpread({}, d, {
          scroll: i
        });
      });
      this.rowsData = data;
      this.rows = data;
    },
    calcWidths: function calcWidths() {
      var width = this.width,
          mergedConfig = this.mergedConfig,
          rowsData = this.rowsData;
      var columnWidth = mergedConfig.columnWidth,
          header = mergedConfig.header;
      var usedWidth = columnWidth.reduce(function (all, w) {
        return all + w;
      }, 0);
      var columnNum = 0;

      if (rowsData[0]) {
        columnNum = rowsData[0].ceils.length;
      } else if (header.length) {
        columnNum = header.length;
      }

      var avgWidth = (width - usedWidth) / (columnNum - columnWidth.length);
      var widths = new Array(columnNum).fill(avgWidth);
      this.widths = deepMerge(widths, columnWidth);
    },
    calcHeights: function calcHeights() {
      var onresize = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
      var height = this.height,
          mergedConfig = this.mergedConfig,
          header = this.header;
      var headerHeight = mergedConfig.headerHeight,
          rowNum = mergedConfig.rowNum,
          data = mergedConfig.data;
      var allHeight = height;
      if (header.length) allHeight -= headerHeight;
      var avgHeight = allHeight / rowNum;
      this.avgHeight = avgHeight;
      if (!onresize) this.heights = new Array(data.length).fill(avgHeight);
    },
    calcAligns: function calcAligns() {
      var header = this.header,
          mergedConfig = this.mergedConfig;
      var columnNum = header.length;
      var aligns = new Array(columnNum).fill('left');
      var align = mergedConfig.align;
      this.aligns = deepMerge(aligns, align);
    },
    animation: function animation() {
      var _arguments = arguments,
          _this = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var _this$heights;

        var start, avgHeight, animationIndex, mergedConfig, rowsData, animation, updater, waitTime, carousel, rowNum, rowLength, animationNum, rows, back;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                start = _arguments.length > 0 && _arguments[0] !== undefined ? _arguments[0] : false;
                avgHeight = _this.avgHeight, animationIndex = _this.animationIndex, mergedConfig = _this.mergedConfig, rowsData = _this.rowsData, animation = _this.animation, updater = _this.updater;
                waitTime = mergedConfig.waitTime, carousel = mergedConfig.carousel, rowNum = mergedConfig.rowNum;
                rowLength = rowsData.length;

                if (!(rowNum >= rowLength)) {
                  _context.next = 6;
                  break;
                }

                return _context.abrupt("return");

              case 6:
                if (!start) {
                  _context.next = 11;
                  break;
                }

                _context.next = 9;
                return new Promise(function (resolve) {
                  return setTimeout(resolve, waitTime);
                });

              case 9:
                if (!(updater !== _this.updater)) {
                  _context.next = 11;
                  break;
                }

                return _context.abrupt("return");

              case 11:
                animationNum = carousel === 'single' ? 1 : rowNum;
                rows = rowsData.slice(animationIndex);
                rows.push.apply(rows, _toConsumableArray(rowsData.slice(0, animationIndex)));
                _this.rows = rows;
                _this.heights = new Array(rowLength).fill(avgHeight);
                _context.next = 18;
                return new Promise(function (resolve) {
                  return setTimeout(resolve, 300);
                });

              case 18:
                if (!(updater !== _this.updater)) {
                  _context.next = 20;
                  break;
                }

                return _context.abrupt("return");

              case 20:
                (_this$heights = _this.heights).splice.apply(_this$heights, [0, animationNum].concat(_toConsumableArray(new Array(animationNum).fill(0))));

                animationIndex += animationNum;
                back = animationIndex - rowLength;
                if (back >= 0) animationIndex = back;
                _this.animationIndex = animationIndex;
                _this.animationHandler = setTimeout(animation, waitTime - 300);

              case 26:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }))();
    },
    stopAnimation: function stopAnimation() {
      var animationHandler = this.animationHandler,
          updater = this.updater;
      this.updater = (updater + 1) % 999999;
      if (!animationHandler) return;
      clearTimeout(animationHandler);
    },
    emitEvent: function emitEvent(ri, ci, row, ceil) {
      var ceils = row.ceils,
          rowIndex = row.rowIndex;
      this.$emit('click', {
        row: ceils,
        ceil: ceil,
        rowIndex: rowIndex,
        columnIndex: ci
      });
    }
  },
  destroyed: function destroyed() {
    var stopAnimation = this.stopAnimation;
    stopAnimation();
  }
};"},{"version":3,"sources":["main.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgDA,OAAA,UAAA,MAAA,2BAAA;AAEA,SAAA,SAAA,QAAA,kCAAA;AAEA,SAAA,SAAA,QAAA,qCAAA;AAEA,eAAA;AACA,EAAA,IAAA,EAAA,eADA;AAEA,EAAA,MAAA,EAAA,CAAA,UAAA,CAFA;AAGA,EAAA,KAAA,EAAA;AACA,IAAA,MAAA,EAAA;AACA,MAAA,IAAA,EAAA,MADA;AAEA,MAAA,OAAA,EAAA;AAAA,eAAA,EAAA;AAAA;AAFA;AADA,GAHA;AASA,EAAA,IATA,kBASA;AACA,WAAA;AACA,MAAA,GAAA,EAAA,cADA;AAGA,MAAA,aAAA,EAAA;AACA;;;;;;AAMA,QAAA,MAAA,EAAA,EAPA;;AAQA;;;;;AAKA,QAAA,IAAA,EAAA,EAbA;;AAcA;;;;;AAKA,QAAA,MAAA,EAAA,CAnBA;;AAoBA;;;;;AAKA,QAAA,SAAA,EAAA,SAzBA;;AA0BA;;;;;AAKA,QAAA,SAAA,EAAA,SA/BA;;AAgCA;;;;;AAKA,QAAA,UAAA,EAAA,SArCA;;AAsCA;;;;;AAKA,QAAA,QAAA,EAAA,IA3CA;;AA4CA;;;;;AAKA,QAAA,YAAA,EAAA,EAjDA;;AAkDA;;;;;AAKA,QAAA,WAAA,EAAA,EAvDA;;AAwDA;;;;;;AAMA,QAAA,KAAA,EAAA,EA9DA;;AA+DA;;;;;AAKA,QAAA,KAAA,EAAA,KApEA;;AAqEA;;;;;AAKA,QAAA,WAAA,EAAA,GA1EA;;AA2EA;;;;;;AAMA,QAAA,QAAA,EAAA;AAjFA,OAHA;AAuFA,MAAA,YAAA,EAAA,IAvFA;AAyFA,MAAA,MAAA,EAAA,EAzFA;AA2FA,MAAA,QAAA,EAAA,EA3FA;AA6FA,MAAA,IAAA,EAAA,EA7FA;AA+FA,MAAA,MAAA,EAAA,EA/FA;AAiGA,MAAA,OAAA,EAAA,EAjGA;AAmGA,MAAA,SAAA,EAAA,CAnGA;AAqGA,MAAA,MAAA,EAAA,EArGA;AAuGA,MAAA,cAAA,EAAA,CAvGA;AAyGA,MAAA,gBAAA,EAAA,EAzGA;AA2GA,MAAA,OAAA,EAAA;AA3GA,KAAA;AA6GA,GAvHA;AAwHA,EAAA,KAAA,EAAA;AACA,IAAA,MADA,oBACA;AAAA,UACA,aADA,GACA,IADA,CACA,aADA;AAAA,UACA,QADA,GACA,IADA,CACA,QADA;AAGA,MAAA,aAAA;AAEA,MAAA,QAAA;AACA;AAPA,GAxHA;AAiIA,EAAA,OAAA,EAAA;AACA,IAAA,wBADA,sCACA;AAAA,UACA,QADA,GACA,IADA,CACA,QADA;AAGA,MAAA,QAAA;AACA,KALA;AAMA,IAAA,QANA,sBAMA;AAAA,UACA,YADA,GACA,IADA,CACA,YADA;AAAA,UACA,UADA,GACA,IADA,CACA,UADA;AAAA,UACA,WADA,GACA,IADA,CACA,WADA;AAGA,UAAA,CAAA,YAAA,EAAA;AAEA,MAAA,UAAA;AAEA,MAAA,WAAA;AACA,KAdA;AAeA,IAAA,QAfA,sBAeA;AAAA,UACA,WADA,GACA,IADA,CACA,WADA;AAAA,UACA,cADA,GACA,IADA,CACA,cADA;AAAA,UACA,YADA,GACA,IADA,CACA,YADA;AAGA,MAAA,WAAA;AAEA,MAAA,cAAA;AAEA,MAAA,YAAA;AAPA,UASA,UATA,GASA,IATA,CASA,UATA;AAAA,UASA,WATA,GASA,IATA,CASA,WATA;AAAA,UASA,UATA,GASA,IATA,CASA,UATA;AAWA,MAAA,UAAA;AAEA,MAAA,WAAA;AAEA,MAAA,UAAA;AAfA,UAiBA,SAjBA,GAiBA,IAjBA,CAiBA,SAjBA;AAmBA,MAAA,SAAA,CAAA,IAAA,CAAA;AACA,KAnCA;AAoCA,IAAA,WApCA,yBAoCA;AAAA,UACA,MADA,GACA,IADA,CACA,MADA;AAAA,UACA,aADA,GACA,IADA,CACA,aADA;AAGA,WAAA,YAAA,GAAA,SAAA,CAAA,SAAA,CAAA,aAAA,EAAA,IAAA,CAAA,EAAA,MAAA,IAAA,EAAA,CAAA;AACA,KAxCA;AAyCA,IAAA,cAzCA,4BAyCA;AAAA,+BACA,KAAA,YADA;AAAA,UACA,MADA,sBACA,MADA;AAAA,UACA,KADA,sBACA,KADA;AAAA,UACA,WADA,sBACA,WADA;;AAGA,UAAA,CAAA,MAAA,CAAA,MAAA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","sourcesContent":["<template>\r\n <div class=\"dv-scroll-board\" :ref=\"ref\">\r\n <div class=\"header\" v-if=\"header.length && mergedConfig\" :style=\"`background-color: ${mergedConfig.headerBGC};`\">\r\n <div\r\n class=\"header-item\"\r\n v-for=\"(headerItem, i) in header\"\r\n :key=\"headerItem + i\"\r\n :style=\"`\r\n height: ${mergedConfig.headerHeight}px;\r\n line-height: ${mergedConfig.headerHeight}px;\r\n width: ${widths[i]}px;\r\n `\"\r\n :align=\"aligns[i]\"\r\n v-html=\"headerItem\"\r\n />\r\n </div>\r\n\r\n <div\r\n v-if=\"mergedConfig\"\r\n class=\"rows\"\r\n :style=\"`height: ${height - (header.length ? mergedConfig.headerHeight : 0)}px;`\"\r\n >\r\n <div\r\n class=\"row-item\"\r\n v-for=\"(row, ri) in rows\"\r\n :key=\"row.toString() + row.scroll\"\r\n :style=\"`\r\n height: ${heights[ri]}px;\r\n line-height: ${heights[ri]}px;\r\n background-color: ${mergedConfig[row.rowIndex % 2 === 0 ? 'evenRowBGC' : 'oddRowBGC']};\r\n `\"\r\n >\r\n <div\r\n class=\"ceil\"\r\n v-for=\"(ceil, ci) in row.ceils\"\r\n :key=\"ceil + ri + ci\"\r\n :style=\"`width: ${widths[ci]}px;`\"\r\n :align=\"aligns[ci]\"\r\n v-html=\"ceil\"\r\n @click=\"emitEvent(ri, ci, row, ceil)\"\r\n />\r\n\r\n </div>\r\n </div>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport autoResize from '../../../mixin/autoResize'\r\n\r\nimport { deepMerge } from '@jiaminghi/charts/lib/util/index'\r\n\r\nimport { deepClone } from '@jiaminghi/c-render/lib/plugin/util'\r\n\r\nexport default {\r\n name: 'DvScrollBoard',\r\n mixins: [autoResize],\r\n props: {\r\n config: {\r\n type: Object,\r\n default: () => ({})\r\n }\r\n },\r\n data () {\r\n return {\r\n ref: 'scroll-board',\r\n\r\n defaultConfig: {\r\n /**\r\n * @description Board header\r\n * @type {Array<String>}\r\n * @default header = []\r\n * @example header = ['column1', 'column2', 'column3']\r\n */\r\n header: [],\r\n /**\r\n * @description Board data\r\n * @type {Array<Array>}\r\n * @default data = []\r\n */\r\n data: [],\r\n /**\r\n * @description Row num\r\n * @type {Number}\r\n * @default rowNum = 5\r\n */\r\n rowNum: 5,\r\n /**\r\n * @description Header background color\r\n * @type {String}\r\n * @default headerBGC = '#00BAFF'\r\n */\r\n headerBGC: '#00BAFF',\r\n /**\r\n * @description Odd row background color\r\n * @type {String}\r\n * @default oddRowBGC = '#003B51'\r\n */\r\n oddRowBGC: '#003B51',\r\n /**\r\n * @description Even row background color\r\n * @type {String}\r\n * @default evenRowBGC = '#003B51'\r\n */\r\n evenRowBGC: '#0A2732',\r\n /**\r\n * @description Scroll wait time\r\n * @type {Number}\r\n * @default waitTime = 2000\r\n */\r\n waitTime: 2000,\r\n /**\r\n * @description Header height\r\n * @type {Number}\r\n * @default headerHeight = 35\r\n */\r\n headerHeight: 35,\r\n /**\r\n * @description Column width\r\n * @type {Array<Number>}\r\n * @default columnWidth = []\r\n */\r\n columnWidth: [],\r\n /**\r\n * @description Column align\r\n * @type {Array<String>}\r\n * @default align = []\r\n * @example align = ['left', 'center', 'right']\r\n */\r\n align: [],\r\n /**\r\n * @description Show index\r\n * @type {Boolean}\r\n * @default index = false\r\n */\r\n index: false,\r\n /**\r\n * @description index Header\r\n * @type {String}\r\n * @default indexHeader = '#'\r\n */\r\n indexHeader: '#',\r\n /**\r\n * @description Carousel type\r\n * @type {String}\r\n * @default carousel = 'single'\r\n * @example carousel = 'single' | 'page'\r\n */\r\n carousel: 'single'\r\n },\r\n\r\n mergedConfig: null,\r\n\r\n header: [],\r\n\r\n rowsData: [],\r\n\r\n rows: [],\r\n\r\n widths: [],\r\n\r\n heights: [],\r\n\r\n avgHeight: 0,\r\n\r\n aligns: [],\r\n\r\n animationIndex: 0,\r\n\r\n animationHandler: '',\r\n\r\n updater: 0\r\n }\r\n },\r\n watch: {\r\n config () {\r\n const { stopAnimation, calcData } = this\r\n\r\n stopAnimation()\r\n\r\n calcData()\r\n }\r\n },\r\n methods: {\r\n afterAutoResizeMixinInit () {\r\n const { calcData } = this\r\n\r\n calcData()\r\n },\r\n onResize () {\r\n const { mergedConfig, calcWidths, calcHeights } = this\r\n\r\n if (!mergedConfig) return\r\n\r\n calcWidths()\r\n\r\n calcHeights()\r\n },\r\n calcData () {\r\n const { mergeConfig, calcHeaderData, calcRowsData } = this\r\n\r\n mergeConfig()\r\n\r\n calcHeaderData()\r\n\r\n calcRowsData()\r\n\r\n const { calcWidths, calcHeights, calcAligns } = this\r\n\r\n calcWidths()\r\n\r\n calcHeights()\r\n\r\n calcAligns()\r\n\r\n const { animation } = this\r\n\r\n animation(true)\r\n },\r\n mergeConfig () {\r\n let { config, defaultConfig } = this\r\n\r\n this.mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})\r\n },\r\n calcHeaderData () {\r\n let { header, index, indexHeader} = this.mergedConfig\r\n\r\n if (!header.length) {\r\n this.header = []\r\n\r\n return\r\n }\r\n\r\n header = [...header]\r\n\r\n if (index) header.unshift(indexHeader)\r\n\r\n this.header = header\r\n },\r\n calcRowsData () {\r\n let { data, index, headerBGC, rowNum } = this.mergedConfig\r\n\r\n if (index) {\r\n data = data.map((row, i) => {\r\n row = [...row]\r\n\r\n const indexTag = `<span class=\"index\" style=\"background-color: ${headerBGC};\">${i + 1}</span>`\r\n\r\n row.unshift(indexTag)\r\n\r\n return row\r\n })\r\n }\r\n\r\n data = data.map((ceils, i) => ({ ceils, rowIndex: i }))\r\n\r\n const rowLength = data.length\r\n\r\n if (rowLength > rowNum && rowLength < 2 * rowNum) {\r\n data = [...data, ...data]\r\n }\r\n\r\n data = data.map((d, i) => ({ ...d, scroll: i }))\r\n\r\n this.rowsData = data\r\n this.rows = data\r\n },\r\n calcWidths () {\r\n const { width, mergedConfig, rowsData } = this\r\n\r\n const { columnWidth, header } = mergedConfig\r\n\r\n const usedWidth = columnWidth.reduce((all, w) => all + w, 0)\r\n\r\n let columnNum = 0\r\n if (rowsData[0]) {\r\n columnNum = rowsData[0].ceils.length\r\n } else if (header.length) {\r\n columnNum = header.length\r\n }\r\n\r\n const avgWidth = (width - usedWidth) / (columnNum - columnWidth.length)\r\n\r\n const widths = new Array(columnNum).fill(avgWidth)\r\n\r\n this.widths = deepMerge(widths, columnWidth)\r\n },\r\n calcHeights (onresize = false) {\r\n const { height, mergedConfig, header } = this\r\n\r\n const { headerHeight, rowNum, data } = mergedConfig\r\n\r\n let allHeight = height\r\n\r\n if (header.length) allHeight -= headerHeight\r\n\r\n const avgHeight = allHeight / rowNum\r\n\r\n this.avgHeight = avgHeight\r\n\r\n if (!onresize) this.heights = new Array(data.length).fill(avgHeight)\r\n },\r\n calcAligns () {\r\n const { header, mergedConfig } = this\r\n\r\n const columnNum = header.length\r\n\r\n let aligns = new Array(columnNum).fill('left')\r\n\r\n const { align } = mergedConfig\r\n\r\n this.aligns = deepMerge(aligns, align)\r\n },\r\n async animation (start = false) {\r\n let { avgHeight, animationIndex, mergedConfig, rowsData, animation, updater } = this\r\n\r\n const { waitTime, carousel, rowNum } = mergedConfig\r\n\r\n const rowLength = rowsData.length\r\n\r\n if (rowNum >= rowLength) return\r\n\r\n if (start) {\r\n await new Promise(resolve => setTimeout(resolve, waitTime))\r\n if (updater !== this.updater) return\r\n }\r\n\r\n const animationNum = carousel === 'single' ? 1 : rowNum\r\n\r\n let rows = rowsData.slice(animationIndex)\r\n rows.push(...rowsData.slice(0, animationIndex))\r\n\r\n this.rows = rows\r\n this.heights = new Array(rowLength).fill(avgHeight)\r\n\r\n await new Promise(resolve => setTimeout(resolve, 300))\r\n if (updater !== this.updater) return\r\n\r\n this.heights.splice(0, animationNum, ...new Array(animationNum).fill(0))\r\n\r\n animationIndex += animationNum\r\n\r\n const back = animationIndex - rowLength\r\n if (back >= 0) animationIndex = back\r\n\r\n this.animationIndex = animationIndex\r\n this.animationHandler = setTimeout(animation, waitTime - 300)\r\n },\r\n stopAnimation () {\r\n const { animationHandler, updater } = this\r\n\r\n this.updater = (updater + 1) % 999999\r\n\r\n if (!animationHandler) return\r\n\r\n clearTimeout(animationHandler)\r\n },\r\n emitEvent (ri, ci, row, ceil) {\r\n const { ceils, rowIndex } = row\r\n\r\n this.$emit('click', {\r\n row: ceils,\r\n ceil,\r\n rowIndex,\r\n columnIndex: ci\r\n })\r\n }\r\n },\r\n destroyed () {\r\n const { stopAnimation } = this\r\n\r\n stopAnimation()\r\n }\r\n}\r\n</script>"],"sourceRoot":"node_modules/@jiaminghi/data-view/lib/components/scrollBoard/src"}]}