UNPKG

kepler.gl

Version:

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

201 lines (169 loc) 20.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getDefaultInteraction = getDefaultInteraction; exports.findFieldsToShow = findFieldsToShow; exports.getTooltipDisplayDeltaValue = getTooltipDisplayDeltaValue; exports.getTooltipDisplayValue = getTooltipDisplayValue; exports.BRUSH_CONFIG = exports.TOOLTIP_MINUS_SIGN = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _defaultSettings = require("../constants/default-settings"); var _dataUtils = require("./data-utils"); var _icons = require("../components/common/icons"); var _tooltip = require("../constants/tooltip"); // Copyright (c) 2021 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // \u2212 is the minus sign that d3-format uses for decimal number formatting var TOOLTIP_MINUS_SIGN = "\u2212"; /** * @type {typeof import('./interaction-utils').getDefaultInteraction} */ exports.TOOLTIP_MINUS_SIGN = TOOLTIP_MINUS_SIGN; function getDefaultInteraction() { return { tooltip: { id: 'tooltip', label: 'interactions.tooltip', enabled: true, iconComponent: _icons.Messages, config: { fieldsToShow: {}, compareMode: false, compareType: _tooltip.COMPARE_TYPES.ABSOLUTE } }, geocoder: { id: 'geocoder', label: 'interactions.geocoder', enabled: false, iconComponent: _icons.Pin, position: null }, brush: { id: 'brush', label: 'interactions.brush', enabled: false, iconComponent: _icons.Crosshairs, config: { // size is in km size: 0.5 } }, coordinate: { id: 'coordinate', label: 'interactions.coordinate', enabled: false, iconComponent: _icons.CursorClick, position: null } }; } var BRUSH_CONFIG = { range: [0, 50] }; /** * @type {typeof import('./interaction-utils').findFieldsToShow} */ exports.BRUSH_CONFIG = BRUSH_CONFIG; function findFieldsToShow(_ref) { var fields = _ref.fields, id = _ref.id; // first find default tooltip fields for trips var fieldsToShow = _defaultSettings.DEFAULT_TOOLTIP_FIELDS.reduce(function (prev, curr) { if (fields.find(function (_ref2) { var name = _ref2.name; return curr.name === name; })) { prev.push(curr); } return prev; }, []); return (0, _defineProperty2["default"])({}, id, fieldsToShow.length ? fieldsToShow : autoFindTooltipFields(fields)); } function autoFindTooltipFields(fields) { var ptFields = _mergeFieldPairs(_defaultSettings.TRIP_POINT_FIELDS); // filter out the default fields that contains lat and lng and any geometry var fieldsToShow = fields.filter(function (_ref4) { var name = _ref4.name, type = _ref4.type; return name.replace(/[_,.]+/g, ' ').trim().split(' ').every(function (seg) { return !ptFields.includes(seg); }) && type !== _defaultSettings.ALL_FIELD_TYPES.geojson && type !== 'object'; }); return fieldsToShow.slice(0, _defaultSettings.MAX_DEFAULT_TOOLTIPS).map(function (_ref5) { var name = _ref5.name; return { name: name, format: null }; }); } function _mergeFieldPairs(pairs) { return pairs.reduce(function (prev, pair) { return [].concat((0, _toConsumableArray2["default"])(prev), (0, _toConsumableArray2["default"])(pair)); }, []); } /** * @type {typeof import('./interaction-utils').getTooltipDisplayDeltaValue} */ function getTooltipDisplayDeltaValue(_ref6) { var primaryData = _ref6.primaryData, field = _ref6.field, compareType = _ref6.compareType, data = _ref6.data, fieldIdx = _ref6.fieldIdx, item = _ref6.item; var displayDeltaValue = null; if (primaryData && ( // comparison mode only works for numeric field field.type === _defaultSettings.ALL_FIELD_TYPES.integer || field.type === _defaultSettings.ALL_FIELD_TYPES.real)) { var baseDp = primaryData.valueAt(fieldIdx); var dp = data.valueAt(fieldIdx); if ((0, _dataUtils.isNumber)(baseDp) && (0, _dataUtils.isNumber)(dp)) { var deltaValue = compareType === _tooltip.COMPARE_TYPES.RELATIVE ? dp / baseDp - 1 : dp - baseDp; var deltaFormat = compareType === _tooltip.COMPARE_TYPES.RELATIVE ? _tooltip.TOOLTIP_FORMATS.DECIMAL_PERCENT_FULL_2[_tooltip.TOOLTIP_KEY] : item.format || _tooltip.TOOLTIP_FORMATS.DECIMAL_DECIMAL_FIXED_3[_tooltip.TOOLTIP_KEY]; displayDeltaValue = (0, _dataUtils.getFormatter)(deltaFormat)(deltaValue); // safely cast string displayDeltaValue = (0, _dataUtils.defaultFormatter)(displayDeltaValue); var deltaFirstChar = displayDeltaValue.charAt(0); if (deltaFirstChar !== '+' && deltaFirstChar !== TOOLTIP_MINUS_SIGN) { displayDeltaValue = "+".concat(displayDeltaValue); } } else { displayDeltaValue = TOOLTIP_MINUS_SIGN; } } return displayDeltaValue; } /** * @type {typeof import('./interaction-utils').getTooltipDisplayValue} */ function getTooltipDisplayValue(_ref7) { var item = _ref7.item, field = _ref7.field, data = _ref7.data, fieldIdx = _ref7.fieldIdx; var dataValue = data.valueAt(fieldIdx); if (!(0, _dataUtils.notNullorUndefined)(dataValue)) { return ''; } return item.format ? (0, _dataUtils.getFormatter)(item.format, field)(dataValue) : (0, _dataUtils.parseFieldValue)(dataValue, field.type); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/interaction-utils.js"],"names":["TOOLTIP_MINUS_SIGN","getDefaultInteraction","tooltip","id","label","enabled","iconComponent","Messages","config","fieldsToShow","compareMode","compareType","COMPARE_TYPES","ABSOLUTE","geocoder","Pin","position","brush","Crosshairs","size","coordinate","CursorClick","BRUSH_CONFIG","range","findFieldsToShow","fields","DEFAULT_TOOLTIP_FIELDS","reduce","prev","curr","find","name","push","length","autoFindTooltipFields","ptFields","_mergeFieldPairs","TRIP_POINT_FIELDS","filter","type","replace","trim","split","every","seg","includes","ALL_FIELD_TYPES","geojson","slice","MAX_DEFAULT_TOOLTIPS","map","format","pairs","pair","getTooltipDisplayDeltaValue","primaryData","field","data","fieldIdx","item","displayDeltaValue","integer","real","baseDp","valueAt","dp","deltaValue","RELATIVE","deltaFormat","TOOLTIP_FORMATS","DECIMAL_PERCENT_FULL_2","TOOLTIP_KEY","DECIMAL_DECIMAL_FIXED_3","deltaFirstChar","charAt","getTooltipDisplayValue","dataValue"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 {\n  DEFAULT_TOOLTIP_FIELDS,\n  MAX_DEFAULT_TOOLTIPS,\n  ALL_FIELD_TYPES,\n  TRIP_POINT_FIELDS\n} from 'constants/default-settings';\nimport {\n  parseFieldValue,\n  getFormatter,\n  isNumber,\n  defaultFormatter,\n  notNullorUndefined\n} from 'utils/data-utils';\nimport {Messages, Crosshairs, CursorClick, Pin} from 'components/common/icons/index';\nimport {TOOLTIP_FORMATS, TOOLTIP_KEY, COMPARE_TYPES} from 'constants/tooltip';\n\n// \\u2212 is the minus sign that d3-format uses for decimal number formatting\nexport const TOOLTIP_MINUS_SIGN = '\\u2212';\n\n/**\n * @type {typeof import('./interaction-utils').getDefaultInteraction}\n */\nexport function getDefaultInteraction() {\n  return {\n    tooltip: {\n      id: 'tooltip',\n      label: 'interactions.tooltip',\n      enabled: true,\n      iconComponent: Messages,\n      config: {\n        fieldsToShow: {},\n        compareMode: false,\n        compareType: COMPARE_TYPES.ABSOLUTE\n      }\n    },\n    geocoder: {\n      id: 'geocoder',\n      label: 'interactions.geocoder',\n      enabled: false,\n      iconComponent: Pin,\n      position: null\n    },\n    brush: {\n      id: 'brush',\n      label: 'interactions.brush',\n      enabled: false,\n      iconComponent: Crosshairs,\n      config: {\n        // size is in km\n        size: 0.5\n      }\n    },\n    coordinate: {\n      id: 'coordinate',\n      label: 'interactions.coordinate',\n      enabled: false,\n      iconComponent: CursorClick,\n      position: null\n    }\n  };\n}\n\nexport const BRUSH_CONFIG = {\n  range: [0, 50]\n};\n\n/**\n * @type {typeof import('./interaction-utils').findFieldsToShow}\n */\nexport function findFieldsToShow({fields, id}) {\n  // first find default tooltip fields for trips\n  const fieldsToShow = DEFAULT_TOOLTIP_FIELDS.reduce((prev, curr) => {\n    if (fields.find(({name}) => curr.name === name)) {\n      prev.push(curr);\n    }\n    return prev;\n  }, []);\n\n  return {\n    [id]: fieldsToShow.length ? fieldsToShow : autoFindTooltipFields(fields)\n  };\n}\n\nfunction autoFindTooltipFields(fields) {\n  const ptFields = _mergeFieldPairs(TRIP_POINT_FIELDS);\n  // filter out the default fields that contains lat and lng and any geometry\n  const fieldsToShow = fields.filter(\n    ({name, type}) =>\n      name\n        .replace(/[_,.]+/g, ' ')\n        .trim()\n        .split(' ')\n        .every(seg => !ptFields.includes(seg)) &&\n      type !== ALL_FIELD_TYPES.geojson &&\n      type !== 'object'\n  );\n\n  return fieldsToShow.slice(0, MAX_DEFAULT_TOOLTIPS).map(({name}) => {\n    return {\n      name,\n      format: null\n    };\n  });\n}\n\nfunction _mergeFieldPairs(pairs) {\n  return pairs.reduce((prev, pair) => [...prev, ...pair], []);\n}\n\n/**\n * @type {typeof import('./interaction-utils').getTooltipDisplayDeltaValue}\n */\nexport function getTooltipDisplayDeltaValue({\n  primaryData,\n  field,\n  compareType,\n  data,\n  fieldIdx,\n  item\n}) {\n  let displayDeltaValue = null;\n\n  if (\n    primaryData &&\n    // comparison mode only works for numeric field\n    (field.type === ALL_FIELD_TYPES.integer || field.type === ALL_FIELD_TYPES.real)\n  ) {\n    const baseDp = primaryData.valueAt(fieldIdx);\n    const dp = data.valueAt(fieldIdx);\n    if (isNumber(baseDp) && isNumber(dp)) {\n      const deltaValue = compareType === COMPARE_TYPES.RELATIVE ? dp / baseDp - 1 : dp - baseDp;\n      const deltaFormat =\n        compareType === COMPARE_TYPES.RELATIVE\n          ? TOOLTIP_FORMATS.DECIMAL_PERCENT_FULL_2[TOOLTIP_KEY]\n          : item.format || TOOLTIP_FORMATS.DECIMAL_DECIMAL_FIXED_3[TOOLTIP_KEY];\n\n      displayDeltaValue = getFormatter(deltaFormat)(deltaValue);\n\n      // safely cast string\n      displayDeltaValue = defaultFormatter(displayDeltaValue);\n      const deltaFirstChar = displayDeltaValue.charAt(0);\n      if (deltaFirstChar !== '+' && deltaFirstChar !== TOOLTIP_MINUS_SIGN) {\n        displayDeltaValue = `+${displayDeltaValue}`;\n      }\n    } else {\n      displayDeltaValue = TOOLTIP_MINUS_SIGN;\n    }\n  }\n\n  return displayDeltaValue;\n}\n\n/**\n * @type {typeof import('./interaction-utils').getTooltipDisplayValue}\n */\nexport function getTooltipDisplayValue({item, field, data, fieldIdx}) {\n  const dataValue = data.valueAt(fieldIdx);\n  if (!notNullorUndefined(dataValue)) {\n    return '';\n  }\n\n  return item.format\n    ? getFormatter(item.format, field)(dataValue)\n    : parseFieldValue(dataValue, field.type);\n}\n"]}