kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
167 lines (165 loc) • 27.5 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.SchemaPanelDropMessage = exports.SchemaPanel = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _reactRedux = require("react-redux");
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _components = require("@kepler.gl/components");
var _processors = require("@kepler.gl/processors");
var _tree = require("./tree");
var _init = require("../init");
var _duckdbTableUtils = require("../table/duckdb-table-utils");
var _templateObject, _templateObject2, _templateObject3, _templateObject4; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
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; }
// TODO note that demo state is available in demo-app, but not when add modules to dependencies in a custom map
var StyledSchemaPanel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-size: 12px;\n padding: 12px;\n font-family: ", ";\n height: 100%;\n"])), function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.fontFamily;
});
var StyledLoadingSpinnerWrapper = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: center;\n align-items: center;\n height: 100%;\n"])));
function getColumnSchema(_x, _x2) {
return _getColumnSchema.apply(this, arguments);
}
function _getColumnSchema() {
_getColumnSchema = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(connection, tableName) {
var columnResult, columnDescribe, keplerFields;
return _regenerator["default"].wrap(function _callee2$(_context2) {
while (1) switch (_context2.prev = _context2.next) {
case 0:
_context2.next = 2;
return connection.query("Select * from '".concat(tableName, "' LIMIT 1;"));
case 2:
columnResult = _context2.sent;
_context2.next = 5;
return (0, _duckdbTableUtils.getDuckDBColumnTypes)(connection, tableName);
case 5:
columnDescribe = _context2.sent;
keplerFields = (0, _processors.arrowSchemaToFields)(columnResult, (0, _duckdbTableUtils.getDuckDBColumnTypesMap)(columnDescribe));
return _context2.abrupt("return", {
key: tableName,
object: {
type: 'dataset',
tableName: tableName
},
children: columnResult.schema.fields.map(function (field, fieldIndex) {
return {
key: field.name,
object: {
type: 'column',
name: field.name,
arrowType: field.type,
fieldType: keplerFields[fieldIndex].type
}
};
})
});
case 8:
case "end":
return _context2.stop();
}
}, _callee2);
}));
return _getColumnSchema.apply(this, arguments);
}
function getSchemaSuggestion(result) {
return result.reduce(function (accu, data) {
var columns = data.children.map(function (child) {
return {
column_name: child.key,
table_name: data.key
};
});
return accu.concat(columns);
}, []);
}
var StyledSchemaPanelDropMessage = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: center;\n align-items: center;\n height: 100%;\n flex-direction: column;\n text-align: center;\n\n div {\n margin: 5px;\n }\n .header {\n font-size: 15px;\n }\n .bold {\n font-weight: 700;\n }\n"])));
var StyledAddIcon = (0, _styledComponents["default"])(_components.Icons.Add)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline;\n margin-top: -3px;\n"])));
var SchemaPanelDropMessage = exports.SchemaPanelDropMessage = function SchemaPanelDropMessage() {
return /*#__PURE__*/_react["default"].createElement(StyledSchemaPanelDropMessage, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "header"
}, /*#__PURE__*/_react["default"].createElement(StyledAddIcon, null), " Add files to DuckDB"), /*#__PURE__*/_react["default"].createElement("div", {
className: "bold"
}, "Supported formats: "), /*#__PURE__*/_react["default"].createElement("div", null, ".csv, .json, .geojson, .parquet, .arrow"), /*#__PURE__*/_react["default"].createElement("div", null, "Files you add will stay local to your browser."));
};
var SchemaPanel = exports.SchemaPanel = function SchemaPanel(_ref) {
var setTableSchema = _ref.setTableSchema,
droppedFile = _ref.droppedFile,
schemaUpdateTrigger = _ref.schemaUpdateTrigger;
var _useState = (0, _react.useState)([]),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
columnSchemas = _useState2[0],
setColumnSchemas = _useState2[1];
var datasets = (0, _reactRedux.useSelector)(function (state) {
var _state$demo;
return state === null || state === void 0 || (_state$demo = state.demo) === null || _state$demo === void 0 || (_state$demo = _state$demo.keplerGl) === null || _state$demo === void 0 || (_state$demo = _state$demo.map) === null || _state$demo === void 0 ? void 0 : _state$demo.visState.datasets;
});
var getTableSchema = (0, _react.useCallback)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
var _tableResult$getChild, _ref3;
var db, c, tableResult, tableNames, result, tableSchema;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
_context.next = 2;
return (0, _init.getDuckDB)();
case 2:
db = _context.sent;
_context.next = 5;
return db.connect();
case 5:
c = _context.sent;
_context.next = 8;
return c.query('SHOW TABLES;');
case 8:
tableResult = _context.sent;
tableNames = (_tableResult$getChild = tableResult.getChildAt(0)) === null || _tableResult$getChild === void 0 ? void 0 : _tableResult$getChild.toJSON();
_context.next = 12;
return Promise.all((_ref3 = tableNames || []) === null || _ref3 === void 0 ? void 0 : _ref3.map(function (name) {
return getColumnSchema(c, name);
}));
case 12:
result = _context.sent;
tableSchema = getSchemaSuggestion(result);
setColumnSchemas(result);
setTableSchema(tableSchema);
_context.next = 18;
return c.close();
case 18:
case "end":
return _context.stop();
}
}, _callee);
})), [setColumnSchemas, setTableSchema, schemaUpdateTrigger]);
(0, _react.useEffect)(function () {
getTableSchema();
}, [datasets, droppedFile, getTableSchema]);
return /*#__PURE__*/_react["default"].createElement(StyledSchemaPanel, null, columnSchemas !== null && columnSchemas !== void 0 && columnSchemas.length ? columnSchemas.map(function (data) {
return /*#__PURE__*/_react["default"].createElement(_tree.Tree, {
key: data.key,
treeData: data,
renderNode: function renderNode(node) {
if (node.object.type === 'dataset') {
return /*#__PURE__*/_react["default"].createElement(_tree.DatasetNode, {
node: node
});
} else if (node.object.type === 'column') {
return /*#__PURE__*/_react["default"].createElement(_tree.ColumnNode, {
node: node
});
}
return null;
}
});
}) : droppedFile ? /*#__PURE__*/_react["default"].createElement(StyledLoadingSpinnerWrapper, null, /*#__PURE__*/_react["default"].createElement(_components.LoadingSpinner, null)) : /*#__PURE__*/_react["default"].createElement(SchemaPanelDropMessage, null));
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_styledComponents","_interopRequireDefault","_components","_processors","_tree","_init","_duckdbTableUtils","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledSchemaPanel","styled","div","_taggedTemplateLiteral2","props","theme","textColor","fontFamily","StyledLoadingSpinnerWrapper","getColumnSchema","_x","_x2","_getColumnSchema","apply","arguments","_asyncToGenerator2","_regenerator","mark","_callee2","connection","tableName","columnResult","columnDescribe","keplerFields","wrap","_callee2$","_context2","prev","next","query","concat","sent","getDuckDBColumnTypes","arrowSchemaToFields","getDuckDBColumnTypesMap","abrupt","key","object","type","children","schema","fields","map","field","fieldIndex","name","arrowType","fieldType","stop","getSchemaSuggestion","result","reduce","accu","data","columns","child","column_name","table_name","StyledSchemaPanelDropMessage","StyledAddIcon","Icons","Add","SchemaPanelDropMessage","exports","createElement","className","SchemaPanel","_ref","setTableSchema","droppedFile","schemaUpdateTrigger","_useState","useState","_useState2","_slicedToArray2","columnSchemas","setColumnSchemas","datasets","useSelector","state","_state$demo","demo","keplerGl","visState","getTableSchema","useCallback","_callee","_tableResult$getChild","_ref3","db","c","tableResult","tableNames","tableSchema","_callee$","_context","getDuckDB","connect","getChildAt","toJSON","Promise","all","close","useEffect","length","Tree","treeData","renderNode","node","DatasetNode","ColumnNode","LoadingSpinner"],"sources":["../../src/components/schema-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useEffect, useState} from 'react';\nimport {useSelector} from 'react-redux';\nimport styled from 'styled-components';\nimport {AsyncDuckDBConnection} from '@duckdb/duckdb-wasm';\n\nimport {LoadingSpinner, Icons} from '@kepler.gl/components';\nimport {arrowSchemaToFields} from '@kepler.gl/processors';\nimport {VisState} from '@kepler.gl/schemas';\n\nimport {Tree, DatasetNode, ColumnNode, TreeNodeData} from './tree';\nimport {getDuckDB} from '../init';\nimport {getDuckDBColumnTypes, getDuckDBColumnTypesMap} from '../table/duckdb-table-utils';\n\n// TODO note that demo state is available in demo-app, but not when add modules to dependencies in a custom map\ntype State = {\n  demo?: {\n    keplerGl: {\n      map: {\n        visState: VisState;\n      };\n    };\n  };\n};\n\nconst StyledSchemaPanel = styled.div`\n  color: ${props => props.theme.textColor};\n  font-size: 12px;\n  padding: 12px;\n  font-family: ${props => props.theme.fontFamily};\n  height: 100%;\n`;\n\nconst StyledLoadingSpinnerWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  height: 100%;\n`;\n\nasync function getColumnSchema(connection: AsyncDuckDBConnection, tableName: string) {\n  const columnResult = await connection.query(`Select * from '${tableName}' LIMIT 1;`);\n\n  const columnDescribe = await getDuckDBColumnTypes(connection, tableName);\n  const keplerFields = arrowSchemaToFields(columnResult, getDuckDBColumnTypesMap(columnDescribe));\n\n  return {\n    key: tableName,\n    object: {\n      type: 'dataset',\n      tableName: tableName\n    },\n    children: columnResult.schema.fields.map((field, fieldIndex) => {\n      return {\n        key: field.name,\n        object: {\n          type: 'column',\n          name: field.name,\n          arrowType: field.type,\n          fieldType: keplerFields[fieldIndex].type\n        }\n      };\n    })\n  };\n}\n\nexport type SchemaSuggestion = {column_name: string; table_name: string};\n\nfunction getSchemaSuggestion(result: {key: string; children: {key: string}[]}[]) {\n  return result.reduce((accu, data) => {\n    const columns = data.children.map(child => ({\n      column_name: child.key,\n      table_name: data.key\n    }));\n    return accu.concat(columns);\n  }, [] as SchemaSuggestion[]);\n}\n\ntype SchemaPanelProps = {\n  setTableSchema: (tableSchema: SchemaSuggestion[]) => void;\n  droppedFile: File | null;\n  schemaUpdateTrigger: number;\n};\n\nconst StyledSchemaPanelDropMessage = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  height: 100%;\n  flex-direction: column;\n  text-align: center;\n\n  div {\n    margin: 5px;\n  }\n  .header {\n    font-size: 15px;\n  }\n  .bold {\n    font-weight: 700;\n  }\n`;\n\nconst StyledAddIcon = styled(Icons.Add)`\n  display: inline;\n  margin-top: -3px;\n`;\n\nexport const SchemaPanelDropMessage = () => {\n  return (\n    <StyledSchemaPanelDropMessage>\n      <div className=\"header\">\n        <StyledAddIcon /> Add files to DuckDB\n      </div>\n      <div className=\"bold\">Supported formats: </div>\n      <div>.csv, .json, .geojson, .parquet, .arrow</div>\n      <div>Files you add will stay local to your browser.</div>\n    </StyledSchemaPanelDropMessage>\n  );\n};\n\nexport const SchemaPanel = ({\n  setTableSchema,\n  droppedFile,\n  schemaUpdateTrigger\n}: SchemaPanelProps) => {\n  const [columnSchemas, setColumnSchemas] = useState<TreeNodeData<{type: string}>[]>([]);\n  const datasets = useSelector((state: State) => state?.demo?.keplerGl?.map?.visState.datasets);\n\n  const getTableSchema = useCallback(async () => {\n    const db = await getDuckDB();\n    const c = await db.connect();\n\n    const tableResult = await c.query('SHOW TABLES;');\n\n    const tableNames: string[] | undefined = tableResult.getChildAt(0)?.toJSON();\n\n    const result = await Promise.all((tableNames || [])?.map(name => getColumnSchema(c, name)));\n    const tableSchema = getSchemaSuggestion(result);\n\n    setColumnSchemas(result);\n    setTableSchema(tableSchema);\n    await c.close();\n\n    // schemaUpdateTrigger indicates possible change in DuckDB\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [setColumnSchemas, setTableSchema, schemaUpdateTrigger]);\n\n  useEffect(() => {\n    getTableSchema();\n  }, [datasets, droppedFile, getTableSchema]);\n\n  return (\n    <StyledSchemaPanel>\n      {columnSchemas?.length ? (\n        columnSchemas.map(data => (\n          <Tree\n            key={data.key}\n            treeData={data}\n            renderNode={node => {\n              if (node.object.type === 'dataset') {\n                return <DatasetNode node={node} />;\n              } else if (node.object.type === 'column') {\n                return <ColumnNode node={node} />;\n              }\n              return null;\n            }}\n          />\n        ))\n      ) : droppedFile ? (\n        <StyledLoadingSpinnerWrapper>\n          <LoadingSpinner />\n        </StyledLoadingSpinnerWrapper>\n      ) : (\n        <SchemaPanelDropMessage />\n      )}\n    </StyledSchemaPanel>\n  );\n};\n"],"mappings":"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","ignoreList":[]}
;