kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
302 lines (288 loc) • 33.9 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ACCEPTED_ANALYZER_TYPES = void 0;
exports.analyzerTypeToFieldType = analyzerTypeToFieldType;
exports.getFieldsFromData = getFieldsFromData;
exports.getSampleForTypeAnalyze = getSampleForTypeAnalyze;
exports.getSampleForTypeAnalyzeArrow = getSampleForTypeAnalyzeArrow;
exports.renameDuplicateFields = renameDuplicateFields;
var _typeAnalyzer = require("type-analyzer");
var _constants = require("@kepler.gl/constants");
var _window = require("global/window");
var _d3Array = require("d3-array");
var _data = require("./data");
var _h3Utils = require("./h3-utils");
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var H3_ANALYZER_TYPE = 'H3';
var ACCEPTED_ANALYZER_TYPES = exports.ACCEPTED_ANALYZER_TYPES = [_typeAnalyzer.DATA_TYPES.DATE, _typeAnalyzer.DATA_TYPES.TIME, _typeAnalyzer.DATA_TYPES.DATETIME, _typeAnalyzer.DATA_TYPES.NUMBER, _typeAnalyzer.DATA_TYPES.INT, _typeAnalyzer.DATA_TYPES.FLOAT, _typeAnalyzer.DATA_TYPES.BOOLEAN, _typeAnalyzer.DATA_TYPES.STRING, _typeAnalyzer.DATA_TYPES.GEOMETRY, _typeAnalyzer.DATA_TYPES.GEOMETRY_FROM_STRING, _typeAnalyzer.DATA_TYPES.PAIR_GEOMETRY_FROM_STRING, _typeAnalyzer.DATA_TYPES.ZIPCODE, _typeAnalyzer.DATA_TYPES.ARRAY, _typeAnalyzer.DATA_TYPES.OBJECT, H3_ANALYZER_TYPE];
var IGNORE_DATA_TYPES = Object.keys(_typeAnalyzer.DATA_TYPES).filter(function (type) {
return !ACCEPTED_ANALYZER_TYPES.includes(type);
});
/**
* Getting sample data for analyzing field type.
*/
function getSampleForTypeAnalyze(_ref) {
var fields = _ref.fields,
rows = _ref.rows,
_ref$sampleCount = _ref.sampleCount,
sampleCount = _ref$sampleCount === void 0 ? 50 : _ref$sampleCount;
var total = Math.min(sampleCount, rows.length);
// const fieldOrder = fields.map(f => f.name);
var sample = (0, _d3Array.range)(0, total, 1).map(function () {
return {};
});
if (rows.length < 1) {
return [];
}
var isRowObject = !Array.isArray(rows[0]);
// collect sample data for each field
fields.forEach(function (field, fieldIdx) {
// row counter
var i = 0;
// sample counter
var j = 0;
while (j < total) {
if (i >= rows.length) {
// if depleted data pool
sample[j][field] = null;
j++;
} else if ((0, _data.notNullorUndefined)(rows[i][isRowObject ? field : fieldIdx])) {
var value = rows[i][isRowObject ? field : fieldIdx];
sample[j][field] = typeof value === 'string' ? value.trim() : value;
j++;
i++;
} else {
i++;
}
}
});
return sample;
}
/**
* Getting sample data for analyzing field type for Arrow tables.
* @param table Arrow table or an array of vectors.
* @param fields Field names.
* @param sampleCount Number of sample rows to get.
* @returns Sample rows.
*/
function getSampleForTypeAnalyzeArrow(table, fields) {
var sampleCount = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 50;
var isTable = !Array.isArray(table);
var numRows = isTable ? table.numRows : table[0].length;
var getVector = isTable ? function (index) {
return table.getChildAt(index);
} : function (index) {
return table[index];
};
var total = Math.min(sampleCount, numRows);
var sample = (0, _d3Array.range)(0, total, 1).map(function () {
return {};
});
if (numRows < 1) {
return [];
}
// collect sample data for each field
fields.forEach(function (field, fieldIdx) {
var rowIndex = 0;
var sampleIndex = 0;
while (sampleIndex < total) {
var _getVector;
if (rowIndex >= numRows) {
// if depleted data pool
sample[sampleIndex][field] = null;
sampleIndex++;
} else if ((0, _data.notNullorUndefined)((_getVector = getVector(fieldIdx)) === null || _getVector === void 0 ? void 0 : _getVector.get(rowIndex))) {
var _getVector2;
var value = (_getVector2 = getVector(fieldIdx)) === null || _getVector2 === void 0 ? void 0 : _getVector2.get(rowIndex);
sample[sampleIndex][field] = typeof value === 'string' ? value.trim() : value;
sampleIndex++;
rowIndex++;
} else {
rowIndex++;
}
}
});
return sample;
}
/**
* Convert type-analyzer output to kepler.gl field types
*
* @param aType
* @returns corresponding type in `ALL_FIELD_TYPES`
*/
/* eslint-disable complexity */
function analyzerTypeToFieldType(aType) {
var DATE = _typeAnalyzer.DATA_TYPES.DATE,
TIME = _typeAnalyzer.DATA_TYPES.TIME,
DATETIME = _typeAnalyzer.DATA_TYPES.DATETIME,
NUMBER = _typeAnalyzer.DATA_TYPES.NUMBER,
INT = _typeAnalyzer.DATA_TYPES.INT,
FLOAT = _typeAnalyzer.DATA_TYPES.FLOAT,
BOOLEAN = _typeAnalyzer.DATA_TYPES.BOOLEAN,
STRING = _typeAnalyzer.DATA_TYPES.STRING,
GEOMETRY = _typeAnalyzer.DATA_TYPES.GEOMETRY,
GEOMETRY_FROM_STRING = _typeAnalyzer.DATA_TYPES.GEOMETRY_FROM_STRING,
PAIR_GEOMETRY_FROM_STRING = _typeAnalyzer.DATA_TYPES.PAIR_GEOMETRY_FROM_STRING,
ZIPCODE = _typeAnalyzer.DATA_TYPES.ZIPCODE,
ARRAY = _typeAnalyzer.DATA_TYPES.ARRAY,
OBJECT = _typeAnalyzer.DATA_TYPES.OBJECT;
// TODO: un recognized types
// CURRENCY PERCENT NONE
switch (aType) {
case DATE:
return _constants.ALL_FIELD_TYPES.date;
case TIME:
case DATETIME:
return _constants.ALL_FIELD_TYPES.timestamp;
case FLOAT:
return _constants.ALL_FIELD_TYPES.real;
case INT:
return _constants.ALL_FIELD_TYPES.integer;
case BOOLEAN:
return _constants.ALL_FIELD_TYPES["boolean"];
case GEOMETRY:
case GEOMETRY_FROM_STRING:
case PAIR_GEOMETRY_FROM_STRING:
return _constants.ALL_FIELD_TYPES.geojson;
case ARRAY:
return _constants.ALL_FIELD_TYPES.array;
case OBJECT:
return _constants.ALL_FIELD_TYPES.object;
case NUMBER:
case STRING:
case ZIPCODE:
return _constants.ALL_FIELD_TYPES.string;
case H3_ANALYZER_TYPE:
return _constants.ALL_FIELD_TYPES.h3;
default:
_window.console.warn("Unsupported analyzer type: ".concat(aType));
return _constants.ALL_FIELD_TYPES.string;
}
}
/**
* Analyze field types from data in `string` format, e.g. uploaded csv.
* Assign `type`, `fieldIdx` and `format` (timestamp only) to each field
*
* @param data array of row object
* @param fieldOrder array of field names as string
* @returns formatted fields
* @public
* @example
*
* import {getFieldsFromData} from '@kepler.gl/common-utils';
* const data = [{
* time: '2016-09-17 00:09:55',
* value: '4',
* surge: '1.2',
* isTrip: 'true',
* zeroOnes: '0'
* }, {
* time: '2016-09-17 00:30:08',
* value: '3',
* surge: null,
* isTrip: 'false',
* zeroOnes: '1'
* }, {
* time: null,
* value: '2',
* surge: '1.3',
* isTrip: null,
* zeroOnes: '1'
* }];
*
* const fieldOrder = ['time', 'value', 'surge', 'isTrip', 'zeroOnes'];
* const fields = getFieldsFromData(data, fieldOrder);
* // fields = [
* // {name: 'time', format: 'YYYY-M-D H:m:s', fieldIdx: 1, type: 'timestamp'},
* // {name: 'value', format: '', fieldIdx: 4, type: 'integer'},
* // {name: 'surge', format: '', fieldIdx: 5, type: 'real'},
* // {name: 'isTrip', format: '', fieldIdx: 6, type: 'boolean'},
* // {name: 'zeroOnes', format: '', fieldIdx: 7, type: 'integer'}];
*
*/
function getFieldsFromData(data, fieldOrder) {
// add a check for epoch timestamp
var metadata = _typeAnalyzer.Analyzer.computeColMeta(data, [{
regex: /.*geojson|all_points/g,
dataType: 'GEOMETRY'
}, {
regex: /.*census/g,
dataType: 'STRING'
}], {
ignoredDataTypes: IGNORE_DATA_TYPES
});
var _renameDuplicateField = renameDuplicateFields(fieldOrder),
fieldByIndex = _renameDuplicateField.fieldByIndex;
var result = fieldOrder.map(function (field, index) {
var name = fieldByIndex[index];
var fieldMeta = metadata.find(function (m) {
return m.key === field;
});
// fieldMeta could be undefined if the field has no data and Analyzer.computeColMeta
// will ignore the field. In this case, we will simply assign the field type to STRING
// since dropping the column in the RowData could be expensive
var type = (fieldMeta === null || fieldMeta === void 0 ? void 0 : fieldMeta.type) || 'STRING';
var format = (fieldMeta === null || fieldMeta === void 0 ? void 0 : fieldMeta.format) || '';
// quick check if first valid string in column is H3
if (type === _typeAnalyzer.DATA_TYPES.STRING) {
for (var i = 0, n = data.length; i < n; ++i) {
if ((0, _data.notNullorUndefined)(data[i][name])) {
type = (0, _h3Utils.h3IsValid)(data[i][name] || '') ? H3_ANALYZER_TYPE : type;
break;
}
}
}
// quick check if string is hex wkb
if (type === _typeAnalyzer.DATA_TYPES.STRING) {
type = data.some(function (d) {
return (0, _data.isHexWkb)(d[name]);
}) ? _typeAnalyzer.DATA_TYPES.GEOMETRY : type;
}
return {
name: name,
id: name,
displayName: name,
format: format,
fieldIdx: index,
type: analyzerTypeToFieldType(type),
analyzerType: type,
valueAccessor: function valueAccessor(dc) {
return function (d) {
return dc.valueAt(d.index, index);
};
}
};
});
return result;
}
/**
* pass in an array of field names, rename duplicated one
* and return a map from old field index to new name
*
* @param fieldOrder
* @returns new field name by index
*/
function renameDuplicateFields(fieldOrder) {
return fieldOrder.reduce(function (accu, field, i) {
var allNames = accu.allNames;
var fieldName = field;
// add a counter to duplicated names
if (allNames.includes(field)) {
var counter = 0;
while (allNames.includes("".concat(field, "-").concat(counter))) {
counter++;
}
fieldName = "".concat(field, "-").concat(counter);
}
accu.fieldByIndex[i] = fieldName;
accu.allNames.push(fieldName);
return accu;
}, {
allNames: [],
fieldByIndex: []
});
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_typeAnalyzer","require","_constants","_window","_d3Array","_data","_h3Utils","H3_ANALYZER_TYPE","ACCEPTED_ANALYZER_TYPES","exports","AnalyzerDATA_TYPES","DATE","TIME","DATETIME","NUMBER","INT","FLOAT","BOOLEAN","STRING","GEOMETRY","GEOMETRY_FROM_STRING","PAIR_GEOMETRY_FROM_STRING","ZIPCODE","ARRAY","OBJECT","IGNORE_DATA_TYPES","Object","keys","filter","type","includes","getSampleForTypeAnalyze","_ref","fields","rows","_ref$sampleCount","sampleCount","total","Math","min","length","sample","range","map","isRowObject","Array","isArray","forEach","field","fieldIdx","i","j","notNullorUndefined","value","trim","getSampleForTypeAnalyzeArrow","table","arguments","undefined","isTable","numRows","getVector","index","getChildAt","rowIndex","sampleIndex","_getVector","get","_getVector2","analyzerTypeToFieldType","aType","ALL_FIELD_TYPES","date","timestamp","real","integer","geojson","array","object","string","h3","globalConsole","warn","concat","getFieldsFromData","data","fieldOrder","metadata","Analyzer","computeColMeta","regex","dataType","ignoredDataTypes","_renameDuplicateField","renameDuplicateFields","fieldByIndex","result","name","fieldMeta","find","m","key","format","n","h3IsValid","some","d","isHexWkb","id","displayName","analyzerType","valueAccessor","dc","valueAt","reduce","accu","allNames","fieldName","counter","push"],"sources":["../src/data-type.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Analyzer, DATA_TYPES as AnalyzerDATA_TYPES} from 'type-analyzer';\nimport {ArrowTableInterface, ApacheVectorInterface, RowData, Field} from '@kepler.gl/types';\nimport {ALL_FIELD_TYPES} from '@kepler.gl/constants';\nimport {console as globalConsole} from 'global/window';\nimport {range} from 'd3-array';\nimport {isHexWkb, notNullorUndefined} from './data';\nimport {h3IsValid} from './h3-utils';\n\nconst H3_ANALYZER_TYPE = 'H3';\n\nexport const ACCEPTED_ANALYZER_TYPES = [\n  AnalyzerDATA_TYPES.DATE,\n  AnalyzerDATA_TYPES.TIME,\n  AnalyzerDATA_TYPES.DATETIME,\n  AnalyzerDATA_TYPES.NUMBER,\n  AnalyzerDATA_TYPES.INT,\n  AnalyzerDATA_TYPES.FLOAT,\n  AnalyzerDATA_TYPES.BOOLEAN,\n  AnalyzerDATA_TYPES.STRING,\n  AnalyzerDATA_TYPES.GEOMETRY,\n  AnalyzerDATA_TYPES.GEOMETRY_FROM_STRING,\n  AnalyzerDATA_TYPES.PAIR_GEOMETRY_FROM_STRING,\n  AnalyzerDATA_TYPES.ZIPCODE,\n  AnalyzerDATA_TYPES.ARRAY,\n  AnalyzerDATA_TYPES.OBJECT,\n  H3_ANALYZER_TYPE\n];\n\nconst IGNORE_DATA_TYPES = Object.keys(AnalyzerDATA_TYPES).filter(\n  type => !ACCEPTED_ANALYZER_TYPES.includes(type)\n);\n\n/**\n * Getting sample data for analyzing field type.\n */\nexport function getSampleForTypeAnalyze({\n  fields,\n  rows,\n  sampleCount = 50\n}: {\n  fields: string[];\n  rows: unknown[][] | RowData;\n  sampleCount?: number;\n}): RowData {\n  const total = Math.min(sampleCount, rows.length);\n  // const fieldOrder = fields.map(f => f.name);\n  const sample = range(0, total, 1).map(() => ({}));\n\n  if (rows.length < 1) {\n    return [];\n  }\n  const isRowObject = !Array.isArray(rows[0]);\n\n  // collect sample data for each field\n  fields.forEach((field, fieldIdx) => {\n    // row counter\n    let i = 0;\n    // sample counter\n    let j = 0;\n\n    while (j < total) {\n      if (i >= rows.length) {\n        // if depleted data pool\n        sample[j][field] = null;\n        j++;\n      } else if (notNullorUndefined(rows[i][isRowObject ? field : fieldIdx])) {\n        const value = rows[i][isRowObject ? field : fieldIdx];\n        sample[j][field] = typeof value === 'string' ? value.trim() : value;\n        j++;\n        i++;\n      } else {\n        i++;\n      }\n    }\n  });\n\n  return sample;\n}\n\n/**\n * Getting sample data for analyzing field type for Arrow tables.\n * @param table Arrow table or an array of vectors.\n * @param fields Field names.\n * @param sampleCount Number of sample rows to get.\n * @returns Sample rows.\n */\nexport function getSampleForTypeAnalyzeArrow(\n  table: ArrowTableInterface | ApacheVectorInterface[],\n  fields: string[],\n  sampleCount = 50\n): any[] {\n  const isTable = !Array.isArray(table);\n\n  const numRows = isTable ? table.numRows : table[0].length;\n  const getVector = isTable ? index => table.getChildAt(index) : index => table[index];\n\n  const total = Math.min(sampleCount, numRows);\n  const sample = range(0, total, 1).map(() => ({}));\n\n  if (numRows < 1) {\n    return [];\n  }\n\n  // collect sample data for each field\n  fields.forEach((field, fieldIdx) => {\n    let rowIndex = 0;\n    let sampleIndex = 0;\n\n    while (sampleIndex < total) {\n      if (rowIndex >= numRows) {\n        // if depleted data pool\n        sample[sampleIndex][field] = null;\n        sampleIndex++;\n      } else if (notNullorUndefined(getVector(fieldIdx)?.get(rowIndex))) {\n        const value = getVector(fieldIdx)?.get(rowIndex);\n        sample[sampleIndex][field] = typeof value === 'string' ? value.trim() : value;\n        sampleIndex++;\n        rowIndex++;\n      } else {\n        rowIndex++;\n      }\n    }\n  });\n\n  return sample;\n}\n\n/**\n * Convert type-analyzer output to kepler.gl field types\n *\n * @param aType\n * @returns corresponding type in `ALL_FIELD_TYPES`\n */\n/* eslint-disable complexity */\nexport function analyzerTypeToFieldType(aType: string): string {\n  const {\n    DATE,\n    TIME,\n    DATETIME,\n    NUMBER,\n    INT,\n    FLOAT,\n    BOOLEAN,\n    STRING,\n    GEOMETRY,\n    GEOMETRY_FROM_STRING,\n    PAIR_GEOMETRY_FROM_STRING,\n    ZIPCODE,\n    ARRAY,\n    OBJECT\n  } = AnalyzerDATA_TYPES;\n\n  // TODO: un recognized types\n  // CURRENCY PERCENT NONE\n  switch (aType) {\n    case DATE:\n      return ALL_FIELD_TYPES.date;\n    case TIME:\n    case DATETIME:\n      return ALL_FIELD_TYPES.timestamp;\n    case FLOAT:\n      return ALL_FIELD_TYPES.real;\n    case INT:\n      return ALL_FIELD_TYPES.integer;\n    case BOOLEAN:\n      return ALL_FIELD_TYPES.boolean;\n    case GEOMETRY:\n    case GEOMETRY_FROM_STRING:\n    case PAIR_GEOMETRY_FROM_STRING:\n      return ALL_FIELD_TYPES.geojson;\n    case ARRAY:\n      return ALL_FIELD_TYPES.array;\n    case OBJECT:\n      return ALL_FIELD_TYPES.object;\n    case NUMBER:\n    case STRING:\n    case ZIPCODE:\n      return ALL_FIELD_TYPES.string;\n    case H3_ANALYZER_TYPE:\n      return ALL_FIELD_TYPES.h3;\n    default:\n      globalConsole.warn(`Unsupported analyzer type: ${aType}`);\n      return ALL_FIELD_TYPES.string;\n  }\n}\n\n/**\n * Analyze field types from data in `string` format, e.g. uploaded csv.\n * Assign `type`, `fieldIdx` and `format` (timestamp only) to each field\n *\n * @param data array of row object\n * @param fieldOrder array of field names as string\n * @returns formatted fields\n * @public\n * @example\n *\n * import {getFieldsFromData} from '@kepler.gl/common-utils';\n * const data = [{\n *   time: '2016-09-17 00:09:55',\n *   value: '4',\n *   surge: '1.2',\n *   isTrip: 'true',\n *   zeroOnes: '0'\n * }, {\n *   time: '2016-09-17 00:30:08',\n *   value: '3',\n *   surge: null,\n *   isTrip: 'false',\n *   zeroOnes: '1'\n * }, {\n *   time: null,\n *   value: '2',\n *   surge: '1.3',\n *   isTrip: null,\n *   zeroOnes: '1'\n * }];\n *\n * const fieldOrder = ['time', 'value', 'surge', 'isTrip', 'zeroOnes'];\n * const fields = getFieldsFromData(data, fieldOrder);\n * // fields = [\n * // {name: 'time', format: 'YYYY-M-D H:m:s', fieldIdx: 1, type: 'timestamp'},\n * // {name: 'value', format: '', fieldIdx: 4, type: 'integer'},\n * // {name: 'surge', format: '', fieldIdx: 5, type: 'real'},\n * // {name: 'isTrip', format: '', fieldIdx: 6, type: 'boolean'},\n * // {name: 'zeroOnes', format: '', fieldIdx: 7, type: 'integer'}];\n *\n */\nexport function getFieldsFromData(data: RowData, fieldOrder: string[]): Field[] {\n  // add a check for epoch timestamp\n  const metadata = Analyzer.computeColMeta(\n    data,\n    [\n      {regex: /.*geojson|all_points/g, dataType: 'GEOMETRY'},\n      {regex: /.*census/g, dataType: 'STRING'}\n    ],\n    {ignoredDataTypes: IGNORE_DATA_TYPES}\n  );\n\n  const {fieldByIndex} = renameDuplicateFields(fieldOrder);\n\n  const result = fieldOrder.map((field, index) => {\n    const name = fieldByIndex[index];\n\n    const fieldMeta = metadata.find(m => m.key === field);\n\n    // fieldMeta could be undefined if the field has no data and Analyzer.computeColMeta\n    // will ignore the field. In this case, we will simply assign the field type to STRING\n    // since dropping the column in the RowData could be expensive\n    let type = fieldMeta?.type || 'STRING';\n    const format = fieldMeta?.format || '';\n\n    // quick check if first valid string in column is H3\n    if (type === AnalyzerDATA_TYPES.STRING) {\n      for (let i = 0, n = data.length; i < n; ++i) {\n        if (notNullorUndefined(data[i][name])) {\n          type = h3IsValid(data[i][name] || '') ? H3_ANALYZER_TYPE : type;\n          break;\n        }\n      }\n    }\n\n    // quick check if string is hex wkb\n    if (type === AnalyzerDATA_TYPES.STRING) {\n      type = data.some(d => isHexWkb(d[name])) ? AnalyzerDATA_TYPES.GEOMETRY : type;\n    }\n\n    return {\n      name,\n      id: name,\n      displayName: name,\n      format,\n      fieldIdx: index,\n      type: analyzerTypeToFieldType(type),\n      analyzerType: type,\n      valueAccessor: dc => d => {\n        return dc.valueAt(d.index, index);\n      }\n    };\n  });\n\n  return result;\n}\n\n/**\n * pass in an array of field names, rename duplicated one\n * and return a map from old field index to new name\n *\n * @param fieldOrder\n * @returns new field name by index\n */\nexport function renameDuplicateFields(fieldOrder: string[]): {\n  allNames: string[];\n  fieldByIndex: string[];\n} {\n  return fieldOrder.reduce<{allNames: string[]; fieldByIndex: string[]}>(\n    (accu, field, i) => {\n      const {allNames} = accu;\n      let fieldName = field;\n\n      // add a counter to duplicated names\n      if (allNames.includes(field)) {\n        let counter = 0;\n        while (allNames.includes(`${field}-${counter}`)) {\n          counter++;\n        }\n        fieldName = `${field}-${counter}`;\n      }\n\n      accu.fieldByIndex[i] = fieldName;\n      accu.allNames.push(fieldName);\n\n      return accu;\n    },\n    {allNames: [], fieldByIndex: []}\n  );\n}\n"],"mappings":"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","ignoreList":[]}
;