kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
72 lines (70 loc) • 13.8 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ChannelByValueSelectorFactory = ChannelByValueSelectorFactory;
exports["default"] = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _constants = require("@kepler.gl/constants");
var _dimensionScaleSelector = _interopRequireDefault(require("./dimension-scale-selector"));
var _visConfigByFieldSelector = _interopRequireDefault(require("./vis-config-by-field-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
ChannelByValueSelectorFactory.deps = [_visConfigByFieldSelector["default"], _dimensionScaleSelector["default"]];
function ChannelByValueSelectorFactory(VisConfigByFieldSelector, DimensionScaleSelector) {
var ChannelByValueSelector = function ChannelByValueSelector(_ref) {
var layer = _ref.layer,
channel = _ref.channel,
onChange = _ref.onChange,
fields = _ref.fields,
dataset = _ref.dataset,
description = _ref.description,
setColorUI = _ref.setColorUI,
disabled = _ref.disabled;
var channelScaleType = channel.channelScaleType,
field = channel.field,
key = channel.key,
property = channel.property,
scale = channel.scale,
defaultMeasure = channel.defaultMeasure,
supportedFieldTypes = channel.supportedFieldTypes;
var channelSupportedFieldTypes = supportedFieldTypes || _constants.CHANNEL_SCALE_SUPPORTED_FIELDS[channelScaleType];
var supportedFields = fields.filter(function (_ref2) {
var type = _ref2.type;
return channelSupportedFieldTypes.includes(type);
});
var showScale = !layer.isAggregated && layer.config[scale] && layer.config[field];
var defaultDescription = 'layerConfiguration.defaultDescription';
var updateField = (0, _react.useCallback)(function (val) {
onChange((0, _defineProperty2["default"])({}, field, val), key);
}, [onChange, field, key]);
return /*#__PURE__*/_react["default"].createElement("div", {
className: "channel-by-value-selector"
}, /*#__PURE__*/_react["default"].createElement(VisConfigByFieldSelector, {
description: description || defaultDescription,
fields: supportedFields,
id: layer.id,
key: "".concat(key, "-channel-selector"),
property: property,
disabled: disabled,
placeholder: defaultMeasure || 'placeholder.selectField',
selectedField: layer.config[field],
updateField: updateField
}), showScale && !disabled ? /*#__PURE__*/_react["default"].createElement(DimensionScaleSelector, {
layer: layer,
channel: channel,
dataset: dataset,
label: "".concat(property, " scale"),
setColorUI: setColorUI,
onChange: onChange
}) : null);
};
return ChannelByValueSelector;
}
var _default = exports["default"] = ChannelByValueSelectorFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_constants","_dimensionScaleSelector","_interopRequireDefault","_visConfigByFieldSelector","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ChannelByValueSelectorFactory","deps","VisConfigByFieldSelectorFactory","DimensionScaleSelectorFactory","VisConfigByFieldSelector","DimensionScaleSelector","ChannelByValueSelector","_ref","layer","channel","onChange","fields","dataset","description","setColorUI","disabled","channelScaleType","field","key","property","scale","defaultMeasure","supportedFieldTypes","channelSupportedFieldTypes","CHANNEL_SCALE_SUPPORTED_FIELDS","supportedFields","filter","_ref2","type","includes","showScale","isAggregated","config","defaultDescription","updateField","useCallback","val","_defineProperty2","createElement","className","id","concat","placeholder","selectedField","label","_default","exports"],"sources":["../../../src/side-panel/layer-panel/channel-by-value-selector.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback} from 'react';\n\nimport {CHANNEL_SCALE_SUPPORTED_FIELDS} from '@kepler.gl/constants';\nimport {Layer, VisualChannel} from '@kepler.gl/layers';\nimport {KeplerTable} from '@kepler.gl/table';\nimport {ColorUI, Field, LayerVisConfig, NestedPartial} from '@kepler.gl/types';\n\nimport DimensionScaleSelectorFactory from './dimension-scale-selector';\nimport VisConfigByFieldSelectorFactory from './vis-config-by-field-selector';\n\nexport type ChannelByValueSelectorProps = {\n  layer: Layer;\n  channel: VisualChannel;\n  onChange: (\n    newConfig: {[key: string]: Field | null | string},\n    key: string,\n    newVisConfig?: Partial<LayerVisConfig>\n  ) => void;\n  fields: Field[];\n  dataset: KeplerTable | undefined;\n  description?: string;\n  setColorUI: (prop: string, newConfig: NestedPartial<ColorUI>) => void;\n  updateLayerVisConfig: (newConfig: Partial<LayerVisConfig>) => void;\n  disabled?: boolean;\n};\n\nChannelByValueSelectorFactory.deps = [\n  VisConfigByFieldSelectorFactory,\n  DimensionScaleSelectorFactory\n];\n\nexport function ChannelByValueSelectorFactory(\n  VisConfigByFieldSelector: ReturnType<typeof VisConfigByFieldSelectorFactory>,\n  DimensionScaleSelector: ReturnType<typeof DimensionScaleSelectorFactory>\n): React.FC<ChannelByValueSelectorProps> {\n  const ChannelByValueSelector: React.FC<ChannelByValueSelectorProps> = ({\n    layer,\n    channel,\n    onChange,\n    fields,\n    dataset,\n    description,\n    setColorUI,\n    disabled\n  }) => {\n    const {channelScaleType, field, key, property, scale, defaultMeasure, supportedFieldTypes} =\n      channel;\n    const channelSupportedFieldTypes =\n      supportedFieldTypes || CHANNEL_SCALE_SUPPORTED_FIELDS[channelScaleType];\n    const supportedFields = fields.filter(({type}) => channelSupportedFieldTypes.includes(type));\n    const showScale = !layer.isAggregated && layer.config[scale] && layer.config[field];\n    const defaultDescription = 'layerConfiguration.defaultDescription';\n    const updateField = useCallback(\n      val => {\n        onChange({[field]: val}, key);\n      },\n      [onChange, field, key]\n    );\n\n    return (\n      <div className=\"channel-by-value-selector\">\n        <VisConfigByFieldSelector\n          description={description || defaultDescription}\n          fields={supportedFields}\n          id={layer.id}\n          key={`${key}-channel-selector`}\n          property={property}\n          disabled={disabled}\n          placeholder={defaultMeasure || 'placeholder.selectField'}\n          selectedField={layer.config[field]}\n          updateField={updateField}\n        />\n        {showScale && !disabled ? (\n          <DimensionScaleSelector\n            layer={layer}\n            channel={channel}\n            dataset={dataset}\n            label={`${property} scale`}\n            setColorUI={setColorUI}\n            onChange={onChange}\n          />\n        ) : null}\n      </div>\n    );\n  };\n\n  return ChannelByValueSelector;\n}\n\nexport default ChannelByValueSelectorFactory;\n"],"mappings":"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","ignoreList":[]}
;