UNPKG

kepler.gl.geoiq

Version:

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

218 lines (187 loc) 28 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.VisualChannelMetric = exports.StyledMapControlLegend = exports.SingleColorLegend = exports.MultiColorLegend = exports.LayerSizeLegend = exports.LayerColorLegend = 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 _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"); var _templateObject; var StyledMapControlLegend = exports.StyledMapControlLegend = _styledComponents["default"].div(_templateObject || (_templateObject = (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"])), 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 = exports.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_by" }, "by "), /*#__PURE__*/_react["default"].createElement("span", { className: "legend--layer_color_field" }, name)) ); }; var LayerSizeLegend = exports.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" }, label)), /*#__PURE__*/_react["default"].createElement(VisualChannelMetric, { name: name })) ); }; var propTypes = { layers: _propTypes["default"].arrayOf(_propTypes["default"].object) }; var SingleColorDomain = ['']; var SingleColorLegend = exports.SingleColorLegend = _react["default"].memo(function (_ref3) { var width = _ref3.width, color = _ref3.color; return (/*#__PURE__*/_react["default"].createElement(_colorLegend["default"], { scaleType: "ordinal", displayLabel: false, domain: SingleColorDomain, fieldType: null, range: [_d3Color.rgb.apply(void 0, (0, _toConsumableArray2["default"])(color)).toString()], width: width }) ); }); SingleColorLegend.displayName = 'SingleColorLegend'; var MultiColorLegend = exports.MultiColorLegend = _react["default"].memo(function (_ref4) { var colorRange = _ref4.colorRange, colorScale = _ref4.colorScale, colorDomain = _ref4.colorDomain, colorField = _ref4.colorField, width = _ref4.width, legend = _ref4.legend; return (/*#__PURE__*/_react["default"].createElement(_colorLegend["default"], { scaleType: colorScale, displayLabel: true, domain: colorDomain, fieldType: colorField && colorField.type || 'real', range: colorRange.colors, width: width, legend: legend }) ); }); MultiColorLegend.displayName = 'MultiColorLegend'; var LayerColorLegend = exports.LayerColorLegend = _react["default"].memo(function (_ref5) { var description = _ref5.description, config = _ref5.config, width = _ref5.width, colorChannel = _ref5.colorChannel; var enableColorBy = description.measure; var scale = colorChannel.scale, field = colorChannel.field, domain = colorChannel.domain, range = colorChannel.range, property = colorChannel.property, key = colorChannel.key; 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 legend = config.legend; var colorRange = config.visConfig[range]; return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer_type" }, (0, _utils.camelToTitle)(key)), /*#__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(MultiColorLegend, { colorScale: colorScale, colorField: colorField, colorDomain: colorDomain, colorRange: colorRange, width: width, legend: legend }) : /*#__PURE__*/_react["default"].createElement(SingleColorLegend, { color: config.visConfig[property] || config[property] || config.color, width: width }))))) ); }); LayerColorLegend.displayName = 'LayerColorLegend'; var isColorChannel = function isColorChannel(visualChannel) { return [_defaultSettings.CHANNEL_SCALES.color, _defaultSettings.CHANNEL_SCALES.colorAggr].includes(visualChannel.channelScaleType); }; var MAP_LEGEND_WIDTH = _defaultSettings.DIMENSIONS.mapControl.width - 2 * _defaultSettings.DIMENSIONS.mapControl.padding; var MapLegend = function MapLegend(_ref6) { var _ref6$layers = _ref6.layers, layers = _ref6$layers === void 0 ? [] : _ref6$layers; return (/*#__PURE__*/_react["default"].createElement("div", null, layers.map(function (layer, index) { if (!layer.isValidToSave()) { return null; } 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(StyledMapControlLegend, { className: "legend--layer", last: index === layers.length - 1, key: index }, /*#__PURE__*/_react["default"].createElement("div", { className: "legend--layer_name" }, layer.config.label), 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: MAP_LEGEND_WIDTH, 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; })) ); })) ); }; MapLegend.propTypes = propTypes; var _default = exports["default"] = MapLegend; //# 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","SingleColorDomain","SingleColorLegend","React","memo","width","color","rgb","toString","displayName","MultiColorLegend","colorRange","colorScale","colorDomain","colorField","legend","type","colors","LayerColorLegend","description","config","colorChannel","enableColorBy","measure","scale","field","domain","range","property","key","map","k","visConfig","isColorChannel","visualChannel","CHANNEL_SCALES","colorAggr","includes","channelScaleType","MAP_LEGEND_WIDTH","DIMENSIONS","MapLegend","layer","index","isValidToSave","colorChannels","Object","values","visualChannels","filter","nonColorChannels","vc","length","condition","getVisualChannelDescription","matchCondition","enabled","defaultMeasure"],"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 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, CHANNEL_SCALES} from 'constants/default-settings';\nimport {camelToTitle} from 'utils/utils';\n\nexport const 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\nexport const 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\nexport const 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 SingleColorDomain = [''];\nexport const SingleColorLegend = React.memo(({width, color}) => (\n  <ColorLegend\n    scaleType=\"ordinal\"\n    displayLabel={false}\n    domain={SingleColorDomain}\n    fieldType={null}\n    range={[rgb(...color).toString()]}\n    width={width}\n  />\n));\n\nSingleColorLegend.displayName = 'SingleColorLegend';\n\nexport const MultiColorLegend = React.memo(\n  ({colorRange, colorScale, colorDomain, colorField, width, legend}) => (\n    <ColorLegend\n      scaleType={colorScale}\n      displayLabel\n      domain={colorDomain}\n      fieldType={(colorField && colorField.type) || 'real'}\n      range={colorRange.colors}\n      width={width}\n      legend={legend}\n    />\n  )\n);\n\nMultiColorLegend.displayName = 'MultiColorLegend';\n\nexport const LayerColorLegend = React.memo(\n  ({description, config, width, colorChannel}) => {\n    const enableColorBy = description.measure;\n    const {scale, field, domain, range, property, key} = colorChannel;\n    const [colorScale, colorField, colorDomain] = [scale, field, domain].map(\n      k => config[k]\n    );\n    const legend = config.legend;\n    const colorRange = config.visConfig[range];\n\n    return (\n      <div>\n        <div className=\"legend--layer_type\">{camelToTitle(key)}</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\n                  colorScale={colorScale}\n                  colorField={colorField}\n                  colorDomain={colorDomain}\n                  colorRange={colorRange}\n                  width={width}\n                  legend={legend}\n                />\n              ) : (\n                <SingleColorLegend\n                  color={\n                    config.visConfig[property] ||\n                    config[property] ||\n                    config.color\n                  }\n                  width={width}\n                />\n              )}\n            </div>\n          </div>\n        </div>\n      </div>\n    );\n  }\n);\n\nLayerColorLegend.displayName = 'LayerColorLegend';\n\nconst isColorChannel = visualChannel =>\n  [CHANNEL_SCALES.color, CHANNEL_SCALES.colorAggr].includes(\n    visualChannel.channelScaleType\n  );\n\nconst MAP_LEGEND_WIDTH =\n  DIMENSIONS.mapControl.width - 2 * DIMENSIONS.mapControl.padding;\n\nconst MapLegend = ({layers = []}) => (\n  <div>\n    {layers.map((layer, index) => {\n      if (!layer.isValidToSave()) {\n        return null;\n      }\n\n      const colorChannels = Object.values(layer.visualChannels).filter(\n        isColorChannel\n      );\n      const nonColorChannels = Object.values(layer.visualChannels).filter(\n        vc => !isColorChannel(vc)\n      );\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          {colorChannels.map(colorChannel =>\n            !colorChannel.condition || colorChannel.condition(layer.config) ? (\n              <LayerColorLegend\n                key={colorChannel.key}\n                description={layer.getVisualChannelDescription(\n                  colorChannel.key\n                )}\n                config={layer.config}\n                width={MAP_LEGEND_WIDTH}\n                colorChannel={colorChannel}\n              />\n            ) : null\n          )}\n          {nonColorChannels.map(visualChannel => {\n            const matchCondition =\n              !visualChannel.condition || visualChannel.condition(layer.config);\n            const enabled =\n              layer.config[visualChannel.field] || visualChannel.defaultMeasure;\n\n            const description = layer.getVisualChannelDescription(\n              visualChannel.key\n            );\n\n            return matchCondition && enabled ? (\n              <LayerSizeLegend\n                key={visualChannel.key}\n                label={description.label}\n                name={description.measure}\n              />\n            ) : null;\n          })}\n        </StyledMapControlLegend>\n      );\n    })}\n  </div>\n);\n\nMapLegend.propTypes = propTypes;\n\nexport default MapLegend;\n"]}