kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
243 lines (197 loc) • 30.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"] = exports.FieldHeaderFactory = exports.CellFactory = void 0;
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 _reactVirtualized = require("react-virtualized");
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _reselect = require("reselect");
var _classnames2 = _interopRequireDefault(require("classnames"));
var _fieldToken = _interopRequireDefault(require("./field-token"));
var _icons = require("./icons");
var _dataUtils = require("../../utils/data-utils");
var _constants = require("../../constants");
var _templateObject, _templateObject2, _templateObject3;
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 DataGridWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n overflow-x: auto;\n\n .ReactVirtualized__Grid:focus,\n .ReactVirtualized__Grid:active {\n outline: 0;\n }\n .ReactVirtualized__Grid__innerScrollContainer {\n ", ";\n }\n\n .ReactVirtualized__Grid {\n .column-0 .cell {\n padding-left: ", "px;\n }\n\n .header-0 .header-cell {\n padding-left: ", "px;\n }\n\n .cell {\n overflow-y: auto;\n overflow-x: hidden;\n padding-right: ", "px;\n }\n\n .last {\n .cell {\n padding-right: ", "px;\n }\n .header-cell {\n padding-right: ", "px;\n }\n }\n }\n"])), function (props) {
return props.theme.modalScrollBar;
}, function (props) {
return props.theme.gridPaddingSide;
}, function (props) {
return props.theme.gridPaddingSide;
}, function (props) {
return props.theme.cellPaddingSide;
}, function (props) {
return props.theme.gridPaddingSide;
}, function (props) {
return props.theme.gridPaddingSide;
});
var StyledFieldHeader = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: left;\n border-right: 0;\n border-bottom: 0;\n background: ", ";\n color: ", ";\n height: 100%;\n\n .header-content {\n display: flex;\n flex-direction: column;\n }\n\n .label-wrapper {\n display: flex;\n align-items: center;\n }\n\n .icon-wrapper {\n margin-right: ", ";\n height: 16px;\n }\n"])), function (props) {
return props.theme.panelBackgroundLT;
}, function (props) {
return props.theme.titleColorLT;
}, function (props) {
return props.type === 'timestamp' ? '2px' : '0';
});
var FieldHeaderFactory = exports.FieldHeaderFactory = function FieldHeaderFactory() {
var Header = function Header(_ref) {
var className = _ref.className,
value = _ref.value,
type = _ref.type;
return (/*#__PURE__*/_react["default"].createElement(StyledFieldHeader, {
className: className || '',
type: type,
title: value
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "field-header-content"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "label-wrapper"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "icon-wrapper"
}, type === 'timestamp' ? /*#__PURE__*/_react["default"].createElement(_icons.Clock, {
height: "16px"
}) : null), /*#__PURE__*/_react["default"].createElement("span", null, value)), /*#__PURE__*/_react["default"].createElement("div", {
className: "field-wrapper"
}, /*#__PURE__*/_react["default"].createElement(_fieldToken["default"], {
type: type
}))))
);
};
Header.displayName = 'Header';
return Header;
};
var StyledCell = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n border-right: 0;\n border-bottom: ", ";\n color: ", ";\n text-overflow: ellipsis;\n height: 100%;\n width: 100%;\n\n span {\n text-overflow: ellipsis;\n white-space: pre-wrap;\n word-wrap: break-word;\n width: 100%;\n }\n"])), function (props) {
return props.theme.panelBorderLT;
}, function (props) {
return props.theme.labelColorLT;
});
var CellFactory = exports.CellFactory = function CellFactory() {
var Cell = function Cell(_ref2) {
var className = _ref2.className,
value = _ref2.value;
return (/*#__PURE__*/_react["default"].createElement(StyledCell, {
className: className || '',
title: value
}, /*#__PURE__*/_react["default"].createElement("span", null, value))
);
};
Cell.displayName = 'Cell';
return Cell;
};
DataGridFactory.deps = [FieldHeaderFactory, CellFactory];
function DataGridFactory(FieldHeader, Cell) {
var DataGrid = /*#__PURE__*/function (_PureComponent) {
(0, _inherits2["default"])(DataGrid, _PureComponent);
var _super = _createSuper(DataGrid);
function DataGrid() {
var _this;
(0, _classCallCheck2["default"])(this, DataGrid);
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), "columnsSelector", function (props) {
return props.columns;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "hasGeojson", (0, _reselect.createSelector)(_this.columnsSelector, function (columns) {
return columns.some(function (c) {
return c.type === _constants.ALL_FIELD_TYPES.geojson;
});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_cellRenderer", function (_ref3) {
var _classnames;
var columnIndex = _ref3.columnIndex,
key = _ref3.key,
rowIndex = _ref3.rowIndex,
style = _ref3.style;
var _this$props = _this.props,
columns = _this$props.columns,
rows = _this$props.rows;
var isLast = columnIndex === columns.length - 1;
var type = columns[columnIndex].type; // rowIndex -1 because data rows start rendering at index 1 and we normalize back using the -1 param
var className = (0, _classnames2["default"])((_classnames = {
last: isLast
}, (0, _defineProperty2["default"])(_classnames, "header-".concat(columnIndex), rowIndex === 0), (0, _defineProperty2["default"])(_classnames, "row-".concat(rowIndex - 1, " column-").concat(columnIndex), rowIndex > 0), _classnames));
return (/*#__PURE__*/_react["default"].createElement("div", {
key: key,
style: style,
className: className
}, rowIndex === 0 ? /*#__PURE__*/_react["default"].createElement(FieldHeader, {
className: "header-cell ".concat(type),
value: columns[columnIndex].name,
type: type
}) : /*#__PURE__*/_react["default"].createElement(Cell, {
className: "cell ".concat(type),
value: (0, _dataUtils.parseFieldValue)(rows[rowIndex - 1][columnIndex], type),
type: type
}))
);
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_rowHeight", function (_ref4) {
var index = _ref4.index;
return index === 0 ? _this.props.theme.cellHeaderHeight : _this.hasGeojson(_this.props) ? _this.props.theme.extendCellHeight : _this.props.theme.cellHeight;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_columnWidth", function (_ref5) {
var index = _ref5.index;
var isGeojsonField = _this.props.columns[index].type === _constants.ALL_FIELD_TYPES.geojson;
return isGeojsonField ? _this.props.theme.extendColumnWidth : _this.props.theme.columnWidth;
});
return _this;
}
(0, _createClass2["default"])(DataGrid, [{
key: "render",
value: function render() {
var _this$props2 = this.props,
columns = _this$props2.columns,
height = _this$props2.height,
rows = _this$props2.rows,
theme = _this$props2.theme,
width = _this$props2.width;
return (/*#__PURE__*/_react["default"].createElement(DataGridWrapper, {
className: "datagrid-wrapper"
}, /*#__PURE__*/_react["default"].createElement(_reactVirtualized.MultiGrid, {
cellRenderer: this._cellRenderer,
columnWidth: this._columnWidth,
columnCount: columns.length,
fixedRowCount: 1,
enableFixedRowScroll: true,
width: width || theme.gridDefaultWidth,
height: height || theme.gridDefaultHeight,
rowHeight: this._rowHeight,
rowCount: rows.length + 1,
hideTopRightGridScrollbar: true,
hideBottomLeftGridScrollbar: true
}))
);
}
}]);
return DataGrid;
}(_react.PureComponent);
(0, _defineProperty2["default"])(DataGrid, "propTypes", {
theme: _propTypes["default"].object,
columns: _propTypes["default"].arrayOf(_propTypes["default"].object).isRequired,
height: _propTypes["default"].number.isRequired,
rows: _propTypes["default"].arrayOf(_propTypes["default"].arrayOf(_propTypes["default"].any)).isRequired,
width: _propTypes["default"].number.isRequired
});
DataGrid.displayName = 'DataGrid'; // Wrapping the component using withTheme because we need to
// access variables outside sytled-components context
return (0, _styledComponents.withTheme)(DataGrid);
}
var _default = exports["default"] = DataGridFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/datagrid.js"],"names":["DataGridWrapper","styled","div","props","theme","modalScrollBar","gridPaddingSide","cellPaddingSide","StyledFieldHeader","panelBackgroundLT","titleColorLT","type","FieldHeaderFactory","Header","className","value","displayName","StyledCell","panelBorderLT","labelColorLT","CellFactory","Cell","DataGridFactory","deps","FieldHeader","DataGrid","columns","columnsSelector","some","c","ALL_FIELD_TYPES","geojson","columnIndex","key","rowIndex","style","rows","isLast","length","last","name","index","cellHeaderHeight","hasGeojson","extendCellHeight","cellHeight","isGeojsonField","extendColumnWidth","columnWidth","height","width","_cellRenderer","_columnWidth","gridDefaultWidth","gridDefaultHeight","_rowHeight","PureComponent","PropTypes","object","arrayOf","isRequired","number","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, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {MultiGrid} from 'react-virtualized';\nimport styled, {withTheme}from 'styled-components';\nimport {createSelector} from 'reselect';\nimport classnames from 'classnames';\nimport FieldToken from 'components/common/field-token';\nimport {Clock} from 'components/common/icons/index';\nimport {parseFieldValue} from 'utils/data-utils';\nimport {ALL_FIELD_TYPES} from 'constants';\n\nconst DataGridWrapper = styled.div`\n  width: 100%;\n  overflow-x: auto;\n\n  .ReactVirtualized__Grid:focus,\n  .ReactVirtualized__Grid:active {\n    outline: 0;\n  }\n  .ReactVirtualized__Grid__innerScrollContainer {\n    ${props => props.theme.modalScrollBar};\n  }\n\n  .ReactVirtualized__Grid {\n    .column-0 .cell {\n      padding-left: ${props => props.theme.gridPaddingSide}px;\n    }\n\n    .header-0 .header-cell {\n      padding-left: ${props => props.theme.gridPaddingSide}px;\n    }\n\n    .cell {\n      overflow-y: auto;\n      overflow-x: hidden;\n      padding-right: ${props => props.theme.cellPaddingSide}px;\n    }\n\n    .last {\n      .cell {\n        padding-right: ${props => props.theme.gridPaddingSide}px;\n      }\n      .header-cell {\n        padding-right: ${props => props.theme.gridPaddingSide}px;\n      }\n    }\n  }\n`;\n\nconst StyledFieldHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: left;\n  border-right: 0;\n  border-bottom: 0;\n  background: ${props => props.theme.panelBackgroundLT};\n  color: ${props => props.theme.titleColorLT};\n  height: 100%;\n\n  .header-content {\n    display: flex;\n    flex-direction: column;\n  }\n\n  .label-wrapper {\n    display: flex;\n    align-items: center;\n  }\n\n  .icon-wrapper {\n    margin-right: ${props => props.type === 'timestamp' ? '2px' : '0'};\n    height: 16px;\n  }\n`;\n\nexport const FieldHeaderFactory = () => {\n  const Header = ({className, value, type}) => (\n    <StyledFieldHeader className={className || ''} type={type} title={value}>\n      <div className=\"field-header-content\">\n        <div className=\"label-wrapper\">\n          <div className=\"icon-wrapper\">\n            {type === 'timestamp' ? <Clock height=\"16px\" /> : null}\n          </div>\n          <span>{value}</span>\n        </div>\n        <div className=\"field-wrapper\">\n          <FieldToken type={type} />\n        </div>\n      </div>\n    </StyledFieldHeader>\n  );\n\n  Header.displayName = 'Header';\n\n  return Header;\n};\n\nconst StyledCell = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  border-right: 0;\n  border-bottom: ${props => props.theme.panelBorderLT};\n  color: ${props => props.theme.labelColorLT};\n  text-overflow: ellipsis;\n  height: 100%;\n  width: 100%;\n\n  span {\n    text-overflow: ellipsis;\n    white-space: pre-wrap;\n    word-wrap: break-word;\n    width: 100%;\n  }\n`;\n\nexport const CellFactory = () => {\n  const Cell = ({className, value}) => (\n    <StyledCell className={className || ''} title={value}>\n      <span>{value}</span>\n    </StyledCell>\n  );\n\n  Cell.displayName = 'Cell';\n\n  return Cell;\n};\n\nDataGridFactory.deps = [\n  FieldHeaderFactory,\n  CellFactory\n];\n\nfunction DataGridFactory(\n  FieldHeader,\n  Cell\n) {\n  class DataGrid extends PureComponent {\n    static propTypes = {\n      theme: PropTypes.object,\n      columns: PropTypes.arrayOf(PropTypes.object).isRequired,\n      height: PropTypes.number.isRequired,\n      rows: PropTypes.arrayOf(PropTypes.arrayOf(PropTypes.any)).isRequired,\n      width: PropTypes.number.isRequired\n    };\n\n    columnsSelector = props => props.columns;\n    hasGeojson = createSelector(this.columnsSelector, columns =>\n      columns.some(c => c.type === ALL_FIELD_TYPES.geojson)\n    );\n\n    _cellRenderer = ({columnIndex, key, rowIndex, style}) => {\n      const {columns, rows} = this.props;\n      const isLast = columnIndex === columns.length - 1\n      const type = columns[columnIndex].type;\n\n      // rowIndex -1 because data rows start rendering at index 1 and we normalize back using the -1 param\n      const className = classnames({\n        last: isLast,\n        [`header-${columnIndex}`]: rowIndex === 0,\n        [`row-${rowIndex-1} column-${columnIndex}`]: rowIndex > 0\n      });\n\n      return (\n        <div key={key} style={style} className={className}>\n          {rowIndex === 0\n            ? (<FieldHeader className={`header-cell ${type}`} value={columns[columnIndex].name} type={type} />)\n            : (<Cell className={`cell ${type}`} value={parseFieldValue(rows[rowIndex - 1][columnIndex], type)} type={type} />)\n          }\n        </div>\n      );\n    };\n\n    _rowHeight = ({index}) => index === 0\n      ? this.props.theme.cellHeaderHeight\n      : this.hasGeojson(this.props) ? this.props.theme.extendCellHeight : this.props.theme.cellHeight;\n\n    _columnWidth = ({index}) => {\n      const isGeojsonField = this.props.columns[index].type === ALL_FIELD_TYPES.geojson;\n      return isGeojsonField ? this.props.theme.extendColumnWidth : this.props.theme.columnWidth;\n    };\n\n    render() {\n      const {columns, height, rows, theme, width} = this.props;\n\n      return (\n        <DataGridWrapper className=\"datagrid-wrapper\">\n          <MultiGrid\n            cellRenderer={this._cellRenderer}\n            columnWidth={this._columnWidth}\n            columnCount={columns.length}\n            fixedRowCount={1}\n            enableFixedRowScroll={true}\n            width={width || theme.gridDefaultWidth}\n            height={height || theme.gridDefaultHeight}\n            rowHeight={this._rowHeight}\n            rowCount={rows.length + 1}\n            hideTopRightGridScrollbar={true}\n            hideBottomLeftGridScrollbar={true}\n          />\n        </DataGridWrapper>\n      );\n    }\n  }\n\n  DataGrid.displayName = 'DataGrid';\n\n  // Wrapping the component using withTheme because we need to\n  // access variables outside sytled-components context\n  return withTheme(DataGrid);\n}\n\nexport default DataGridFactory;\n"]}