kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
199 lines (170 loc) • 20.5 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n .layer__remove-layer {\n opacity: 0;\n }\n :hover {\n cursor: pointer;\n background-color: ', ';\n \n .layer__drag-handle {\n opacity: 1;\n }\n \n .layer__remove-layer {\n opacity: 1; \n }\n \n .layer__enable-config {\n color: white\n }\n }\n'], ['\n .layer__remove-layer {\n opacity: 0;\n }\n :hover {\n cursor: pointer;\n background-color: ', ';\n \n .layer__drag-handle {\n opacity: 1;\n }\n \n .layer__remove-layer {\n opacity: 1; \n }\n \n .layer__enable-config {\n color: white\n }\n }\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n color: ', ';\n'], ['\n display: flex;\n color: ', ';\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n'], ['\n display: flex;\n']),
_templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n margin-left: 12px;\n\n .layer__title__type {\n color: ', ';\n font-size: 10px;\n line-height: 12px;\n letter-spacing: 0.37px;\n text-transform: capitalize;\n }\n'], ['\n margin-left: 12px;\n\n .layer__title__type {\n color: ', ';\n font-size: 10px;\n line-height: 12px;\n letter-spacing: 0.37px;\n text-transform: capitalize;\n }\n']),
_templateObject5 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n align-items: center;\n opacity: 0;\n \n :hover {\n cursor: move;\n color: ', ';\n }\n'], ['\n display: flex;\n align-items: center;\n opacity: 0;\n \n :hover {\n cursor: move;\n color: ', ';\n }\n']); // Copyright (c) 2018 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _panelHeaderAction = require('../panel-header-action');
var _panelHeaderAction2 = _interopRequireDefault(_panelHeaderAction);
var _icons = require('../../common/icons');
var _styledComponents3 = require('../../common/styled-components');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var propTypes = {
// required
id: _propTypes2.default.string.isRequired,
isDragNDropEnabled: _propTypes2.default.bool,
isVisible: _propTypes2.default.bool.isRequired,
label: _propTypes2.default.string.isRequired,
onToggleVisibility: _propTypes2.default.func.isRequired,
// optional
className: _propTypes2.default.string,
idx: _propTypes2.default.number,
isConfigActive: _propTypes2.default.bool,
labelRCGColorValues: _propTypes2.default.array,
onUpdateLayerLabel: _propTypes2.default.func,
onRemoveLayer: _propTypes2.default.func
};
var defaultProps = {
isDragNDropEnabled: true,
showRemoveLayer: true
};
var StyledLayerPanelHeader = _styledComponents3.StyledPanelHeader.extend(_templateObject, function (props) {
return props.theme.panelBackgroundHover;
});
var HeaderLabelSection = _styledComponents2.default.div(_templateObject2, function (props) {
return props.theme.textColor;
});
var HeaderActionSection = _styledComponents2.default.div(_templateObject3);
var LayerTitleSection = _styledComponents2.default.div(_templateObject4, function (props) {
return props.theme.subtextColor;
});
var DragHandle = _styledComponents2.default.div(_templateObject5, function (props) {
return props.theme.textColorHl;
});
var LayerPanelHeader = function LayerPanelHeader(_ref) {
var className = _ref.className,
idx = _ref.idx,
isConfigActive = _ref.isConfigActive,
isDragNDropEnabled = _ref.isDragNDropEnabled,
isVisible = _ref.isVisible,
label = _ref.label,
layerId = _ref.layerId,
layerType = _ref.layerType,
labelRCGColorValues = _ref.labelRCGColorValues,
onToggleVisibility = _ref.onToggleVisibility,
onUpdateLayerLabel = _ref.onUpdateLayerLabel,
onToggleEnableConfig = _ref.onToggleEnableConfig,
onRemoveLayer = _ref.onRemoveLayer,
showRemoveLayer = _ref.showRemoveLayer;
return _react2.default.createElement(
StyledLayerPanelHeader,
{
className: (0, _classnames2.default)('layer-panel__header', {
'sort--handle': !isConfigActive
}),
active: isConfigActive,
labelRCGColorValues: labelRCGColorValues,
onClick: onToggleEnableConfig
},
_react2.default.createElement(
HeaderLabelSection,
{ className: 'layer-panel__header__content' },
isDragNDropEnabled && _react2.default.createElement(
DragHandle,
{ className: 'layer__drag-handle' },
_react2.default.createElement(_icons.VertDots, { height: '20px' })
),
_react2.default.createElement(_panelHeaderAction2.default, {
className: 'layer__visibility-toggle',
id: layerId,
tooltip: isVisible ? 'hide layer' : 'show layer',
onClick: onToggleVisibility,
IconComponent: isVisible ? _icons.EyeSeen : _icons.EyeUnseen,
active: isVisible,
flush: true
}),
_react2.default.createElement(
LayerTitleSection,
{ className: 'layer__title' },
_react2.default.createElement(
'div',
null,
_react2.default.createElement(LayerLabelEditor, { label: label, onEdit: onUpdateLayerLabel }),
_react2.default.createElement(
'div',
{ className: 'layer__title__type' },
layerType
)
)
)
),
_react2.default.createElement(
HeaderActionSection,
{ className: 'layer-panel__header__actions' },
showRemoveLayer ? _react2.default.createElement(_panelHeaderAction2.default, {
className: 'layer__remove-layer',
id: layerId,
tooltip: 'Remove layer',
onClick: onRemoveLayer,
tooltipType: 'error',
IconComponent: _icons.Trash
}) : null,
_react2.default.createElement(_panelHeaderAction2.default, {
className: 'layer__enable-config',
id: layerId,
tooltip: 'Layer settings',
onClick: onToggleEnableConfig,
IconComponent: _icons.ArrowDown
})
)
);
};
var LayerLabelEditor = function LayerLabelEditor(_ref2) {
var label = _ref2.label,
onEdit = _ref2.onEdit;
return _react2.default.createElement(_styledComponents3.InlineInput, {
type: 'text',
className: 'layer__title__editor',
value: label,
onClick: function onClick(e) {
e.stopPropagation();
},
onChange: onEdit,
id: 'input-layer-label'
});
};
LayerPanelHeader.propTypes = propTypes;
LayerPanelHeader.defaultProps = defaultProps;
exports.default = LayerPanelHeader;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-panel-header.js"],"names":["propTypes","id","PropTypes","string","isRequired","isDragNDropEnabled","bool","isVisible","label","onToggleVisibility","func","className","idx","number","isConfigActive","labelRCGColorValues","array","onUpdateLayerLabel","onRemoveLayer","defaultProps","showRemoveLayer","StyledLayerPanelHeader","StyledPanelHeader","extend","props","theme","panelBackgroundHover","HeaderLabelSection","styled","div","textColor","HeaderActionSection","LayerTitleSection","subtextColor","DragHandle","textColorHl","LayerPanelHeader","layerId","layerType","onToggleEnableConfig","EyeSeen","EyeUnseen","Trash","ArrowDown","LayerLabelEditor","onEdit","e","stopPropagation"],"mappings":"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","file":"layer-panel-header.js","sourcesContent":["// Copyright (c) 2018 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 from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\nimport PanelHeaderAction from 'components/side-panel/panel-header-action';\nimport {\n  EyeSeen,\n  EyeUnseen,\n  VertDots,\n  ArrowDown,\n  Trash\n} from 'components/common/icons';\n\nimport {InlineInput, StyledPanelHeader} from 'components/common/styled-components';\n\nconst propTypes = {\n  // required\n  id: PropTypes.string.isRequired,\n  isDragNDropEnabled: PropTypes.bool,\n  isVisible: PropTypes.bool.isRequired,\n  label: PropTypes.string.isRequired,\n  onToggleVisibility: PropTypes.func.isRequired,\n\n  // optional\n  className: PropTypes.string,\n  idx: PropTypes.number,\n  isConfigActive: PropTypes.bool,\n  labelRCGColorValues: PropTypes.array,\n  onUpdateLayerLabel: PropTypes.func,\n  onRemoveLayer: PropTypes.func\n};\n\nconst defaultProps = {\n  isDragNDropEnabled: true,\n  showRemoveLayer: true\n};\n\nconst StyledLayerPanelHeader = StyledPanelHeader.extend`\n  .layer__remove-layer {\n    opacity: 0;\n  }\n  :hover {\n    cursor: pointer;\n    background-color: ${props => props.theme.panelBackgroundHover};\n    \n    .layer__drag-handle {\n      opacity: 1;\n    }\n    \n    .layer__remove-layer {\n      opacity: 1;  \n    }\n    \n    .layer__enable-config {\n      color: white\n    }\n  }\n`;\n\nconst HeaderLabelSection = styled.div`\n  display: flex;\n  color: ${props => props.theme.textColor};\n`;\n\nconst HeaderActionSection = styled.div`\n  display: flex;\n`;\n\nconst LayerTitleSection = styled.div`\n  margin-left: 12px;\n\n  .layer__title__type {\n    color: ${props => props.theme.subtextColor};\n    font-size: 10px;\n    line-height: 12px;\n    letter-spacing: 0.37px;\n    text-transform: capitalize;\n  }\n`;\n\nconst DragHandle = styled.div`\n  display: flex;\n  align-items: center;\n  opacity: 0;\n  \n  :hover {\n    cursor: move;\n    color: ${props => props.theme.textColorHl};\n  }\n`;\n\nconst LayerPanelHeader = ({\n  className,\n  idx,\n  isConfigActive,\n  isDragNDropEnabled,\n  isVisible,\n  label,\n  layerId,\n  layerType,\n  labelRCGColorValues,\n  onToggleVisibility,\n  onUpdateLayerLabel,\n  onToggleEnableConfig,\n  onRemoveLayer,\n  showRemoveLayer\n}) => (\n  <StyledLayerPanelHeader\n    className={classnames('layer-panel__header', {\n      'sort--handle': !isConfigActive\n    })}\n    active={isConfigActive}\n    labelRCGColorValues={labelRCGColorValues}\n    onClick={onToggleEnableConfig}\n  >\n    <HeaderLabelSection className=\"layer-panel__header__content\">\n      {isDragNDropEnabled && (\n        <DragHandle className=\"layer__drag-handle\">\n          <VertDots height=\"20px\" />\n        </DragHandle>\n      )}\n      <PanelHeaderAction\n        className=\"layer__visibility-toggle\"\n        id={layerId}\n        tooltip={isVisible ? 'hide layer' : 'show layer'}\n        onClick={onToggleVisibility}\n        IconComponent={isVisible ? EyeSeen : EyeUnseen}\n        active={isVisible}\n        flush\n      />\n      <LayerTitleSection className=\"layer__title\">\n        <div>\n          <LayerLabelEditor label={label} onEdit={onUpdateLayerLabel} />\n          <div className=\"layer__title__type\">{layerType}</div>\n        </div>\n      </LayerTitleSection>\n    </HeaderLabelSection>\n    <HeaderActionSection className=\"layer-panel__header__actions\">\n      {showRemoveLayer ? (\n        <PanelHeaderAction\n          className=\"layer__remove-layer\"\n          id={layerId}\n          tooltip={'Remove layer'}\n          onClick={onRemoveLayer}\n          tooltipType=\"error\"\n          IconComponent={Trash}\n        />\n      ) : null}\n      <PanelHeaderAction\n        className=\"layer__enable-config\"\n        id={layerId}\n        tooltip={'Layer settings'}\n        onClick={onToggleEnableConfig}\n        IconComponent={ArrowDown}\n      />\n    </HeaderActionSection>\n  </StyledLayerPanelHeader>\n);\n\nconst LayerLabelEditor = ({label, onEdit}) => (\n  <InlineInput\n    type=\"text\"\n    className=\"layer__title__editor\"\n    value={label}\n    onClick={e => {\n      e.stopPropagation();\n    }}\n    onChange={onEdit}\n    id=\"input-layer-label\"\n  />\n);\n\nLayerPanelHeader.propTypes = propTypes;\nLayerPanelHeader.defaultProps = defaultProps;\n\nexport default LayerPanelHeader;\n"]}