kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
204 lines (172 loc) • 25.2 kB
JavaScript
;
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 _categoryWidgetIcon = _interopRequireDefault(require("./category-widget-icon"));
var _aggregateUtils = require("../../utils/aggregate-utils");
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 _newWidget$config = newWidget.config,
dataId = _newWidget$config.dataId,
aggregationType = _newWidget$config.aggregationType,
bounds = _newWidget$config.bounds;
var _state$datasets$dataI = state.datasets[dataId],
data = _state$datasets$dataI.data,
label = _state$datasets$dataI.label;
var sortableCategories = [];
var fields = state.datasets[dataId].fields;
var categoryField = newWidget.config.categoryField;
var fieldName = newWidget.config.fieldName;
var categoryFieldIdx = fields.findIndex(function (f) {
return f.name === categoryField;
});
var fieldIdx = fields.findIndex(function (f) {
return f.name === fieldName;
});
var boundingBox;
var cUL, cUR, cLL, cLR;
var latRange, lngRange;
if (!newWidget.config.selectedLayer) {
return newWidget;
}
var idx = state.layers.findIndex(function (l) {
return l.id === newWidget.config.selectedLayer.id;
});
if (!aggregationType || aggregationType !== 'count' && fieldIdx <= 0) return {
newWidget: newWidget,
updatedState: state
};
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) {
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)]);
})
})))
});
}
data = state.datasets[dataId].simplifiedGeoJSON.filter(function (d) {
return !(0, _booleanDisjoint["default"])(d[0], boundingPolygon);
});
}
}
var categories = data.reduce(function (acc, curr, idx) {
if (acc[curr[categoryFieldIdx]] === undefined) acc[curr[categoryFieldIdx]] = aggregationType === 'count' ? [1] : [curr[fieldIdx]];else acc[curr[categoryFieldIdx]].push(aggregationType === 'count' ? 1 : curr[fieldIdx]);
return acc;
}, {});
for (var category in categories) {
sortableCategories.push([category, (0, _aggregateUtils.aggregate)(categories[category], aggregationType)]);
}
sortableCategories = sortableCategories.sort(function (a, b) {
return b[1] - a[1];
});
sortableCategories.length = 5;
sortableCategories = sortableCategories.map(function (sc) {
return {
y: sc[0],
x: sc[1]
};
});
newWidget.config.aggregatedData = sortableCategories;
return {
newWidget: newWidget,
updatedState: state
};
}
}, {
key: "type",
get: function get() {
return 'Category';
}
}, {
key: "isAggregated",
get: function get() {
return false;
}
}, {
key: "widgetIcon",
get: function get() {
return _categoryWidgetIcon["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/category-widget/category-widget.js"],"names":["FunctionWidget","props","newWidget","state","mapState","config","dataId","aggregationType","bounds","datasets","data","label","sortableCategories","fields","categoryField","fieldName","categoryFieldIdx","findIndex","f","name","fieldIdx","boundingBox","cUL","cUR","cLL","cLR","latRange","lngRange","selectedLayer","idx","layers","l","id","updatedState","longitude","latitude","height","width","zoom","pitch","bearing","geoViewport","viewport","WebMercatorViewport","unproject","Set","sort","a","b","boundingPolygon","type","coordinates","crs","properties","latIdx","columns","lat","lngIdx","lng","filter","d","simplifiedGeoJSON","map","categories","reduce","acc","curr","undefined","push","category","length","sc","y","x","aggregatedData","CategoryWidgetIcon","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 CategoryWidgetIcon from './category-widget-icon';\nimport {aggregate} from '../../utils/aggregate-utils';\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 'Category';\n  }\n  get isAggregated() {\n    return false;\n  }\n  get widgetIcon() {\n    return CategoryWidgetIcon;\n  }\n  get widgetAggregatedData() {\n    return null;\n  }\n\n  calculateAggregationData(newWidget, state, mapState) {\n    const {dataId, aggregationType, bounds} = newWidget.config;\n    var {data, label} = state.datasets[dataId];\n    let sortableCategories = [];\n    const {fields} = state.datasets[dataId];\n    const categoryField = newWidget.config.categoryField;\n    const fieldName = newWidget.config.fieldName;\n    const categoryFieldIdx = fields.findIndex(f => f.name === categoryField);\n    const fieldIdx = fields.findIndex(f => f.name === fieldName);\n    let boundingBox;\n    let cUL, cUR, cLL, cLR;\n    let latRange, lngRange;\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    if (!aggregationType || (aggregationType !== 'count' && fieldIdx <= 0))\n      return {newWidget, updatedState: state};\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 (!state.datasets[dataId].simplifiedGeoJSON) {\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        data = state.datasets[dataId].simplifiedGeoJSON.filter(\n          d => !booleanDisjoint(d[0], boundingPolygon)\n        );\n      }\n    }\n\n    const categories = data.reduce((acc, curr, idx) => {\n      if (acc[curr[categoryFieldIdx]] === undefined)\n        acc[curr[categoryFieldIdx]] =\n          aggregationType === 'count' ? [1] : [curr[fieldIdx]];\n      else\n        acc[curr[categoryFieldIdx]].push(\n          aggregationType === 'count' ? 1 : curr[fieldIdx]\n        );\n      return acc;\n    }, {});\n    for (var category in categories) {\n      sortableCategories.push([\n        category,\n        aggregate(categories[category], aggregationType)\n      ]);\n    }\n\n    sortableCategories = sortableCategories.sort(function(a, b) {\n      return b[1] - a[1];\n    });\n    sortableCategories.length = 5;\n    sortableCategories = sortableCategories.map(sc => {\n      return {y: sc[0], x: sc[1]};\n    });\n\n    newWidget.config.aggregatedData = sortableCategories;\n    return {newWidget, updatedState: state};\n  }\n}\n"]}