kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
165 lines (164 loc) • 35.3 kB
JavaScript
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 _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _localization = require("@kepler.gl/localization");
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _icons = require("../../common/icons");
var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector"));
var _rangeSlider = _interopRequireDefault(require("../../common/range-slider"));
var _styledComponents2 = require("../../common/styled-components");
var _switch = _interopRequireDefault(require("../../common/switch"));
var _layerConfigGroup = _interopRequireWildcard(require("./layer-config-group"));
var _constants = require("@kepler.gl/constants");
var _fieldSelector = _interopRequireDefault(require("../../common/field-selector"));
var _colorSelector = _interopRequireDefault(require("./color-selector"));
var _templateObject; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
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; }
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
var SwitchWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n line-height: 11px;\n margin-bottom: 8px;\n"])));
TextLabelPanelFactory.deps = [_rangeSlider["default"], _layerConfigGroup["default"], _fieldSelector["default"], _colorSelector["default"]];
function TextLabelPanelFactory(RangeSlider, LayerConfigGroup, FieldSelector, ColorSelector) {
var TextLabelPanel = /*#__PURE__*/function (_Component) {
function TextLabelPanel() {
(0, _classCallCheck2["default"])(this, TextLabelPanel);
return _callSuper(this, TextLabelPanel, arguments);
}
(0, _inherits2["default"])(TextLabelPanel, _Component);
return (0, _createClass2["default"])(TextLabelPanel, [{
key: "render",
value: function render() {
var _this = this;
var _this$props = this.props,
updateLayerTextLabel = _this$props.updateLayerTextLabel,
textLabel = _this$props.textLabel,
fields = _this$props.fields;
var currentFields = textLabel.map(function (tl) {
return tl.field && tl.field.name;
}).filter(function (d) {
return Boolean(d);
});
return /*#__PURE__*/_react["default"].createElement(LayerConfigGroup, {
label: 'panel.text.label',
collapsible: true
}, /*#__PURE__*/_react["default"].createElement(_layerConfigGroup.ConfigGroupCollapsibleHeader, null, /*#__PURE__*/_react["default"].createElement(FieldSelector, {
fields: fields,
value: currentFields,
onSelect: function onSelect(selected) {
return updateLayerTextLabel('all', 'fields', selected);
},
multiSelect: true
})), /*#__PURE__*/_react["default"].createElement(_layerConfigGroup.ConfigGroupCollapsibleContent, null, textLabel.map(function (tl, idx) {
return /*#__PURE__*/_react["default"].createElement("div", {
key: tl.field ? tl.field.name : "null-".concat(idx)
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'panel.text.labelWithId',
values: {
labelId: idx + 1
}
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(FieldSelector, {
fields: fields,
value: tl.field && tl.field.name || 'placeholder.selectField',
placeholder: 'placeholder.empty',
onSelect: function onSelect(v) {
return updateLayerTextLabel(idx, 'field', v);
},
erasable: true
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.fontSize"
})), /*#__PURE__*/_react["default"].createElement(RangeSlider, (0, _extends2["default"])({}, _constants.LAYER_TEXT_CONFIGS.fontSize, {
value1: tl.size,
isRanged: false,
onChange: function onChange(v) {
return updateLayerTextLabel(idx, 'size', v[1]);
}
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.fontColor"
})), /*#__PURE__*/_react["default"].createElement(ColorSelector, {
colorSets: [{
selectedColor: tl.color,
setColor: function setColor(v) {
return updateLayerTextLabel(idx, 'color', v);
}
}]
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.outlineWidth"
})), /*#__PURE__*/_react["default"].createElement(RangeSlider, (0, _extends2["default"])({}, _constants.LAYER_TEXT_CONFIGS.outlineWidth, {
value1: tl.outlineWidth,
isRanged: false,
onChange: function onChange(v) {
return updateLayerTextLabel(idx, 'outlineWidth', v[1]);
}
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.outlineColor"
})), /*#__PURE__*/_react["default"].createElement(ColorSelector, {
colorSets: [{
selectedColor: tl.outlineColor,
setColor: function setColor(v) {
return updateLayerTextLabel(idx, 'outlineColor', v);
}
}],
useOpacity: true
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(SwitchWrapper, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.backgroundColor"
})), /*#__PURE__*/_react["default"].createElement(_switch["default"], {
checked: tl.background,
id: "".concat(_this.props.id, "-textBackgroundEnabled-").concat(idx),
onChange: function onChange() {
return updateLayerTextLabel(idx, 'background', !tl.background);
}
})), /*#__PURE__*/_react["default"].createElement(ColorSelector, {
colorSets: [{
selectedColor: tl.backgroundColor,
setColor: function setColor(v) {
return updateLayerTextLabel(idx, 'backgroundColor', v);
}
}],
useOpacity: true,
disabled: !tl.background
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.SpaceBetweenFlexbox, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.SBFlexboxItem, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.textAnchor"
})), /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], (0, _extends2["default"])({}, _constants.LAYER_TEXT_CONFIGS.textAnchor, {
selectedItems: tl.anchor,
onChange: function onChange(val) {
return updateLayerTextLabel(idx, 'anchor', val);
}
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SBFlexboxItem, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.alignment"
})), /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], (0, _extends2["default"])({}, _constants.LAYER_TEXT_CONFIGS.textAlignment, {
selectedItems: tl.alignment,
onChange: function onChange(val) {
return updateLayerTextLabel(idx, 'alignment', val);
}
}))))));
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
link: true,
onClick: function onClick() {
return updateLayerTextLabel(textLabel.length, '', null);
}
}, /*#__PURE__*/_react["default"].createElement(_icons.Add, {
height: "12px"
}), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "panel.text.addMoreLabel"
})))));
}
}]);
}(_react.Component);
return TextLabelPanel;
}
var _default = exports["default"] = TextLabelPanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_localization","require","_react","_interopRequireWildcard","_styledComponents","_interopRequireDefault","_icons","_itemSelector","_rangeSlider","_styledComponents2","_switch","_layerConfigGroup","_constants","_fieldSelector","_colorSelector","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_callSuper","o","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","SwitchWrapper","styled","div","_taggedTemplateLiteral2","TextLabelPanelFactory","deps","RangeSliderFactory","LayerConfigGroupFactory","FieldSelectorFactory","ColorSelectorFactory","RangeSlider","LayerConfigGroup","FieldSelector","ColorSelector","TextLabelPanel","_Component","_classCallCheck2","arguments","_inherits2","_createClass2","key","value","render","_this","_this$props","props","updateLayerTextLabel","textLabel","fields","currentFields","map","tl","field","name","filter","d","createElement","label","collapsible","ConfigGroupCollapsibleHeader","onSelect","selected","multiSelect","ConfigGroupCollapsibleContent","idx","concat","PanelLabel","FormattedMessage","id","values","labelId","SidePanelSection","placeholder","v","erasable","_extends2","LAYER_TEXT_CONFIGS","fontSize","value1","size","isRanged","onChange","colorSets","selectedColor","color","setColor","outlineWidth","outlineColor","useOpacity","checked","background","backgroundColor","disabled","SpaceBetweenFlexbox","SBFlexboxItem","textAnchor","selectedItems","anchor","val","textAlignment","alignment","Button","link","onClick","length","Add","height","Component","_default","exports"],"sources":["../../../src/side-panel/layer-panel/text-label-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {ColorRange} from '@kepler.gl/types';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport React, {Component} from 'react';\nimport styled from 'styled-components';\n\nimport {Add} from '../../common/icons';\nimport ItemSelector from '../../common/item-selector/item-selector';\nimport RangeSliderFactory from '../../common/range-slider';\nimport {\n  Button,\n  PanelLabel,\n  SBFlexboxItem,\n  SidePanelSection,\n  SpaceBetweenFlexbox\n} from '../../common/styled-components';\nimport Switch from '../../common/switch';\nimport LayerConfigGroupFactory, {\n  ConfigGroupCollapsibleContent,\n  ConfigGroupCollapsibleHeader\n} from './layer-config-group';\n\nimport {LAYER_TEXT_CONFIGS} from '@kepler.gl/constants';\nimport {Field, LayerTextLabel, RGBAColor, RGBColor} from '@kepler.gl/types';\nimport FieldSelectorFactory from '../../common/field-selector';\nimport ColorSelectorFactory from './color-selector';\n\nconst SwitchWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  line-height: 11px;\n  margin-bottom: 8px;\n`;\n\ntype TextLabelPanelProps = {\n  id?: string;\n  fields: Field[];\n  textLabel: LayerTextLabel[];\n  updateLayerTextLabel: (idx: number | 'all', prop: string, value: any) => void;\n};\n\nTextLabelPanelFactory.deps = [\n  RangeSliderFactory,\n  LayerConfigGroupFactory,\n  FieldSelectorFactory,\n  ColorSelectorFactory\n];\n\nfunction TextLabelPanelFactory(\n  RangeSlider: ReturnType<typeof RangeSliderFactory>,\n  LayerConfigGroup: ReturnType<typeof LayerConfigGroupFactory>,\n  FieldSelector: ReturnType<typeof FieldSelectorFactory>,\n  ColorSelector: ReturnType<typeof ColorSelectorFactory>\n): React.ComponentType<TextLabelPanelProps> {\n  class TextLabelPanel extends Component<TextLabelPanelProps> {\n    render() {\n      const {updateLayerTextLabel, textLabel, fields} = this.props;\n      const currentFields = textLabel.map(tl => tl.field && tl.field.name).filter(d => Boolean(d));\n\n      return (\n        <LayerConfigGroup label={'panel.text.label'} collapsible>\n          <ConfigGroupCollapsibleHeader>\n            <FieldSelector\n              fields={fields}\n              value={currentFields as string[]}\n              onSelect={selected => updateLayerTextLabel('all', 'fields', selected)}\n              multiSelect\n            />\n          </ConfigGroupCollapsibleHeader>\n          <ConfigGroupCollapsibleContent>\n            {textLabel.map((tl, idx) => (\n              <div key={tl.field ? tl.field.name : `null-${idx}`}>\n                <PanelLabel>\n                  <FormattedMessage id={'panel.text.labelWithId'} values={{labelId: idx + 1}} />\n                </PanelLabel>\n                <SidePanelSection>\n                  <FieldSelector\n                    fields={fields}\n                    value={(tl.field && tl.field.name) || 'placeholder.selectField'}\n                    placeholder={'placeholder.empty'}\n                    onSelect={v => updateLayerTextLabel(idx, 'field', v)}\n                    erasable\n                  />\n                </SidePanelSection>\n                <SidePanelSection>\n                  <PanelLabel>\n                    <FormattedMessage id=\"panel.text.fontSize\" />\n                  </PanelLabel>\n                  <RangeSlider\n                    {...LAYER_TEXT_CONFIGS.fontSize}\n                    value1={tl.size}\n                    isRanged={false}\n                    onChange={v => updateLayerTextLabel(idx, 'size', v[1])}\n                  />\n                </SidePanelSection>\n                <SidePanelSection>\n                  <PanelLabel>\n                    <FormattedMessage id=\"panel.text.fontColor\" />\n                  </PanelLabel>\n                  <ColorSelector\n                    colorSets={[\n                      {\n                        selectedColor: tl.color,\n                        setColor: (v: RGBColor | RGBAColor | ColorRange) =>\n                          updateLayerTextLabel(idx, 'color', v)\n                      }\n                    ]}\n                  />\n                </SidePanelSection>\n\n                <SidePanelSection>\n                  <PanelLabel>\n                    <FormattedMessage id=\"panel.text.outlineWidth\" />\n                  </PanelLabel>\n                  <RangeSlider\n                    {...LAYER_TEXT_CONFIGS.outlineWidth}\n                    value1={tl.outlineWidth}\n                    isRanged={false}\n                    onChange={v => updateLayerTextLabel(idx, 'outlineWidth', v[1])}\n                  />\n                </SidePanelSection>\n                <SidePanelSection>\n                  <PanelLabel>\n                    <FormattedMessage id=\"panel.text.outlineColor\" />\n                  </PanelLabel>\n                  <ColorSelector\n                    colorSets={[\n                      {\n                        selectedColor: tl.outlineColor,\n                        setColor: v => updateLayerTextLabel(idx, 'outlineColor', v)\n                      }\n                    ]}\n                    useOpacity={true}\n                  />\n                </SidePanelSection>\n\n                <SidePanelSection>\n                  <SwitchWrapper>\n                    <PanelLabel>\n                      <FormattedMessage id=\"panel.text.backgroundColor\" />\n                    </PanelLabel>\n                    <Switch\n                      checked={tl.background}\n                      id={`${this.props.id}-textBackgroundEnabled-${idx}`}\n                      onChange={() => updateLayerTextLabel(idx, 'background', !tl.background)}\n                    />\n                  </SwitchWrapper>\n\n                  <ColorSelector\n                    colorSets={[\n                      {\n                        selectedColor: tl.backgroundColor,\n                        setColor: v => updateLayerTextLabel(idx, 'backgroundColor', v)\n                      }\n                    ]}\n                    useOpacity={true}\n                    disabled={!tl.background}\n                  />\n                </SidePanelSection>\n\n                <SidePanelSection>\n                  <SpaceBetweenFlexbox>\n                    <SBFlexboxItem>\n                      <PanelLabel>\n                        <FormattedMessage id=\"panel.text.textAnchor\" />\n                      </PanelLabel>\n                      <ItemSelector\n                        {...LAYER_TEXT_CONFIGS.textAnchor}\n                        selectedItems={tl.anchor}\n                        onChange={val => updateLayerTextLabel(idx, 'anchor', val)}\n                      />\n                    </SBFlexboxItem>\n                    <SBFlexboxItem>\n                      <PanelLabel>\n                        <FormattedMessage id=\"panel.text.alignment\" />\n                      </PanelLabel>\n                      <ItemSelector\n                        {...LAYER_TEXT_CONFIGS.textAlignment}\n                        selectedItems={tl.alignment}\n                        onChange={val => updateLayerTextLabel(idx, 'alignment', val)}\n                      />\n                    </SBFlexboxItem>\n                  </SpaceBetweenFlexbox>\n                </SidePanelSection>\n              </div>\n            ))}\n            <SidePanelSection>\n              <Button link onClick={() => updateLayerTextLabel(textLabel.length, '', null)}>\n                <Add height=\"12px\" />\n                <FormattedMessage id=\"panel.text.addMoreLabel\" />\n              </Button>\n            </SidePanelSection>\n          </ConfigGroupCollapsibleContent>\n        </LayerConfigGroup>\n      );\n    }\n  }\n\n  return TextLabelPanel;\n}\n\nexport default TextLabelPanelFactory;\n"],"mappings":"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","ignoreList":[]}
;