UNPKG

kepler.gl

Version:

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

224 lines (192 loc) 22.4 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray'); var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.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'], ['\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']); // 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 _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _d3Color = require('d3-color'); var _colorLegend = require('../common/color-legend'); var _colorLegend2 = _interopRequireDefault(_colorLegend); var _defaultSettings = require('../../constants/default-settings'); var _utils = require('../../utils/utils'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var StyledMapControlLegend = _styledComponents2.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 _react2.default.createElement( 'div', { className: 'legend--layer__title' }, _react2.default.createElement( 'span', { className: 'legend--layer_by' }, 'by ' ), _react2.default.createElement( 'span', { className: 'legend--layer_color_field' }, name ) ); }; var LayerSizeLegend = function LayerSizeLegend(_ref2) { var label = _ref2.label, name = _ref2.name; return _react2.default.createElement( 'div', { className: 'legend--layer_size-schema' }, _react2.default.createElement( 'p', null, _react2.default.createElement( 'span', { className: 'legend--layer_by' }, label ) ), _react2.default.createElement(VisualChannelMetric, { name: name }) ); }; var propTypes = { layers: _propTypes2.default.array }; var SingleColorLegend = function SingleColorLegend(_ref3) { var layer = _ref3.layer, width = _ref3.width; return _react2.default.createElement(_colorLegend2.default, { scaleType: 'ordinal', displayLabel: false, domain: [''], fieldType: null, range: [_d3Color.rgb.apply(undefined, (0, _toConsumableArray3.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 _react2.default.createElement(_colorLegend2.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 _react2.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 _react2.default.createElement( StyledMapControlLegend, { className: 'legend--layer', last: index === layers.length - 1, key: index }, _react2.default.createElement( 'div', { className: 'legend--layer_name' }, layer.config.label ), _react2.default.createElement( 'div', { className: 'legend--layer_type' }, (0, _utils.capitalizeFirstLetter)(layer.name) + ' color' ), _react2.default.createElement( 'div', { className: 'legend--layer_color-schema' }, _react2.default.createElement( 'div', null, enableColorBy ? _react2.default.createElement(VisualChannelMetric, { name: enableColorBy }) : null, _react2.default.createElement( 'div', { className: 'legend--layer_color-legend' }, enableColorBy ? _react2.default.createElement(MultiColorLegend, { layer: layer, width: width }) : _react2.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 _react2.default.createElement(LayerSizeLegend, { key: key, label: visualChannelDescription.label, name: visualChannelDescription.measure }); } return null; }) ); }) ); }; MapLegend.propTypes = propTypes; 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","array","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","matchCondition","key","condition","enabled","field","defaultMeasure","visualChannelDescription"],"mappings":"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","file":"map-legend.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 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.array\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\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 = DIMENSIONS.mapControl.width - 2 * DIMENSIONS.mapControl.padding;\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          <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                  <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(key);\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"]}