kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
98 lines (97 loc) • 18.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"] = exports.StyledToggleOption = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _orderByList = _interopRequireDefault(require("../common/icons/order-by-list"));
var _orderByDataset = _interopRequireDefault(require("../common/icons/order-by-dataset"));
var _styledComponents2 = require("../common/styled-components");
var _localization = require("@kepler.gl/localization");
var _constants = require("@kepler.gl/constants");
var _templateObject, _templateObject2, _templateObject3; // 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 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 PanelViewListToggleContainer = _styledComponents["default"].div.attrs({
className: 'panel-view-list-toggle'
})(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])([""])));
var PanelViewListToggleWrapper = _styledComponents["default"].div.attrs({
className: 'panel-view-list-toggle-inner'
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-end;\n align-content: center;\n gap: 10px;\n"])));
var StyledToggleOption = exports.StyledToggleOption = _styledComponents["default"].div.attrs({
className: 'layer-panel-toggle-option'
})(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n &:hover {\n cursor: pointer;\n color: ", ";\n }\n"])), function (props) {
return props.active ? props.theme.subtextColorActive : props.theme.panelTabColor;
}, function (props) {
return props.theme.subtextColorActive;
});
function ToggleOptionFactory() {
var ToggleOption = function ToggleOption(_ref) {
var isActive = _ref.isActive,
onClick = _ref.onClick,
option = _ref.option;
return /*#__PURE__*/_react["default"].createElement(StyledToggleOption, {
"data-tip": true,
"data-for": "".concat(option.id, "-toggle-option"),
active: isActive,
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(option.iconComponent, {
height: "20px"
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "".concat(option.id, "-toggle-option"),
effect: "solid",
delayShow: 500,
place: "bottom"
}, /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: option.label
}))));
};
return ToggleOption;
}
var TOGGLE_OPTIONS = [{
id: _constants.PANEL_VIEW_TOGGLES.list,
iconComponent: _orderByList["default"],
label: 'sidebar.panelViewToggle.list'
}, {
id: _constants.PANEL_VIEW_TOGGLES.byDataset,
iconComponent: _orderByDataset["default"],
label: 'sidebar.panelViewToggle.byDataset'
}];
PanelViewListToggleFactory.deps = [ToggleOptionFactory];
function PanelViewListToggleFactory(ToggleOption) {
var PanelViewListToggle = function PanelViewListToggle(_ref2) {
var mode = _ref2.mode,
togglePanelListView = _ref2.togglePanelListView;
var toggleListView = function toggleListView(listView) {
return togglePanelListView(listView);
};
var options = (0, _react.useMemo)(function () {
return TOGGLE_OPTIONS.map(function (opt) {
return _objectSpread(_objectSpread({}, opt), {}, {
isActive: mode === opt.id
});
});
}, [mode]);
return /*#__PURE__*/_react["default"].createElement(PanelViewListToggleContainer, null, /*#__PURE__*/_react["default"].createElement(PanelViewListToggleWrapper, null, options.map(function (opt) {
return /*#__PURE__*/_react["default"].createElement(ToggleOption, {
key: opt.id,
onClick: function onClick() {
return toggleListView(opt.id);
},
option: opt,
isActive: opt.isActive
});
})));
};
return PanelViewListToggle;
}
var _default = exports["default"] = PanelViewListToggleFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_orderByList","_orderByDataset","_styledComponents2","_localization","_constants","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","PanelViewListToggleContainer","styled","div","attrs","className","_taggedTemplateLiteral2","PanelViewListToggleWrapper","StyledToggleOption","exports","props","active","theme","subtextColorActive","panelTabColor","ToggleOptionFactory","ToggleOption","_ref","isActive","onClick","option","createElement","concat","id","iconComponent","height","Tooltip","effect","delayShow","place","FormattedMessage","label","TOGGLE_OPTIONS","PANEL_VIEW_TOGGLES","list","OrderByList","byDataset","OrderByDataset","PanelViewListToggleFactory","deps","PanelViewListToggle","_ref2","mode","togglePanelListView","toggleListView","listView","options","useMemo","map","opt","key","_default"],"sources":["../../src/side-panel/panel-view-list-toggle.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo} from 'react';\nimport styled from 'styled-components';\nimport OrderByList from '../common/icons/order-by-list';\nimport OrderByDataset from '../common/icons/order-by-dataset';\nimport {Tooltip} from '../common/styled-components';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {PanelListView} from '@kepler.gl/types';\nimport {PANEL_VIEW_TOGGLES} from '@kepler.gl/constants';\n\ntype ToggleOptionProps = {\n  isActive: boolean;\n  onClick: () => void;\n  option: (typeof TOGGLE_OPTIONS)[0];\n};\n\ntype PanelViewListToggleProps = {\n  mode: PanelListView;\n  togglePanelListView: (view: string) => void;\n};\n\nconst PanelViewListToggleContainer = styled.div.attrs({\n  className: 'panel-view-list-toggle'\n})``;\n\nconst PanelViewListToggleWrapper = styled.div.attrs({\n  className: 'panel-view-list-toggle-inner'\n})`\n  display: flex;\n  justify-content: flex-end;\n  align-content: center;\n  gap: 10px;\n`;\n\nexport const StyledToggleOption = styled.div.attrs({\n  className: 'layer-panel-toggle-option'\n})<{active: boolean}>`\n  color: ${props => (props.active ? props.theme.subtextColorActive : props.theme.panelTabColor)};\n  &:hover {\n    cursor: pointer;\n    color: ${props => props.theme.subtextColorActive};\n  }\n`;\n\nfunction ToggleOptionFactory() {\n  const ToggleOption: React.FC<ToggleOptionProps> = ({isActive, onClick, option}) => (\n    <StyledToggleOption\n      data-tip\n      data-for={`${option.id}-toggle-option`}\n      active={isActive}\n      onClick={onClick}\n    >\n      <option.iconComponent height=\"20px\" />\n      <Tooltip id={`${option.id}-toggle-option`} effect=\"solid\" delayShow={500} place=\"bottom\">\n        <span>\n          <FormattedMessage id={option.label} />\n        </span>\n      </Tooltip>\n    </StyledToggleOption>\n  );\n\n  return ToggleOption;\n}\n\nconst TOGGLE_OPTIONS = [\n  {\n    id: PANEL_VIEW_TOGGLES.list,\n    iconComponent: OrderByList,\n    label: 'sidebar.panelViewToggle.list'\n  },\n  {\n    id: PANEL_VIEW_TOGGLES.byDataset,\n    iconComponent: OrderByDataset,\n    label: 'sidebar.panelViewToggle.byDataset'\n  }\n];\n\nPanelViewListToggleFactory.deps = [ToggleOptionFactory];\n\nfunction PanelViewListToggleFactory(ToggleOption: ReturnType<typeof ToggleOptionFactory>) {\n  const PanelViewListToggle: React.FC<PanelViewListToggleProps> = ({mode, togglePanelListView}) => {\n    const toggleListView = listView => togglePanelListView(listView);\n\n    const options = useMemo(\n      () => TOGGLE_OPTIONS.map(opt => ({...opt, isActive: mode === opt.id})),\n      [mode]\n    );\n\n    return (\n      <PanelViewListToggleContainer>\n        <PanelViewListToggleWrapper>\n          {options.map(opt => (\n            <ToggleOption\n              key={opt.id}\n              onClick={() => toggleListView(opt.id)}\n              option={opt}\n              isActive={opt.isActive}\n            />\n          ))}\n        </PanelViewListToggleWrapper>\n      </PanelViewListToggleContainer>\n    );\n  };\n\n  return PanelViewListToggle;\n}\n\nexport default PanelViewListToggleFactory;\n"],"mappings":"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","ignoreList":[]}
;