UNPKG

kepler.gl

Version:

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

211 lines (177 loc) 20.5 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.pointColResolver = exports.mapboxRequiredColumns = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _baseLayer = _interopRequireWildcard(require("./base-layer")); var _reselect = require("reselect"); var _mapboxUtils = require("./mapbox-utils"); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var mapboxRequiredColumns = ['lat', 'lng']; exports.mapboxRequiredColumns = mapboxRequiredColumns; var pointColResolver = function pointColResolver(_ref) { var lat = _ref.lat, lng = _ref.lng; return "".concat(lat.fieldIdx, "-").concat(lng.fieldIdx); }; exports.pointColResolver = pointColResolver; var MapboxLayerGL = /*#__PURE__*/ function (_Layer) { (0, _inherits2["default"])(MapboxLayerGL, _Layer); function MapboxLayerGL() { var _getPrototypeOf2; var _this; (0, _classCallCheck2["default"])(this, MapboxLayerGL); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(MapboxLayerGL)).call.apply(_getPrototypeOf2, [this].concat(args))); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "datasetSelector", function (config) { return config.dataId; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "gpuFilterSelector", function (config, datasets) { return (datasets[config.dataId] || {}).gpuFilter; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "columnsSelector", function (config) { return pointColResolver(config.columns); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "sourceSelector", (0, _reselect.createSelector)(_this.datasetSelector, _this.columnsSelector, function (datasetId, columns) { return "".concat(datasetId, "-").concat(columns); })); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "filterSelector", (0, _reselect.createSelector)(_this.gpuFilterSelector, function (gpuFilter) { return (0, _mapboxUtils.gpuFilterToMapboxFilter)(gpuFilter); })); return _this; } (0, _createClass2["default"])(MapboxLayerGL, [{ key: "isValidFilter", value: function isValidFilter(filter) { // mapbox will crash if filter is not an array or empty return Array.isArray(filter) && filter.length; } }, { key: "getDataUpdateTriggers", value: function getDataUpdateTriggers(_ref2) { var _this2 = this; var filteredIndex = _ref2.filteredIndex, gpuFilter = _ref2.gpuFilter, id = _ref2.id; var columns = this.config.columns; var visualChannelFields = Object.values(this.visualChannels).reduce(function (accu, v) { return _objectSpread({}, accu, {}, _this2.config[v.field] ? (0, _defineProperty2["default"])({}, v.field, _this2.config[v.field].name) : {}); }, {}); var updateTriggers = { getData: _objectSpread({ datasetId: id, columns: columns, filteredIndex: filteredIndex }, visualChannelFields, {}, gpuFilter.filterValueUpdateTriggers), getMeta: { datasetId: id, columns: columns } }; return updateTriggers; } }, { key: "calculateDataAttribute", value: function calculateDataAttribute(_ref4, getPosition) { var _this3 = this; var allData = _ref4.allData, filteredIndex = _ref4.filteredIndex, gpuFilter = _ref4.gpuFilter; var getGeometry = function getGeometry(d) { return _this3.getGeometry(getPosition(d)); }; var vcFields = Object.values(this.visualChannels).map(function (v) { return _this3.config[v.field]; }).filter(function (v) { return v; }); var getPropertyFromVisualChanel = vcFields.length ? function (d) { return vcFields.reduce(function (accu, field) { return _objectSpread({}, accu, (0, _defineProperty2["default"])({}, field.name, d[field.tableFieldIndex - 1])); }, {}); } : function (d) { return {}; }; var filterValueUpdateTriggers = gpuFilter.filterValueUpdateTriggers, filterValueAccessor = gpuFilter.filterValueAccessor; // gpuField To property var hasFilter = Object.values(filterValueUpdateTriggers).filter(function (d) { return d; }).length; var valueAccessor = filterValueAccessor(); var getPropertyFromFilter = hasFilter ? function (d, index) { var filterValue = valueAccessor({ data: d, index: index }); return Object.values(filterValueUpdateTriggers).reduce(function (accu, name, i) { return _objectSpread({}, accu, {}, name ? (0, _defineProperty2["default"])({}, (0, _mapboxUtils.prefixGpuField)(name), filterValue[i]) : {}); }, {}); } : function (d) { return {}; }; var getProperties = function getProperties(d, i) { return _objectSpread({}, getPropertyFromVisualChanel(d), {}, getPropertyFromFilter(d, i)); }; return (0, _mapboxUtils.geoJsonFromData)(allData, filteredIndex, getGeometry, getProperties); } // this layer is rendered at mapbox level // todo: maybe need to find a better solution for this one }, { key: "shouldRenderLayer", value: function shouldRenderLayer() { return this.type && this.config.isVisible && this.hasAllColumns(); } }, { key: "overlayType", get: function get() { return _baseLayer.OVERLAY_TYPE.mapboxgl; } }, { key: "type", get: function get() { return null; } }, { key: "isAggregated", get: function get() { return true; } }, { key: "requiredLayerColumns", get: function get() { return mapboxRequiredColumns; } }, { key: "columnPairs", get: function get() { return this.defaultPointColumnPairs; } }, { key: "noneLayerDataAffectingProps", get: function get() { return []; } }, { key: "visualChannels", get: function get() { return {}; } }]); return MapboxLayerGL; }(_baseLayer["default"]); var _default = MapboxLayerGL; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/layers/mapboxgl-layer.js"],"names":["mapboxRequiredColumns","pointColResolver","lat","lng","fieldIdx","MapboxLayerGL","config","dataId","datasets","gpuFilter","columns","datasetSelector","columnsSelector","datasetId","gpuFilterSelector","filter","Array","isArray","length","filteredIndex","id","visualChannelFields","Object","values","visualChannels","reduce","accu","v","field","name","updateTriggers","getData","filterValueUpdateTriggers","getMeta","getPosition","allData","getGeometry","d","vcFields","map","getPropertyFromVisualChanel","tableFieldIndex","filterValueAccessor","hasFilter","valueAccessor","getPropertyFromFilter","index","filterValue","data","i","getProperties","type","isVisible","hasAllColumns","OVERLAY_TYPE","mapboxgl","defaultPointColumnPairs","Layer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AAEA;;;;;;AAEO,IAAMA,qBAAqB,GAAG,CAAC,KAAD,EAAQ,KAAR,CAA9B;;;AAEA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB;AAAA,MAAEC,GAAF,QAAEA,GAAF;AAAA,MAAOC,GAAP,QAAOA,GAAP;AAAA,mBAAmBD,GAAG,CAACE,QAAvB,cAAmCD,GAAG,CAACC,QAAvC;AAAA,CAAzB;;;;IAEDC,a;;;;;;;;;;;;;;;;;wGA4Bc,UAAAC,MAAM;AAAA,aAAIA,MAAM,CAACC,MAAX;AAAA,K;0GACJ,UAACD,MAAD,EAASE,QAAT;AAAA,aAAsB,CAACA,QAAQ,CAACF,MAAM,CAACC,MAAR,CAAR,IAA2B,EAA5B,EAAgCE,SAAtD;AAAA,K;wGACF,UAAAH,MAAM;AAAA,aAAIL,gBAAgB,CAACK,MAAM,CAACI,OAAR,CAApB;AAAA,K;uGAEP,8BACf,MAAKC,eADU,EAEf,MAAKC,eAFU,EAGf,UAACC,SAAD,EAAYH,OAAZ;AAAA,uBAA2BG,SAA3B,cAAwCH,OAAxC;AAAA,KAHe,C;uGAMA,8BAAe,MAAKI,iBAApB,EAAuC,UAAAL,SAAS;AAAA,aAC/D,0CAAwBA,SAAxB,CAD+D;AAAA,KAAhD,C;;;;;;kCAIHM,M,EAAQ;AACpB;AACA,aAAOC,KAAK,CAACC,OAAN,CAAcF,MAAd,KAAyBA,MAAM,CAACG,MAAvC;AACD;;;iDAEqD;AAAA;;AAAA,UAA/BC,aAA+B,SAA/BA,aAA+B;AAAA,UAAhBV,SAAgB,SAAhBA,SAAgB;AAAA,UAALW,EAAK,SAALA,EAAK;AAAA,UAC7CV,OAD6C,GAClC,KAAKJ,MAD6B,CAC7CI,OAD6C;AAGpD,UAAMW,mBAAmB,GAAGC,MAAM,CAACC,MAAP,CAAc,KAAKC,cAAnB,EAAmCC,MAAnC,CAC1B,UAACC,IAAD,EAAOC,CAAP;AAAA,iCACKD,IADL,MAEM,MAAI,CAACpB,MAAL,CAAYqB,CAAC,CAACC,KAAd,yCAAyBD,CAAC,CAACC,KAA3B,EAAmC,MAAI,CAACtB,MAAL,CAAYqB,CAAC,CAACC,KAAd,EAAqBC,IAAxD,IAAgE,EAFtE;AAAA,OAD0B,EAK1B,EAL0B,CAA5B;AAQA,UAAMC,cAAc,GAAG;AACrBC,QAAAA,OAAO;AACLlB,UAAAA,SAAS,EAAEO,EADN;AAELV,UAAAA,OAAO,EAAPA,OAFK;AAGLS,UAAAA,aAAa,EAAbA;AAHK,WAIFE,mBAJE,MAKFZ,SAAS,CAACuB,yBALR,CADc;AAQrBC,QAAAA,OAAO,EAAE;AAACpB,UAAAA,SAAS,EAAEO,EAAZ;AAAgBV,UAAAA,OAAO,EAAPA;AAAhB;AARY,OAAvB;AAWA,aAAOoB,cAAP;AACD;;;kDAE2DI,W,EAAa;AAAA;;AAAA,UAAjDC,OAAiD,SAAjDA,OAAiD;AAAA,UAAxChB,aAAwC,SAAxCA,aAAwC;AAAA,UAAzBV,SAAyB,SAAzBA,SAAyB;;AACvE,UAAM2B,WAAW,GAAG,SAAdA,WAAc,CAAAC,CAAC;AAAA,eAAI,MAAI,CAACD,WAAL,CAAiBF,WAAW,CAACG,CAAD,CAA5B,CAAJ;AAAA,OAArB;;AAEA,UAAMC,QAAQ,GAAGhB,MAAM,CAACC,MAAP,CAAc,KAAKC,cAAnB,EACde,GADc,CACV,UAAAZ,CAAC;AAAA,eAAI,MAAI,CAACrB,MAAL,CAAYqB,CAAC,CAACC,KAAd,CAAJ;AAAA,OADS,EAEdb,MAFc,CAEP,UAAAY,CAAC;AAAA,eAAIA,CAAJ;AAAA,OAFM,CAAjB;AAIA,UAAMa,2BAA2B,GAAGF,QAAQ,CAACpB,MAAT,GAChC,UAAAmB,CAAC;AAAA,eACCC,QAAQ,CAACb,MAAT,CACE,UAACC,IAAD,EAAOE,KAAP;AAAA,mCACKF,IADL,uCAEGE,KAAK,CAACC,IAFT,EAEgBQ,CAAC,CAACT,KAAK,CAACa,eAAN,GAAwB,CAAzB,CAFjB;AAAA,SADF,EAKE,EALF,CADD;AAAA,OAD+B,GAShC,UAAAJ,CAAC;AAAA,eAAK,EAAL;AAAA,OATL;AAPuE,UAkBhEL,yBAlBgE,GAkBdvB,SAlBc,CAkBhEuB,yBAlBgE;AAAA,UAkBrCU,mBAlBqC,GAkBdjC,SAlBc,CAkBrCiC,mBAlBqC,EAoBvE;;AACA,UAAMC,SAAS,GAAGrB,MAAM,CAACC,MAAP,CAAcS,yBAAd,EAAyCjB,MAAzC,CAAgD,UAAAsB,CAAC;AAAA,eAAIA,CAAJ;AAAA,OAAjD,EAAwDnB,MAA1E;AACA,UAAM0B,aAAa,GAAGF,mBAAmB,EAAzC;AAEA,UAAMG,qBAAqB,GAAGF,SAAS,GACnC,UAACN,CAAD,EAAIS,KAAJ,EAAc;AACZ,YAAMC,WAAW,GAAGH,aAAa,CAAC;AAACI,UAAAA,IAAI,EAAEX,CAAP;AAAUS,UAAAA,KAAK,EAALA;AAAV,SAAD,CAAjC;AACA,eAAOxB,MAAM,CAACC,MAAP,CAAcS,yBAAd,EAAyCP,MAAzC,CACL,UAACC,IAAD,EAAOG,IAAP,EAAaoB,CAAb;AAAA,mCACKvB,IADL,MAEMG,IAAI,wCAAK,iCAAeA,IAAf,CAAL,EAA4BkB,WAAW,CAACE,CAAD,CAAvC,IAA8C,EAFxD;AAAA,SADK,EAKL,EALK,CAAP;AAOD,OAVkC,GAWnC,UAAAZ,CAAC;AAAA,eAAK,EAAL;AAAA,OAXL;;AAaA,UAAMa,aAAa,GAAG,SAAhBA,aAAgB,CAACb,CAAD,EAAIY,CAAJ;AAAA,iCACjBT,2BAA2B,CAACH,CAAD,CADV,MAEjBQ,qBAAqB,CAACR,CAAD,EAAIY,CAAJ,CAFJ;AAAA,OAAtB;;AAKA,aAAO,kCAAgBd,OAAhB,EAAyBhB,aAAzB,EAAwCiB,WAAxC,EAAqDc,aAArD,CAAP;AACD,K,CAED;AACA;;;;wCACoB;AAClB,aAAO,KAAKC,IAAL,IAAa,KAAK7C,MAAL,CAAY8C,SAAzB,IAAsC,KAAKC,aAAL,EAA7C;AACD;;;wBAxHiB;AAChB,aAAOC,wBAAaC,QAApB;AACD;;;wBAEU;AACT,aAAO,IAAP;AACD;;;wBAEkB;AACjB,aAAO,IAAP;AACD;;;wBAE0B;AACzB,aAAOvD,qBAAP;AACD;;;wBAEiB;AAChB,aAAO,KAAKwD,uBAAZ;AACD;;;wBAEiC;AAChC,aAAO,EAAP;AACD;;;wBAEoB;AACnB,aAAO,EAAP;AACD;;;EA3ByBC,qB;;eA4HbpD,a","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 Layer, {OVERLAY_TYPE} from './base-layer';\nimport {createSelector} from 'reselect';\n\nimport {geoJsonFromData, prefixGpuField, gpuFilterToMapboxFilter} from './mapbox-utils';\n\nexport const mapboxRequiredColumns = ['lat', 'lng'];\n\nexport const pointColResolver = ({lat, lng}) => `${lat.fieldIdx}-${lng.fieldIdx}`;\n\nclass MapboxLayerGL extends Layer {\n  get overlayType() {\n    return OVERLAY_TYPE.mapboxgl;\n  }\n\n  get type() {\n    return null;\n  }\n\n  get isAggregated() {\n    return true;\n  }\n\n  get requiredLayerColumns() {\n    return mapboxRequiredColumns;\n  }\n\n  get columnPairs() {\n    return this.defaultPointColumnPairs;\n  }\n\n  get noneLayerDataAffectingProps() {\n    return [];\n  }\n\n  get visualChannels() {\n    return {};\n  }\n  datasetSelector = config => config.dataId;\n  gpuFilterSelector = (config, datasets) => (datasets[config.dataId] || {}).gpuFilter;\n  columnsSelector = config => pointColResolver(config.columns);\n\n  sourceSelector = createSelector(\n    this.datasetSelector,\n    this.columnsSelector,\n    (datasetId, columns) => `${datasetId}-${columns}`\n  );\n\n  filterSelector = createSelector(this.gpuFilterSelector, gpuFilter =>\n    gpuFilterToMapboxFilter(gpuFilter)\n  );\n\n  isValidFilter(filter) {\n    // mapbox will crash if filter is not an array or empty\n    return Array.isArray(filter) && filter.length;\n  }\n\n  getDataUpdateTriggers({filteredIndex, gpuFilter, id}) {\n    const {columns} = this.config;\n\n    const visualChannelFields = Object.values(this.visualChannels).reduce(\n      (accu, v) => ({\n        ...accu,\n        ...(this.config[v.field] ? {[v.field]: this.config[v.field].name} : {})\n      }),\n      {}\n    );\n\n    const updateTriggers = {\n      getData: {\n        datasetId: id,\n        columns,\n        filteredIndex,\n        ...visualChannelFields,\n        ...gpuFilter.filterValueUpdateTriggers\n      },\n      getMeta: {datasetId: id, columns}\n    };\n\n    return updateTriggers;\n  }\n\n  calculateDataAttribute({allData, filteredIndex, gpuFilter}, getPosition) {\n    const getGeometry = d => this.getGeometry(getPosition(d));\n\n    const vcFields = Object.values(this.visualChannels)\n      .map(v => this.config[v.field])\n      .filter(v => v);\n\n    const getPropertyFromVisualChanel = vcFields.length\n      ? d =>\n          vcFields.reduce(\n            (accu, field) => ({\n              ...accu,\n              [field.name]: d[field.tableFieldIndex - 1]\n            }),\n            {}\n          )\n      : d => ({});\n\n    const {filterValueUpdateTriggers, filterValueAccessor} = gpuFilter;\n\n    // gpuField To property\n    const hasFilter = Object.values(filterValueUpdateTriggers).filter(d => d).length;\n    const valueAccessor = filterValueAccessor();\n\n    const getPropertyFromFilter = hasFilter\n      ? (d, index) => {\n          const filterValue = valueAccessor({data: d, index});\n          return Object.values(filterValueUpdateTriggers).reduce(\n            (accu, name, i) => ({\n              ...accu,\n              ...(name ? {[prefixGpuField(name)]: filterValue[i]} : {})\n            }),\n            {}\n          );\n        }\n      : d => ({});\n\n    const getProperties = (d, i) => ({\n      ...getPropertyFromVisualChanel(d),\n      ...getPropertyFromFilter(d, i)\n    });\n\n    return geoJsonFromData(allData, filteredIndex, getGeometry, getProperties);\n  }\n\n  // this layer is rendered at mapbox level\n  // todo: maybe need to find a better solution for this one\n  shouldRenderLayer() {\n    return this.type && this.config.isVisible && this.hasAllColumns();\n  }\n}\n\nexport default MapboxLayerGL;\n"]}