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","tooltipType","disabled","className","IconComponent","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":";;;;;;;;;AAGA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,iBAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,aAAA,GAAAH,OAAA;AACA,IAAAI,kBAAA,GAAAJ,OAAA;AAAoD,IAAAK,eAAA,EARpD;AACA;AAAA,SAAAC,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA;AAqCA,IAAMoB,mBAAmB,GAAGC,4BAAM,CAACC,GAAG,CAACC,KAAK,CAA8B,UAAAC,KAAK;EAAA,OAAK;IAClFC,UAAU,EAAED,KAAK,CAACE;EACpB,CAAC;AAAA,CAAC,CAAC,CAAA5B,eAAA,KAAAA,eAAA,OAAA6B,uBAAA,6PACc,UAAAH,KAAK;EAAA,OAAKA,KAAK,CAACI,KAAK,GAAG,CAAC,GAAG,CAAC;AAAA,CAAC,EAGpC,UAAAJ,KAAK;EAAA,OACZA,KAAK,CAACK,MAAM,GAAGL,KAAK,CAACM,KAAK,CAACC,qBAAqB,GAAGP,KAAK,CAACM,KAAK,CAACE,eAAe;AAAA,GAKrE,UAAAR,KAAK;EAAA,OACZA,KAAK,CAACS,UAAU,GAAGT,KAAK,CAACM,KAAK,CAACN,KAAK,CAACS,UAAU,CAAC,GAAGT,KAAK,CAACM,KAAK,CAACI,oBAAoB;AAAA,EAQxF;AAEDC,wBAAwB,CAACC,IAAI,GAAG,EAAE;AAClC;AACe,SAASD,wBAAwBA,CAAA,EAAqC;EACnF,IAAME,2BAA6D,GAAG,SAAhEA,2BAA6DA,CAAAC,IAAA,EAY7D;IAAA,IAXJC,OAAO,GAAAD,IAAA,CAAPC,OAAO;MACPC,OAAO,GAAAF,IAAA,CAAPE,OAAO;MACPC,EAAE,GAAAH,IAAA,CAAFG,EAAE;MAAAC,WAAA,GAAAJ,IAAA,CACFT,MAAM;MAANA,MAAM,GAAAa,WAAA,cAAG,KAAK,GAAAA,WAAA;MACdd,KAAK,GAAAU,IAAA,CAALV,KAAK;MACLK,UAAU,GAAAK,IAAA,CAAVL,UAAU;MACVU,WAAW,GAAAL,IAAA,CAAXK,WAAW;MACXC,QAAQ,GAAAN,IAAA,CAARM,QAAQ;MACRC,SAAS,GAAAP,IAAA,CAATO,SAAS;MACTC,aAAa,GAAAR,IAAA,CAAbQ,aAAa;MACbpB,MAAM,GAAAY,IAAA,CAANZ,MAAM;IAEN,oBACEnC,MAAA,YAAAwD,aAAA,CAAC3B,mBAAmB;MAClByB,SAAS,EAAE,IAAAG,sBAAU,EAAC,uBAAuB,EAAApC,aAAA;QAC3CgC,QAAQ,EAARA;MAAQ,GACJC,SAAS,OAAA7B,gBAAA,iBAAK6B,SAAS,EAAG,IAAI,IAAI,CAAC,CAAC,CACzC,CAAE;MACHhB,MAAM,EAAEA,MAAO;MACfI,UAAU,EAAEA,UAAW;MACvBL,KAAK,EAAEA;IAAM,GAEZkB,aAAa,gBACZvD,MAAA,YAAAwD,aAAA,CAACD,aAAa;MACZD,SAAS,EAAC,kCAAkC;MAC5C,eAAanB,MAAO;MACpB,gBAAQ;MACR,eAAAuB,MAAA,CAAaT,OAAO,OAAAS,MAAA,CAAIR,EAAE,CAAG;MAC7BS,MAAM,EAAC,MAAM;MACbX,OAAO,EAAEA;IAAQ,CAClB,CAAC,GACA,IAAI,EACPC,OAAO,gBACNjD,MAAA,YAAAwD,aAAA,CAAClD,kBAAA,CAAAsD,OAAO;MAACV,EAAE,KAAAQ,MAAA,CAAKT,OAAO,OAAAS,MAAA,CAAIR,EAAE,CAAG;MAACW,MAAM,EAAC,OAAO;MAACC,SAAS,EAAE,GAAI;MAACC,IAAI,EAAEX;IAAY,gBAChFpD,MAAA,YAAAwD,aAAA,4BACExD,MAAA,YAAAwD,aAAA,CAACnD,aAAA,CAAA2D,gBAAgB;MAACd,EAAE,EAAED;IAAQ,CAAE,CAC5B,CACC,CAAC,GACR,IACe,CAAC;EAE1B,CAAC;EAED,IAAMgB,iBAAiB,gBAAGC,iBAAK,CAACC,IAAI,CAACrB,2BAA2B,CAAC;EACjEmB,iBAAiB,CAACG,WAAW,GAAG,mBAAmB;EACnD,OAAOH,iBAAiB;AAC1B","ignoreList":[]}
;