kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
97 lines (96 loc) • 18.3 kB
JavaScript
"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 _utils = require("@kepler.gl/utils");
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 ? "".concat((0, _utils.getApplicationConfig)().cdnUrl, "/").concat(_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","_utils","_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","concat","getApplicationConfig","cdnUrl","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';\nimport {getApplicationConfig} from '@kepler.gl/utils';\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          ({\n            id,\n            custom,\n            icon = `${getApplicationConfig().cdnUrl}/${NO_BASEMAP_ICON}`,\n            label = 'Untitled'\n          }) => (\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;AAEA,IAAAK,MAAA,GAAAL,OAAA;AAEA,IAAAM,MAAA,GAAAN,OAAA;AACA,IAAAO,kBAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,kBAAA,GAAAR,OAAA;AAMwC,IAAAS,eAAA,EArBxC;AACA;AA0BA,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,oBACExC,MAAA,YAAAyC,aAAA,2BACEzC,MAAA,YAAAyC,aAAA,CAAC/B,kBAAA,CAAAgC,UAAU,qBACT1C,MAAA,YAAAyC,aAAA,CAACpC,aAAA,CAAAsC,gBAAgB;MAACC,EAAE,EAAE;IAAsB,CAAE,CACpC,CAAC,EAEZC,MAAM,CAACC,MAAM,CAACP,SAAS,CAAC,CAACQ,GAAG,CAC3B,UAAAC,KAAA;MAAA,IACEJ,EAAE,GAAAI,KAAA,CAAFJ,EAAE;QACFK,MAAM,GAAAD,KAAA,CAANC,MAAM;QAAAC,UAAA,GAAAF,KAAA,CACNG,IAAI;QAAJA,IAAI,GAAAD,UAAA,iBAAAE,MAAA,CAAM,IAAAC,2BAAoB,EAAC,CAAC,CAACC,MAAM,OAAAF,MAAA,CAAIG,0BAAe,IAAAL,UAAA;QAAAM,WAAA,GAAAR,KAAA,CAC1DS,KAAK;QAALA,KAAK,GAAAD,WAAA,cAAG,UAAU,GAAAA,WAAA;MAAA,oBAElBxD,MAAA,YAAAyC,aAAA,CAAC7B,iBAAiB;QAChB8C,SAAS,EAAE,IAAAC,sBAAU,EAAC,qBAAqB,EAAE;UAC3CC,SAAS,EAAE,CAACzB,WAAW,IAAIS,EAAE,KAAKJ,SAAS;UAC3CqB,QAAQ,EAAE1B,WAAW,IAAIS,EAAE,KAAKJ;QAClC,CAAC,CAAE;QACHsB,GAAG,EAAElB,EAAG;QACRmB,OAAO,EAAE5B,WAAW,GAAG;UAAA,OAAMF,QAAQ,CAACW,EAAE,CAAC;QAAA,IAAGV,YAAa;QACzDZ,UAAU,EAAE0C,OAAO,CAACf,MAAM;MAAE,gBAE5BjD,MAAA,YAAAyC,aAAA,CAAC/B,kBAAA,CAAAuD,kBAAkB;QAACP,SAAS,EAAC;MAAiB,gBAC7C1D,MAAA,YAAAyC,aAAA;QAAKiB,SAAS,EAAC,aAAa;QAACQ,GAAG,EAAEf;MAAK,CAAE,CAAC,eAC1CnD,MAAA,YAAAyC,aAAA,CAAC/B,kBAAA,CAAAyD,gBAAgB;QAACT,SAAS,EAAC;MAAkB,GAAED,KAAwB,CACtD,CAAC,EACpB,CAACtB,WAAW,gBACXnC,MAAA,YAAAyC,aAAA,CAACf,iBAAiB;QAChBgC,SAAS,EAAC,oCAAoC;QAC9Cd,EAAE,EAAC,mBAAmB;QACtBwB,aAAa,EAAE9B,WAAW,CAACV,SAAU;QACrCyC,OAAO,EAAE,4BAA6B;QACtCN,OAAO,EAAE7B;MAAa,CACvB,CAAC,GACA,IAAI,EACPC,WAAW,IAAIc,MAAM,gBACpBjD,MAAA,YAAAyC,aAAA;QAAKiB,SAAS,EAAC;MAAsB,GAClC,CAAC,CAAAtB,sBAAsB,aAAtBA,sBAAsB,uBAAtBA,sBAAsB,CAAGQ,EAAE,CAAC,KAAI,EAAE,EAAEG,GAAG,CAAC,UAAAuB,MAAM;QAAA,oBAC9CtE,MAAA,YAAAyC,aAAA,CAACf,iBAAiB;UAChBoC,GAAG,EAAEQ,MAAM,CAAC1B,EAAG;UACfc,SAAS,EAAC,oCAAoC;UAC9Cd,EAAE,EAAE0B,MAAM,CAAC1B,EAAG;UACdwB,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,OAAOjC,gBAAgB;AACzB;AAAC,IAAA2C,QAAA,GAAAC,OAAA,cAEcnD,uBAAuB","ignoreList":[]}