UNPKG

kepler.gl.geoiq

Version:

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

243 lines (207 loc) 28.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); 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 _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _baseWidget = _interopRequireDefault(require("../base-widget")); var _aggregateUtils = require("../../utils/aggregate-utils"); var _functionWidgetIcon = _interopRequireDefault(require("./function-widget-icon")); var _geoViewport = _interopRequireDefault(require("@mapbox/geo-viewport")); var _viewportMercatorProject = _interopRequireDefault(require("viewport-mercator-project")); var _fileHandler = require("../../processors/file-handler"); var _booleanDisjoint = _interopRequireDefault(require("@turf/boolean-disjoint")); var _helpers = require("@turf/helpers"); var _simplifyGeojson = _interopRequireDefault(require("simplify-geojson")); 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 FunctionWidget = /*#__PURE__*/ function (_Widget) { (0, _inherits2["default"])(FunctionWidget, _Widget); function FunctionWidget(props) { (0, _classCallCheck2["default"])(this, FunctionWidget); return (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(FunctionWidget).call(this, props)); } (0, _createClass2["default"])(FunctionWidget, [{ key: "calculateAggregationData", value: function calculateAggregationData(newWidget, state, mapState) { var latRange, lngRange; var _newWidget$config = newWidget.config, dataId = _newWidget$config.dataId, aggregationType = _newWidget$config.aggregationType, bounds = _newWidget$config.bounds; var boundingBox; var cUL, cUR, cLL, cLR; var _state$datasets$dataI = state.datasets[dataId], data = _state$datasets$dataI.data, label = _state$datasets$dataI.label; if (!newWidget.config.selectedLayer) { return newWidget; } var idx = state.layers.findIndex(function (l) { return l.id === newWidget.config.selectedLayer.id; }); var fields = state.datasets[dataId].fields; if (mapState && bounds) { var longitude = mapState.longitude, latitude = mapState.latitude, height = mapState.height, width = mapState.width, zoom = mapState.zoom, pitch = mapState.pitch, bearing = mapState.bearing; boundingBox = _geoViewport["default"].bounds([longitude, latitude], zoom, [width, height]); var viewport = new _viewportMercatorProject["default"]({ width: width, height: height, longitude: longitude, latitude: latitude, zoom: zoom, pitch: pitch, bearing: bearing }); cUL = viewport.unproject([0, 0]); cUR = viewport.unproject([width, 0]); cLR = viewport.unproject([width, height]); cLL = viewport.unproject([0, height]); latRange = (0, _toConsumableArray2["default"])(new Set([cLL[1], cUR[1], cLR[1], cUL[1]])).sort(function (a, b) { return a - b; }); lngRange = (0, _toConsumableArray2["default"])(new Set([cLL[0], cUR[0], cLR[0], cUL[0]])).sort(function (a, b) { return a - b; }); var boundingPolygon = { type: 'Polygon', coordinates: [[cUL, cUR, cLR, cLL]], crs: { type: 'name', properties: { name: 'EPSG:4326' } } }; if ((0, _fileHandler.getFileType)(label) !== 'json' && boundingBox) { var latIdx = state.layers[idx].config.columns.lat.fieldIdx; var lngIdx = state.layers[idx].config.columns.lng.fieldIdx; data = data.filter(function (d) { return pitch || bearing ? !(0, _booleanDisjoint["default"])((0, _helpers.point)([d[lngIdx], d[latIdx]]), boundingPolygon) : d[latIdx] > latRange[0] && d[latIdx] < latRange[1] && d[lngIdx] > lngRange[0] && d[lngIdx] < lngRange[1]; }); } else if (boundingBox) { if (!state.datasets[dataId].simplifiedGeoJSON || data.length !== state.datasets[dataId].simplifiedGeoJSON.length) { state = _objectSpread({}, state, { datasets: _objectSpread({}, state.datasets, (0, _defineProperty2["default"])({}, dataId, _objectSpread({}, state.datasets[dataId], { simplifiedGeoJSON: data.map(function (d) { return [].concat((0, _toConsumableArray2["default"])(d), [d[0] = (0, _simplifyGeojson["default"])(d[0], 0.01)]); }) }))) }); } //commented part is using viewport to tell which point is in the viewport and faster than turf.js // console.log('state inside geojson aggregation ', state); // data = state.d atasets[dataId].simplifiedGeoJSON.filter(d => // d.geometry.coordinates.reduce((accu, val) => { // var pointInsideBounds = false; // if (accu) return accu; // var i = 0; // const flatVal = flatValToPoint(val); // // if (val[i].length > 2) { // // flatVal = val.flat(); // // } // do { // const p = flatVal[i]; // // console.log('point inside do while loop', p); // if ( // viewport.project([p[0], p[1]])[0] > 0 && // viewport.project([p[0], p[1]])[0] < width && // viewport.project([p[0], p[1]])[1] > 0 && // viewport.project([p[0], p[1]])[1] < height // ) { // pointInsideBounds = true; // } // i++; // } while (!pointInsideBounds && i < val.length); // return pointInsideBounds; // }, false) // ); data = state.datasets[dataId].simplifiedGeoJSON.filter(function (d) { return !(0, _booleanDisjoint["default"])(d[0], boundingPolygon); }); // console.log( // viewport.project([0, 0])[0] > 0 && viewport.project([0, 0])[0] < width // ); // console.log(data.length); // data = state.datasets[dataId].simplifiedGeoJSON.filter( // d => !booleanDisjoint(d, boundingPolygon) // ); // console.log(data.length); // data = data.map(d => { // console.log(d[0]); // console.log(); // }); } } if (aggregationType === 'count') { newWidget.config.aggregatedData = data.length; } else { var fieldName = newWidget.config.fieldName; var fieldIdx = fields.findIndex(function (f) { return f.name === fieldName; }); if (fieldName) { var fieldData = data.map(function (d) { if (d.data) { return d.data[fieldIdx]; } else { return d[fieldIdx]; } }); var aggregatedData = (0, _aggregateUtils.aggregate)(fieldData, aggregationType); if (typeof aggregatedData === 'number') { newWidget.config.aggregatedData = +aggregatedData.toFixed(2); } else { newWidget.config.aggregatedData = aggregatedData; } newWidget.config.aggregatedData; } } // console.log( // 'newWidget and state inside calculateAggregationData', // newWidget, // state // ); newWidget.config.isCalculating = false; return { newWidget: newWidget, updatedState: state }; } }, { key: "type", get: function get() { return 'Function'; } }, { key: "isAggregated", get: function get() { return false; } }, { key: "widgetIcon", get: function get() { return _functionWidgetIcon["default"]; } }, { key: "widgetAggregatedData", get: function get() { return null; } }]); return FunctionWidget; }(_baseWidget["default"]); exports["default"] = FunctionWidget; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/widgets/function-widget/function-widget.js"],"names":["FunctionWidget","props","newWidget","state","mapState","latRange","lngRange","config","dataId","aggregationType","bounds","boundingBox","cUL","cUR","cLL","cLR","datasets","data","label","selectedLayer","idx","layers","findIndex","l","id","fields","longitude","latitude","height","width","zoom","pitch","bearing","geoViewport","viewport","WebMercatorViewport","unproject","Set","sort","a","b","boundingPolygon","type","coordinates","crs","properties","name","latIdx","columns","lat","fieldIdx","lngIdx","lng","filter","d","simplifiedGeoJSON","length","map","aggregatedData","fieldName","f","fieldData","toFixed","isCalculating","updatedState","FunctionWidgetIcon","Widget"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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 Widget from '../base-widget';\nimport {aggregate} from '../../utils/aggregate-utils';\nimport FunctionWidgetIcon from './function-widget-icon';\nimport geoViewport from '@mapbox/geo-viewport';\nimport WebMercatorViewport from 'viewport-mercator-project';\nimport {getFileType} from 'processors/file-handler';\nimport booleanDisjoint from '@turf/boolean-disjoint';\nimport {point, polygon} from '@turf/helpers';\n// import simplify from '@turf/simplify';\nimport simplify from 'simplify-geojson';\n\nexport default class FunctionWidget extends Widget {\n  constructor(props) {\n    super(props);\n  }\n  get type() {\n    return 'Function';\n  }\n  get isAggregated() {\n    return false;\n  }\n  get widgetIcon() {\n    return FunctionWidgetIcon;\n  }\n  get widgetAggregatedData() {\n    return null;\n  }\n\n  calculateAggregationData(newWidget, state, mapState) {\n    let latRange, lngRange;\n\n    const {dataId, aggregationType, bounds} = newWidget.config;\n    let boundingBox;\n    let cUL, cUR, cLL, cLR;\n    var {data, label} = state.datasets[dataId];\n\n    if (!newWidget.config.selectedLayer) {\n      return newWidget;\n    }\n\n    const idx = state.layers.findIndex(\n      l => l.id === newWidget.config.selectedLayer.id\n    );\n\n    const {fields} = state.datasets[dataId];\n\n    if (mapState && bounds) {\n      const {\n        longitude,\n        latitude,\n        height,\n        width,\n        zoom,\n        pitch,\n        bearing\n      } = mapState;\n\n      boundingBox = geoViewport.bounds([longitude, latitude], zoom, [\n        width,\n        height\n      ]);\n\n      const viewport = new WebMercatorViewport({\n        width: width,\n        height: height,\n        longitude: longitude,\n        latitude: latitude,\n        zoom: zoom,\n        pitch: pitch,\n        bearing: bearing\n      });\n      cUL = viewport.unproject([0, 0]);\n      cUR = viewport.unproject([width, 0]);\n      cLR = viewport.unproject([width, height]);\n      cLL = viewport.unproject([0, height]);\n\n      latRange = [...new Set([cLL[1], cUR[1], cLR[1], cUL[1]])].sort(\n        (a, b) => a - b\n      );\n      lngRange = [...new Set([cLL[0], cUR[0], cLR[0], cUL[0]])].sort(\n        (a, b) => a - b\n      );\n\n      const boundingPolygon = {\n        type: 'Polygon',\n        coordinates: [[cUL, cUR, cLR, cLL]],\n        crs: {\n          type: 'name',\n          properties: {\n            name: 'EPSG:4326'\n          }\n        }\n      };\n\n      if (getFileType(label) !== 'json' && boundingBox) {\n        const latIdx = state.layers[idx].config.columns.lat.fieldIdx;\n        const lngIdx = state.layers[idx].config.columns.lng.fieldIdx;\n        data = data.filter(d =>\n          pitch || bearing\n            ? !booleanDisjoint(point([d[lngIdx], d[latIdx]]), boundingPolygon)\n            : d[latIdx] > latRange[0] &&\n              d[latIdx] < latRange[1] &&\n              d[lngIdx] > lngRange[0] &&\n              d[lngIdx] < lngRange[1]\n        );\n      } else if (boundingBox) {\n        if (\n          !state.datasets[dataId].simplifiedGeoJSON ||\n          data.length !== state.datasets[dataId].simplifiedGeoJSON.length\n        ) {\n          state = {\n            ...state,\n            datasets: {\n              ...state.datasets,\n              [dataId]: {\n                ...state.datasets[dataId],\n                simplifiedGeoJSON: data.map(d => [\n                  ...d,\n                  (d[0] = simplify(d[0], 0.01))\n                ])\n              }\n            }\n          };\n        }\n\n        //commented part is using viewport to tell which point is in the viewport and faster than turf.js\n\n        // console.log('state inside geojson aggregation ', state);\n        // data = state.d atasets[dataId].simplifiedGeoJSON.filter(d =>\n        //   d.geometry.coordinates.reduce((accu, val) => {\n        //     var pointInsideBounds = false;\n        //     if (accu) return accu;\n        //     var i = 0;\n        //     const flatVal = flatValToPoint(val);\n        //     // if (val[i].length > 2) {\n        //     //   flatVal = val.flat();\n        //     // }\n        //     do {\n        //       const p = flatVal[i];\n        //       // console.log('point inside do while loop', p);\n        //       if (\n        //         viewport.project([p[0], p[1]])[0] > 0 &&\n        //         viewport.project([p[0], p[1]])[0] < width &&\n        //         viewport.project([p[0], p[1]])[1] > 0 &&\n        //         viewport.project([p[0], p[1]])[1] < height\n        //       ) {\n        //         pointInsideBounds = true;\n        //       }\n        //       i++;\n        //     } while (!pointInsideBounds && i < val.length);\n        //     return pointInsideBounds;\n        //   }, false)\n        // );\n        data = state.datasets[dataId].simplifiedGeoJSON.filter(\n          d => !booleanDisjoint(d[0], boundingPolygon)\n        );\n\n        // console.log(\n        //   viewport.project([0, 0])[0] > 0 && viewport.project([0, 0])[0] < width\n        // );\n        // console.log(data.length);\n        // data = state.datasets[dataId].simplifiedGeoJSON.filter(\n        //   d => !booleanDisjoint(d, boundingPolygon)\n        // );\n        // console.log(data.length);\n\n        // data = data.map(d => {\n        //   console.log(d[0]);\n        //   console.log();\n        // });\n      }\n    }\n\n    if (aggregationType === 'count') {\n      newWidget.config.aggregatedData = data.length;\n    } else {\n      const fieldName = newWidget.config.fieldName;\n      const fieldIdx = fields.findIndex(f => f.name === fieldName);\n      if (fieldName) {\n        let fieldData = data.map(d => {\n          if (d.data) {\n            return d.data[fieldIdx];\n          } else {\n            return d[fieldIdx];\n          }\n        });\n        const aggregatedData = aggregate(fieldData, aggregationType);\n        if (typeof aggregatedData === 'number') {\n          newWidget.config.aggregatedData = +aggregatedData.toFixed(2);\n        } else {\n          newWidget.config.aggregatedData = aggregatedData;\n        }\n        newWidget.config.aggregatedData;\n      }\n    }\n    // console.log(\n    //   'newWidget and state inside calculateAggregationData',\n    //   newWidget,\n    //   state\n    // );\n    newWidget.config.isCalculating = false;\n    return {newWidget, updatedState: state};\n  }\n}\n"]}