kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
148 lines (147 loc) • 23.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PureFeatureActionPanelFactory = PureFeatureActionPanelFactory;
exports["default"] = FeatureActionPanelFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _reactIntl = require("react-intl");
var _copyToClipboard = _interopRequireDefault(require("copy-to-clipboard"));
var _react2 = require("@floating-ui/react");
var _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _utils = require("@kepler.gl/utils");
var _actionPanel = _interopRequireWildcard(require("../common/action-panel"));
var _icons = require("../common/icons");
var _templateObject; // 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; }
var LAYOVER_OFFSET = 4;
var StyledActionsLayer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n .layer-panel-item-disabled {\n color: ", ";\n }\n"])), function (props) {
return props.theme.textColor;
});
var defaultActionIcons = {
remove: _icons.Trash,
layer: _icons.Layers,
copy: _icons.Copy,
copied: _icons.Checkmark
};
PureFeatureActionPanelFactory.deps = [];
function PureFeatureActionPanelFactory() {
var FeatureActionPanel = function FeatureActionPanel(_ref) {
var className = _ref.className,
datasets = _ref.datasets,
selectedFeature = _ref.selectedFeature,
_ref$position = _ref.position,
position = _ref$position === void 0 ? null : _ref$position,
layers = _ref.layers,
currentFilter = _ref.currentFilter,
onToggleLayer = _ref.onToggleLayer,
onDeleteFeature = _ref.onDeleteFeature,
_ref$actionIcons = _ref.actionIcons,
actionIcons = _ref$actionIcons === void 0 ? defaultActionIcons : _ref$actionIcons,
children = _ref.children,
onClose = _ref.onClose;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
copied = _useState2[0],
setCopied = _useState2[1];
var _ref2 = currentFilter || {},
_ref2$layerId = _ref2.layerId,
layerId = _ref2$layerId === void 0 ? [] : _ref2$layerId;
var intl = (0, _reactIntl.useIntl)();
var _useFloating = (0, _react2.useFloating)({
open: true,
onOpenChange: function onOpenChange(v) {
if (!v && onClose) {
onClose();
}
}
}),
refs = _useFloating.refs,
context = _useFloating.context;
var dismiss = (0, _react2.useDismiss)(context);
var _useInteractions = (0, _react2.useInteractions)([dismiss]),
getFloatingProps = _useInteractions.getFloatingProps;
var copyGeometry = (0, _react.useCallback)(function () {
if (selectedFeature !== null && selectedFeature !== void 0 && selectedFeature.geometry) (0, _copyToClipboard["default"])(JSON.stringify(selectedFeature.geometry));
setCopied(true);
}, [selectedFeature === null || selectedFeature === void 0 ? void 0 : selectedFeature.geometry]);
if (!position) {
return null;
}
var isFilterLayerDisabled = !(0, _utils.canApplyFeatureFilter)(selectedFeature);
return /*#__PURE__*/_react["default"].createElement(StyledActionsLayer, (0, _extends2["default"])({
ref: refs.setFloating
}, getFloatingProps(), {
className: (0, _classnames["default"])('feature-action-panel', className),
style: {
top: "".concat(position.y + LAYOVER_OFFSET, "px"),
left: "".concat(position.x + LAYOVER_OFFSET, "px")
}
}), /*#__PURE__*/_react["default"].createElement(_actionPanel["default"], null, /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
className: "editor-layers-list",
label: intl.formatMessage({
id: 'editor.filterLayer',
defaultMessage: 'Filter layers'
}),
Icon: actionIcons.layer,
isDisabled: isFilterLayerDisabled,
tooltipText: isFilterLayerDisabled ? intl.formatMessage({
id: 'editor.filterLayerDisabled'
}) : null
}, layers.length ? layers.map(function (layer, index) {
return /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
key: index,
label: layer.config.label
// @ts-ignore
,
color: datasets[layer.config.dataId].color,
isSelection: true,
isActive: layerId.includes(layer.id),
onClick: function onClick() {
return onToggleLayer(layer);
},
className: "layer-panel-item"
});
}) : /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
key: 'no-layers',
label: intl.formatMessage({
id: 'editor.noLayersToFilter',
defaultMessage: 'No layers to filter'
}),
isSelection: false,
isActive: false,
className: "layer-panel-item-disabled"
})), /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
label: intl.formatMessage({
id: 'editor.copyGeometry',
defaultMessage: 'Copy Geometry'
}),
className: "delete-panel-item",
Icon: copied ? actionIcons.copied : actionIcons.copy,
onClick: copyGeometry
}), children, /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
label: intl.formatMessage({
id: 'tooltip.delete',
defaultMessage: 'Delete'
}),
className: "delete-panel-item",
Icon: actionIcons.remove,
onClick: onDeleteFeature
})));
};
FeatureActionPanel.displayName = 'FeatureActionPanel';
return FeatureActionPanel;
}
FeatureActionPanelFactory.deps = PureFeatureActionPanelFactory.deps;
function FeatureActionPanelFactory() {
return PureFeatureActionPanelFactory();
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactIntl","_copyToClipboard","_interopRequireDefault","_react2","_classnames","_styledComponents","_utils","_actionPanel","_icons","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","LAYOVER_OFFSET","StyledActionsLayer","styled","div","_taggedTemplateLiteral2","props","theme","textColor","defaultActionIcons","remove","Trash","layer","Layers","copy","Copy","copied","Checkmark","PureFeatureActionPanelFactory","deps","FeatureActionPanel","_ref","className","datasets","selectedFeature","_ref$position","position","layers","currentFilter","onToggleLayer","onDeleteFeature","_ref$actionIcons","actionIcons","children","onClose","_useState","useState","_useState2","_slicedToArray2","setCopied","_ref2","_ref2$layerId","layerId","intl","useIntl","_useFloating","useFloating","open","onOpenChange","v","refs","context","dismiss","useDismiss","_useInteractions","useInteractions","getFloatingProps","copyGeometry","useCallback","geometry","JSON","stringify","isFilterLayerDisabled","canApplyFeatureFilter","createElement","_extends2","ref","setFloating","classnames","style","top","concat","y","left","x","ActionPanelItem","label","formatMessage","id","defaultMessage","Icon","isDisabled","tooltipText","length","map","index","key","config","color","dataId","isSelection","isActive","includes","onClick","displayName","FeatureActionPanelFactory"],"sources":["../../src/editor/feature-action-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useState, ComponentType} from 'react';\nimport {useIntl} from 'react-intl';\nimport copy from 'copy-to-clipboard';\nimport {useDismiss, useFloating, useInteractions} from '@floating-ui/react';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\n\nimport {Layer} from '@kepler.gl/layers';\nimport {Filter} from '@kepler.gl/types';\nimport {Feature} from '@nebula.gl/edit-modes';\nimport {Datasets} from '@kepler.gl/table';\nimport {canApplyFeatureFilter} from '@kepler.gl/utils';\n\nimport ActionPanel, {ActionPanelItem} from '../common/action-panel';\nimport {Trash, Layers, Copy, Checkmark} from '../common/icons';\n\nconst LAYOVER_OFFSET = 4;\n\nconst StyledActionsLayer = styled.div`\n  position: absolute;\n  .layer-panel-item-disabled {\n    color: ${props => props.theme.textColor};\n  }\n`;\nconst defaultActionIcons = {\n  remove: Trash,\n  layer: Layers,\n  copy: Copy,\n  copied: Checkmark\n};\nPureFeatureActionPanelFactory.deps = [];\n\nexport interface FeatureActionPanelProps {\n  className?: string;\n  datasets: Datasets;\n  selectedFeature: Feature | null;\n  position: {\n    x: number;\n    y: number;\n  } | null;\n  layers: Layer[];\n  currentFilter?: Filter;\n  onToggleLayer: (layer: Layer) => void;\n  onDeleteFeature: () => void;\n  onClose?: () => void;\n  children?: React.ReactNode;\n  actionIcons?: {\n    [id: string]: React.ElementType;\n  };\n}\n\nexport function PureFeatureActionPanelFactory(): React.FC<FeatureActionPanelProps> {\n  const FeatureActionPanel = ({\n    className,\n    datasets,\n    selectedFeature,\n    position = null,\n    layers,\n    currentFilter,\n    onToggleLayer,\n    onDeleteFeature,\n    actionIcons = defaultActionIcons,\n    children,\n    onClose\n  }: FeatureActionPanelProps) => {\n    const [copied, setCopied] = useState(false);\n    const {layerId = []} = currentFilter || {};\n    const intl = useIntl();\n\n    const {refs, context} = useFloating({\n      open: true,\n      onOpenChange: v => {\n        if (!v && onClose) {\n          onClose();\n        }\n      }\n    });\n    const dismiss = useDismiss(context);\n\n    const {getFloatingProps} = useInteractions([dismiss]);\n\n    const copyGeometry = useCallback(() => {\n      if (selectedFeature?.geometry) copy(JSON.stringify(selectedFeature.geometry));\n      setCopied(true);\n    }, [selectedFeature?.geometry]);\n\n    if (!position) {\n      return null;\n    }\n\n    const isFilterLayerDisabled = !canApplyFeatureFilter(selectedFeature as any);\n    return (\n      <StyledActionsLayer\n        ref={refs.setFloating}\n        {...getFloatingProps()}\n        className={classnames('feature-action-panel', className)}\n        style={{\n          top: `${position.y + LAYOVER_OFFSET}px`,\n          left: `${position.x + LAYOVER_OFFSET}px`\n        }}\n      >\n        <ActionPanel>\n          <ActionPanelItem\n            className=\"editor-layers-list\"\n            label={intl.formatMessage({id: 'editor.filterLayer', defaultMessage: 'Filter layers'})}\n            Icon={actionIcons.layer}\n            isDisabled={isFilterLayerDisabled}\n            tooltipText={\n              isFilterLayerDisabled ? intl.formatMessage({id: 'editor.filterLayerDisabled'}) : null\n            }\n          >\n            {layers.length ? (\n              layers.map((layer, index) => (\n                <ActionPanelItem\n                  key={index}\n                  label={layer.config.label}\n                  // @ts-ignore\n                  color={datasets[layer.config.dataId].color}\n                  isSelection={true}\n                  isActive={layerId.includes(layer.id)}\n                  onClick={() => onToggleLayer(layer)}\n                  className=\"layer-panel-item\"\n                />\n              ))\n            ) : (\n              <ActionPanelItem\n                key={'no-layers'}\n                label={intl.formatMessage({\n                  id: 'editor.noLayersToFilter',\n                  defaultMessage: 'No layers to filter'\n                })}\n                isSelection={false}\n                isActive={false}\n                className=\"layer-panel-item-disabled\"\n              />\n            )}\n          </ActionPanelItem>\n          <ActionPanelItem\n            label={intl.formatMessage({id: 'editor.copyGeometry', defaultMessage: 'Copy Geometry'})}\n            className=\"delete-panel-item\"\n            Icon={copied ? actionIcons.copied : actionIcons.copy}\n            onClick={copyGeometry}\n          />\n          {children}\n          <ActionPanelItem\n            label={intl.formatMessage({id: 'tooltip.delete', defaultMessage: 'Delete'})}\n            className=\"delete-panel-item\"\n            Icon={actionIcons.remove}\n            onClick={onDeleteFeature}\n          />\n        </ActionPanel>\n      </StyledActionsLayer>\n    );\n  };\n\n  FeatureActionPanel.displayName = 'FeatureActionPanel';\n\n  return FeatureActionPanel;\n}\n\nFeatureActionPanelFactory.deps = PureFeatureActionPanelFactory.deps;\n\nexport default function FeatureActionPanelFactory(): ComponentType<FeatureActionPanelProps> {\n  return PureFeatureActionPanelFactory();\n}\n"],"mappings":"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","ignoreList":[]}