UNPKG

kepler.gl

Version:

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

303 lines (237 loc) 29.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.unique = unique; exports.findMapBounds = findMapBounds; exports.getLatLngBounds = getLatLngBounds; exports.clamp = clamp; exports.getSampleData = getSampleData; exports.timeToUnixMilli = timeToUnixMilli; exports.maybeToDate = maybeToDate; exports.notNullorUndefined = notNullorUndefined; exports.isPlainObject = isPlainObject; exports.numberSort = numberSort; exports.getSortingFunction = getSortingFunction; exports.preciseRound = preciseRound; exports.getRoundingDecimalFromStep = getRoundingDecimalFromStep; exports.roundValToStep = roundValToStep; exports.findFirstNoneEmpty = findFirstNoneEmpty; exports.arrayMove = exports.parseFieldValue = exports.FIELD_DISPLAY_FORMAT = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _moment = _interopRequireDefault(require("moment")); var _assert = _interopRequireDefault(require("assert")); var _defaultSettings = require("../constants/default-settings"); var _FIELD_DISPLAY_FORMAT; var MAX_LATITUDE = 90; var MIN_LATITUDE = -90; var MAX_LONGITUDE = 180; var MIN_LONGITUDE = -180; /** * simple getting unique values of an array * * @param {array} values * @returns {array} unique values */ function unique(values) { var results = []; values.forEach(function (v) { if (!results.includes(v) && notNullorUndefined(v)) { results.push(v); } }); return results; } /* eslint-disable max-statements */ /** * return center of map from given points * @param {array} layers * @param {string} dataId * @returns {object} coordinates of map center, empty if not found */ function findMapBounds(layers) { // find bounds in formatted layerData // take ALL layers into account when finding map bounds var availableLayerBounds = layers.reduce(function (res, l) { if (l.meta && l.meta.bounds) { res.push(l.meta.bounds); } return res; }, []); // return null if no layer is available if (availableLayerBounds.length === 0) { return null; } // merge bounds in each layer var newBounds = availableLayerBounds.reduce(function (res, b) { return [Math.min(res[0], b[0]), Math.min(res[1], b[1]), Math.max(res[2], b[2]), Math.max(res[3], b[3])]; }, [MAX_LONGITUDE, MAX_LATITUDE, MIN_LONGITUDE, MIN_LATITUDE]); return newBounds; } /* eslint-enable max-statements */ function getLatLngBounds(points, idx, limit) { var lats = points.map(function (d) { return Array.isArray(d) && d[idx]; }).filter(Number.isFinite).sort(numberSort); if (!lats.length) { return null; } // clamp to limit return [Math.max(lats[0], limit[0]), Math.min(lats[lats.length - 1], limit[1])]; } function clamp(_ref, val) { var _ref2 = (0, _slicedToArray2["default"])(_ref, 2), min = _ref2[0], max = _ref2[1]; return val <= min ? min : val >= max ? max : val; } function getSampleData(data) { var sampleSize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 500; var getValue = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function (d) { return d; }; var sampleStep = Math.max(Math.floor(data.length / sampleSize), 1); var output = []; for (var i = 0; i < data.length; i += sampleStep) { output.push(getValue(data[i])); } return output; } /** * Convert different time format to unix milliseconds * @param {*} value * @param {*} format */ function timeToUnixMilli(value, format) { if (notNullorUndefined(value)) { return typeof value === 'string' ? _moment["default"].utc(value, format).valueOf() : format === 'x' ? value * 1000 : value; } return null; } function maybeToDate(isTime, fieldIdx, format, d) { if (isTime) { return timeToUnixMilli(d[fieldIdx], format); } return d[fieldIdx]; } /** * whether null or undefined * @returns {boolean} - yes or no */ function notNullorUndefined(d) { return d !== undefined && d !== null; } function isPlainObject(obj) { return obj === Object(obj) && typeof obj !== 'function' && !Array.isArray(obj); } function numberSort(a, b) { return a - b; } function getSortingFunction(fieldType) { switch (fieldType) { case _defaultSettings.ALL_FIELD_TYPES.real: case _defaultSettings.ALL_FIELD_TYPES.integer: case _defaultSettings.ALL_FIELD_TYPES.timestamp: return numberSort; default: return undefined; } } /** * round number with exact number of decimals * return as a string * @param {number} num * @param {number} decimals * @returns {string} - a rounded number in string format */ function preciseRound(num, decimals) { var t = Math.pow(10, decimals); return (Math.round(num * t + (decimals > 0 ? 1 : 0) * (Math.sign(num) * (10 / Math.pow(100, decimals)))) / t).toFixed(decimals); } /** * get number of decimals to round to for slider from step * @param {number} step * @returns {number} - number of decimal */ function getRoundingDecimalFromStep(step) { if (isNaN(step)) { (0, _assert["default"])('step is not a number'); (0, _assert["default"])(step); } var splitZero = step.toString().split('.'); if (splitZero.length === 1) { return 0; } return splitZero[1].length; } /** * round the value to step for the slider * @param {number} minValue * @param {number} step * @param {number} val * @returns {number} - rounded number */ function roundValToStep(minValue, step, val) { if (isNaN(step)) { return val; } var decimal = getRoundingDecimalFromStep(step); var steps = Math.floor((val - minValue) / step); var remain = val - (steps * step + minValue); // has to round because javascript turns 0.1 into 0.9999999999999987 remain = Number(preciseRound(remain, 8)); var closest; if (remain === 0) { closest = val; } else if (remain < step / 2) { closest = steps * step + minValue; } else { closest = (steps + 1) * step + minValue; } // precise round return a string rounded to the defined decimal var rounded = preciseRound(closest, decimal); return Number(rounded); } var identity = function identity(d) { return d; }; var FIELD_DISPLAY_FORMAT = (_FIELD_DISPLAY_FORMAT = {}, (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES.string, identity), (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES.timestamp, identity), (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES.integer, identity), (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES.real, identity), (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES["boolean"], function (d) { return String(d); }), (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES.date, identity), (0, _defineProperty2["default"])(_FIELD_DISPLAY_FORMAT, _defaultSettings.ALL_FIELD_TYPES.geojson, function (d) { return typeof d === 'string' ? d : isPlainObject(d) ? JSON.stringify(d) : Array.isArray(d) ? "[".concat(String(d), "]") : ''; }), _FIELD_DISPLAY_FORMAT); /** * Parse field value and type and return a string representation * @param {string} value the field value * @param {string} type the field type * @return {*} */ exports.FIELD_DISPLAY_FORMAT = FIELD_DISPLAY_FORMAT; var parseFieldValue = function parseFieldValue(value, type) { if (!notNullorUndefined(value)) { return ''; } return FIELD_DISPLAY_FORMAT[type] ? FIELD_DISPLAY_FORMAT[type](value) : String(value); }; exports.parseFieldValue = parseFieldValue; var arrayMoveMutate = function arrayMoveMutate(array, from, to) { array.splice(to < 0 ? array.length + to : to, 0, array.splice(from, 1)[0]); }; var arrayMove = function arrayMove(array, from, to) { array = array.slice(); arrayMoveMutate(array, from, to); return array; }; exports.arrayMove = arrayMove; function findFirstNoneEmpty(data) { var count = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; var getValue = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : identity; var c = 0; var found = []; while (c < count && c < data.length) { var value = getValue(data[c]); if (notNullorUndefined(value)) { found.push(value); } c++; } return found; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/data-utils.js"],"names":["MAX_LATITUDE","MIN_LATITUDE","MAX_LONGITUDE","MIN_LONGITUDE","unique","values","results","forEach","v","includes","notNullorUndefined","push","findMapBounds","layers","availableLayerBounds","reduce","res","l","meta","bounds","length","newBounds","b","Math","min","max","getLatLngBounds","points","idx","limit","lats","map","d","Array","isArray","filter","Number","isFinite","sort","numberSort","clamp","val","getSampleData","data","sampleSize","getValue","sampleStep","floor","output","i","timeToUnixMilli","value","format","moment","utc","valueOf","maybeToDate","isTime","fieldIdx","undefined","isPlainObject","obj","Object","a","getSortingFunction","fieldType","ALL_FIELD_TYPES","real","integer","timestamp","preciseRound","num","decimals","t","pow","round","sign","toFixed","getRoundingDecimalFromStep","step","isNaN","splitZero","toString","split","roundValToStep","minValue","decimal","steps","remain","closest","rounded","identity","FIELD_DISPLAY_FORMAT","string","String","date","geojson","JSON","stringify","parseFieldValue","type","arrayMoveMutate","array","from","to","splice","arrayMove","slice","findFirstNoneEmpty","count","c","found"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport moment from 'moment';\nimport assert from 'assert';\nimport {ALL_FIELD_TYPES} from 'constants/default-settings';\n\nconst MAX_LATITUDE = 90;\nconst MIN_LATITUDE = -90;\nconst MAX_LONGITUDE = 180;\nconst MIN_LONGITUDE = -180;\n\n/**\n * simple getting unique values of an array\n *\n * @param {array} values\n * @returns {array} unique values\n */\nexport function unique(values) {\n  const results = [];\n  values.forEach(v => {\n    if (!results.includes(v) && notNullorUndefined(v)) {\n      results.push(v);\n    }\n  });\n\n  return results;\n}\n\n/* eslint-disable max-statements */\n/**\n * return center of map from given points\n * @param {array} layers\n * @param {string} dataId\n * @returns {object} coordinates of map center, empty if not found\n */\nexport function findMapBounds(layers) {\n  // find bounds in formatted layerData\n  // take ALL layers into account when finding map bounds\n  const availableLayerBounds = layers.reduce((res, l) => {\n    if (l.meta && l.meta.bounds) {\n      res.push(l.meta.bounds);\n    }\n    return res;\n  }, []);\n  // return null if no layer is available\n  if (availableLayerBounds.length === 0) {\n    return null;\n  }\n  // merge bounds in each layer\n  const newBounds = availableLayerBounds.reduce(\n    (res, b) => {\n      return [\n        Math.min(res[0], b[0]),\n        Math.min(res[1], b[1]),\n        Math.max(res[2], b[2]),\n        Math.max(res[3], b[3])\n      ];\n    },\n    [MAX_LONGITUDE, MAX_LATITUDE, MIN_LONGITUDE, MIN_LATITUDE]\n  );\n  return newBounds;\n}\n/* eslint-enable max-statements */\n\nexport function getLatLngBounds(points, idx, limit) {\n  const lats = points\n    .map(d => Array.isArray(d) && d[idx])\n    .filter(Number.isFinite)\n    .sort(numberSort);\n\n  if (!lats.length) {\n    return null;\n  }\n\n  // clamp to limit\n  return [Math.max(lats[0], limit[0]), Math.min(lats[lats.length - 1], limit[1])];\n}\n\nexport function clamp([min, max], val) {\n  return val <= min ? min : val >= max ? max : val;\n}\n\nexport function getSampleData(data, sampleSize = 500, getValue = d => d) {\n  const sampleStep = Math.max(Math.floor(data.length / sampleSize), 1);\n  const output = [];\n  for (let i = 0; i < data.length; i += sampleStep) {\n    output.push(getValue(data[i]));\n  }\n\n  return output;\n}\n\n/**\n * Convert different time format to unix milliseconds\n * @param {*} value\n * @param {*} format\n */\nexport function timeToUnixMilli(value, format) {\n  if (notNullorUndefined(value)) {\n    return typeof value === 'string'\n      ? moment.utc(value, format).valueOf()\n      : format === 'x'\n      ? value * 1000\n      : value;\n  }\n  return null;\n}\n\nexport function maybeToDate(isTime, fieldIdx, format, d) {\n  if (isTime) {\n    return timeToUnixMilli(d[fieldIdx], format);\n  }\n\n  return d[fieldIdx];\n}\n\n/**\n * whether null or undefined\n * @returns {boolean} - yes or no\n */\nexport function notNullorUndefined(d) {\n  return d !== undefined && d !== null;\n}\n\nexport function isPlainObject(obj) {\n  return obj === Object(obj) && typeof obj !== 'function' && !Array.isArray(obj);\n}\n\nexport function numberSort(a, b) {\n  return a - b;\n}\n\nexport function getSortingFunction(fieldType) {\n  switch (fieldType) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n    case ALL_FIELD_TYPES.timestamp:\n      return numberSort;\n    default:\n      return undefined;\n  }\n}\n\n/**\n * round number with exact number of decimals\n * return as a string\n * @param {number} num\n * @param {number} decimals\n * @returns {string} - a rounded number in string format\n */\nexport function preciseRound(num, decimals) {\n  const t = Math.pow(10, decimals);\n  return (\n    Math.round(\n      num * t + (decimals > 0 ? 1 : 0) * (Math.sign(num) * (10 / Math.pow(100, decimals)))\n    ) / t\n  ).toFixed(decimals);\n}\n\n/**\n * get number of decimals to round to for slider from step\n * @param {number} step\n * @returns {number} - number of decimal\n */\nexport function getRoundingDecimalFromStep(step) {\n  if (isNaN(step)) {\n    assert('step is not a number');\n    assert(step);\n  }\n\n  const splitZero = step.toString().split('.');\n  if (splitZero.length === 1) {\n    return 0;\n  }\n  return splitZero[1].length;\n}\n\n/**\n * round the value to step for the slider\n * @param {number} minValue\n * @param {number} step\n * @param {number} val\n * @returns {number} - rounded number\n */\nexport function roundValToStep(minValue, step, val) {\n  if (isNaN(step)) {\n    return val;\n  }\n\n  const decimal = getRoundingDecimalFromStep(step);\n  const steps = Math.floor((val - minValue) / step);\n  let remain = val - (steps * step + minValue);\n\n  // has to round because javascript turns 0.1 into 0.9999999999999987\n  remain = Number(preciseRound(remain, 8));\n\n  let closest;\n  if (remain === 0) {\n    closest = val;\n  } else if (remain < step / 2) {\n    closest = steps * step + minValue;\n  } else {\n    closest = (steps + 1) * step + minValue;\n  }\n\n  // precise round return a string rounded to the defined decimal\n  const rounded = preciseRound(closest, decimal);\n\n  return Number(rounded);\n}\n\nconst identity = d => d;\n\nexport const FIELD_DISPLAY_FORMAT = {\n  [ALL_FIELD_TYPES.string]: identity,\n  [ALL_FIELD_TYPES.timestamp]: identity,\n  [ALL_FIELD_TYPES.integer]: identity,\n  [ALL_FIELD_TYPES.real]: identity,\n  [ALL_FIELD_TYPES.boolean]: d => String(d),\n  [ALL_FIELD_TYPES.date]: identity,\n  [ALL_FIELD_TYPES.geojson]: d =>\n    typeof d === 'string'\n      ? d\n      : isPlainObject(d)\n      ? JSON.stringify(d)\n      : Array.isArray(d)\n      ? `[${String(d)}]`\n      : ''\n};\n\n/**\n * Parse field value and type and return a string representation\n * @param {string} value the field value\n * @param {string} type the field type\n * @return {*}\n */\nexport const parseFieldValue = (value, type) => {\n  if (!notNullorUndefined(value)) {\n    return '';\n  }\n\n  return FIELD_DISPLAY_FORMAT[type] ? FIELD_DISPLAY_FORMAT[type](value) : String(value);\n};\n\nconst arrayMoveMutate = (array, from, to) => {\n  array.splice(to < 0 ? array.length + to : to, 0, array.splice(from, 1)[0]);\n};\n\nexport const arrayMove = (array, from, to) => {\n  array = array.slice();\n  arrayMoveMutate(array, from, to);\n  return array;\n};\n\nexport function findFirstNoneEmpty(data, count = 1, getValue = identity) {\n  let c = 0;\n  const found = [];\n  while (c < count && c < data.length) {\n    const value = getValue(data[c]);\n    if (notNullorUndefined(value)) {\n      found.push(value);\n    }\n    c++;\n  }\n  return found;\n}\n"]}