kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
154 lines (125 loc) • 18.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PureFeatureActionPanelFactory = PureFeatureActionPanelFactory;
exports["default"] = FeatureActionPanelFactory;
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 _actionPanel = _interopRequireWildcard(require("../common/action-panel"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactOnclickoutside = _interopRequireDefault(require("react-onclickoutside"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _icons = require("../common/icons");
var _copyToClipboard = _interopRequireDefault(require("copy-to-clipboard"));
var _templateObject;
var LAYOVER_OFFSET = 4;
var StyledActionsLayer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n"])));
PureFeatureActionPanelFactory.deps = [];
function PureFeatureActionPanelFactory() {
var FeatureActionPanel = function FeatureActionPanel(_ref) {
var className = _ref.className,
datasets = _ref.datasets,
selectedFeature = _ref.selectedFeature,
position = _ref.position,
layers = _ref.layers,
currentFilter = _ref.currentFilter,
onToggleLayer = _ref.onToggleLayer,
onDeleteFeature = _ref.onDeleteFeature;
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 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]);
return /*#__PURE__*/_react["default"].createElement(StyledActionsLayer, {
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: _icons.Layers
}, layers.map(function (layer, index) {
return /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
key: index,
label: layer.config.label,
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, {
label: intl.formatMessage({
id: 'editor.copyGeometry',
defaultMessage: 'Copy Geometry'
}),
className: "delete-panel-item",
Icon: copied ? _icons.Checkmark : _icons.Copy,
onClick: copyGeometry
}), /*#__PURE__*/_react["default"].createElement(_actionPanel.ActionPanelItem, {
label: intl.formatMessage({
id: 'tooltip.delete',
defaultMessage: 'Delete'
}),
className: "delete-panel-item",
Icon: _icons.Trash,
onClick: onDeleteFeature
})));
};
FeatureActionPanel.displayName = 'FeatureActionPanel';
FeatureActionPanel.propTypes = {
className: _propTypes["default"].string,
datasets: _propTypes["default"].object.isRequired,
position: _propTypes["default"].object.isRequired,
layers: _propTypes["default"].arrayOf(_propTypes["default"].object).isRequired,
currentFilter: _propTypes["default"].object,
onClose: _propTypes["default"].func.isRequired,
onDeleteFeature: _propTypes["default"].func.isRequired
};
FeatureActionPanel.defaultProps = {
position: {}
};
return FeatureActionPanel;
}
FeatureActionPanelFactory.deps = PureFeatureActionPanelFactory.deps;
function FeatureActionPanelFactory() {
var PureFeatureActionPanel = PureFeatureActionPanelFactory();
var ClickOutsideFeatureActionPanel = function ClickOutsideFeatureActionPanel(props) {
// @ts-ignore
ClickOutsideFeatureActionPanel.handleClickOutside = function (e) {
var _props$onClose;
e.preventDefault();
e.stopPropagation();
(_props$onClose = props.onClose) === null || _props$onClose === void 0 ? void 0 : _props$onClose.call(props);
};
return /*#__PURE__*/_react["default"].createElement(PureFeatureActionPanel, props);
};
var clickOutsideConfig = {
// @ts-ignore
handleClickOutside: function handleClickOutside() {
return ClickOutsideFeatureActionPanel.handleClickOutside;
}
};
return (0, _reactOnclickoutside["default"])(ClickOutsideFeatureActionPanel, clickOutsideConfig);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/editor/feature-action-panel.js"],"names":["LAYOVER_OFFSET","StyledActionsLayer","styled","div","PureFeatureActionPanelFactory","deps","FeatureActionPanel","className","datasets","selectedFeature","position","layers","currentFilter","onToggleLayer","onDeleteFeature","copied","setCopied","layerId","intl","copyGeometry","geometry","JSON","stringify","top","y","left","x","formatMessage","id","defaultMessage","Layers","map","layer","index","config","label","dataId","color","includes","Checkmark","Copy","Trash","displayName","propTypes","PropTypes","string","object","isRequired","arrayOf","onClose","func","defaultProps","FeatureActionPanelFactory","PureFeatureActionPanel","ClickOutsideFeatureActionPanel","props","handleClickOutside","e","preventDefault","stopPropagation","clickOutsideConfig"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {useCallback, useState} from 'react';\nimport {useIntl} from 'react-intl';\n\nimport ActionPanel, {ActionPanelItem} from 'components/common/action-panel';\nimport styled from 'styled-components';\nimport onClickOutside from 'react-onclickoutside';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport {Trash, Layers, Copy, Checkmark} from 'components/common/icons';\nimport copy from 'copy-to-clipboard';\n\nconst LAYOVER_OFFSET = 4;\n\nconst StyledActionsLayer = styled.div`\n  position: absolute;\n`;\n\nPureFeatureActionPanelFactory.deps = [];\n\nexport function PureFeatureActionPanelFactory() {\n  const FeatureActionPanel = ({\n    className,\n    datasets,\n    selectedFeature,\n    position,\n    layers,\n    currentFilter,\n    onToggleLayer,\n    onDeleteFeature\n  }) => {\n    const [copied, setCopied] = useState(false);\n    const {layerId = []} = currentFilter || {};\n    const intl = useIntl();\n\n    const copyGeometry = useCallback(() => {\n      if (selectedFeature?.geometry) copy(JSON.stringify(selectedFeature.geometry));\n      setCopied(true);\n    }, [selectedFeature?.geometry]);\n\n    return (\n      <StyledActionsLayer\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={Layers}\n          >\n            {layers.map((layer, index) => (\n              <ActionPanelItem\n                key={index}\n                label={layer.config.label}\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          </ActionPanelItem>\n          <ActionPanelItem\n            label={intl.formatMessage({id: 'editor.copyGeometry', defaultMessage: 'Copy Geometry'})}\n            className=\"delete-panel-item\"\n            Icon={copied ? Checkmark : Copy}\n            onClick={copyGeometry}\n          />\n\n          <ActionPanelItem\n            label={intl.formatMessage({id: 'tooltip.delete', defaultMessage: 'Delete'})}\n            className=\"delete-panel-item\"\n            Icon={Trash}\n            onClick={onDeleteFeature}\n          />\n        </ActionPanel>\n      </StyledActionsLayer>\n    );\n  };\n\n  FeatureActionPanel.displayName = 'FeatureActionPanel';\n  FeatureActionPanel.propTypes = {\n    className: PropTypes.string,\n    datasets: PropTypes.object.isRequired,\n    position: PropTypes.object.isRequired,\n    layers: PropTypes.arrayOf(PropTypes.object).isRequired,\n    currentFilter: PropTypes.object,\n    onClose: PropTypes.func.isRequired,\n    onDeleteFeature: PropTypes.func.isRequired\n  };\n\n  FeatureActionPanel.defaultProps = {\n    position: {}\n  };\n\n  return FeatureActionPanel;\n}\n\nFeatureActionPanelFactory.deps = PureFeatureActionPanelFactory.deps;\n\nexport default function FeatureActionPanelFactory() {\n  const PureFeatureActionPanel = PureFeatureActionPanelFactory();\n\n  const ClickOutsideFeatureActionPanel = props => {\n    // @ts-ignore\n    ClickOutsideFeatureActionPanel.handleClickOutside = e => {\n      e.preventDefault();\n      e.stopPropagation();\n      props.onClose?.();\n    };\n    return <PureFeatureActionPanel {...props} />;\n  };\n\n  const clickOutsideConfig = {\n    // @ts-ignore\n    handleClickOutside: () => ClickOutsideFeatureActionPanel.handleClickOutside\n  };\n\n  return onClickOutside(ClickOutsideFeatureActionPanel, clickOutsideConfig);\n}\n"]}