UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

206 lines (203 loc) 20.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.RowDataContainer = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _dataRow = require("./data-row"); var _marked = /*#__PURE__*/_regenerator["default"].mark(rowsIterator), _marked2 = /*#__PURE__*/_regenerator["default"].mark(columnIterator); // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project /** * @param dataContainer * @param sharedRow */ function rowsIterator(dataContainer, sharedRow) { var numRows, rowIndex; return _regenerator["default"].wrap(function rowsIterator$(_context) { while (1) switch (_context.prev = _context.next) { case 0: numRows = dataContainer.numRows(); rowIndex = 0; case 2: if (!(rowIndex < numRows)) { _context.next = 8; break; } _context.next = 5; return dataContainer.row(rowIndex, sharedRow); case 5: ++rowIndex; _context.next = 2; break; case 8: case "end": return _context.stop(); } }, _marked); } /** * @param dataContainer * @param columnIndex */ function columnIterator(dataContainer, columnIndex) { var numRows, rowIndex; return _regenerator["default"].wrap(function columnIterator$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: numRows = dataContainer.numRows(); rowIndex = 0; case 2: if (!(rowIndex < numRows)) { _context2.next = 8; break; } _context2.next = 5; return dataContainer.valueAt(rowIndex, columnIndex); case 5: ++rowIndex; _context2.next = 2; break; case 8: case "end": return _context2.stop(); } }, _marked2); } /** * A data container where all data is stored internally as a 2D array. */ var RowDataContainer = exports.RowDataContainer = /*#__PURE__*/function () { function RowDataContainer(data) { var _data$rows$; (0, _classCallCheck2["default"])(this, RowDataContainer); (0, _defineProperty2["default"])(this, "_rows", void 0); (0, _defineProperty2["default"])(this, "_numColumns", void 0); if (!data.rows) { throw Error('RowDataContainer: no rows provided'); } if (!Array.isArray(data.rows)) { throw Error("RowDataContainer: rows object isn't an array"); } this._rows = data.rows; this._numColumns = ((_data$rows$ = data.rows[0]) === null || _data$rows$ === void 0 ? void 0 : _data$rows$.length) || 0; } return (0, _createClass2["default"])(RowDataContainer, [{ key: "numRows", value: function numRows() { return this._rows.length; } }, { key: "numColumns", value: function numColumns() { return this._numColumns; } }, { key: "valueAt", value: function valueAt(rowIndex, columnIndex) { if (this._rows[rowIndex] === null) { return null; } return this._rows[rowIndex][columnIndex]; } }, { key: "row", value: function row(rowIndex, sharedRow) { var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); if (tSharedRow) { tSharedRow.setSource(this, rowIndex); return tSharedRow; } return new _dataRow.DataRow(this, rowIndex); } }, { key: "rowAsArray", value: function rowAsArray(rowIndex) { return this._rows[rowIndex]; } }, { key: "rows", value: function rows(sharedRow) { var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); return rowsIterator(this, tSharedRow); } }, { key: "column", value: function column(columnIndex) { return columnIterator(this, columnIndex); } }, { key: "flattenData", value: function flattenData() { return this._rows; } }, { key: "getPlainIndex", value: function getPlainIndex() { return this._rows.map(function (_, i) { return i; }); } }, { key: "map", value: function map(func, sharedRow) { var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); var _options$start = options.start, start = _options$start === void 0 ? 0 : _options$start, _options$end = options.end, end = _options$end === void 0 ? this.numRows() : _options$end; var endRow = Math.min(this.numRows(), end); var out = []; for (var rowIndex = start; rowIndex < endRow; ++rowIndex) { var row = this.row(rowIndex, tSharedRow); out.push(func(row, rowIndex)); } return out; } }, { key: "mapIndex", value: function mapIndex(func) { var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var _options$start2 = options.start, start = _options$start2 === void 0 ? 0 : _options$start2, _options$end2 = options.end, end = _options$end2 === void 0 ? this.numRows() : _options$end2; var endRow = Math.min(this.numRows(), end); var out = []; for (var rowIndex = start; rowIndex < endRow; ++rowIndex) { out.push(func({ index: rowIndex }, this)); } return out; } }, { key: "find", value: function find(func, sharedRow) { var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); for (var rowIndex = 0; rowIndex < this._rows.length; ++rowIndex) { var row = this.row(rowIndex, tSharedRow); if (func(row, rowIndex)) { return row; } } return undefined; } }, { key: "reduce", value: function reduce(func, initialValue, sharedRow) { var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); for (var rowIndex = 0; rowIndex < this._rows.length; ++rowIndex) { var row = this.row(rowIndex, tSharedRow); initialValue = func(initialValue, row, rowIndex); } return initialValue; } }]); }(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_dataRow","require","_marked","_regenerator","mark","rowsIterator","_marked2","columnIterator","dataContainer","sharedRow","numRows","rowIndex","wrap","rowsIterator$","_context","prev","next","row","stop","columnIndex","columnIterator$","_context2","valueAt","RowDataContainer","exports","data","_data$rows$","_classCallCheck2","_defineProperty2","rows","Error","Array","isArray","_rows","_numColumns","length","_createClass2","key","value","numColumns","tSharedRow","DataRow","createSharedRow","setSource","rowAsArray","column","flattenData","getPlainIndex","map","_","i","func","options","arguments","undefined","_options$start","start","_options$end","end","endRow","Math","min","out","push","mapIndex","_options$start2","_options$end2","index","find","reduce","initialValue"],"sources":["../src/row-data-container.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {DataRow, SharedRowOptions} from './data-row';\nimport {ProtoDatasetField} from '@kepler.gl/types';\nimport {DataContainerInterface, RangeOptions} from './data-container-interface';\n\ntype RowDataContainerInput = {\n  rows: any[][];\n  fields?: ProtoDatasetField[];\n};\n\n/**\n * @param dataContainer\n * @param sharedRow\n */\nfunction* rowsIterator(dataContainer: DataContainerInterface, sharedRow: SharedRowOptions) {\n  const numRows = dataContainer.numRows();\n  for (let rowIndex = 0; rowIndex < numRows; ++rowIndex) {\n    yield dataContainer.row(rowIndex, sharedRow);\n  }\n}\n\n/**\n * @param dataContainer\n * @param columnIndex\n */\nfunction* columnIterator(dataContainer: DataContainerInterface, columnIndex: number) {\n  const numRows = dataContainer.numRows();\n  for (let rowIndex = 0; rowIndex < numRows; ++rowIndex) {\n    yield dataContainer.valueAt(rowIndex, columnIndex);\n  }\n}\n\n/**\n * A data container where all data is stored internally as a 2D array.\n */\nexport class RowDataContainer implements DataContainerInterface {\n  _rows: any[][];\n  _numColumns: number;\n\n  constructor(data: RowDataContainerInput) {\n    if (!data.rows) {\n      throw Error('RowDataContainer: no rows provided');\n    }\n\n    if (!Array.isArray(data.rows)) {\n      throw Error(\"RowDataContainer: rows object isn't an array\");\n    }\n\n    this._rows = data.rows;\n    this._numColumns = data.rows[0]?.length || 0;\n  }\n\n  numRows(): number {\n    return this._rows.length;\n  }\n\n  numColumns(): number {\n    return this._numColumns;\n  }\n\n  valueAt(rowIndex: number, columnIndex: number): any {\n    if (this._rows[rowIndex] === null) {\n      return null;\n    }\n    return this._rows[rowIndex][columnIndex];\n  }\n\n  row(rowIndex: number, sharedRow?: SharedRowOptions): DataRow {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n    if (tSharedRow) {\n      tSharedRow.setSource(this, rowIndex);\n      return tSharedRow;\n    }\n\n    return new DataRow(this, rowIndex);\n  }\n\n  rowAsArray(rowIndex: number): any[] {\n    return this._rows[rowIndex];\n  }\n\n  rows(sharedRow: SharedRowOptions) {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n    return rowsIterator(this, tSharedRow);\n  }\n\n  column(columnIndex: number) {\n    return columnIterator(this, columnIndex);\n  }\n\n  flattenData(): any[][] {\n    return this._rows;\n  }\n\n  getPlainIndex(): number[] {\n    return this._rows.map((_, i) => i);\n  }\n\n  map<T>(\n    func: (row: DataRow, index: number) => T,\n    sharedRow?: SharedRowOptions,\n    options: RangeOptions = {}\n  ): T[] {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n\n    const {start = 0, end = this.numRows()} = options;\n    const endRow = Math.min(this.numRows(), end);\n\n    const out: T[] = [];\n    for (let rowIndex = start; rowIndex < endRow; ++rowIndex) {\n      const row = this.row(rowIndex, tSharedRow);\n      out.push(func(row, rowIndex));\n    }\n    return out;\n  }\n\n  mapIndex<T>(\n    func: ({index: number}, dc: DataContainerInterface) => T,\n    options: RangeOptions = {}\n  ): T[] {\n    const {start = 0, end = this.numRows()} = options;\n    const endRow = Math.min(this.numRows(), end);\n\n    const out: T[] = [];\n    for (let rowIndex = start; rowIndex < endRow; ++rowIndex) {\n      out.push(func({index: rowIndex}, this));\n    }\n    return out;\n  }\n\n  find(\n    func: (row: DataRow, index: number) => boolean,\n    sharedRow?: SharedRowOptions\n  ): DataRow | undefined {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n\n    for (let rowIndex = 0; rowIndex < this._rows.length; ++rowIndex) {\n      const row = this.row(rowIndex, tSharedRow);\n      if (func(row, rowIndex)) {\n        return row;\n      }\n    }\n    return undefined;\n  }\n\n  reduce<T>(\n    func: (acc: T, row: DataRow, index: number) => T,\n    initialValue: T,\n    sharedRow?: SharedRowOptions\n  ): T {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n\n    for (let rowIndex = 0; rowIndex < this._rows.length; ++rowIndex) {\n      const row = this.row(rowIndex, tSharedRow);\n      initialValue = func(initialValue, row, rowIndex);\n    }\n    return initialValue;\n  }\n}\n"],"mappings":"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","ignoreList":[]}