UNPKG

kepler.gl

Version:

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

214 lines (210 loc) 22.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.IndexedDataContainer = 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 indices * @param sharedRow * @returns */ function rowsIterator(dataContainer, indices, sharedRow) { var numRows, rowIndex, mappedRowIndex; return _regenerator["default"].wrap(function rowsIterator$(_context) { while (1) switch (_context.prev = _context.next) { case 0: numRows = indices.length; rowIndex = 0; case 2: if (!(rowIndex < numRows)) { _context.next = 9; break; } mappedRowIndex = indices[rowIndex]; _context.next = 6; return dataContainer.row(mappedRowIndex, sharedRow); case 6: ++rowIndex; _context.next = 2; break; case 9: case "end": return _context.stop(); } }, _marked); } /** * @param dataContainer * @param indices * @param columnIndex * @returns */ function columnIterator(dataContainer, indices, columnIndex) { var numRows, rowIndex, mappedRowIndex; return _regenerator["default"].wrap(function columnIterator$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: numRows = indices.length; rowIndex = 0; case 2: if (!(rowIndex < numRows)) { _context2.next = 9; break; } mappedRowIndex = indices[rowIndex]; _context2.next = 6; return dataContainer.valueAt(mappedRowIndex, columnIndex); case 6: ++rowIndex; _context2.next = 2; break; case 9: case "end": return _context2.stop(); } }, _marked2); } /** * A data container wrapper around another data container. * You have to pass an array of indices to reference rows in the parent data container. * For example indices [3, 4, 6, 8] means that IndexedDataContainer is going to have * 4 rows and row(2) points to 6th row in the referenced data container. */ var IndexedDataContainer = exports.IndexedDataContainer = /*#__PURE__*/function () { function IndexedDataContainer(parentDataContainer, indices) { (0, _classCallCheck2["default"])(this, IndexedDataContainer); (0, _defineProperty2["default"])(this, "_parentDataContainer", void 0); (0, _defineProperty2["default"])(this, "_indices", void 0); this._parentDataContainer = parentDataContainer; this._indices = indices; } return (0, _createClass2["default"])(IndexedDataContainer, [{ key: "numRows", value: function numRows() { return this._indices.length; } }, { key: "numColumns", value: function numColumns() { return this._parentDataContainer.numColumns(); } /** * Remaps a local index to an index in the parent dataset * @param rowIndex * @returns number */ }, { key: "_mappedRowIndex", value: function _mappedRowIndex(rowIndex) { return this._indices[rowIndex]; } }, { key: "valueAt", value: function valueAt(rowIndex, columnIndex) { return this._parentDataContainer.valueAt(this._mappedRowIndex(rowIndex), columnIndex); } }, { key: "row", value: function row(rowIndex, sharedRow) { return this._parentDataContainer.row(this._mappedRowIndex(rowIndex), sharedRow); } }, { key: "rowAsArray", value: function rowAsArray(rowIndex) { return this._parentDataContainer.rowAsArray(this._mappedRowIndex(rowIndex)); } }, { key: "rows", value: function rows(sharedRow) { return rowsIterator(this._parentDataContainer, this._indices, sharedRow); } }, { key: "column", value: function column(columnIndex) { return columnIterator(this._parentDataContainer, this._indices, columnIndex); } }, { key: "getPlainIndex", value: function getPlainIndex() { return this._indices.map(function (_, i) { return i; }); } }, { key: "flattenData", value: function flattenData() { var _this = this; var tSharedRow = _dataRow.DataRow.createSharedRow(true); return this._indices.map(function (_, i) { return _this.row(i, tSharedRow).values(); }, this); } }, { key: "map", value: function map(func, sharedRow) { var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 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 tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); 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: this._mappedRowIndex(rowIndex) }, this._parentDataContainer)); } return out; } }, { key: "find", value: function find(func, sharedRow) { var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow); for (var rowIndex = 0; rowIndex < this.numRows(); ++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._indices.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","indices","sharedRow","numRows","rowIndex","mappedRowIndex","wrap","rowsIterator$","_context","prev","next","length","row","stop","columnIndex","columnIterator$","_context2","valueAt","IndexedDataContainer","exports","parentDataContainer","_classCallCheck2","_defineProperty2","_parentDataContainer","_indices","_createClass2","key","value","numColumns","_mappedRowIndex","rowAsArray","rows","column","getPlainIndex","map","_","i","flattenData","_this","tSharedRow","DataRow","createSharedRow","values","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/indexed-data-container.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {DataContainerInterface, RangeOptions} from './data-container-interface';\nimport {DataRow, SharedRowOptions} from './data-row';\n\n/**\n * @param dataContainer\n * @param indices\n * @param sharedRow\n * @returns\n */\nfunction* rowsIterator(\n  dataContainer: DataContainerInterface,\n  indices: number[],\n  sharedRow: SharedRowOptions\n): Generator<DataRow> {\n  const numRows = indices.length;\n  for (let rowIndex = 0; rowIndex < numRows; ++rowIndex) {\n    const mappedRowIndex = indices[rowIndex];\n    yield dataContainer.row(mappedRowIndex, sharedRow);\n  }\n}\n\n/**\n * @param dataContainer\n * @param indices\n * @param columnIndex\n * @returns\n */\nfunction* columnIterator(\n  dataContainer: DataContainerInterface,\n  indices: number[],\n  columnIndex: number\n): Generator<any> {\n  const numRows = indices.length;\n  for (let rowIndex = 0; rowIndex < numRows; ++rowIndex) {\n    const mappedRowIndex = indices[rowIndex];\n    yield dataContainer.valueAt(mappedRowIndex, columnIndex);\n  }\n}\n\n/**\n * A data container wrapper around another data container.\n * You have to pass an array of indices to reference rows in the parent data container.\n * For example indices [3, 4, 6, 8] means that IndexedDataContainer is going to have\n * 4 rows and row(2) points to 6th row in the referenced data container.\n */\nexport class IndexedDataContainer implements DataContainerInterface {\n  _parentDataContainer: DataContainerInterface;\n  _indices: number[];\n\n  constructor(parentDataContainer: DataContainerInterface, indices: number[]) {\n    this._parentDataContainer = parentDataContainer;\n    this._indices = indices;\n  }\n\n  numRows(): number {\n    return this._indices.length;\n  }\n\n  numColumns(): number {\n    return this._parentDataContainer.numColumns();\n  }\n\n  /**\n   * Remaps a local index to an index in the parent dataset\n   * @param rowIndex\n   * @returns number\n   */\n  _mappedRowIndex(rowIndex: number): number {\n    return this._indices[rowIndex];\n  }\n\n  valueAt(rowIndex: number, columnIndex: number): any {\n    return this._parentDataContainer.valueAt(this._mappedRowIndex(rowIndex), columnIndex);\n  }\n\n  row(rowIndex: number, sharedRow?: SharedRowOptions): DataRow {\n    return this._parentDataContainer.row(this._mappedRowIndex(rowIndex), sharedRow);\n  }\n\n  rowAsArray(rowIndex: number): any[] {\n    return this._parentDataContainer.rowAsArray(this._mappedRowIndex(rowIndex));\n  }\n\n  rows(sharedRow?: SharedRowOptions) {\n    return rowsIterator(this._parentDataContainer, this._indices, sharedRow);\n  }\n\n  column(columnIndex: number) {\n    return columnIterator(this._parentDataContainer, this._indices, columnIndex);\n  }\n\n  getPlainIndex(): number[] {\n    return this._indices.map((_, i) => i);\n  }\n\n  flattenData(): any[][] {\n    const tSharedRow = DataRow.createSharedRow(true);\n\n    return this._indices.map((_, i) => {\n      return this.row(i, tSharedRow).values();\n    }, this);\n  }\n\n  map<T>(\n    func: (row: DataRow, index: number) => T,\n    sharedRow?: SharedRowOptions,\n    options: RangeOptions = {}\n  ): T[] {\n    const {start = 0, end = this.numRows()} = options;\n    const endRow = Math.min(this.numRows(), end);\n\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\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}: {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: this._mappedRowIndex(rowIndex)}, this._parentDataContainer));\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.numRows(); ++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._indices.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":[]}