kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
170 lines (135 loc) • 18.5 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = DatasetTitleFactory;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
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 _localization = require("../../../localization");
var _styledComponents2 = require("../../common/styled-components");
var _icons = require("../../common/icons");
var _datasetTag = _interopRequireDefault(require("./dataset-tag"));
var _templateObject, _templateObject2;
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
function nop(_) {}
var StyledDatasetTitle = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n display: flex;\n align-items: flex-start;\n\n .source-data-arrow {\n height: 16px;\n }\n :hover {\n cursor: ", ";\n\n .dataset-name {\n color: ", ";\n }\n\n .dataset-action {\n color: ", ";\n opacity: 1;\n }\n\n .dataset-action:hover {\n color: ", ";\n }\n }\n"])), function (props) {
return props.theme.textColor;
}, function (props) {
return props.clickable ? 'pointer' : 'auto';
}, function (props) {
return props.clickable ? props.theme.textColorHl : props.theme.textColor;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.textColorHl;
});
var DataTagAction = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n height: 16px;\n opacity: 0;\n"])));
var ShowDataTable = function ShowDataTable(_ref) {
var id = _ref.id,
_ref$showDatasetTable = _ref.showDatasetTable,
showDatasetTable = _ref$showDatasetTable === void 0 ? nop : _ref$showDatasetTable;
return /*#__PURE__*/_react["default"].createElement(DataTagAction, {
className: "dataset-action show-data-table",
"data-tip": true,
"data-for": "data-table-".concat(id)
}, /*#__PURE__*/_react["default"].createElement(_icons.Table, {
height: "16px",
onClick: function onClick(e) {
e.stopPropagation();
showDatasetTable(id);
}
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "data-table-".concat(id),
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'datasetTitle.showDataTable'
}))));
};
var RemoveDataset = function RemoveDataset(_ref2) {
var datasetKey = _ref2.datasetKey,
_ref2$removeDataset = _ref2.removeDataset,
removeDataset = _ref2$removeDataset === void 0 ? nop : _ref2$removeDataset;
return /*#__PURE__*/_react["default"].createElement(DataTagAction, {
className: "dataset-action remove-dataset",
"data-tip": true,
"data-for": "delete-".concat(datasetKey)
}, /*#__PURE__*/_react["default"].createElement(_icons.Trash, {
height: "16px",
onClick: function onClick(e) {
e.stopPropagation();
removeDataset(datasetKey);
}
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "delete-".concat(datasetKey),
effect: "solid",
type: "error"
}, /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'datasetTitle.removeDataset'
}))));
};
DatasetTitleFactory.deps = [_datasetTag["default"]];
function DatasetTitleFactory(DatasetTag) {
var DatasetTitle = /*#__PURE__*/function (_PureComponent) {
(0, _inherits2["default"])(DatasetTitle, _PureComponent);
var _super = _createSuper(DatasetTitle);
function DatasetTitle() {
var _this;
(0, _classCallCheck2["default"])(this, DatasetTitle);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onClickTitle", function (e) {
e.stopPropagation();
if (typeof _this.props.onTitleClick === 'function') {
_this.props.onTitleClick();
} else if (typeof _this.props.showDatasetTable === 'function') {
_this.props.showDatasetTable(_this.props.dataset.id);
}
});
return _this;
}
(0, _createClass2["default"])(DatasetTitle, [{
key: "render",
value: function render() {
var _this$props = this.props,
showDatasetTable = _this$props.showDatasetTable,
showDeleteDataset = _this$props.showDeleteDataset,
onTitleClick = _this$props.onTitleClick,
removeDataset = _this$props.removeDataset,
dataset = _this$props.dataset;
return /*#__PURE__*/_react["default"].createElement(StyledDatasetTitle, {
className: "source-data-title",
clickable: Boolean(showDatasetTable || onTitleClick)
}, /*#__PURE__*/_react["default"].createElement(DatasetTag, {
dataset: dataset,
onClick: this._onClickTitle
}), showDatasetTable ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, {
className: "source-data-arrow"
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, {
height: "12px"
})) : null, showDatasetTable ? /*#__PURE__*/_react["default"].createElement(ShowDataTable, {
id: dataset.id,
showDatasetTable: showDatasetTable
}) : null, showDeleteDataset ? /*#__PURE__*/_react["default"].createElement(RemoveDataset, {
datasetKey: dataset.id,
removeDataset: removeDataset
}) : null);
}
}]);
return DatasetTitle;
}(_react.PureComponent);
return DatasetTitle;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/common/dataset-title.js"],"names":["nop","_","StyledDatasetTitle","styled","div","props","theme","textColor","clickable","textColorHl","DataTagAction","ShowDataTable","id","showDatasetTable","e","stopPropagation","RemoveDataset","datasetKey","removeDataset","DatasetTitleFactory","deps","DatasetTagFactory","DatasetTag","DatasetTitle","onTitleClick","dataset","showDeleteDataset","Boolean","_onClickTitle","PureComponent"],"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, {PureComponent} from 'react';\nimport styled from 'styled-components';\nimport {FormattedMessage} from 'localization';\n\nimport {CenterFlexbox, Tooltip} from 'components/common/styled-components';\nimport {ArrowRight, Table, Trash} from 'components/common/icons';\nimport DatasetTagFactory from 'components/side-panel/common/dataset-tag';\n\nfunction nop(_) {}\n\nconst StyledDatasetTitle = styled.div`\n  color: ${props => props.theme.textColor};\n  display: flex;\n  align-items: flex-start;\n\n  .source-data-arrow {\n    height: 16px;\n  }\n  :hover {\n    cursor: ${props => (props.clickable ? 'pointer' : 'auto')};\n\n    .dataset-name {\n      color: ${props => (props.clickable ? props.theme.textColorHl : props.theme.textColor)};\n    }\n\n    .dataset-action {\n      color: ${props => props.theme.textColor};\n      opacity: 1;\n    }\n\n    .dataset-action:hover {\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst DataTagAction = styled.div`\n  margin-left: 12px;\n  height: 16px;\n  opacity: 0;\n`;\n\nconst ShowDataTable = ({id, showDatasetTable = nop}) => (\n  <DataTagAction className=\"dataset-action show-data-table\" data-tip data-for={`data-table-${id}`}>\n    <Table\n      height=\"16px\"\n      onClick={e => {\n        e.stopPropagation();\n        showDatasetTable(id);\n      }}\n    />\n    <Tooltip id={`data-table-${id}`} effect=\"solid\">\n      <span>\n        <FormattedMessage id={'datasetTitle.showDataTable'} />\n      </span>\n    </Tooltip>\n  </DataTagAction>\n);\n\nconst RemoveDataset = ({datasetKey, removeDataset = nop}) => (\n  <DataTagAction\n    className=\"dataset-action remove-dataset\"\n    data-tip\n    data-for={`delete-${datasetKey}`}\n  >\n    <Trash\n      height=\"16px\"\n      onClick={e => {\n        e.stopPropagation();\n        removeDataset(datasetKey);\n      }}\n    />\n    <Tooltip id={`delete-${datasetKey}`} effect=\"solid\" type=\"error\">\n      <span>\n        <FormattedMessage id={'datasetTitle.removeDataset'} />\n      </span>\n    </Tooltip>\n  </DataTagAction>\n);\n\nDatasetTitleFactory.deps = [DatasetTagFactory];\n\nexport default function DatasetTitleFactory(DatasetTag) {\n  class DatasetTitle extends PureComponent {\n    _onClickTitle = e => {\n      e.stopPropagation();\n      if (typeof this.props.onTitleClick === 'function') {\n        this.props.onTitleClick();\n      } else if (typeof this.props.showDatasetTable === 'function') {\n        this.props.showDatasetTable(this.props.dataset.id);\n      }\n    };\n\n    render() {\n      const {\n        showDatasetTable,\n        showDeleteDataset,\n        onTitleClick,\n        removeDataset,\n        dataset\n      } = this.props;\n\n      return (\n        <StyledDatasetTitle\n          className=\"source-data-title\"\n          clickable={Boolean(showDatasetTable || onTitleClick)}\n        >\n          <DatasetTag dataset={dataset} onClick={this._onClickTitle} />\n          {showDatasetTable ? (\n            <CenterFlexbox className=\"source-data-arrow\">\n              <ArrowRight height=\"12px\" />\n            </CenterFlexbox>\n          ) : null}\n          {showDatasetTable ? (\n            <ShowDataTable id={dataset.id} showDatasetTable={showDatasetTable} />\n          ) : null}\n          {showDeleteDataset ? (\n            <RemoveDataset datasetKey={dataset.id} removeDataset={removeDataset} />\n          ) : null}\n        </StyledDatasetTitle>\n      );\n    }\n  }\n\n  return DatasetTitle;\n}\n"]}