UNPKG

kepler.gl

Version:

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

244 lines (209 loc) 30.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.LayerLegendHeaderFactory = LayerLegendHeaderFactory; exports.LayerLegendContentFactory = LayerLegendContentFactory; exports["default"] = exports.LayerColorLegend = exports.SingleColorLegend = exports.LayerSizeLegend = exports.VisualChannelMetric = exports.StyledMapControlLegend = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); 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 _localization = require("../../localization"); var _templateObject; var StyledMapControlLegend = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 10px ", "px 10px\n ", "px;\n font-size: 11px;\n border-bottom-color: ", ";\n border-bottom-style: solid;\n border-bottom-width: ", ";\n width: ", "px;\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"])), function (props) { return props.theme.mapControl.padding; }, function (props) { return props.theme.mapControl.padding; }, function (props) { return props.theme.panelBorderColor; }, function (props) { return props.last ? 0 : '1px'; }, function (props) { return props.width; }, function (props) { return props.theme.mapControl.padding; }, function (props) { return props.theme.textColor; }, 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.textColorHl; }); exports.StyledMapControlLegend = StyledMapControlLegend; var VisualChannelMetric = function VisualChannelMetric(_ref) { var name = _ref.name; return /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer__title" }, /*#__PURE__*/_react["default"].createElement("span", { className: "legend--layer_color_field" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: name }))); }; /** @type {typeof import('./map-legend').LayerSizeLegend} */ exports.VisualChannelMetric = VisualChannelMetric; var LayerSizeLegend = function LayerSizeLegend(_ref2) { var label = _ref2.label, name = _ref2.name; return /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer_size-schema" }, /*#__PURE__*/_react["default"].createElement("p", null, /*#__PURE__*/_react["default"].createElement("span", { className: "legend--layer_by" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: label })), /*#__PURE__*/_react["default"].createElement("span", { className: "legend--layer_by" }, " by ")), /*#__PURE__*/_react["default"].createElement(VisualChannelMetric, { name: name })); }; exports.LayerSizeLegend = LayerSizeLegend; var SINGLE_COLOR_DOMAIN = ['']; /** @type {typeof import('./map-legend').SingleColorLegend} */ var SingleColorLegend = /*#__PURE__*/_react["default"].memo(function (_ref3) { var width = _ref3.width, color = _ref3.color; return /*#__PURE__*/_react["default"].createElement(_colorLegend["default"], { scaleType: "ordinal", displayLabel: false, domain: SINGLE_COLOR_DOMAIN, fieldType: null, range: { colors: [_d3Color.rgb.apply(void 0, (0, _toConsumableArray2["default"])(color)).toString()] }, width: width }); }); exports.SingleColorLegend = SingleColorLegend; SingleColorLegend.displayName = 'SingleColorLegend'; /** @type {typeof import('./map-legend').LayerColorLegend} */ var LayerColorLegend = /*#__PURE__*/_react["default"].memo(function (_ref4) { var description = _ref4.description, config = _ref4.config, width = _ref4.width, colorChannel = _ref4.colorChannel; var enableColorBy = description.measure; var scale = colorChannel.scale, field = colorChannel.field, domain = colorChannel.domain, range = colorChannel.range, property = colorChannel.property; var _map = [scale, field, domain].map(function (k) { return config[k]; }), _map2 = (0, _slicedToArray2["default"])(_map, 3), colorScale = _map2[0], colorField = _map2[1], colorDomain = _map2[2]; var colorRange = config.visConfig[range]; return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer_color-schema" }, /*#__PURE__*/_react["default"].createElement("div", null, enableColorBy ? /*#__PURE__*/_react["default"].createElement(VisualChannelMetric, { name: enableColorBy }) : null, /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer_color-legend" }, enableColorBy ? /*#__PURE__*/_react["default"].createElement(_colorLegend["default"], { scaleType: colorScale, displayLabel: true, domain: colorDomain, fieldType: colorField && colorField.type || 'real', range: colorRange, width: width }) : /*#__PURE__*/_react["default"].createElement(SingleColorLegend, { color: config.visConfig[property] || config[property] || config.color, width: width }))))); }); exports.LayerColorLegend = LayerColorLegend; LayerColorLegend.displayName = 'LayerColorLegend'; var isColorChannel = function isColorChannel(visualChannel) { return [_defaultSettings.CHANNEL_SCALES.color, _defaultSettings.CHANNEL_SCALES.colorAggr].includes(visualChannel.channelScaleType); }; function LayerLegendHeaderFactory() { /** @type {typeof import('./map-legend').LayerLegendHeader }> */ var LayerLegendHeader = function LayerLegendHeader(_ref5) { var options = _ref5.options, layer = _ref5.layer; return (options === null || options === void 0 ? void 0 : options.showLayerName) !== false ? /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer_name" }, layer.config.label) : null; }; return LayerLegendHeader; } function LayerLegendContentFactory() { /** @type {typeof import('./map-legend').LayerLegendContent }> */ var LayerLegendContent = function LayerLegendContent(_ref6) { var layer = _ref6.layer, containerW = _ref6.containerW; var colorChannels = Object.values(layer.visualChannels).filter(isColorChannel); var nonColorChannels = Object.values(layer.visualChannels).filter(function (vc) { return !isColorChannel(vc); }); return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, colorChannels.map(function (colorChannel) { return !colorChannel.condition || colorChannel.condition(layer.config) ? /*#__PURE__*/_react["default"].createElement(LayerColorLegend, { key: colorChannel.key, description: layer.getVisualChannelDescription(colorChannel.key), config: layer.config, width: containerW - 2 * _defaultSettings.DIMENSIONS.mapControl.padding, colorChannel: colorChannel }) : null; }), nonColorChannels.map(function (visualChannel) { var matchCondition = !visualChannel.condition || visualChannel.condition(layer.config); var enabled = layer.config[visualChannel.field] || visualChannel.defaultMeasure; var description = layer.getVisualChannelDescription(visualChannel.key); return matchCondition && enabled ? /*#__PURE__*/_react["default"].createElement(LayerSizeLegend, { key: visualChannel.key, label: description.label, name: description.measure }) : null; })); }; return LayerLegendContent; } MapLegendFactory.deps = [LayerLegendHeaderFactory, LayerLegendContentFactory]; function MapLegendFactory(LayerLegendHeader, LayerLegendContent) { /** @type {typeof import('./map-legend').MapLegend }> */ var MapLegend = function MapLegend(_ref7) { var _ref7$layers = _ref7.layers, layers = _ref7$layers === void 0 ? [] : _ref7$layers, width = _ref7.width, options = _ref7.options; return /*#__PURE__*/_react["default"].createElement("div", { className: "map-legend" }, layers.map(function (layer, index) { if (!layer.isValidToSave() || layer.config.hidden) { return null; } var containerW = width || _defaultSettings.DIMENSIONS.mapControl.width; return /*#__PURE__*/_react["default"].createElement(StyledMapControlLegend, { className: "legend--layer", last: index === layers.length - 1, key: index, width: containerW }, /*#__PURE__*/_react["default"].createElement(LayerLegendHeader, { options: options, layer: layer }), /*#__PURE__*/_react["default"].createElement(LayerLegendContent, { containerW: containerW, layer: layer })); })); }; MapLegend.displayName = 'MapLegend'; return MapLegend; } var _default = MapLegendFactory; 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","width","textColor","subtextColor","textColorHl","VisualChannelMetric","name","LayerSizeLegend","label","SINGLE_COLOR_DOMAIN","SingleColorLegend","React","memo","color","colors","rgb","toString","displayName","LayerColorLegend","description","config","colorChannel","enableColorBy","measure","scale","field","domain","range","property","map","k","colorScale","colorField","colorDomain","colorRange","visConfig","type","isColorChannel","visualChannel","CHANNEL_SCALES","colorAggr","includes","channelScaleType","LayerLegendHeaderFactory","LayerLegendHeader","options","layer","showLayerName","LayerLegendContentFactory","LayerLegendContent","containerW","colorChannels","Object","values","visualChannels","filter","nonColorChannels","vc","condition","key","getVisualChannelDescription","DIMENSIONS","matchCondition","enabled","defaultMeasure","MapLegendFactory","deps","MapLegend","layers","index","isValidToSave","hidden","length"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 styled from 'styled-components';\nimport {rgb} from 'd3-color';\nimport ColorLegend from 'components/common/color-legend';\nimport {CHANNEL_SCALES, DIMENSIONS} from 'constants/default-settings';\nimport {FormattedMessage} from 'localization';\n\nexport const StyledMapControlLegend = styled.div`\n  padding: 10px ${props => props.theme.mapControl.padding}px 10px\n    ${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  width: ${props => props.width}px;\n\n  .legend--layer_name {\n    font-size: 12px;\n    padding-right: ${props => props.theme.mapControl.padding}px;\n    color: ${props => props.theme.textColor};\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.textColorHl};\n    font-weight: 500;\n  }\n\n  .legend--layer_color-legend {\n    margin-top: 6px;\n  }\n`;\n\nexport const VisualChannelMetric = ({name}) => {\n  return (\n    <div className=\"legend--layer__title\">\n      <span className=\"legend--layer_color_field\">\n        <FormattedMessage id={name} />\n      </span>\n    </div>\n  );\n};\n\n/** @type {typeof import('./map-legend').LayerSizeLegend} */\nexport const LayerSizeLegend = ({label, name}) => (\n  <div className=\"legend--layer_size-schema\">\n    <p>\n      <span className=\"legend--layer_by\">\n        <FormattedMessage id={label} />\n      </span>\n      <span className=\"legend--layer_by\"> by </span>\n    </p>\n    <VisualChannelMetric name={name} />\n  </div>\n);\n\nconst SINGLE_COLOR_DOMAIN = [''];\n\n/** @type {typeof import('./map-legend').SingleColorLegend} */\nexport const SingleColorLegend = React.memo(({width, color}) => (\n  <ColorLegend\n    scaleType=\"ordinal\"\n    displayLabel={false}\n    domain={SINGLE_COLOR_DOMAIN}\n    fieldType={null}\n    range={{colors: [rgb(...color).toString()]}}\n    width={width}\n  />\n));\n\nSingleColorLegend.displayName = 'SingleColorLegend';\n\n/** @type {typeof import('./map-legend').LayerColorLegend} */\nexport const LayerColorLegend = React.memo(({description, config, width, colorChannel}) => {\n  const enableColorBy = description.measure;\n  const {scale, field, domain, range, property} = colorChannel;\n  const [colorScale, colorField, colorDomain] = [scale, field, domain].map(k => config[k]);\n  const colorRange = config.visConfig[range];\n\n  return (\n    <div>\n      <div className=\"legend--layer_color-schema\">\n        <div>\n          {enableColorBy ? <VisualChannelMetric name={enableColorBy} /> : null}\n          <div className=\"legend--layer_color-legend\">\n            {enableColorBy ? (\n              <ColorLegend\n                scaleType={colorScale}\n                displayLabel\n                domain={colorDomain}\n                fieldType={(colorField && colorField.type) || 'real'}\n                range={colorRange}\n                width={width}\n              />\n            ) : (\n              <SingleColorLegend\n                color={config.visConfig[property] || config[property] || config.color}\n                width={width}\n              />\n            )}\n          </div>\n        </div>\n      </div>\n    </div>\n  );\n});\n\nLayerColorLegend.displayName = 'LayerColorLegend';\n\nconst isColorChannel = visualChannel =>\n  [CHANNEL_SCALES.color, CHANNEL_SCALES.colorAggr].includes(visualChannel.channelScaleType);\n\nexport function LayerLegendHeaderFactory() {\n  /** @type {typeof import('./map-legend').LayerLegendHeader }> */\n  const LayerLegendHeader = ({options, layer}) => {\n    return options?.showLayerName !== false ? (\n      <div className=\"legend--layer_name\">{layer.config.label}</div>\n    ) : null;\n  };\n  return LayerLegendHeader;\n}\n\nexport function LayerLegendContentFactory() {\n  /** @type {typeof import('./map-legend').LayerLegendContent }> */\n  const LayerLegendContent = ({layer, containerW}) => {\n    const colorChannels = Object.values(layer.visualChannels).filter(isColorChannel);\n    const nonColorChannels = Object.values(layer.visualChannels).filter(vc => !isColorChannel(vc));\n\n    return (\n      <>\n        {colorChannels.map(colorChannel =>\n          !colorChannel.condition || colorChannel.condition(layer.config) ? (\n            <LayerColorLegend\n              key={colorChannel.key}\n              description={layer.getVisualChannelDescription(colorChannel.key)}\n              config={layer.config}\n              width={containerW - 2 * DIMENSIONS.mapControl.padding}\n              colorChannel={colorChannel}\n            />\n          ) : null\n        )}\n        {nonColorChannels.map(visualChannel => {\n          const matchCondition = !visualChannel.condition || visualChannel.condition(layer.config);\n          const enabled = layer.config[visualChannel.field] || visualChannel.defaultMeasure;\n\n          const description = layer.getVisualChannelDescription(visualChannel.key);\n\n          return matchCondition && enabled ? (\n            <LayerSizeLegend\n              key={visualChannel.key}\n              label={description.label}\n              name={description.measure}\n            />\n          ) : null;\n        })}\n      </>\n    );\n  };\n\n  return LayerLegendContent;\n}\n\nMapLegendFactory.deps = [LayerLegendHeaderFactory, LayerLegendContentFactory];\nfunction MapLegendFactory(LayerLegendHeader, LayerLegendContent) {\n  /** @type {typeof import('./map-legend').MapLegend }> */\n  const MapLegend = ({layers = [], width, options}) => (\n    <div className=\"map-legend\">\n      {layers.map((layer, index) => {\n        if (!layer.isValidToSave() || layer.config.hidden) {\n          return null;\n        }\n        const containerW = width || DIMENSIONS.mapControl.width;\n\n        return (\n          <StyledMapControlLegend\n            className=\"legend--layer\"\n            last={index === layers.length - 1}\n            key={index}\n            width={containerW}\n          >\n            <LayerLegendHeader options={options} layer={layer} />\n            <LayerLegendContent containerW={containerW} layer={layer} />\n          </StyledMapControlLegend>\n        );\n      })}\n    </div>\n  );\n\n  MapLegend.displayName = 'MapLegend';\n\n  return MapLegend;\n}\n\nexport default MapLegendFactory;\n"]}