kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
147 lines (127 loc) • 19.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _panelHeaderAction = _interopRequireDefault(require("../panel-header-action"));
var _icons = require("../../common/icons");
var _styledComponents2 = require("../../common/styled-components");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
var propTypes = {
// required
id: _propTypes["default"].string.isRequired,
isDragNDropEnabled: _propTypes["default"].bool,
isVisible: _propTypes["default"].bool.isRequired,
label: _propTypes["default"].string.isRequired,
onToggleVisibility: _propTypes["default"].func.isRequired,
// optional
className: _propTypes["default"].string,
idx: _propTypes["default"].number,
isConfigActive: _propTypes["default"].bool,
labelRCGColorValues: _propTypes["default"].arrayOf(_propTypes["default"].number),
onUpdateWidgetLabel: _propTypes["default"].func,
onRemoveLayer: _propTypes["default"].func
};
var defaultProps = {
isDragNDropEnabled: true,
showRemoveLayer: true
};
var StyledWidgetPanelHeader = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["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: #494c52;\n }\n }\n"])), function (props) {
return props.theme.panelBackgroundHover;
});
var HeaderLabelSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n"])), function (props) {
return props.theme.textColor;
});
var HeaderActionSection = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"])));
var WidgetTitleSection = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["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"])), function (props) {
return props.theme.subtextColor;
});
var DragHandle = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n opacity: 0;\n\n :hover {\n cursor: move;\n color: ", ";\n }\n"])), function (props) {
return props.theme.textColorHl;
});
var WidgetPanelHeader = function WidgetPanelHeader(_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,
onUpdateWidgetLabel = _ref.onUpdateWidgetLabel,
onToggleEnableConfig = _ref.onToggleEnableConfig,
onRemoveWidget = _ref.onRemoveWidget,
showRemoveLayer = _ref.showRemoveLayer;
return (/*#__PURE__*/_react["default"].createElement(StyledWidgetPanelHeader, {
className: (0, _classnames["default"])('layer-panel__header', {
'sort--handle': !isConfigActive
}),
active: isConfigActive,
labelRCGColorValues: labelRCGColorValues,
onClick: onToggleEnableConfig
}, /*#__PURE__*/_react["default"].createElement(HeaderLabelSection, {
className: "layer-panel__header__content"
}, isDragNDropEnabled && /*#__PURE__*/_react["default"].createElement(DragHandle, {
className: "layer__drag-handle"
}, /*#__PURE__*/_react["default"].createElement(_icons.VertDots, {
height: "20px"
})), /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["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
}), /*#__PURE__*/_react["default"].createElement(WidgetTitleSection, {
className: "layer__title"
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(WidgetLabelEditor, {
label: label,
onEdit: onUpdateWidgetLabel
}), /*#__PURE__*/_react["default"].createElement("div", {
className: "layer__title__type"
}, layerType)))), /*#__PURE__*/_react["default"].createElement(HeaderActionSection, {
className: "layer-panel__header__actions"
}, showRemoveLayer ? /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["default"], {
className: "layer__remove-layer",
id: layerId,
tooltip: 'Remove widget',
onClick: onRemoveWidget,
tooltipType: "error",
IconComponent: _icons.Trash
}) : null, /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["default"], {
className: "layer__enable-config",
id: layerId,
tooltip: 'Layer settings',
onClick: onToggleEnableConfig,
IconComponent: _icons.ArrowDown
})))
);
};
var WidgetLabelEditor = function WidgetLabelEditor(_ref2) {
var label = _ref2.label,
onEdit = _ref2.onEdit;
return (/*#__PURE__*/_react["default"].createElement(_styledComponents2.InlineInput, {
type: "text",
className: "layer__title__editor",
value: label,
onClick: function onClick(e) {
e.stopPropagation();
},
onChange: onEdit,
id: "input-layer-label"
})
);
};
WidgetPanelHeader.propTypes = propTypes;
WidgetPanelHeader.defaultProps = defaultProps;
var _default = exports["default"] = WidgetPanelHeader;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/widget-panel/widget-panel-header.js"],"names":["propTypes","id","PropTypes","string","isRequired","isDragNDropEnabled","bool","isVisible","label","onToggleVisibility","func","className","idx","number","isConfigActive","labelRCGColorValues","arrayOf","onUpdateWidgetLabel","onRemoveLayer","defaultProps","showRemoveLayer","StyledWidgetPanelHeader","StyledPanelHeader","props","theme","panelBackgroundHover","HeaderLabelSection","styled","div","textColor","HeaderActionSection","WidgetTitleSection","subtextColor","DragHandle","textColorHl","WidgetPanelHeader","layerId","layerType","onToggleEnableConfig","onRemoveWidget","EyeSeen","EyeUnseen","Trash","ArrowDown","WidgetLabelEditor","onEdit","e","stopPropagation"],"mappings":";;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAQA;;;;AAKA,IAAMA,SAAS,GAAG;AAChB;AACAC,EAAAA,EAAE,EAAEC,sBAAUC,MAAV,CAAiBC,UAFL;AAGhBC,EAAAA,kBAAkB,EAAEH,sBAAUI,IAHd;AAIhBC,EAAAA,SAAS,EAAEL,sBAAUI,IAAV,CAAeF,UAJV;AAKhBI,EAAAA,KAAK,EAAEN,sBAAUC,MAAV,CAAiBC,UALR;AAMhBK,EAAAA,kBAAkB,EAAEP,sBAAUQ,IAAV,CAAeN,UANnB;AAQhB;AACAO,EAAAA,SAAS,EAAET,sBAAUC,MATL;AAUhBS,EAAAA,GAAG,EAAEV,sBAAUW,MAVC;AAWhBC,EAAAA,cAAc,EAAEZ,sBAAUI,IAXV;AAYhBS,EAAAA,mBAAmB,EAAEb,sBAAUc,OAAV,CAAkBd,sBAAUW,MAA5B,CAZL;AAahBI,EAAAA,mBAAmB,EAAEf,sBAAUQ,IAbf;AAchBQ,EAAAA,aAAa,EAAEhB,sBAAUQ;AAdT,CAAlB;AAiBA,IAAMS,YAAY,GAAG;AACnBd,EAAAA,kBAAkB,EAAE,IADD;AAEnBe,EAAAA,eAAe,EAAE;AAFE,CAArB;AAKA,IAAMC,uBAAuB,GAAG,kCAAOC,oCAAP,CAAH,yXAML,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,oBAAhB;AAAA,CANA,CAA7B;;AAsBA,IAAMC,kBAAkB,GAAGC,6BAAOC,GAAV,6HAEb,UAAAL,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYK,SAAhB;AAAA,CAFQ,CAAxB;;AAKA,IAAMC,mBAAmB,GAAGH,6BAAOC,GAAV,4GAAzB;;AAIA,IAAMG,kBAAkB,GAAGJ,6BAAOC,GAAV,+QAIX,UAAAL,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYQ,YAAhB;AAAA,CAJM,CAAxB;;AAYA,IAAMC,UAAU,GAAGN,6BAAOC,GAAV,4MAOH,UAAAL,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYU,WAAhB;AAAA,CAPF,CAAhB;;AAWA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB;AAAA,MACxBxB,SADwB,QACxBA,SADwB;AAAA,MAExBC,GAFwB,QAExBA,GAFwB;AAAA,MAGxBE,cAHwB,QAGxBA,cAHwB;AAAA,MAIxBT,kBAJwB,QAIxBA,kBAJwB;AAAA,MAKxBE,SALwB,QAKxBA,SALwB;AAAA,MAMxBC,KANwB,QAMxBA,KANwB;AAAA,MAOxB4B,OAPwB,QAOxBA,OAPwB;AAAA,MAQxBC,SARwB,QAQxBA,SARwB;AAAA,MASxBtB,mBATwB,QASxBA,mBATwB;AAAA,MAUxBN,kBAVwB,QAUxBA,kBAVwB;AAAA,MAWxBQ,mBAXwB,QAWxBA,mBAXwB;AAAA,MAYxBqB,oBAZwB,QAYxBA,oBAZwB;AAAA,MAaxBC,cAbwB,QAaxBA,cAbwB;AAAA,MAcxBnB,eAdwB,QAcxBA,eAdwB;AAAA,uBAgBxB,gCAAC,uBAAD;AACE,MAAA,SAAS,EAAE,4BAAW,qBAAX,EAAkC;AAC3C,wBAAgB,CAACN;AAD0B,OAAlC,CADb;AAIE,MAAA,MAAM,EAAEA,cAJV;AAKE,MAAA,mBAAmB,EAAEC,mBALvB;AAME,MAAA,OAAO,EAAEuB;AANX,oBAQE,gCAAC,kBAAD;AAAoB,MAAA,SAAS,EAAC;AAA9B,OACGjC,kBAAkB,iBACjB,gCAAC,UAAD;AAAY,MAAA,SAAS,EAAC;AAAtB,oBACE,gCAAC,eAAD;AAAU,MAAA,MAAM,EAAC;AAAjB,MADF,CAFJ,eAME,gCAAC,6BAAD;AACE,MAAA,SAAS,EAAC,0BADZ;AAEE,MAAA,EAAE,EAAE+B,OAFN;AAGE,MAAA,OAAO,EAAE7B,SAAS,GAAG,YAAH,GAAkB,YAHtC;AAIE,MAAA,OAAO,EAAEE,kBAJX;AAKE,MAAA,aAAa,EAAEF,SAAS,GAAGiC,cAAH,GAAaC,gBALvC;AAME,MAAA,MAAM,EAAElC,SANV;AAOE,MAAA,KAAK;AAPP,MANF,eAeE,gCAAC,kBAAD;AAAoB,MAAA,SAAS,EAAC;AAA9B,oBACE,0DACE,gCAAC,iBAAD;AAAmB,MAAA,KAAK,EAAEC,KAA1B;AAAiC,MAAA,MAAM,EAAES;AAAzC,MADF,eAEE;AAAK,MAAA,SAAS,EAAC;AAAf,OAAqCoB,SAArC,CAFF,CADF,CAfF,CARF,eA8BE,gCAAC,mBAAD;AAAqB,MAAA,SAAS,EAAC;AAA/B,OACGjB,eAAe,gBACd,gCAAC,6BAAD;AACE,MAAA,SAAS,EAAC,qBADZ;AAEE,MAAA,EAAE,EAAEgB,OAFN;AAGE,MAAA,OAAO,EAAE,eAHX;AAIE,MAAA,OAAO,EAAEG,cAJX;AAKE,MAAA,WAAW,EAAC,OALd;AAME,MAAA,aAAa,EAAEG;AANjB,MADc,GASZ,IAVN,eAWE,gCAAC,6BAAD;AACE,MAAA,SAAS,EAAC,sBADZ;AAEE,MAAA,EAAE,EAAEN,OAFN;AAGE,MAAA,OAAO,EAAE,gBAHX;AAIE,MAAA,OAAO,EAAEE,oBAJX;AAKE,MAAA,aAAa,EAAEK;AALjB,MAXF,CA9BF;AAhBwB;AAAA,CAA1B;;AAoEA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB;AAAA,MAAEpC,KAAF,SAAEA,KAAF;AAAA,MAASqC,MAAT,SAASA,MAAT;AAAA,uBACxB,gCAAC,8BAAD;AACE,MAAA,IAAI,EAAC,MADP;AAEE,MAAA,SAAS,EAAC,sBAFZ;AAGE,MAAA,KAAK,EAAErC,KAHT;AAIE,MAAA,OAAO,EAAE,iBAAAsC,CAAC,EAAI;AACZA,QAAAA,CAAC,CAACC,eAAF;AACD,OANH;AAOE,MAAA,QAAQ,EAAEF,MAPZ;AAQE,MAAA,EAAE,EAAC;AARL;AADwB;AAAA,CAA1B;;AAaAV,iBAAiB,CAACnC,SAAlB,GAA8BA,SAA9B;AACAmC,iBAAiB,CAAChB,YAAlB,GAAiCA,YAAjC;;oCAEegB,iB","sourcesContent":["// Copyright (c) 2023 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 {\n  InlineInput,\n  StyledPanelHeader\n} 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.arrayOf(PropTypes.number),\n  onUpdateWidgetLabel: PropTypes.func,\n  onRemoveLayer: PropTypes.func\n};\n\nconst defaultProps = {\n  isDragNDropEnabled: true,\n  showRemoveLayer: true\n};\n\nconst StyledWidgetPanelHeader = styled(StyledPanelHeader)`\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: #494c52;\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 WidgetTitleSection = 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 WidgetPanelHeader = ({\n  className,\n  idx,\n  isConfigActive,\n  isDragNDropEnabled,\n  isVisible,\n  label,\n  layerId,\n  layerType,\n  labelRCGColorValues,\n  onToggleVisibility,\n  onUpdateWidgetLabel,\n  onToggleEnableConfig,\n  onRemoveWidget,\n  showRemoveLayer\n}) => (\n  <StyledWidgetPanelHeader\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      <WidgetTitleSection className=\"layer__title\">\n        <div>\n          <WidgetLabelEditor label={label} onEdit={onUpdateWidgetLabel} />\n          <div className=\"layer__title__type\">{layerType}</div>\n        </div>\n      </WidgetTitleSection>\n    </HeaderLabelSection>\n    <HeaderActionSection className=\"layer-panel__header__actions\">\n      {showRemoveLayer ? (\n        <PanelHeaderAction\n          className=\"layer__remove-layer\"\n          id={layerId}\n          tooltip={'Remove widget'}\n          onClick={onRemoveWidget}\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  </StyledWidgetPanelHeader>\n);\n\nconst WidgetLabelEditor = ({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\nWidgetPanelHeader.propTypes = propTypes;\nWidgetPanelHeader.defaultProps = defaultProps;\n\nexport default WidgetPanelHeader;\n"]}