UNPKG

kepler.gl

Version:

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

96 lines (95 loc) 17.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _localization = require("@kepler.gl/localization"); var _constants = require("@kepler.gl/constants"); var _icons = require("../../common/icons"); var _panelHeaderAction = _interopRequireDefault(require("../panel-header-action")); var _styledComponents2 = require("../../common/styled-components"); var _templateObject; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var StyledMapDropdown = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n height: 48px;\n margin-bottom: 5px;\n opacity: 1;\n position: relative;\n transition: opacity 0.05s ease-in, height 0.25s ease-out;\n\n &.collapsed {\n height: 0;\n margin-bottom: 0;\n opacity: 0;\n }\n\n &:hover {\n cursor: pointer;\n background-color: ", ";\n }\n\n .map-title-block img {\n margin-right: 12px;\n }\n\n .map-preview {\n border-radius: 3px;\n height: 30px;\n width: 40px;\n }\n\n &.selected {\n outline: 1px solid #caf2f4;\n }\n\n /* show callout dot if props.hasCallout and theme provides calloutDot base styles */\n &:after {\n ", "\n background-color: #00ACF5;\n top: 12px;\n left: 15px;\n display: ", ";\n }\n\n .custom-style-actions {\n display: flex;\n justify-content: space-between;\n align-items: center;\n }\n"])), function (props) { return props.theme.panelBackgroundHover; }, function (_ref) { var theme = _ref.theme; return theme.calloutDot; }, function (_ref2) { var theme = _ref2.theme, hasCallout = _ref2.hasCallout; return theme.calloutDot && hasCallout ? 'block' : 'none'; }); MapStyleSelectorFactory.deps = [_panelHeaderAction["default"]]; function MapStyleSelectorFactory(PanelHeaderAction) { var defaultActionIcons = { arrowDown: _icons.ArrowDown }; var MapStyleSelector = function MapStyleSelector(_ref3) { var mapStyle = _ref3.mapStyle, onChange = _ref3.onChange, toggleActive = _ref3.toggleActive, isSelecting = _ref3.isSelecting, customMapStylesActions = _ref3.customMapStylesActions, _ref3$actionIcons = _ref3.actionIcons, actionIcons = _ref3$actionIcons === void 0 ? defaultActionIcons : _ref3$actionIcons; var mapStyles = mapStyle.mapStyles, styleType = mapStyle.styleType; return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'mapManager.mapStyle' })), Object.values(mapStyles).map(function (_ref4) { var id = _ref4.id, custom = _ref4.custom, _ref4$icon = _ref4.icon, icon = _ref4$icon === void 0 ? _constants.NO_BASEMAP_ICON : _ref4$icon, _ref4$label = _ref4.label, label = _ref4$label === void 0 ? 'Untitled' : _ref4$label; return /*#__PURE__*/_react["default"].createElement(StyledMapDropdown, { className: (0, _classnames["default"])('map-dropdown-option', { collapsed: !isSelecting && id !== styleType, selected: isSelecting && id === styleType }), key: id, onClick: isSelecting ? function () { return onChange(id); } : toggleActive, hasCallout: Boolean(custom) }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderContent, { className: "map-title-block" }, /*#__PURE__*/_react["default"].createElement("img", { className: "map-preview", src: icon }), /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderTitle, { className: "map-preview-name" }, label)), !isSelecting ? /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { className: "map-dropdown-option__enable-config", id: "map-enable-config", IconComponent: actionIcons.arrowDown, tooltip: 'tooltip.selectBaseMapStyle', onClick: toggleActive }) : null, isSelecting && custom ? /*#__PURE__*/_react["default"].createElement("div", { className: "custom-style-actions" }, ((customMapStylesActions === null || customMapStylesActions === void 0 ? void 0 : customMapStylesActions[id]) || []).map(function (action) { return /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, { key: action.id, className: "map-dropdown-option__enable-config", id: action.id, IconComponent: action.IconComponent, tooltip: action.tooltip, onClick: function onClick(e) { e.stopPropagation(); action.onClick(); } }); })) : null); })); }; return MapStyleSelector; } var _default = exports["default"] = MapStyleSelectorFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styledComponents","_classnames","_localization","_constants","_icons","_panelHeaderAction","_styledComponents2","_templateObject","StyledMapDropdown","styled","StyledPanelHeader","_taggedTemplateLiteral2","props","theme","panelBackgroundHover","_ref","calloutDot","_ref2","hasCallout","MapStyleSelectorFactory","deps","PanelHeaderActionFactory","PanelHeaderAction","defaultActionIcons","arrowDown","ArrowDown","MapStyleSelector","_ref3","mapStyle","onChange","toggleActive","isSelecting","customMapStylesActions","_ref3$actionIcons","actionIcons","mapStyles","styleType","createElement","PanelLabel","FormattedMessage","id","Object","values","map","_ref4","custom","_ref4$icon","icon","NO_BASEMAP_ICON","_ref4$label","label","className","classnames","collapsed","selected","key","onClick","Boolean","PanelHeaderContent","src","PanelHeaderTitle","IconComponent","tooltip","action","e","stopPropagation","_default","exports"],"sources":["../../../src/side-panel/map-style-panel/map-style-selector.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {ComponentType} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\n\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {MapStyle} from '@kepler.gl/reducers';\nimport {NO_BASEMAP_ICON} from '@kepler.gl/constants';\nimport {MapStyles} from '@kepler.gl/types';\n\nimport {ArrowDown} from '../../common/icons';\nimport PanelHeaderActionFactory from '../panel-header-action';\nimport {\n  PanelHeaderContent,\n  PanelHeaderTitle,\n  PanelLabel,\n  StyledPanelHeader,\n  StyledPanelHeaderProps\n} from '../../common/styled-components';\nimport {BaseProps} from '../../common/icons';\nimport {PanelHeaderActionIcon} from '../panel-header-action';\n\ntype StyledMapDropdownProps = StyledPanelHeaderProps & {hasCallout: boolean};\n\nconst StyledMapDropdown = styled(StyledPanelHeader)<StyledMapDropdownProps>`\n  height: 48px;\n  margin-bottom: 5px;\n  opacity: 1;\n  position: relative;\n  transition: opacity 0.05s ease-in, height 0.25s ease-out;\n\n  &.collapsed {\n    height: 0;\n    margin-bottom: 0;\n    opacity: 0;\n  }\n\n  &:hover {\n    cursor: pointer;\n    background-color: ${props => props.theme.panelBackgroundHover};\n  }\n\n  .map-title-block img {\n    margin-right: 12px;\n  }\n\n  .map-preview {\n    border-radius: 3px;\n    height: 30px;\n    width: 40px;\n  }\n\n  &.selected {\n    outline: 1px solid #caf2f4;\n  }\n\n  /* show callout dot if props.hasCallout and theme provides calloutDot base styles */\n  &:after {\n    ${({theme}) => theme.calloutDot}\n    background-color: #00ACF5;\n    top: 12px;\n    left: 15px;\n    display: ${({theme, hasCallout}) => (theme.calloutDot && hasCallout ? 'block' : 'none')};\n  }\n\n  .custom-style-actions {\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n  }\n`;\n\nexport type MapStyleSelectorProps = {\n  mapStyle: MapStyle;\n  onChange: (payload: string) => void;\n  toggleActive: () => void;\n  isSelecting: boolean;\n  customMapStylesActions?: Record<\n    string,\n    {\n      id: string;\n      IconComponent: PanelHeaderActionIcon;\n      tooltip: string;\n      onClick: () => void;\n    }[]\n  >;\n  actionIcons?: Record<string, ComponentType<Partial<BaseProps>>>;\n};\n\nMapStyleSelectorFactory.deps = [PanelHeaderActionFactory];\n\nfunction MapStyleSelectorFactory(PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>) {\n  const defaultActionIcons = {\n    arrowDown: ArrowDown\n  };\n\n  const MapStyleSelector = ({\n    mapStyle,\n    onChange,\n    toggleActive,\n    isSelecting,\n    customMapStylesActions,\n    actionIcons = defaultActionIcons\n  }: MapStyleSelectorProps) => {\n    const {mapStyles, styleType}: {mapStyles: MapStyles; styleType: string} = mapStyle;\n\n    return (\n      <div>\n        <PanelLabel>\n          <FormattedMessage id={'mapManager.mapStyle'} />\n        </PanelLabel>\n\n        {Object.values(mapStyles).map(\n          ({id, custom, icon = NO_BASEMAP_ICON, label = 'Untitled'}) => (\n            <StyledMapDropdown\n              className={classnames('map-dropdown-option', {\n                collapsed: !isSelecting && id !== styleType,\n                selected: isSelecting && id === styleType\n              })}\n              key={id}\n              onClick={isSelecting ? () => onChange(id) : toggleActive}\n              hasCallout={Boolean(custom)}\n            >\n              <PanelHeaderContent className=\"map-title-block\">\n                <img className=\"map-preview\" src={icon} />\n                <PanelHeaderTitle className=\"map-preview-name\">{label}</PanelHeaderTitle>\n              </PanelHeaderContent>\n              {!isSelecting ? (\n                <PanelHeaderAction\n                  className=\"map-dropdown-option__enable-config\"\n                  id=\"map-enable-config\"\n                  IconComponent={actionIcons.arrowDown}\n                  tooltip={'tooltip.selectBaseMapStyle'}\n                  onClick={toggleActive}\n                />\n              ) : null}\n              {isSelecting && custom ? (\n                <div className=\"custom-style-actions\">\n                  {(customMapStylesActions?.[id] || []).map(action => (\n                    <PanelHeaderAction\n                      key={action.id}\n                      className=\"map-dropdown-option__enable-config\"\n                      id={action.id}\n                      IconComponent={action.IconComponent}\n                      tooltip={action.tooltip}\n                      onClick={e => {\n                        e.stopPropagation();\n                        action.onClick();\n                      }}\n                    />\n                  ))}\n                </div>\n              ) : null}\n            </StyledMapDropdown>\n          )\n        )}\n      </div>\n    );\n  };\n\n  return MapStyleSelector;\n}\n\nexport default MapStyleSelectorFactory;\n"],"mappings":";;;;;;;;AAGA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,WAAA,GAAAH,sBAAA,CAAAC,OAAA;AAEA,IAAAG,aAAA,GAAAH,OAAA;AAEA,IAAAI,UAAA,GAAAJ,OAAA;AAGA,IAAAK,MAAA,GAAAL,OAAA;AACA,IAAAM,kBAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,kBAAA,GAAAP,OAAA;AAMwC,IAAAQ,eAAA,EApBxC;AACA;AAyBA,IAAMC,iBAAiB,GAAG,IAAAC,4BAAM,EAACC,oCAAiB,CAAC,CAAAH,eAAA,KAAAA,eAAA,OAAAI,uBAAA,k0BAe3B,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACC,oBAAoB;AAAA,GAmB3D,UAAAC,IAAA;EAAA,IAAEF,KAAK,GAAAE,IAAA,CAALF,KAAK;EAAA,OAAMA,KAAK,CAACG,UAAU;AAAA,GAIpB,UAAAC,KAAA;EAAA,IAAEJ,KAAK,GAAAI,KAAA,CAALJ,KAAK;IAAEK,UAAU,GAAAD,KAAA,CAAVC,UAAU;EAAA,OAAOL,KAAK,CAACG,UAAU,IAAIE,UAAU,GAAG,OAAO,GAAG,MAAM;AAAA,CAAC,CAQ1F;AAmBDC,uBAAuB,CAACC,IAAI,GAAG,CAACC,6BAAwB,CAAC;AAEzD,SAASF,uBAAuBA,CAACG,iBAA8D,EAAE;EAC/F,IAAMC,kBAAkB,GAAG;IACzBC,SAAS,EAAEC;EACb,CAAC;EAED,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAgBA,CAAAC,KAAA,EAOO;IAAA,IAN3BC,QAAQ,GAAAD,KAAA,CAARC,QAAQ;MACRC,QAAQ,GAAAF,KAAA,CAARE,QAAQ;MACRC,YAAY,GAAAH,KAAA,CAAZG,YAAY;MACZC,WAAW,GAAAJ,KAAA,CAAXI,WAAW;MACXC,sBAAsB,GAAAL,KAAA,CAAtBK,sBAAsB;MAAAC,iBAAA,GAAAN,KAAA,CACtBO,WAAW;MAAXA,WAAW,GAAAD,iBAAA,cAAGV,kBAAkB,GAAAU,iBAAA;IAEhC,IAAOE,SAAS,GAA0DP,QAAQ,CAA3EO,SAAS;MAAEC,SAAS,GAA+CR,QAAQ,CAAhEQ,SAAS;IAE3B,oBACEvC,MAAA,YAAAwC,aAAA,2BACExC,MAAA,YAAAwC,aAAA,CAAC/B,kBAAA,CAAAgC,UAAU,qBACTzC,MAAA,YAAAwC,aAAA,CAACnC,aAAA,CAAAqC,gBAAgB;MAACC,EAAE,EAAE;IAAsB,CAAE,CACpC,CAAC,EAEZC,MAAM,CAACC,MAAM,CAACP,SAAS,CAAC,CAACQ,GAAG,CAC3B,UAAAC,KAAA;MAAA,IAAEJ,EAAE,GAAAI,KAAA,CAAFJ,EAAE;QAAEK,MAAM,GAAAD,KAAA,CAANC,MAAM;QAAAC,UAAA,GAAAF,KAAA,CAAEG,IAAI;QAAJA,IAAI,GAAAD,UAAA,cAAGE,0BAAe,GAAAF,UAAA;QAAAG,WAAA,GAAAL,KAAA,CAAEM,KAAK;QAALA,KAAK,GAAAD,WAAA,cAAG,UAAU,GAAAA,WAAA;MAAA,oBACtDpD,MAAA,YAAAwC,aAAA,CAAC7B,iBAAiB;QAChB2C,SAAS,EAAE,IAAAC,sBAAU,EAAC,qBAAqB,EAAE;UAC3CC,SAAS,EAAE,CAACtB,WAAW,IAAIS,EAAE,KAAKJ,SAAS;UAC3CkB,QAAQ,EAAEvB,WAAW,IAAIS,EAAE,KAAKJ;QAClC,CAAC,CAAE;QACHmB,GAAG,EAAEf,EAAG;QACRgB,OAAO,EAAEzB,WAAW,GAAG;UAAA,OAAMF,QAAQ,CAACW,EAAE,CAAC;QAAA,IAAGV,YAAa;QACzDZ,UAAU,EAAEuC,OAAO,CAACZ,MAAM;MAAE,gBAE5BhD,MAAA,YAAAwC,aAAA,CAAC/B,kBAAA,CAAAoD,kBAAkB;QAACP,SAAS,EAAC;MAAiB,gBAC7CtD,MAAA,YAAAwC,aAAA;QAAKc,SAAS,EAAC,aAAa;QAACQ,GAAG,EAAEZ;MAAK,CAAE,CAAC,eAC1ClD,MAAA,YAAAwC,aAAA,CAAC/B,kBAAA,CAAAsD,gBAAgB;QAACT,SAAS,EAAC;MAAkB,GAAED,KAAwB,CACtD,CAAC,EACpB,CAACnB,WAAW,gBACXlC,MAAA,YAAAwC,aAAA,CAACf,iBAAiB;QAChB6B,SAAS,EAAC,oCAAoC;QAC9CX,EAAE,EAAC,mBAAmB;QACtBqB,aAAa,EAAE3B,WAAW,CAACV,SAAU;QACrCsC,OAAO,EAAE,4BAA6B;QACtCN,OAAO,EAAE1B;MAAa,CACvB,CAAC,GACA,IAAI,EACPC,WAAW,IAAIc,MAAM,gBACpBhD,MAAA,YAAAwC,aAAA;QAAKc,SAAS,EAAC;MAAsB,GAClC,CAAC,CAAAnB,sBAAsB,aAAtBA,sBAAsB,uBAAtBA,sBAAsB,CAAGQ,EAAE,CAAC,KAAI,EAAE,EAAEG,GAAG,CAAC,UAAAoB,MAAM;QAAA,oBAC9ClE,MAAA,YAAAwC,aAAA,CAACf,iBAAiB;UAChBiC,GAAG,EAAEQ,MAAM,CAACvB,EAAG;UACfW,SAAS,EAAC,oCAAoC;UAC9CX,EAAE,EAAEuB,MAAM,CAACvB,EAAG;UACdqB,aAAa,EAAEE,MAAM,CAACF,aAAc;UACpCC,OAAO,EAAEC,MAAM,CAACD,OAAQ;UACxBN,OAAO,EAAE,SAATA,OAAOA,CAAEQ,CAAC,EAAI;YACZA,CAAC,CAACC,eAAe,CAAC,CAAC;YACnBF,MAAM,CAACP,OAAO,CAAC,CAAC;UAClB;QAAE,CACH,CAAC;MAAA,CACH,CACE,CAAC,GACJ,IACa,CAAC;IAAA,CAExB,CACG,CAAC;EAEV,CAAC;EAED,OAAO9B,gBAAgB;AACzB;AAAC,IAAAwC,QAAA,GAAAC,OAAA,cAEchD,uBAAuB","ignoreList":[]}