kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
187 lines (150 loc) • 24.5 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
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 _propTypes = _interopRequireDefault(require("prop-types"));
var _reactAnythingSortable = _interopRequireDefault(require("react-anything-sortable"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reselect = require("reselect");
var _widgetPanel = _interopRequireDefault(require("./widget-panel/widget-panel"));
var _sourceDataCatalog = _interopRequireDefault(require("./common/source-data-catalog"));
var _icons = require("../common/icons");
var _styledComponents2 = require("../common/styled-components");
var _templateObject;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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; } }
var StyledSortable = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .ui-sortable {\n display: block;\n position: relative;\n overflow: visible;\n user-select: none;\n\n :before {\n content: ' ';\n display: table;\n }\n\n :after {\n content: ' ';\n display: table;\n }\n }\n\n .ui-sortable-item.ui-sortable-dragging {\n position: absolute;\n z-index: 1688;\n cursor: move;\n }\n\n .ui-sortable-item.ui-sortable-dragging:hover {\n cursor: move;\n opacity: 0.5;\n }\n\n .ui-sortable-placeholder {\n display: none;\n }\n\n .ui-sortable-placeholder.visible {\n display: block;\n opacity: 0;\n z-index: -1;\n }\n"])));
WidgetManagerFactory.deps = [_widgetPanel["default"], _sourceDataCatalog["default"]];
function WidgetManagerFactory(WidgetPanel, SourceDataCatalog) {
var _class, _temp;
return _temp = _class = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(WidgetManager, _Component);
var _super = _createSuper(WidgetManager);
function WidgetManager() {
var _this;
(0, _classCallCheck2["default"])(this, WidgetManager);
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), "widgetClassSelector", function (props) {
return props.widgetClasses;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "widgetTypeOptionsSelector", (0, _reselect.createSelector)(_this.widgetClassSelector, function (widgetClasses) {
return Object.keys(widgetClasses).map(function (key) {
var widget = new widgetClasses[key]();
return {
id: key,
label: widget.name,
icon: widget.widgetIcon
};
});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_addEmptyNewWidget", function () {
_this.props.addWidget();
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleSort", function (order) {
_this.props.updateWidgetOrder(order);
});
return _this;
}
(0, _createClass2["default"])(WidgetManager, [{
key: "render",
value: function render() {
var _this$props = this.props,
widgets = _this$props.widgets,
layers = _this$props.layers,
datasets = _this$props.datasets,
widgetOrder = _this$props.widgetOrder,
openModal = _this$props.openModal,
mapState = _this$props.mapState,
filters = _this$props.filters,
auth = _this$props.auth,
project = _this$props.project;
var hadDataset = Object.keys(datasets).length;
var hadEmptyWidget = widgets.some(function (w) {
return !w.name;
});
var widgetTypeOptions = this.widgetTypeOptionsSelector(this.props);
var widgetActions = {
widgetConfigChange: this.props.widgetConfigChange,
widgetVisualChannelConfigChange: this.props.widgetVisualChannelConfigChange,
widgetTypeChange: this.props.widgetTypeChange,
widgetVisConfigChange: this.props.widgetVisConfigChange,
removeWidget: this.props.removeWidget
};
var panelProps = {
datasets: datasets,
openModal: openModal,
widgetTypeOptions: widgetTypeOptions
};
return (/*#__PURE__*/_react["default"].createElement(StyledSortable, {
className: "widget-manager"
}, /*#__PURE__*/_react["default"].createElement(SourceDataCatalog, {
datasets: datasets,
showDatasetTable: this.props.showDatasetTable
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelDivider, null), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_reactAnythingSortable["default"], {
onSort: this._handleSort,
direction: "vertical",
sortHandle: "sort--handle",
dynamic: true
}, widgetOrder.map(function (idx) {
return (/*#__PURE__*/_react["default"].createElement(WidgetPanel, (0, _extends2["default"])({}, panelProps, widgetActions, {
sortData: idx,
key: widgets[idx].id,
idx: idx,
widget: widgets[idx],
layers: layers,
filters: filters,
mapState: mapState,
auth: auth,
project: project
}))
);
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
inactive: hadEmptyWidget || !hadDataset,
onClick: this._addEmptyNewWidget,
width: "auto"
}, /*#__PURE__*/_react["default"].createElement(_icons.Add, {
height: "12px"
}), "Add Widget")))
);
}
}]);
return WidgetManager;
}(_react.Component), (0, _defineProperty2["default"])(_class, "propTypes", {
addWidget: _propTypes["default"].func.isRequired,
datasets: _propTypes["default"].object.isRequired,
widgetClasses: _propTypes["default"].object.isRequired,
widgets: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
widgetConfigChange: _propTypes["default"].func.isRequired,
widgetVisualChannelConfigChange: _propTypes["default"].func.isRequired,
widgetTypeChange: _propTypes["default"].func.isRequired,
widgetVisConfigChange: _propTypes["default"].func.isRequired,
// layers: propTypes.arrayOf(propTypes.any),
openModal: _propTypes["default"].func.isRequired,
removeWidget: _propTypes["default"].func.isRequired,
showDatasetTable: _propTypes["default"].func.isRequired,
updateWidgetOrder: _propTypes["default"].func.isRequired,
mapState: _propTypes["default"].object.isRequired,
auth: _propTypes["default"].object.isRequired,
project: _propTypes["default"].object.isRequired
}), _temp;
}
var _default = exports["default"] = WidgetManagerFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/widget-manager.js"],"names":["StyledSortable","styled","div","WidgetManagerFactory","deps","WidgetPanelFactory","SourceDataCatalogFactory","WidgetPanel","SourceDataCatalog","props","widgetClasses","widgetClassSelector","Object","keys","map","key","widget","id","label","name","icon","widgetIcon","addWidget","order","updateWidgetOrder","widgets","layers","datasets","widgetOrder","openModal","mapState","filters","auth","project","hadDataset","length","hadEmptyWidget","some","w","widgetTypeOptions","widgetTypeOptionsSelector","widgetActions","widgetConfigChange","widgetVisualChannelConfigChange","widgetTypeChange","widgetVisConfigChange","removeWidget","panelProps","showDatasetTable","_handleSort","idx","_addEmptyNewWidget","Component","PropTypes","func","isRequired","object","arrayOf","any"],"mappings":"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","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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport Sortable from 'react-anything-sortable';\nimport styled from 'styled-components';\nimport {createSelector} from 'reselect';\n\nimport WidgetPanelFactory from './widget-panel/widget-panel';\nimport SourceDataCatalogFactory from './common/source-data-catalog';\nimport {Add} from 'components/common/icons';\nimport {\n  SidePanelDivider,\n  SidePanelSection,\n  Button\n} from 'components/common/styled-components';\n\nconst StyledSortable = styled.div`\n  .ui-sortable {\n    display: block;\n    position: relative;\n    overflow: visible;\n    user-select: none;\n\n    :before {\n      content: ' ';\n      display: table;\n    }\n\n    :after {\n      content: ' ';\n      display: table;\n    }\n  }\n\n  .ui-sortable-item.ui-sortable-dragging {\n    position: absolute;\n    z-index: 1688;\n    cursor: move;\n  }\n\n  .ui-sortable-item.ui-sortable-dragging:hover {\n    cursor: move;\n    opacity: 0.5;\n  }\n\n  .ui-sortable-placeholder {\n    display: none;\n  }\n\n  .ui-sortable-placeholder.visible {\n    display: block;\n    opacity: 0;\n    z-index: -1;\n  }\n`;\n\nWidgetManagerFactory.deps = [WidgetPanelFactory, SourceDataCatalogFactory];\n\nfunction WidgetManagerFactory(WidgetPanel, SourceDataCatalog) {\n  return class WidgetManager extends Component {\n    static propTypes = {\n      addWidget: PropTypes.func.isRequired,\n      datasets: PropTypes.object.isRequired,\n      widgetClasses: PropTypes.object.isRequired,\n      widgets: PropTypes.arrayOf(PropTypes.any).isRequired,\n      widgetConfigChange: PropTypes.func.isRequired,\n      widgetVisualChannelConfigChange: PropTypes.func.isRequired,\n      widgetTypeChange: PropTypes.func.isRequired,\n      widgetVisConfigChange: PropTypes.func.isRequired,\n      // layers: propTypes.arrayOf(propTypes.any),\n      openModal: PropTypes.func.isRequired,\n      removeWidget: PropTypes.func.isRequired,\n      showDatasetTable: PropTypes.func.isRequired,\n      updateWidgetOrder: PropTypes.func.isRequired,\n      mapState: PropTypes.object.isRequired,\n      auth: PropTypes.object.isRequired,\n      project: PropTypes.object.isRequired\n    };\n\n    widgetClassSelector = props => props.widgetClasses;\n    widgetTypeOptionsSelector = createSelector(\n      this.widgetClassSelector,\n      widgetClasses =>\n        Object.keys(widgetClasses).map(key => {\n          const widget = new widgetClasses[key]();\n          return {\n            id: key,\n            label: widget.name,\n            icon: widget.widgetIcon\n          };\n        })\n    );\n\n    _addEmptyNewWidget = () => {\n      this.props.addWidget();\n    };\n\n    _handleSort = order => {\n      this.props.updateWidgetOrder(order);\n    };\n\n    render() {\n      const {\n        widgets,\n        layers,\n        datasets,\n        widgetOrder,\n        openModal,\n        mapState,\n        filters,\n        auth,\n        project\n      } = this.props;\n      const hadDataset = Object.keys(datasets).length;\n      const hadEmptyWidget = widgets.some(w => !w.name);\n      const widgetTypeOptions = this.widgetTypeOptionsSelector(this.props);\n\n      const widgetActions = {\n        widgetConfigChange: this.props.widgetConfigChange,\n        widgetVisualChannelConfigChange: this.props\n          .widgetVisualChannelConfigChange,\n        widgetTypeChange: this.props.widgetTypeChange,\n        widgetVisConfigChange: this.props.widgetVisConfigChange,\n        removeWidget: this.props.removeWidget\n      };\n\n      const panelProps = {datasets, openModal, widgetTypeOptions};\n      return (\n        <StyledSortable className=\"widget-manager\">\n          <SourceDataCatalog\n            datasets={datasets}\n            showDatasetTable={this.props.showDatasetTable}\n          />\n          <SidePanelDivider />\n          <SidePanelSection>\n            <Sortable\n              onSort={this._handleSort}\n              direction=\"vertical\"\n              sortHandle=\"sort--handle\"\n              dynamic\n            >\n              {widgetOrder.map(idx => (\n                <WidgetPanel\n                  {...panelProps}\n                  {...widgetActions}\n                  sortData={idx}\n                  key={widgets[idx].id}\n                  idx={idx}\n                  widget={widgets[idx]}\n                  layers={layers}\n                  filters={filters}\n                  mapState={mapState}\n                  auth={auth}\n                  project={project}\n                />\n              ))}\n            </Sortable>\n          </SidePanelSection>\n          <SidePanelSection>\n            <Button\n              inactive={hadEmptyWidget || !hadDataset}\n              onClick={this._addEmptyNewWidget}\n              width=\"auto\"\n            >\n              <Add height=\"12px\" />\n              Add Widget\n            </Button>\n          </SidePanelSection>\n        </StyledSortable>\n      );\n    }\n  };\n}\n\nexport default WidgetManagerFactory;\n"]}