kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
171 lines (146 loc) • 20.9 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _d3Color = require("d3-color");
var _colorLegend = _interopRequireDefault(require("../common/color-legend"));
var _defaultSettings = require("../../constants/default-settings");
var _utils = require("../../utils/utils");
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 10px 0 10px ", "px;\n font-size: 11px;\n border-bottom-color: ", ";\n border-bottom-style: solid;\n border-bottom-width: ", ";\n\n .legend--layer_name {\n font-size: 12px;\n padding-right: ", "px;\n color: ", ";\n font-weight: 500;\n }\n .legend--layer_type {\n color: ", ";\n font-weight: 500;\n font-size: 11px;\n padding-right: ", "px;\n }\n\n .legend--layer__title {\n padding-right: ", "px;\n }\n\n .legend--layer_by {\n color: ", ";\n }\n\n .legend--layer_color_field {\n color: ", ";\n font-weight: 500;\n }\n\n .legend--layer_color-legend {\n margin-top: 6px;\n }\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var StyledMapControlLegend = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.mapControl.padding;
}, function (props) {
return props.theme.panelBorderColor;
}, function (props) {
return props.last ? 0 : '1px';
}, function (props) {
return props.theme.mapControl.padding;
}, function (props) {
return props.theme.textColorHl;
}, function (props) {
return props.theme.subtextColor;
}, function (props) {
return props.theme.mapControl.padding;
}, function (props) {
return props.theme.mapControl.padding;
}, function (props) {
return props.theme.subtextColor;
}, function (props) {
return props.theme.textColor;
});
var VisualChannelMetric = function VisualChannelMetric(_ref) {
var name = _ref.name;
return _react["default"].createElement("div", {
className: "legend--layer__title"
}, _react["default"].createElement("span", {
className: "legend--layer_by"
}, "by "), _react["default"].createElement("span", {
className: "legend--layer_color_field"
}, name));
};
var LayerSizeLegend = function LayerSizeLegend(_ref2) {
var label = _ref2.label,
name = _ref2.name;
return _react["default"].createElement("div", {
className: "legend--layer_size-schema"
}, _react["default"].createElement("p", null, _react["default"].createElement("span", {
className: "legend--layer_by"
}, label)), _react["default"].createElement(VisualChannelMetric, {
name: name
}));
};
var propTypes = {
layers: _propTypes["default"].arrayOf(_propTypes["default"].object)
};
var SingleColorLegend = function SingleColorLegend(_ref3) {
var layer = _ref3.layer,
width = _ref3.width;
return _react["default"].createElement(_colorLegend["default"], {
scaleType: "ordinal",
displayLabel: false,
domain: [''],
fieldType: null,
range: [_d3Color.rgb.apply(void 0, (0, _toConsumableArray2["default"])(layer.config.color)).toString()],
width: width
});
};
var MultiColorLegend = function MultiColorLegend(_ref4) {
var layer = _ref4.layer,
width = _ref4.width;
var _layer$config = layer.config,
visConfig = _layer$config.visConfig,
colorField = _layer$config.colorField,
colorScale = _layer$config.colorScale,
colorDomain = _layer$config.colorDomain;
return _react["default"].createElement(_colorLegend["default"], {
scaleType: colorScale,
displayLabel: true,
domain: colorDomain,
fieldType: colorField && colorField.type || 'real',
range: visConfig.colorRange.colors,
width: width
});
};
var MapLegend = function MapLegend(_ref5) {
var layers = _ref5.layers;
return _react["default"].createElement("div", null, layers.map(function (layer, index) {
if (!layer.isValidToSave()) {
return null;
}
var colorChannelConfig = layer.getVisualChannelDescription('color');
var enableColorBy = colorChannelConfig.measure;
var width = _defaultSettings.DIMENSIONS.mapControl.width - 2 * _defaultSettings.DIMENSIONS.mapControl.padding;
return _react["default"].createElement(StyledMapControlLegend, {
className: "legend--layer",
last: index === layers.length - 1,
key: index
}, _react["default"].createElement("div", {
className: "legend--layer_name"
}, layer.config.label), _react["default"].createElement("div", {
className: "legend--layer_type"
}, "".concat((0, _utils.capitalizeFirstLetter)(layer.name), " color")), _react["default"].createElement("div", {
className: "legend--layer_color-schema"
}, _react["default"].createElement("div", null, enableColorBy ? _react["default"].createElement(VisualChannelMetric, {
name: enableColorBy
}) : null, _react["default"].createElement("div", {
className: "legend--layer_color-legend"
}, enableColorBy ? _react["default"].createElement(MultiColorLegend, {
layer: layer,
width: width
}) : _react["default"].createElement(SingleColorLegend, {
layer: layer,
width: width
})))), Object.keys(layer.visualChannels).filter(function (k) {
return k !== 'color';
}).map(function (key) {
var matchCondition = !layer.visualChannels[key].condition || layer.visualChannels[key].condition(layer.config);
var enabled = layer.config[layer.visualChannels[key].field] || layer.visualChannels[key].defaultMeasure;
var visualChannelDescription = layer.getVisualChannelDescription(key);
if (matchCondition && enabled) {
return _react["default"].createElement(LayerSizeLegend, {
key: key,
label: visualChannelDescription.label,
name: visualChannelDescription.measure
});
}
return null;
}));
}));
};
MapLegend.propTypes = propTypes;
var _default = MapLegend;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-legend.js"],"names":["StyledMapControlLegend","styled","div","props","theme","mapControl","padding","panelBorderColor","last","textColorHl","subtextColor","textColor","VisualChannelMetric","name","LayerSizeLegend","label","propTypes","layers","PropTypes","arrayOf","object","SingleColorLegend","layer","width","rgb","config","color","toString","MultiColorLegend","visConfig","colorField","colorScale","colorDomain","type","colorRange","colors","MapLegend","map","index","isValidToSave","colorChannelConfig","getVisualChannelDescription","enableColorBy","measure","DIMENSIONS","length","Object","keys","visualChannels","filter","k","key","matchCondition","condition","enabled","field","defaultMeasure","visualChannelDescription"],"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 React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport {rgb} from 'd3-color';\nimport ColorLegend from 'components/common/color-legend';\nimport {DIMENSIONS} from 'constants/default-settings';\nimport {capitalizeFirstLetter} from 'utils/utils';\n\nconst StyledMapControlLegend = styled.div`\n  padding: 10px 0 10px ${props => props.theme.mapControl.padding}px;\n  font-size: 11px;\n  border-bottom-color: ${props => props.theme.panelBorderColor};\n  border-bottom-style: solid;\n  border-bottom-width: ${props => (props.last ? 0 : '1px')};\n\n  .legend--layer_name {\n    font-size: 12px;\n    padding-right: ${props => props.theme.mapControl.padding}px;\n    color: ${props => props.theme.textColorHl};\n    font-weight: 500;\n  }\n  .legend--layer_type {\n    color: ${props => props.theme.subtextColor};\n    font-weight: 500;\n    font-size: 11px;\n    padding-right: ${props => props.theme.mapControl.padding}px;\n  }\n\n  .legend--layer__title {\n    padding-right: ${props => props.theme.mapControl.padding}px;\n  }\n\n  .legend--layer_by {\n    color: ${props => props.theme.subtextColor};\n  }\n\n  .legend--layer_color_field {\n    color: ${props => props.theme.textColor};\n    font-weight: 500;\n  }\n\n  .legend--layer_color-legend {\n    margin-top: 6px;\n  }\n`;\n\nconst VisualChannelMetric = ({name}) => (\n  <div className=\"legend--layer__title\">\n    <span className=\"legend--layer_by\">by </span>\n    <span className=\"legend--layer_color_field\">{name}</span>\n  </div>\n);\n\nconst LayerSizeLegend = ({label, name}) => (\n  <div className=\"legend--layer_size-schema\">\n    <p>\n      <span className=\"legend--layer_by\">{label}</span>\n    </p>\n    <VisualChannelMetric name={name} />\n  </div>\n);\n\nconst propTypes = {\n  layers: PropTypes.arrayOf(PropTypes.object)\n};\n\nconst SingleColorLegend = ({layer, width}) => (\n  <ColorLegend\n    scaleType=\"ordinal\"\n    displayLabel={false}\n    domain={['']}\n    fieldType={null}\n    range={[rgb(...layer.config.color).toString()]}\n    width={width}\n  />\n);\n\nconst MultiColorLegend = ({layer, width}) => {\n  const {visConfig, colorField, colorScale, colorDomain} = layer.config;\n  return (\n    <ColorLegend\n      scaleType={colorScale}\n      displayLabel\n      domain={colorDomain}\n      fieldType={(colorField && colorField.type) || 'real'}\n      range={visConfig.colorRange.colors}\n      width={width}\n    />\n  );\n};\n\nconst MapLegend = ({layers}) => (\n  <div>\n    {layers.map((layer, index) => {\n      if (!layer.isValidToSave()) {\n        return null;\n      }\n\n      const colorChannelConfig = layer.getVisualChannelDescription('color');\n      const enableColorBy = colorChannelConfig.measure;\n      const width =\n        DIMENSIONS.mapControl.width - 2 * DIMENSIONS.mapControl.padding;\n\n      return (\n        <StyledMapControlLegend\n          className=\"legend--layer\"\n          last={index === layers.length - 1}\n          key={index}\n        >\n          <div className=\"legend--layer_name\">{layer.config.label}</div>\n          <div className=\"legend--layer_type\">{`${capitalizeFirstLetter(\n            layer.name\n          )} color`}</div>\n          <div className=\"legend--layer_color-schema\">\n            <div>\n              {enableColorBy ? (\n                <VisualChannelMetric name={enableColorBy} />\n              ) : null}\n              <div className=\"legend--layer_color-legend\">\n                {enableColorBy ? (\n                  <MultiColorLegend layer={layer} width={width} />\n                ) : (\n                  <SingleColorLegend layer={layer} width={width} />\n                )}\n              </div>\n            </div>\n          </div>\n          {Object.keys(layer.visualChannels)\n            .filter(k => k !== 'color')\n            .map(key => {\n              const matchCondition =\n                !layer.visualChannels[key].condition ||\n                layer.visualChannels[key].condition(layer.config);\n              const enabled =\n                layer.config[layer.visualChannels[key].field] ||\n                layer.visualChannels[key].defaultMeasure;\n\n              const visualChannelDescription = layer.getVisualChannelDescription(\n                key\n              );\n              if (matchCondition && enabled) {\n                return (\n                  <LayerSizeLegend\n                    key={key}\n                    label={visualChannelDescription.label}\n                    name={visualChannelDescription.measure}\n                  />\n                );\n              }\n              return null;\n            })}\n        </StyledMapControlLegend>\n      );\n    })}\n  </div>\n);\n\nMapLegend.propTypes = propTypes;\n\nexport default MapLegend;\n"]}