UNPKG

kepler.gl

Version:

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

92 lines (90 loc) 17.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectDestructuringEmpty2 = _interopRequireDefault(require("@babel/runtime/helpers/objectDestructuringEmpty")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _constants = require("@kepler.gl/constants"); var _localization = require("@kepler.gl/localization"); var _utils = require("@kepler.gl/utils"); var _react = _interopRequireWildcard(require("react")); var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector")); var _styledComponents = require("../../common/styled-components"); var _colorScaleSelector = _interopRequireDefault(require("./color-scale-selector")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var SizeScaleSelector = function SizeScaleSelector(_ref) { var dropdownSelectProps = (0, _extends2["default"])({}, ((0, _objectDestructuringEmpty2["default"])(_ref), _ref)); return /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], dropdownSelectProps); }; DimensionScaleSelectorFactory.deps = [_colorScaleSelector["default"]]; function DimensionScaleSelectorFactory(ColorScaleSelector) { var DimensionScaleSelector = function DimensionScaleSelector(_ref2) { var _layer$config$colorUI; var layer = _ref2.layer, channel = _ref2.channel, dataset = _ref2.dataset, label = _ref2.label, onChange = _ref2.onChange, setColorUI = _ref2.setColorUI; var channelScaleType = channel.channelScaleType, domain = channel.domain, field = channel.field, key = channel.key, range = channel.range, scale = channel.scale; var scaleType = scale ? layer.config[scale] : null; var layerScaleOptions = layer.getScaleOptions(key); var scaleOptions = layerScaleOptions.map(function (op) { return { label: _constants.SCALE_TYPE_NAMES[op] || op, value: op }; }); var disabled = scaleOptions.length < 2; var isColorScale = channelScaleType === _constants.CHANNEL_SCALES.color || layer.config.aggregatedBins && channelScaleType === _constants.CHANNEL_SCALES.colorAggr; var onSelect = (0, _react.useCallback)(function (val, newRange) { return onChange((0, _defineProperty2["default"])({}, scale, val), key, newRange ? (0, _defineProperty2["default"])({}, range, newRange) : undefined); }, [onChange, range, scale, key]); var _setColorUI = (0, _react.useCallback)(function (newConfig) { return setColorUI(range, newConfig); }, [range, setColorUI]); var dropdownSelectProps = { disabled: disabled, selectedItems: scaleOptions.filter(function (op) { return op.value === scaleType; }), options: scaleOptions, multiSelect: false, searchable: false, onChange: onSelect, displayOption: 'label', getOptionValue: 'value', channelKey: key }; return /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: label ? "scale.".concat((0, _utils.camelize)(label)) : 'misc.scale', defaultMessage: label })), isColorScale && dataset ? /*#__PURE__*/_react["default"].createElement(ColorScaleSelector, (0, _extends2["default"])({}, dropdownSelectProps, { layer: layer, field: layer.config[field], dataset: dataset, onSelect: onSelect, scaleType: scaleType, domain: layer.config[domain], aggregatedBins: layer.config.aggregatedBins, range: layer.config.visConfig[range], setColorUI: _setColorUI, colorUIConfig: (_layer$config$colorUI = layer.config.colorUI) === null || _layer$config$colorUI === void 0 ? void 0 : _layer$config$colorUI[range] })) : /*#__PURE__*/_react["default"].createElement(SizeScaleSelector, dropdownSelectProps)); }; return DimensionScaleSelector; } var _default = exports["default"] = DimensionScaleSelectorFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","_localization","_utils","_react","_interopRequireWildcard","_itemSelector","_interopRequireDefault","_styledComponents","_colorScaleSelector","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SizeScaleSelector","_ref","dropdownSelectProps","_extends2","_objectDestructuringEmpty2","createElement","DimensionScaleSelectorFactory","deps","ColorScaleSelectorFactory","ColorScaleSelector","DimensionScaleSelector","_ref2","_layer$config$colorUI","layer","channel","dataset","label","onChange","setColorUI","channelScaleType","domain","field","key","range","scale","scaleType","config","layerScaleOptions","getScaleOptions","scaleOptions","map","op","SCALE_TYPE_NAMES","value","disabled","length","isColorScale","CHANNEL_SCALES","color","aggregatedBins","colorAggr","onSelect","useCallback","val","newRange","_defineProperty2","undefined","_setColorUI","newConfig","selectedItems","filter","options","multiSelect","searchable","displayOption","getOptionValue","channelKey","SidePanelSection","PanelLabel","FormattedMessage","id","concat","camelize","defaultMessage","visConfig","colorUIConfig","colorUI","_default","exports"],"sources":["../../../src/side-panel/layer-panel/dimension-scale-selector.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {CHANNEL_SCALES, SCALE_TYPE_NAMES} from '@kepler.gl/constants';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {ColorUI, LayerVisConfig} from '@kepler.gl/types';\nimport {camelize} from '@kepler.gl/utils';\nimport {Layer, VisualChannel} from '@kepler.gl/layers';\nimport {default as React, useCallback} from 'react';\nimport {Field} from '@kepler.gl/types';\nimport ItemSelector from '../../common/item-selector/item-selector';\nimport {PanelLabel, SidePanelSection} from '../../common/styled-components';\nimport ColorScaleSelectorFactory from './color-scale-selector';\nimport {KeplerTable} from '@kepler.gl/table';\n\nconst SizeScaleSelector = ({...dropdownSelectProps}: any) => (\n  <ItemSelector {...dropdownSelectProps} />\n);\n\nexport type DimensionScaleSelectorProps = {\n  layer: Layer;\n  channel: VisualChannel;\n  label?: string;\n  dataset: KeplerTable | undefined;\n  onChange: (\n    newConfig: {[key: string]: Field | null | string},\n    key: string,\n    newVisConfig?: Partial<LayerVisConfig>\n  ) => void;\n  setColorUI: (range: string, newConfig: {[key in keyof ColorUI]: ColorUI[key]}) => void;\n};\n\nDimensionScaleSelectorFactory.deps = [ColorScaleSelectorFactory];\n\nfunction DimensionScaleSelectorFactory(\n  ColorScaleSelector: ReturnType<typeof ColorScaleSelectorFactory>\n): React.FC<DimensionScaleSelectorProps> {\n  const DimensionScaleSelector: React.FC<DimensionScaleSelectorProps> = ({\n    layer,\n    channel,\n    dataset,\n    label,\n    onChange,\n    setColorUI\n  }) => {\n    const {channelScaleType, domain, field, key, range, scale} = channel;\n    const scaleType = scale ? layer.config[scale] : null;\n    const layerScaleOptions = layer.getScaleOptions(key);\n    const scaleOptions = layerScaleOptions.map(op => ({\n      label: SCALE_TYPE_NAMES[op] || op,\n      value: op\n    }));\n    const disabled = scaleOptions.length < 2;\n    const isColorScale =\n      channelScaleType === CHANNEL_SCALES.color ||\n      (layer.config.aggregatedBins && channelScaleType === CHANNEL_SCALES.colorAggr);\n\n    const onSelect = useCallback(\n      (val, newRange) => onChange({[scale]: val}, key, newRange ? {[range]: newRange} : undefined),\n      [onChange, range, scale, key]\n    );\n    const _setColorUI = useCallback(newConfig => setColorUI(range, newConfig), [range, setColorUI]);\n\n    const dropdownSelectProps = {\n      disabled,\n      selectedItems: scaleOptions.filter(op => op.value === scaleType),\n      options: scaleOptions,\n      multiSelect: false,\n      searchable: false,\n      onChange: onSelect,\n      displayOption: 'label',\n      getOptionValue: 'value',\n      channelKey: key\n    };\n\n    return (\n      <SidePanelSection>\n        <PanelLabel>\n          <FormattedMessage\n            id={label ? `scale.${camelize(label)}` : 'misc.scale'}\n            defaultMessage={label}\n          />\n        </PanelLabel>\n        {isColorScale && dataset ? (\n          <ColorScaleSelector\n            {...dropdownSelectProps}\n            layer={layer}\n            field={layer.config[field]}\n            dataset={dataset}\n            onSelect={onSelect}\n            scaleType={scaleType}\n            domain={layer.config[domain]}\n            aggregatedBins={layer.config.aggregatedBins}\n            range={layer.config.visConfig[range]}\n            setColorUI={_setColorUI}\n            colorUIConfig={layer.config.colorUI?.[range]}\n          />\n        ) : (\n          <SizeScaleSelector {...dropdownSelectProps} />\n        )}\n      </SidePanelSection>\n    );\n  };\n  return DimensionScaleSelector;\n}\n\nexport default DimensionScaleSelectorFactory;\n"],"mappings":"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","ignoreList":[]}