kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
73 lines (72 loc) • 13.9 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = PanelHeaderActionFactory;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _localization = require("@kepler.gl/localization");
var _styledComponents2 = require("../common/styled-components");
var _templateObject; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var HeaderActionWrapper = _styledComponents["default"].div.attrs(function (props) {
return {
$dataTestId: props.$testId
};
})(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", "px;\n display: flex;\n align-items: center;\n color: ", ";\n\n cursor: pointer;\n\n &:hover {\n color: ", ";\n }\n\n &.disabled {\n cursor: none;\n pointer-events: none;\n opacity: 0.3;\n }\n"])), function (props) {
return props.$flush ? 0 : 8;
}, function (props) {
return props.$active ? props.theme.panelHeaderIconActive : props.theme.panelHeaderIcon;
}, function (props) {
return props.$hoverColor ? props.theme[props.$hoverColor] : props.theme.panelHeaderIconHover;
});
PanelHeaderActionFactory.deps = [];
// Need to use react class to access props.component
function PanelHeaderActionFactory() {
var PanelHeaderActionUnmemoized = function PanelHeaderActionUnmemoized(_ref) {
var onClick = _ref.onClick,
tooltip = _ref.tooltip,
id = _ref.id,
_ref$active = _ref.active,
active = _ref$active === void 0 ? false : _ref$active,
flush = _ref.flush,
hoverColor = _ref.hoverColor,
tooltipType = _ref.tooltipType,
disabled = _ref.disabled,
className = _ref.className,
IconComponent = _ref.IconComponent,
testId = _ref.testId;
return /*#__PURE__*/_react["default"].createElement(HeaderActionWrapper, {
className: (0, _classnames["default"])('panel--header__action', _objectSpread({
disabled: disabled
}, className ? (0, _defineProperty2["default"])({}, className, true) : {})),
$active: active,
$hoverColor: hoverColor,
$flush: flush
}, IconComponent ? /*#__PURE__*/_react["default"].createElement(IconComponent, {
className: "panel--header__action__component",
"data-testid": testId,
"data-tip": true,
"data-for": "".concat(tooltip, "_").concat(id),
height: "16px",
onClick: onClick
}) : null, tooltip ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "".concat(tooltip, "_").concat(id),
effect: "solid",
delayShow: 500,
type: tooltipType
}, /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: tooltip
}))) : null);
};
var PanelHeaderAction = /*#__PURE__*/_react["default"].memo(PanelHeaderActionUnmemoized);
PanelHeaderAction.displayName = 'PanelHeaderAction';
return PanelHeaderAction;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_styledComponents","_localization","_styledComponents2","_templateObject","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","HeaderActionWrapper","styled","div","attrs","props","$dataTestId","$testId","_taggedTemplateLiteral2","$flush","$active","theme","panelHeaderIconActive","panelHeaderIcon","$hoverColor","panelHeaderIconHover","PanelHeaderActionFactory","deps","PanelHeaderActionUnmemoized","_ref","onClick","tooltip","id","_ref$active","active","flush","hoverColor","tooltipType","disabled","className","IconComponent","testId","createElement","classnames","concat","height","Tooltip","effect","delayShow","type","FormattedMessage","PanelHeaderAction","React","memo","displayName"],"sources":["../../src/side-panel/panel-header-action.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {ComponentType, MouseEventHandler} from 'react';\nimport {TooltipProps} from 'react-tooltip';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {Tooltip} from '../common/styled-components';\nimport {BaseProps} from '../common/icons';\nimport {BaseComponentProps} from '../types';\n\nexport type PanelHeaderActionIcon = ComponentType<Partial<BaseProps>>;\n\nexport interface PanelHeaderActionProps {\n  id?: string;\n  tooltip?: string;\n  hoverColor?: string;\n  className?: string;\n  active?: boolean;\n  flush?: boolean;\n  disabled?: boolean;\n  onClick?: MouseEventHandler;\n  tooltipType?: TooltipProps['type'];\n  IconComponent: PanelHeaderActionIcon;\n  testId?: string;\n}\n\ntype HeaderActionWrapperProps = {\n  $flush?: boolean;\n  $active?: boolean;\n  $hoverColor?: string | null;\n  $dataTestId?: any;\n};\n\ntype HeaderActionWrapperCssProps = {$testId?: string} & HeaderActionWrapperProps &\n  BaseComponentProps;\n\nconst HeaderActionWrapper = styled.div.attrs<HeaderActionWrapperCssProps>(props => ({\n  $dataTestId: props.$testId\n}))<HeaderActionWrapperProps>`\n  margin-left: ${props => (props.$flush ? 0 : 8)}px;\n  display: flex;\n  align-items: center;\n  color: ${props =>\n    props.$active ? props.theme.panelHeaderIconActive : props.theme.panelHeaderIcon};\n\n  cursor: pointer;\n\n  &:hover {\n    color: ${props =>\n      props.$hoverColor ? props.theme[props.$hoverColor] : props.theme.panelHeaderIconHover};\n  }\n\n  &.disabled {\n    cursor: none;\n    pointer-events: none;\n    opacity: 0.3;\n  }\n`;\n\nPanelHeaderActionFactory.deps = [];\n// Need to use react class to access props.component\nexport default function PanelHeaderActionFactory(): React.FC<PanelHeaderActionProps> {\n  const PanelHeaderActionUnmemoized: React.FC<PanelHeaderActionProps> = ({\n    onClick,\n    tooltip,\n    id,\n    active = false,\n    flush,\n    hoverColor,\n    tooltipType,\n    disabled,\n    className,\n    IconComponent,\n    testId\n  }) => {\n    return (\n      <HeaderActionWrapper\n        className={classnames('panel--header__action', {\n          disabled,\n          ...(className ? {[className]: true} : {})\n        })}\n        $active={active}\n        $hoverColor={hoverColor}\n        $flush={flush}\n      >\n        {IconComponent ? (\n          <IconComponent\n            className=\"panel--header__action__component\"\n            data-testid={testId}\n            data-tip\n            data-for={`${tooltip}_${id}`}\n            height=\"16px\"\n            onClick={onClick}\n          />\n        ) : null}\n        {tooltip ? (\n          <Tooltip id={`${tooltip}_${id}`} effect=\"solid\" delayShow={500} type={tooltipType}>\n            <span>\n              <FormattedMessage id={tooltip} />\n            </span>\n          </Tooltip>\n        ) : null}\n      </HeaderActionWrapper>\n    );\n  };\n\n  const PanelHeaderAction = React.memo(PanelHeaderActionUnmemoized);\n  PanelHeaderAction.displayName = 'PanelHeaderAction';\n  return PanelHeaderAction;\n}\n"],"mappings":"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","ignoreList":[]}
;