kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
258 lines (202 loc) • 25.6 kB
JavaScript
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.DatasetTabs = exports.DatasetModalTab = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _datasetLabel = _interopRequireDefault(require("../common/dataset-label"));
var _dataTable = _interopRequireDefault(require("../common/data-table"));
var _reselect = require("reselect");
var _cellSize = require("../common/data-table/cell-size");
var _canvas = _interopRequireDefault(require("../common/data-table/canvas"));
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _templateObject4() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n flex-grow: 1;\n min-height: 70vh;\n max-height: 70vh;\n"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n align-items: center;\n border-bottom: 3px solid ", ";\n cursor: pointer;\n display: flex;\n height: 35px;\n margin: 0 3px;\n padding: 0 5px;\n\n :first-child {\n margin-left: 0;\n padding-left: 0;\n }\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: ", " ", " 0;\n"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 70vh;\n overflow: hidden;\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var dgSettings = {
sidePadding: '38px',
verticalPadding: '16px',
height: '36px'
};
var StyledModal = _styledComponents["default"].div(_templateObject());
var DatasetCatalog = _styledComponents["default"].div(_templateObject2(), dgSettings.verticalPadding, dgSettings.sidePadding);
var DatasetModalTab = _styledComponents["default"].div(_templateObject3(), function (props) {
return props.active ? 'black' : 'transparent';
});
exports.DatasetModalTab = DatasetModalTab;
var DatasetTabs = _react["default"].memo(function (_ref) {
var activeDataset = _ref.activeDataset,
datasets = _ref.datasets,
showDatasetTable = _ref.showDatasetTable;
return _react["default"].createElement(DatasetCatalog, {
className: "dataset-modal-catalog"
}, Object.values(datasets).map(function (dataset) {
return _react["default"].createElement(DatasetModalTab, {
className: "dataset-modal-tab",
active: dataset === activeDataset,
key: dataset.id,
onClick: function onClick() {
return showDatasetTable(dataset.id);
}
}, _react["default"].createElement(_datasetLabel["default"], {
dataset: dataset
}));
}));
});
exports.DatasetTabs = DatasetTabs;
DatasetTabs.displayName = 'DatasetTabs';
DataTableModalFactory.deps = [_dataTable["default"]];
var TableContainer = _styledComponents["default"].div(_templateObject4());
function DataTableModalFactory(DataTable) {
var DataTableModal =
/*#__PURE__*/
function (_React$Component) {
(0, _inherits2["default"])(DataTableModal, _React$Component);
function DataTableModal() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2["default"])(this, DataTableModal);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(DataTableModal)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "datasetCellSizeCache", {});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "dataId", function (props) {
return props.dataId;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "datasets", function (props) {
return props.datasets;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "fields", function (props) {
return (props.datasets[props.dataId] || {}).fields;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "columns", (0, _reselect.createSelector)(_this.fields, function (fields) {
return fields.map(function (f) {
return f.name;
});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "colMeta", (0, _reselect.createSelector)(_this.fields, function (fields) {
return fields.reduce(function (acc, _ref2) {
var name = _ref2.name,
type = _ref2.type;
return _objectSpread({}, acc, (0, _defineProperty2["default"])({}, name, type));
}, {});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "cellSizeCache", (0, _reselect.createSelector)(_this.dataId, _this.datasets, function (dataId, datasets) {
if (!_this.props.datasets[dataId]) {
return {};
}
var _this$props$datasets$ = _this.props.datasets[dataId],
fields = _this$props$datasets$.fields,
allData = _this$props$datasets$.allData;
var showCalculate = null;
if (!_this.datasetCellSizeCache[dataId]) {
showCalculate = true;
} else if (_this.datasetCellSizeCache[dataId].fields !== fields || _this.datasetCellSizeCache[dataId].allData !== allData) {
showCalculate = true;
}
if (!showCalculate) {
return _this.datasetCellSizeCache[dataId].cellSizeCache;
}
var cellSizeCache = fields.reduce(function (acc, field, colIdx) {
return _objectSpread({}, acc, (0, _defineProperty2["default"])({}, field.name, (0, _cellSize.renderedSize)({
text: {
rows: allData,
column: field.name
},
colIdx: colIdx,
type: field.type,
fontSize: _this.props.theme.cellFontSize,
font: _this.props.theme.fontFamily
})));
}, {}); // save it to cache
_this.datasetCellSizeCache[dataId] = {
cellSizeCache: cellSizeCache,
fields: fields,
allData: allData
};
return cellSizeCache;
}));
return _this;
}
(0, _createClass2["default"])(DataTableModal, [{
key: "render",
value: function render() {
var _this$props = this.props,
datasets = _this$props.datasets,
dataId = _this$props.dataId,
showDatasetTable = _this$props.showDatasetTable;
if (!datasets || !dataId) {
return null;
}
var activeDataset = datasets[dataId];
var columns = this.columns(this.props);
var colMeta = this.colMeta(this.props);
var cellSizeCache = this.cellSizeCache(this.props);
return _react["default"].createElement(StyledModal, {
className: "dataset-modal",
id: "dataset-modal"
}, _react["default"].createElement(_canvas["default"], null), _react["default"].createElement(TableContainer, null, _react["default"].createElement(DatasetTabs, {
activeDataset: activeDataset,
datasets: datasets,
showDatasetTable: showDatasetTable
}), datasets[dataId] ? _react["default"].createElement(DataTable, {
key: dataId,
dataId: dataId,
columns: columns,
colMeta: colMeta,
cellSizeCache: cellSizeCache,
rows: activeDataset.allData,
pinnedColumns: activeDataset.pinnedColumns,
sortOrder: activeDataset.sortOrder,
sortColumn: activeDataset.sortColumn,
copyTableColumn: this.props.copyTableColumn,
pinTableColumn: this.props.pinTableColumn,
sortTableColumn: this.props.sortTableColumn
}) : null));
}
}]);
return DataTableModal;
}(_react["default"].Component);
return (0, _styledComponents.withTheme)(DataTableModal);
}
var _default = DataTableModalFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/data-table-modal.js"],"names":["dgSettings","sidePadding","verticalPadding","height","StyledModal","styled","div","DatasetCatalog","DatasetModalTab","props","active","DatasetTabs","React","memo","activeDataset","datasets","showDatasetTable","Object","values","map","dataset","id","displayName","DataTableModalFactory","deps","DataTableFactory","TableContainer","DataTable","DataTableModal","dataId","fields","f","name","reduce","acc","type","allData","showCalculate","datasetCellSizeCache","cellSizeCache","field","colIdx","text","rows","column","fontSize","theme","cellFontSize","font","fontFamily","columns","colMeta","pinnedColumns","sortOrder","sortColumn","copyTableColumn","pinTableColumn","sortTableColumn","Component"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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 styled, {withTheme} from 'styled-components';\nimport DatasetLabel from 'components/common/dataset-label';\nimport DataTableFactory from 'components/common/data-table';\nimport {createSelector} from 'reselect';\nimport {renderedSize} from 'components/common/data-table/cell-size';\nimport CanvasHack from 'components/common/data-table/canvas';\n\nconst dgSettings = {\n  sidePadding: '38px',\n  verticalPadding: '16px',\n  height: '36px'\n};\n\nconst StyledModal = styled.div`\n  min-height: 70vh;\n  overflow: hidden;\n`;\n\nconst DatasetCatalog = styled.div`\n  display: flex;\n  padding: ${dgSettings.verticalPadding} ${dgSettings.sidePadding} 0;\n`;\n\nexport const DatasetModalTab = styled.div`\n  align-items: center;\n  border-bottom: 3px solid ${props => (props.active ? 'black' : 'transparent')};\n  cursor: pointer;\n  display: flex;\n  height: 35px;\n  margin: 0 3px;\n  padding: 0 5px;\n\n  :first-child {\n    margin-left: 0;\n    padding-left: 0;\n  }\n`;\n\nexport const DatasetTabs = React.memo(({activeDataset, datasets, showDatasetTable}) => (\n  <DatasetCatalog className=\"dataset-modal-catalog\">\n    {Object.values(datasets).map(dataset => (\n      <DatasetModalTab\n        className=\"dataset-modal-tab\"\n        active={dataset === activeDataset}\n        key={dataset.id}\n        onClick={() => showDatasetTable(dataset.id)}\n      >\n        <DatasetLabel dataset={dataset} />\n      </DatasetModalTab>\n    ))}\n  </DatasetCatalog>\n));\n\nDatasetTabs.displayName = 'DatasetTabs';\n\nDataTableModalFactory.deps = [DataTableFactory];\n\nconst TableContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  min-height: 70vh;\n  max-height: 70vh;\n`;\n\nfunction DataTableModalFactory(DataTable) {\n  class DataTableModal extends React.Component {\n    datasetCellSizeCache = {};\n    dataId = props => props.dataId;\n    datasets = props => props.datasets;\n    fields = props => (props.datasets[props.dataId] || {}).fields;\n    columns = createSelector(this.fields, fields => fields.map(f => f.name));\n    colMeta = createSelector(this.fields, fields =>\n      fields.reduce(\n        (acc, {name, type}) => ({\n          ...acc,\n          [name]: type\n        }),\n        {}\n      )\n    );\n    cellSizeCache = createSelector(this.dataId, this.datasets, (dataId, datasets) => {\n      if (!this.props.datasets[dataId]) {\n        return {};\n      }\n      const {fields, allData} = this.props.datasets[dataId];\n\n      let showCalculate = null;\n      if (!this.datasetCellSizeCache[dataId]) {\n        showCalculate = true;\n      } else if (\n        this.datasetCellSizeCache[dataId].fields !== fields ||\n        this.datasetCellSizeCache[dataId].allData !== allData\n      ) {\n        showCalculate = true;\n      }\n\n      if (!showCalculate) {\n        return this.datasetCellSizeCache[dataId].cellSizeCache;\n      }\n\n      const cellSizeCache = fields.reduce(\n        (acc, field, colIdx) => ({\n          ...acc,\n          [field.name]: renderedSize({\n            text: {\n              rows: allData,\n              column: field.name\n            },\n            colIdx,\n            type: field.type,\n            fontSize: this.props.theme.cellFontSize,\n            font: this.props.theme.fontFamily\n          })\n        }),\n        {}\n      );\n      // save it to cache\n      this.datasetCellSizeCache[dataId] = {\n        cellSizeCache,\n        fields,\n        allData\n      };\n      return cellSizeCache;\n    });\n\n    render() {\n      const {datasets, dataId, showDatasetTable} = this.props;\n      if (!datasets || !dataId) {\n        return null;\n      }\n\n      const activeDataset = datasets[dataId];\n      const columns = this.columns(this.props);\n      const colMeta = this.colMeta(this.props);\n      const cellSizeCache = this.cellSizeCache(this.props);\n\n      return (\n        <StyledModal className=\"dataset-modal\" id=\"dataset-modal\">\n          <CanvasHack />\n          <TableContainer>\n            <DatasetTabs\n              activeDataset={activeDataset}\n              datasets={datasets}\n              showDatasetTable={showDatasetTable}\n            />\n            {datasets[dataId] ? (\n              <DataTable\n                key={dataId}\n                dataId={dataId}\n                columns={columns}\n                colMeta={colMeta}\n                cellSizeCache={cellSizeCache}\n                rows={activeDataset.allData}\n                pinnedColumns={activeDataset.pinnedColumns}\n                sortOrder={activeDataset.sortOrder}\n                sortColumn={activeDataset.sortColumn}\n                copyTableColumn={this.props.copyTableColumn}\n                pinTableColumn={this.props.pinTableColumn}\n                sortTableColumn={this.props.sortTableColumn}\n              />\n            ) : null}\n          </TableContainer>\n        </StyledModal>\n      );\n    }\n  }\n\n  return withTheme(DataTableModal);\n}\n\nexport default DataTableModalFactory;\n"]}
;