kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
128 lines (126 loc) • 23.4 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PreviewDataPanel = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = require("styled-components");
var _components = require("@kepler.gl/components");
var _processors = require("@kepler.gl/processors");
var _utils = require("@kepler.gl/utils");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var DEFAULT_ROWS_TO_CALCULATE_PREVIEW = 100;
// min Cellsize should take into account option button and field token
var minCellSize = 80;
// option buttons and field token
var optionButtonWidth = 20;
var pinButton = 20;
var cellPadding = 20;
var PreviewDataPanelWOTheme = function PreviewDataPanelWOTheme(_ref) {
var result = _ref.result,
_ref$rowsToCalculateP = _ref.rowsToCalculatePreview,
rowsToCalculatePreview = _ref$rowsToCalculateP === void 0 ? DEFAULT_ROWS_TO_CALCULATE_PREVIEW : _ref$rowsToCalculateP,
_ref$defaultPinnedCol = _ref.defaultPinnedColumns,
defaultPinnedColumns = _ref$defaultPinnedCol === void 0 ? [] : _ref$defaultPinnedCol,
theme = _ref.theme;
var _useState = (0, _react.useState)(defaultPinnedColumns),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
pinnedColumns = _useState2[0],
setPinnedColumns = _useState2[1];
var fields = (0, _react.useMemo)(function () {
return (0, _processors.arrowSchemaToFields)(result.table, result.tableDuckDBTypes);
}, [result]);
var dataContainer = (0, _react.useMemo)(function () {
var cols = (0, _toConsumableArray2["default"])(Array(result.table.numCols).keys()).map(function (i) {
return result.table.getChildAt(i);
});
var dataContainer = (0, _utils.createDataContainer)(cols, {
fields: fields,
inputDataFormat: _utils.DataForm.COLS_ARRAY
});
return dataContainer;
}, [result, fields]);
var columns = (0, _react.useMemo)(function () {
return fields.map(function (f) {
return f.name;
});
}, [fields]);
var colMeta = (0, _react.useMemo)(function () {
return fields.reduce(function (acc, _ref2, colIdx) {
var name = _ref2.name,
displayName = _ref2.displayName,
type = _ref2.type,
displayFormat = _ref2.displayFormat;
return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, name, {
// because '' || 'aaa' = 'aaa'
name: displayName !== undefined ? displayName : name,
displayName: displayName,
displayFormat: displayFormat,
type: type,
colIdx: colIdx
}));
}, {});
}, [fields]);
var copyTableColumn = (0, _react.useCallback)(function (column) {
var _navigator;
var _colMeta$column = colMeta[column],
colIdx = _colMeta$column.colIdx,
type = _colMeta$column.type;
var text = dataContainer.mapIndex(function (row) {
return (0, _utils.parseFieldValue)(dataContainer.valueAt(row.index, colIdx), type);
}).join('\n');
(_navigator = navigator) === null || _navigator === void 0 || _navigator.clipboard.writeText(text);
}, [colMeta, dataContainer]);
var pinTableColumn = (0, _react.useCallback)(function (column) {
return pinnedColumns.includes(column) ? setPinnedColumns(pinnedColumns.filter(function (c) {
return c !== column;
})) : setPinnedColumns([].concat((0, _toConsumableArray2["default"])(pinnedColumns), [column]));
}, [pinnedColumns]);
// TODO Potentially costly operation for non row based data containers. Revisit sorting below.
var dataTableStyle = (0, _react.useMemo)(function () {
return {
minCellSize: minCellSize,
cellPadding: cellPadding,
optionsButton: theme.fieldTokenWidth + theme.fieldTokenRightMargin + optionButtonWidth + pinButton,
fontSize: theme.cellFontSize,
font: theme.fontFamily
};
}, [theme]);
var cellSizeCache = (0, _react.useMemo)(function () {
return columns.reduce(function (acc, column) {
var _colMeta$column2 = colMeta[column],
colIdx = _colMeta$column2.colIdx,
displayName = _colMeta$column2.displayName,
type = _colMeta$column2.type;
return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, column, (0, _components.renderedSize)(_objectSpread({
text: {
dataContainer: dataContainer,
column: displayName
},
colIdx: colIdx,
type: type,
numRowsToCalculate: rowsToCalculatePreview
}, dataTableStyle))));
}, {});
}, [columns, colMeta, dataContainer, rowsToCalculatePreview, dataTableStyle]);
return /*#__PURE__*/_react["default"].createElement(_components.DataTable, {
colMeta: colMeta,
columns: columns,
cellSizeCache: cellSizeCache,
dataContainer: dataContainer,
pinnedColumns: pinnedColumns,
copyTableColumn: copyTableColumn,
pinTableColumn: pinTableColumn
});
};
var PreviewDataPanel = exports.PreviewDataPanel = (0, _styledComponents.withTheme)(PreviewDataPanelWOTheme);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_components","_processors","_utils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","DEFAULT_ROWS_TO_CALCULATE_PREVIEW","minCellSize","optionButtonWidth","pinButton","cellPadding","PreviewDataPanelWOTheme","_ref","result","_ref$rowsToCalculateP","rowsToCalculatePreview","_ref$defaultPinnedCol","defaultPinnedColumns","theme","_useState","useState","_useState2","_slicedToArray2","pinnedColumns","setPinnedColumns","fields","useMemo","arrowSchemaToFields","table","tableDuckDBTypes","dataContainer","cols","_toConsumableArray2","Array","numCols","map","getChildAt","createDataContainer","inputDataFormat","DataForm","COLS_ARRAY","columns","f","name","colMeta","reduce","acc","_ref2","colIdx","displayName","type","displayFormat","undefined","copyTableColumn","useCallback","column","_navigator","_colMeta$column","text","mapIndex","row","parseFieldValue","valueAt","index","join","navigator","clipboard","writeText","pinTableColumn","includes","c","concat","dataTableStyle","optionsButton","fieldTokenWidth","fieldTokenRightMargin","fontSize","cellFontSize","font","fontFamily","cellSizeCache","_colMeta$column2","renderedSize","numRowsToCalculate","createElement","DataTable","PreviewDataPanel","exports","withTheme"],"sources":["../../src/components/preview-data-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport * as arrow from 'apache-arrow';\nimport React, {useCallback, useMemo, useState, CSSProperties} from 'react';\nimport {withTheme} from 'styled-components';\n\nimport {DataTable, renderedSize} from '@kepler.gl/components';\nimport {arrowSchemaToFields} from '@kepler.gl/processors';\nimport {parseFieldValue, createDataContainer, DataForm} from '@kepler.gl/utils';\n\ntype BaseComponentProps = {\n  className?: string;\n  style?: CSSProperties;\n};\n\nconst DEFAULT_ROWS_TO_CALCULATE_PREVIEW = 100;\n// min Cellsize should take into account option button and field token\nconst minCellSize = 80;\n// option buttons and field token\nconst optionButtonWidth = 20;\nconst pinButton = 20;\nconst cellPadding = 20;\n\nexport type ColMeta = {\n  [key: string]: {\n    colIdx: number;\n    name: string;\n    displayName: string;\n    type: string;\n  };\n};\n\nexport type DataTableStyle = {\n  minCellSize?: number;\n  cellPadding?: number;\n  fontSize?: number;\n  font?: string;\n  optionsButton?: number;\n};\n\nexport type QueryResult = {\n  table: arrow.Table;\n  tableDuckDBTypes: Record<string, string>;\n};\n\nexport type PreviewDataPanelProps = BaseComponentProps & {\n  result: QueryResult;\n  rowsToCalculatePreview?: number;\n  theme?: any;\n  setColumnDisplayFormat?: (formats: {[key: string]: string}) => void;\n  defaultPinnedColumns?: string[];\n  dataTableStyle: DataTableStyle;\n  onAddResultToMap: (result: QueryResult) => void;\n};\n\nconst PreviewDataPanelWOTheme: React.FC<PreviewDataPanelProps> = ({\n  result,\n  rowsToCalculatePreview = DEFAULT_ROWS_TO_CALCULATE_PREVIEW,\n  defaultPinnedColumns = [],\n  theme\n}) => {\n  const [pinnedColumns, setPinnedColumns] = useState<string[]>(defaultPinnedColumns);\n  const fields = useMemo(\n    () => arrowSchemaToFields(result.table, result.tableDuckDBTypes),\n    [result]\n  );\n  const dataContainer = useMemo(() => {\n    const cols = [...Array(result.table.numCols).keys()].map(i => result.table.getChildAt(i));\n\n    const dataContainer = createDataContainer(cols, {\n      fields,\n      inputDataFormat: DataForm.COLS_ARRAY\n    });\n    return dataContainer;\n  }, [result, fields]);\n\n  const columns = useMemo(() => fields.map(f => f.name), [fields]);\n  const colMeta = useMemo(\n    () =>\n      fields.reduce(\n        (acc, {name, displayName, type, displayFormat}, colIdx) => ({\n          ...acc,\n          [name]: {\n            // because '' || 'aaa' = 'aaa'\n            name: displayName !== undefined ? displayName : name,\n            displayName,\n            displayFormat,\n            type,\n            colIdx\n          }\n        }),\n        {}\n      ),\n    [fields]\n  );\n  const copyTableColumn = useCallback(\n    column => {\n      const {colIdx, type} = colMeta[column];\n      const text = dataContainer\n        .mapIndex(row => parseFieldValue(dataContainer.valueAt(row.index, colIdx), type))\n        .join('\\n');\n      navigator?.clipboard.writeText(text);\n    },\n    [colMeta, dataContainer]\n  );\n  const pinTableColumn = useCallback(\n    column =>\n      pinnedColumns.includes(column)\n        ? setPinnedColumns(pinnedColumns.filter(c => c !== column))\n        : setPinnedColumns([...pinnedColumns, column]),\n    [pinnedColumns]\n  );\n\n  // TODO Potentially costly operation for non row based data containers. Revisit sorting below.\n  const dataTableStyle = useMemo(\n    () => ({\n      minCellSize,\n      cellPadding,\n      optionsButton:\n        theme.fieldTokenWidth + theme.fieldTokenRightMargin + optionButtonWidth + pinButton,\n      fontSize: theme.cellFontSize,\n      font: theme.fontFamily\n    }),\n    [theme]\n  );\n  const cellSizeCache = useMemo(() => {\n    return columns.reduce((acc, column) => {\n      const {colIdx, displayName, type} = colMeta[column];\n      return {\n        ...acc,\n        [column]: renderedSize({\n          text: {\n            dataContainer,\n            column: displayName\n          },\n          colIdx,\n          type,\n          numRowsToCalculate: rowsToCalculatePreview,\n          ...dataTableStyle\n        })\n      };\n    }, {});\n  }, [columns, colMeta, dataContainer, rowsToCalculatePreview, dataTableStyle]);\n\n  return (\n    <DataTable\n      colMeta={colMeta}\n      columns={columns}\n      cellSizeCache={cellSizeCache}\n      dataContainer={dataContainer}\n      pinnedColumns={pinnedColumns}\n      copyTableColumn={copyTableColumn}\n      pinTableColumn={pinTableColumn}\n    />\n  );\n};\n\nexport const PreviewDataPanel = withTheme(\n  PreviewDataPanelWOTheme\n) as React.FC<PreviewDataPanelProps>;\n"],"mappings":"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","ignoreList":[]}
;