kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
352 lines (341 loc) • 30.5 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.LAYER_TEXT_CONFIGS = exports.LAYER_VIS_CONFIGS = exports.PROPERTY_GROUPS = undefined;
var _keymirror = require('keymirror');
var _keymirror2 = _interopRequireDefault(_keymirror);
var _defaultSettings = require('../constants/default-settings');
var _colorRanges = require('../constants/color-ranges');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var PROPERTY_GROUPS = exports.PROPERTY_GROUPS = (0, _keymirror2.default)({
color: null,
stroke: null,
radius: null,
height: null,
// for heatmap aggregation
cell: null,
precision: null
}); // Copyright (c) 2018 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.
var LAYER_VIS_CONFIGS = exports.LAYER_VIS_CONFIGS = {
thickness: {
type: 'number',
defaultValue: 2,
label: 'Stroke Width',
isRanged: false,
range: [0, 100],
step: 0.1,
group: PROPERTY_GROUPS.stroke,
property: 'thickness'
},
strokeWidthRange: {
type: 'number',
defaultValue: [0, 10],
label: 'Stroke Width Range',
isRanged: true,
range: [0, 200],
step: 0.1,
group: PROPERTY_GROUPS.stroke,
property: 'sizeRange'
},
// radius is actually radiusScale in deck.gl
radius: {
type: 'number',
defaultValue: 10,
label: 'Radius',
isRanged: false,
range: [0, 100],
step: 0.1,
group: PROPERTY_GROUPS.radius,
property: 'radius'
},
fixedRadius: {
defaultValue: false,
type: 'boolean',
label: 'Fixed Radius to meter',
description: 'Map radius to absolute radius in meters, e.g. 5 to 5 meters',
group: PROPERTY_GROUPS.radius,
property: 'fixedRadius'
},
radiusRange: {
type: 'number',
defaultValue: [0, 50],
isRanged: true,
range: [0, 500],
step: 0.1,
label: 'Radius Range',
group: PROPERTY_GROUPS.radius,
property: 'radiusRange'
},
clusterRadius: {
type: 'number',
label: 'Cluster Size (m)',
defaultValue: 40,
isRanged: false,
range: [1, 500],
step: 0.1,
group: PROPERTY_GROUPS.radius,
property: 'clusterRadius'
},
clusterRadiusRange: {
type: 'number',
label: 'Radius Range (m)',
defaultValue: [1, 40],
isRanged: true,
range: [1, 150],
step: 0.1,
group: PROPERTY_GROUPS.radius,
property: 'radiusRange'
},
opacity: {
type: 'number',
defaultValue: 0.8,
label: 'Opacity',
isRanged: false,
range: [0, 1],
step: 0.01,
group: PROPERTY_GROUPS.color,
property: 'opacity'
},
coverage: {
type: 'number',
defaultValue: 1,
label: 'Coverage',
isRanged: false,
range: [0, 1],
step: 0.01,
group: PROPERTY_GROUPS.cell,
property: 'coverage'
},
outline: {
type: 'boolean',
defaultValue: false,
label: 'Draw outline',
group: PROPERTY_GROUPS.display,
property: 'outline'
},
colorRange: {
type: 'color-range-select',
defaultValue: _colorRanges.DefaultColorRange,
label: 'Color range',
group: PROPERTY_GROUPS.color,
property: 'colorRange'
},
targetColor: {
type: 'color-select',
label: 'Target Color',
defaultValue: null,
group: PROPERTY_GROUPS.color,
property: 'targetColor'
},
aggregation: {
type: 'select',
defaultValue: _defaultSettings.AGGREGATION_TYPES.average,
label: 'Color Aggregation',
// aggregation options are based on color field types
options: Object.keys(_defaultSettings.AGGREGATION_TYPES),
group: PROPERTY_GROUPS.color,
property: 'colorAggregation',
condition: function condition(config) {
return config.colorField;
}
},
sizeAggregation: {
type: 'select',
defaultValue: _defaultSettings.AGGREGATION_TYPES.average,
label: 'Height Aggregation',
// aggregation options are based on color field types
options: Object.keys(_defaultSettings.AGGREGATION_TYPES),
group: PROPERTY_GROUPS.height,
property: 'sizeAggregation',
condition: function condition(config) {
return config.sizeField;
}
},
percentile: {
type: 'number',
defaultValue: [0, 100],
label: function label(config) {
return 'Filter by ' + (config.colorField ? config.visConfig.colorAggregation + ' ' + config.colorField.name : 'count') + ' percentile';
},
isRanged: true,
range: [0, 100],
step: 0.01,
group: PROPERTY_GROUPS.color,
property: 'percentile',
// percentile filter only makes sense with linear aggregation
condition: function condition(config) {
return config.colorScale !== 'ordinal';
}
},
elevationPercentile: {
type: 'number',
defaultValue: [0, 100],
label: function label(config) {
return 'Filter by ' + (config.sizeField ? config.visConfig.sizeAggregation + ' ' + config.sizeField.name : 'count') + ' percentile';
},
isRanged: true,
range: [0, 100],
step: 0.01,
group: PROPERTY_GROUPS.height,
property: 'elevationPercentile',
// percentile filter only makes sense with linear aggregation
condition: function condition(config) {
return config.visConfig.enable3d && (config.colorField || config.sizeField);
}
},
resolution: {
type: 'number',
defaultValue: 8,
label: 'Resolution range',
isRanged: false,
range: [0, 13],
step: 1,
group: PROPERTY_GROUPS.cell,
property: 'resolution'
},
worldUnitSize: {
type: 'number',
defaultValue: 1,
label: 'World Unit Size',
isRanged: false,
range: [0.01, 500],
step: 0.01,
group: PROPERTY_GROUPS.cell,
property: 'worldUnitSize'
},
elevationScale: {
type: 'number',
defaultValue: 5,
label: 'Elevation Scale',
isRanged: false,
range: [0, 100],
step: 0.1,
group: PROPERTY_GROUPS.height,
property: 'elevationScale'
},
elevationRange: {
type: 'number',
defaultValue: [0, 500],
label: 'Height Scale',
isRanged: true,
range: [0, 1000],
step: 0.01,
group: PROPERTY_GROUPS.height,
property: 'sizeRange'
},
coverageRange: {
type: 'number',
defaultValue: [0, 1],
label: 'Coverage Range',
isRanged: true,
range: [0, 1],
step: 0.01,
group: PROPERTY_GROUPS.radius,
property: 'coverageRange'
},
'hi-precision': {
type: 'boolean',
defaultValue: false,
label: 'High Precision Rendering',
group: PROPERTY_GROUPS.precision,
property: 'hi-precision',
description: 'High precision will result in slower performance'
},
enable3d: {
type: 'boolean',
defaultValue: false,
label: 'Enable Height',
group: PROPERTY_GROUPS.height,
property: 'enable3d',
description: 'Click button at top right of the map to switch to 3d view'
},
stroked: {
type: 'boolean',
label: 'Polygon Stroke',
defaultValue: true,
group: PROPERTY_GROUPS.display,
property: 'stroked'
},
filled: {
type: 'boolean',
label: 'Polygon Fill',
defaultValue: false,
group: PROPERTY_GROUPS.display,
property: 'filled'
},
extruded: {
type: 'boolean',
defaultValue: false,
label: 'Enable Polygon Height',
group: PROPERTY_GROUPS.display,
property: 'extruded'
},
wireframe: {
type: 'boolean',
defaultValue: false,
label: 'Show Wireframe',
group: PROPERTY_GROUPS.display,
property: 'wireframe'
},
// used for heatmap
weight: {
type: 'number',
defaultValue: 1,
label: 'Weight Intensity',
isRanged: false,
range: [0.01, 500],
step: 0.01,
group: PROPERTY_GROUPS.cell,
property: 'weight',
condition: function condition(config) {
return config.weightField;
}
},
heatmapRadius: {
type: 'number',
defaultValue: 20,
label: 'Radius',
isRanged: false,
range: [0, 100],
step: 0.1,
group: PROPERTY_GROUPS.cell,
property: 'radius'
}
};
var LAYER_TEXT_CONFIGS = exports.LAYER_TEXT_CONFIGS = {
fontSize: {
type: 'number',
range: [1, 100],
value0: 1,
step: 1,
isRanged: false,
label: 'Font size',
showInput: true
},
textAnchor: {
type: 'select',
options: ['start', 'middle', 'end'],
multiSelect: false,
searchable: false
}
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/layers/layer-factory.js"],"names":["PROPERTY_GROUPS","color","stroke","radius","height","cell","precision","LAYER_VIS_CONFIGS","thickness","type","defaultValue","label","isRanged","range","step","group","property","strokeWidthRange","fixedRadius","description","radiusRange","clusterRadius","clusterRadiusRange","opacity","coverage","outline","display","colorRange","DefaultColorRange","targetColor","aggregation","AGGREGATION_TYPES","average","options","Object","keys","condition","config","colorField","sizeAggregation","sizeField","percentile","visConfig","colorAggregation","name","colorScale","elevationPercentile","enable3d","resolution","worldUnitSize","elevationScale","elevationRange","coverageRange","stroked","filled","extruded","wireframe","weight","weightField","heatmapRadius","LAYER_TEXT_CONFIGS","fontSize","value0","showInput","textAnchor","multiSelect","searchable"],"mappings":"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","file":"layer-factory.js","sourcesContent":["// Copyright (c) 2018 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 keyMirror from 'keymirror';\n\nimport {AGGREGATION_TYPES} from 'constants/default-settings';\nimport {DefaultColorRange} from 'constants/color-ranges';\n\nexport const PROPERTY_GROUPS = keyMirror({\n  color: null,\n  stroke: null,\n  radius: null,\n  height: null,\n\n  // for heatmap aggregation\n  cell: null,\n  precision: null\n});\n\nexport const LAYER_VIS_CONFIGS = {\n  thickness: {\n    type: 'number',\n    defaultValue: 2,\n    label: 'Stroke Width',\n    isRanged: false,\n    range: [0, 100],\n    step: 0.1,\n    group: PROPERTY_GROUPS.stroke,\n    property: 'thickness'\n  },\n  strokeWidthRange: {\n    type: 'number',\n    defaultValue: [0, 10],\n    label: 'Stroke Width Range',\n    isRanged: true,\n    range: [0, 200],\n    step: 0.1,\n    group: PROPERTY_GROUPS.stroke,\n    property: 'sizeRange'\n  },\n  // radius is actually radiusScale in deck.gl\n  radius: {\n    type: 'number',\n    defaultValue: 10,\n    label: 'Radius',\n    isRanged: false,\n    range: [0, 100],\n    step: 0.1,\n    group: PROPERTY_GROUPS.radius,\n    property: 'radius'\n  },\n  fixedRadius: {\n    defaultValue: false,\n    type: 'boolean',\n    label: 'Fixed Radius to meter',\n    description: 'Map radius to absolute radius in meters, e.g. 5 to 5 meters',\n    group: PROPERTY_GROUPS.radius,\n    property: 'fixedRadius'\n  },\n  radiusRange: {\n    type: 'number',\n    defaultValue: [0, 50],\n    isRanged: true,\n    range: [0, 500],\n    step: 0.1,\n    label: 'Radius Range',\n    group: PROPERTY_GROUPS.radius,\n    property: 'radiusRange'\n  },\n  clusterRadius: {\n    type: 'number',\n    label: 'Cluster Size (m)',\n    defaultValue: 40,\n    isRanged: false,\n    range: [1, 500],\n    step: 0.1,\n    group: PROPERTY_GROUPS.radius,\n    property: 'clusterRadius'\n  },\n  clusterRadiusRange: {\n    type: 'number',\n    label: 'Radius Range (m)',\n    defaultValue: [1, 40],\n    isRanged: true,\n    range: [1, 150],\n    step: 0.1,\n    group: PROPERTY_GROUPS.radius,\n    property: 'radiusRange'\n  },\n  opacity: {\n    type: 'number',\n    defaultValue: 0.8,\n    label: 'Opacity',\n    isRanged: false,\n    range: [0, 1],\n    step: 0.01,\n    group: PROPERTY_GROUPS.color,\n    property: 'opacity'\n  },\n  coverage: {\n    type: 'number',\n    defaultValue: 1,\n    label: 'Coverage',\n    isRanged: false,\n    range: [0, 1],\n    step: 0.01,\n    group: PROPERTY_GROUPS.cell,\n    property: 'coverage'\n  },\n  outline: {\n    type: 'boolean',\n    defaultValue: false,\n    label: 'Draw outline',\n    group: PROPERTY_GROUPS.display,\n    property: 'outline'\n  },\n  colorRange: {\n    type: 'color-range-select',\n    defaultValue: DefaultColorRange,\n    label: 'Color range',\n    group: PROPERTY_GROUPS.color,\n    property: 'colorRange'\n  },\n  targetColor: {\n    type: 'color-select',\n    label: 'Target Color',\n    defaultValue: null,\n    group: PROPERTY_GROUPS.color,\n    property: 'targetColor'\n  },\n  aggregation: {\n    type: 'select',\n    defaultValue: AGGREGATION_TYPES.average,\n    label: 'Color Aggregation',\n    // aggregation options are based on color field types\n    options: Object.keys(AGGREGATION_TYPES),\n    group: PROPERTY_GROUPS.color,\n    property: 'colorAggregation',\n    condition: config => config.colorField\n  },\n  sizeAggregation: {\n    type: 'select',\n    defaultValue: AGGREGATION_TYPES.average,\n    label: 'Height Aggregation',\n    // aggregation options are based on color field types\n    options: Object.keys(AGGREGATION_TYPES),\n    group: PROPERTY_GROUPS.height,\n    property: 'sizeAggregation',\n    condition: config => config.sizeField\n  },\n  percentile: {\n    type: 'number',\n    defaultValue: [0, 100],\n    label: config =>\n      `Filter by ${\n        config.colorField\n          ? `${config.visConfig.colorAggregation} ${config.colorField.name}`\n          : 'count'\n      } percentile`,\n    isRanged: true,\n    range: [0, 100],\n    step: 0.01,\n    group: PROPERTY_GROUPS.color,\n    property: 'percentile',\n\n    // percentile filter only makes sense with linear aggregation\n    condition: config => config.colorScale !== 'ordinal'\n  },\n  elevationPercentile: {\n    type: 'number',\n    defaultValue: [0, 100],\n    label: config =>\n      `Filter by ${\n        config.sizeField\n          ? `${config.visConfig.sizeAggregation} ${config.sizeField.name}`\n          : 'count'\n      } percentile`,\n    isRanged: true,\n    range: [0, 100],\n    step: 0.01,\n    group: PROPERTY_GROUPS.height,\n    property: 'elevationPercentile',\n    // percentile filter only makes sense with linear aggregation\n    condition: config => config.visConfig.enable3d && (config.colorField || config.sizeField)\n  },\n  resolution: {\n    type: 'number',\n    defaultValue: 8,\n    label: 'Resolution range',\n    isRanged: false,\n    range: [0, 13],\n    step: 1,\n    group: PROPERTY_GROUPS.cell,\n    property: 'resolution'\n  },\n  worldUnitSize: {\n    type: 'number',\n    defaultValue: 1,\n    label: 'World Unit Size',\n    isRanged: false,\n    range: [0.01, 500],\n    step: 0.01,\n    group: PROPERTY_GROUPS.cell,\n    property: 'worldUnitSize'\n  },\n  elevationScale: {\n    type: 'number',\n    defaultValue: 5,\n    label: 'Elevation Scale',\n    isRanged: false,\n    range: [0, 100],\n    step: 0.1,\n    group: PROPERTY_GROUPS.height,\n    property: 'elevationScale'\n  },\n  elevationRange: {\n    type: 'number',\n    defaultValue: [0, 500],\n    label: 'Height Scale',\n    isRanged: true,\n    range: [0, 1000],\n    step: 0.01,\n    group: PROPERTY_GROUPS.height,\n    property: 'sizeRange'\n  },\n  coverageRange: {\n    type: 'number',\n    defaultValue: [0, 1],\n    label: 'Coverage Range',\n    isRanged: true,\n    range: [0, 1],\n    step: 0.01,\n    group: PROPERTY_GROUPS.radius,\n    property: 'coverageRange'\n  },\n  'hi-precision': {\n    type: 'boolean',\n    defaultValue: false,\n    label: 'High Precision Rendering',\n    group: PROPERTY_GROUPS.precision,\n    property: 'hi-precision',\n    description: 'High precision will result in slower performance'\n  },\n  enable3d: {\n    type: 'boolean',\n    defaultValue: false,\n    label: 'Enable Height',\n    group: PROPERTY_GROUPS.height,\n    property: 'enable3d',\n    description: 'Click button at top right of the map to switch to 3d view'\n  },\n  stroked: {\n    type: 'boolean',\n    label: 'Polygon Stroke',\n    defaultValue: true,\n    group: PROPERTY_GROUPS.display,\n    property: 'stroked'\n  },\n  filled: {\n    type: 'boolean',\n    label: 'Polygon Fill',\n    defaultValue: false,\n    group: PROPERTY_GROUPS.display,\n    property: 'filled'\n  },\n  extruded: {\n    type: 'boolean',\n    defaultValue: false,\n    label: 'Enable Polygon Height',\n    group: PROPERTY_GROUPS.display,\n    property: 'extruded'\n  },\n  wireframe: {\n    type: 'boolean',\n    defaultValue: false,\n    label: 'Show Wireframe',\n    group: PROPERTY_GROUPS.display,\n    property: 'wireframe'\n  },\n  // used for heatmap\n  weight: {\n    type: 'number',\n    defaultValue: 1,\n    label: 'Weight Intensity',\n    isRanged: false,\n    range: [0.01, 500],\n    step: 0.01,\n    group: PROPERTY_GROUPS.cell,\n    property: 'weight',\n    condition: config => config.weightField\n  },\n  heatmapRadius: {\n    type: 'number',\n    defaultValue: 20,\n    label: 'Radius',\n    isRanged: false,\n    range: [0, 100],\n    step: 0.1,\n    group: PROPERTY_GROUPS.cell,\n    property: 'radius'\n  }\n};\n\nexport const LAYER_TEXT_CONFIGS = {\n  fontSize: {\n    type: 'number',\n    range: [1, 100],\n    value0: 1,\n    step: 1,\n    isRanged: false,\n    label: 'Font size',\n    showInput: true\n  },\n  textAnchor: {\n    type: 'select',\n    options: ['start', 'middle', 'end'],\n    multiSelect: false,\n    searchable: false\n  }\n};\n"]}