kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
221 lines (194 loc) • 22.1 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.mvtVisConfigs = exports.mvtRequiredUrl = exports["default"] = void 0;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _baseLayer = _interopRequireDefault(require("../base-layer"));
var _mvtLayerIcon = _interopRequireDefault(require("./mvt-layer-icon"));
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var mvtRequiredUrl = exports.mvtRequiredUrl = ['url'];
var mvtVisConfigs = exports.mvtVisConfigs = {
opacity: 'opacity',
thickness: {
type: 'number',
defaultValue: 0.5,
label: 'Stroke Width',
isRanged: false,
range: [0, 100],
step: 0.1,
group: 'stroke',
property: 'thickness'
},
colorRange: 'colorRange',
radius: 'radius',
sizeRange: 'strokeWidthRange',
radiusRange: 'radiusRange',
heightRange: 'elevationRange',
elevationScale: 'elevationScale',
'hi-precision': 'hi-precision',
stroked: 'stroked',
filled: 'filled',
enable3d: 'enable3d',
wireframe: 'wireframe'
};
var MVTLayer = exports["default"] = /*#__PURE__*/function (_Layer) {
(0, _inherits2["default"])(MVTLayer, _Layer);
var _super = _createSuper(MVTLayer);
function MVTLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, MVTLayer);
_this = _super.call(this, props);
_this.dataToFeature = {};
_this.registerVisConfig(mvtVisConfigs);
return _this;
}
(0, _createClass2["default"])(MVTLayer, [{
key: "type",
get: function get() {
return 'tile';
}
}, {
key: "name",
get: function get() {
return 'tile';
}
}, {
key: "layerIcon",
get: function get() {
return _mvtLayerIcon["default"];
}
}, {
key: "requiredLayerColumns",
get: function get() {
return mvtRequiredUrl;
}
}, {
key: "visualChannels",
get: function get() {
return _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(MVTLayer.prototype), "visualChannels", this)), {}, {
size: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(MVTLayer.prototype), "visualChannels", this).size), {}, {
property: 'stroke',
condition: function condition(config) {
return config.visConfig.stroked;
}
}),
height: {
property: 'height',
field: 'heightField',
scale: 'heightScale',
domain: 'heightDomain',
range: 'heightRange',
key: 'height',
channelScaleType: 'size',
condition: function condition(config) {
return config.visConfig.enable3d;
}
},
radius: {
property: 'radius',
field: 'radiusField',
scale: 'radiusScale',
domain: 'radiusDomain',
range: 'radiusRange',
key: 'radius',
channelScaleType: 'radius'
}
});
}
}, {
key: "getDefaultLayerConfig",
value: function getDefaultLayerConfig() {
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
return _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(MVTLayer.prototype), "getDefaultLayerConfig", this).call(this, props)), {}, {
// add height visual channel
heightField: null,
heightDomain: [0, 1],
heightScale: 'linear',
// add radius visual channel
radiusField: null,
radiusDomain: [0, 1],
radiusScale: 'linear'
});
}
}, {
key: "getHoverData",
value: function getHoverData(object, allData) {
// index of allData is saved to feature.properties
return allData[object.properties.index];
}
}, {
key: "formatLayerData",
value: function formatLayerData() {}
}, {
key: "renderLayer",
value: function renderLayer(_ref) {
var _this2 = this;
var idx = _ref.idx,
objectHovered = _ref.objectHovered,
datasets = _ref.datasets,
loadEDLinkData = _ref.loadEDLinkData;
var cfg = this.config; // {"field":"Population","operand":"BETWEEN","values":[90,630]}
this.updateLayerConfig({
colorField: {
format: '',
id: 'population',
name: 'Population',
tableFieldIndex: 2,
type: 'integer'
}
});
this.updateLayerDomain(datasets[this.config.dataId]);
var colorField = {
format: '',
id: 'population',
name: 'Population',
tableFieldIndex: 1,
type: 'integer'
};
var cScale = colorField && this.getVisChannelScale('quantize', this.config.colorDomain, colorRange.colors.map(hexToRgb)); // const getFillColor = d => {
// console.log('d', d);
// cScale
// ? this.getEncodedChannelValue(cScale, d.properties[0], colorField)
// : [128, 128, 128];
// };
var tempLayr = new DeckGLMVTLayer({
id: this.id,
idx: idx,
url: this.config.dataId,
filters: datasets[this.config.dataId].filters,
cScale: cScale,
colorField: colorField,
getEncodedChannelValue: function getEncodedChannelValue(cScale, props, colorField) {
return _this2.getEncodedChannelValue(cScale, props, colorField);
},
loadEDLinkData: loadEDLinkData
});
return [tempLayr].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new DeckGLGeoJsonLayer({
id: "".concat(this.id, "-hovered"),
data: [objectHovered.object],
getLineWidth: 1,
getRadius: 23,
getElevation: 45,
getLineColor: [255, 255, 0],
getFillColor: [0, 255, 255],
stroked: true,
pickable: false,
filled: false
})] : []));
}
}]);
return MVTLayer;
}(_baseLayer["default"]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/mvt-layer/mvt-layer.js"],"names":["mvtRequiredUrl","mvtVisConfigs","opacity","thickness","type","defaultValue","label","isRanged","range","step","group","property","colorRange","radius","sizeRange","radiusRange","heightRange","elevationScale","stroked","filled","enable3d","wireframe","MVTLayer","props","dataToFeature","registerVisConfig","MVTLayerIcon","size","condition","config","visConfig","height","field","scale","domain","key","channelScaleType","heightField","heightDomain","heightScale","radiusField","radiusDomain","radiusScale","object","allData","properties","index","idx","objectHovered","datasets","loadEDLinkData","cfg","updateLayerConfig","colorField","format","id","name","tableFieldIndex","updateLayerDomain","dataId","cScale","getVisChannelScale","colorDomain","colors","map","hexToRgb","tempLayr","DeckGLMVTLayer","url","filters","getEncodedChannelValue","isLayerHovered","DeckGLGeoJsonLayer","data","getLineWidth","getRadius","getElevation","getLineColor","getFillColor","pickable","Layer"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 from '../base-layer';\nimport MVTLayerIcon from './mvt-layer-icon';\n\nexport const mvtRequiredUrl = ['url'];\n\nexport const mvtVisConfigs = {\n  opacity: 'opacity',\n  thickness: {\n    type: 'number',\n    defaultValue: 0.5,\n    label: 'Stroke Width',\n    isRanged: false,\n    range: [0, 100],\n    step: 0.1,\n    group: 'stroke',\n    property: 'thickness'\n  },\n  colorRange: 'colorRange',\n  radius: 'radius',\n\n  sizeRange: 'strokeWidthRange',\n  radiusRange: 'radiusRange',\n  heightRange: 'elevationRange',\n  elevationScale: 'elevationScale',\n\n  'hi-precision': 'hi-precision',\n  stroked: 'stroked',\n  filled: 'filled',\n  enable3d: 'enable3d',\n  wireframe: 'wireframe'\n};\n\nexport default class MVTLayer extends Layer {\n  constructor(props) {\n    super(props);\n\n    this.dataToFeature = {};\n    this.registerVisConfig(mvtVisConfigs);\n  }\n  get type() {\n    return 'tile';\n  }\n\n  get name() {\n    return 'tile';\n  }\n\n  get layerIcon() {\n    return MVTLayerIcon;\n  }\n\n  get requiredLayerColumns() {\n    return mvtRequiredUrl;\n  }\n\n  get visualChannels() {\n    return {\n      ...super.visualChannels,\n      size: {\n        ...super.visualChannels.size,\n        property: 'stroke',\n        condition: config => config.visConfig.stroked\n      },\n      height: {\n        property: 'height',\n        field: 'heightField',\n        scale: 'heightScale',\n        domain: 'heightDomain',\n        range: 'heightRange',\n        key: 'height',\n        channelScaleType: 'size',\n        condition: config => config.visConfig.enable3d\n      },\n      radius: {\n        property: 'radius',\n        field: 'radiusField',\n        scale: 'radiusScale',\n        domain: 'radiusDomain',\n        range: 'radiusRange',\n        key: 'radius',\n        channelScaleType: 'radius'\n      }\n    };\n  }\n\n  getDefaultLayerConfig(props = {}) {\n    return {\n      ...super.getDefaultLayerConfig(props),\n\n      // add height visual channel\n      heightField: null,\n      heightDomain: [0, 1],\n      heightScale: 'linear',\n\n      // add radius visual channel\n      radiusField: null,\n      radiusDomain: [0, 1],\n      radiusScale: 'linear'\n    };\n  }\n\n  getHoverData(object, allData) {\n    // index of allData is saved to feature.properties\n    return allData[object.properties.index];\n  }\n  formatLayerData() {}\n\n  renderLayer({idx, objectHovered, datasets, loadEDLinkData}) {\n    var cfg = this.config;\n    // {\"field\":\"Population\",\"operand\":\"BETWEEN\",\"values\":[90,630]}\n\n    this.updateLayerConfig({\n      colorField: {\n        format: '',\n        id: 'population',\n        name: 'Population',\n        tableFieldIndex: 2,\n        type: 'integer'\n      }\n    });\n    this.updateLayerDomain(datasets[this.config.dataId]);\n    const colorField = {\n      format: '',\n      id: 'population',\n      name: 'Population',\n      tableFieldIndex: 1,\n      type: 'integer'\n    };\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(\n        'quantize',\n        this.config.colorDomain,\n        colorRange.colors.map(hexToRgb)\n      );\n    // const getFillColor = d => {\n    //   console.log('d', d);\n    //   cScale\n    //     ? this.getEncodedChannelValue(cScale, d.properties[0], colorField)\n    //     : [128, 128, 128];\n    // };\n    var tempLayr = new DeckGLMVTLayer({\n      id: this.id,\n      idx,\n      url: this.config.dataId,\n      filters: datasets[this.config.dataId].filters,\n      cScale,\n      colorField,\n      getEncodedChannelValue: (cScale, props, colorField) =>\n        this.getEncodedChannelValue(cScale, props, colorField),\n      loadEDLinkData\n    });\n\n    return [\n      tempLayr,\n      ...(this.isLayerHovered(objectHovered)\n        ? [\n            new DeckGLGeoJsonLayer({\n              id: `${this.id}-hovered`,\n              data: [objectHovered.object],\n              getLineWidth: 1,\n              getRadius: 23,\n              getElevation: 45,\n              getLineColor: [255, 255, 0],\n              getFillColor: [0, 255, 255],\n              stroked: true,\n              pickable: false,\n              filled: false\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}