UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

159 lines (155 loc) 19.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.TableToolComponent = TableToolComponent; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _reactRedux = require("react-redux"); var _react = _interopRequireWildcard(require("react")); var _duckdb = require("@openassistant/duckdb"); var _actions = require("@kepler.gl/actions"); var _processors = require("@kepler.gl/processors"); 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; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project // This component will create a new table using the SQL query which will // 1. add a new column // 2. delete a column // 3. rename a column // 4. change the variable type of a column function TableToolComponent(_ref) { var sql = _ref.sql, dbTableName = _ref.dbTableName, newDatasetName = _ref.queryDatasetName; var datasets = (0, _reactRedux.useSelector)(function (state) { return state.demo.keplerGl.map.visState.datasets; }); var queryInProgress = (0, _react.useRef)(null); var dispatch = (0, _reactRedux.useDispatch)(); var _useState = (0, _react.useState)(null), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), error = _useState2[0], setError = _useState2[1]; (0, _react.useEffect)(function () { // check if the newDatasetName is already in the datasets var newDatasetId = Object.keys(datasets).find(function (dataId) { return datasets[dataId].label === newDatasetName; }); // if the newDatasetName is already in the datasets, return if (newDatasetId) return; var addTable = /*#__PURE__*/function () { var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() { return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: if (!queryInProgress.current) { _context2.next = 3; break; } _context2.next = 3; return queryInProgress.current; case 3: // Create a new promise for this query queryInProgress.current = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() { var duckDB, conn, arrowResult, jsonResult, processedData; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: _context.prev = 0; _context.next = 3; return (0, _duckdb.getDuckDB)(); case 3: duckDB = _context.sent; if (duckDB) { _context.next = 6; break; } throw new Error('DuckDB instance is not initialized'); case 6: if (!(dbTableName && sql)) { _context.next = 22; break; } _context.next = 9; return duckDB.connect(); case 9: conn = _context.sent; _context.next = 12; return conn.query(sql); case 12: arrowResult = _context.sent; // convert arrowResult to a JSON object jsonResult = arrowResult.toArray().map(function (row) { return (0, _duckdb.convertArrowRowToObject)(row); }); // use processFileData to process the rowObject _context.next = 16; return (0, _processors.processFileData)({ content: { fileName: newDatasetName, data: jsonResult }, fileCache: [] }); case 16: processedData = _context.sent; // add the new dataset to the map dispatch((0, _actions.addDataToMap)({ datasets: processedData, options: { autoCreateLayers: true, centerMap: true } })); // delete the table from the database _context.next = 20; return conn.query("DROP TABLE ".concat(dbTableName)); case 20: _context.next = 22; return conn.close(); case 22: _context.next = 28; break; case 24: _context.prev = 24; _context.t0 = _context["catch"](0); console.error(_context.t0); setError(_context.t0 instanceof Error ? _context.t0.message : 'Unknown error occurred'); case 28: _context.prev = 28; queryInProgress.current = null; return _context.finish(28); case 31: case "end": return _context.stop(); } }, _callee, null, [[0, 24, 28, 31]]); }))(); // Wait for the query to complete _context2.next = 6; return queryInProgress.current; case 6: case "end": return _context2.stop(); } }, _callee2); })); return function addTable() { return _ref2.apply(this, arguments); }; }(); addTable(); // eslint-disable-next-line react-hooks/exhaustive-deps }, []); return error ? /*#__PURE__*/_react["default"].createElement("div", { style: { color: 'red', fontSize: '8px' } }, error) : null; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactRedux","require","_react","_interopRequireWildcard","_duckdb","_actions","_processors","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TableToolComponent","_ref","sql","dbTableName","newDatasetName","queryDatasetName","datasets","useSelector","state","demo","keplerGl","map","visState","queryInProgress","useRef","dispatch","useDispatch","_useState","useState","_useState2","_slicedToArray2","error","setError","useEffect","newDatasetId","keys","find","dataId","label","addTable","_ref2","_asyncToGenerator2","_regenerator","mark","_callee2","wrap","_callee2$","_context2","prev","next","current","_callee","duckDB","conn","arrowResult","jsonResult","processedData","_callee$","_context","getDuckDB","sent","Error","connect","query","toArray","row","convertArrowRowToObject","processFileData","content","fileName","data","fileCache","addDataToMap","options","autoCreateLayers","centerMap","concat","close","t0","console","message","finish","stop","apply","arguments","createElement","style","color","fontSize"],"sources":["../../../src/tools/kepler-tools/table-tool.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {useSelector} from 'react-redux';\nimport React, {useEffect, useRef, useState} from 'react';\nimport {useDispatch} from 'react-redux';\nimport {getDuckDB, LocalQueryAdditionalData, convertArrowRowToObject} from '@openassistant/duckdb';\n\nimport {State} from '../../components/ai-assistant-manager';\nimport {addDataToMap} from '@kepler.gl/actions';\nimport {processFileData} from '@kepler.gl/processors';\n\n// This component will create a new table using the SQL query which will\n// 1. add a new column\n// 2. delete a column\n// 3. rename a column\n// 4. change the variable type of a column\nexport function TableToolComponent({\n  sql,\n  dbTableName,\n  queryDatasetName: newDatasetName\n}: LocalQueryAdditionalData) {\n  const datasets = useSelector((state: State) => state.demo.keplerGl.map.visState.datasets);\n  const queryInProgress = useRef<Promise<void> | null>(null);\n  const dispatch = useDispatch();\n\n  const [error, setError] = useState<string | null>(null);\n\n  useEffect(() => {\n    // check if the newDatasetName is already in the datasets\n    const newDatasetId = Object.keys(datasets).find(\n      dataId => datasets[dataId].label === newDatasetName\n    );\n    // if the newDatasetName is already in the datasets, return\n    if (newDatasetId) return;\n\n    const addTable = async () => {\n      // If a query is already in progress, wait for it to complete\n      if (queryInProgress.current) {\n        await queryInProgress.current;\n      }\n\n      // Create a new promise for this query\n      queryInProgress.current = (async () => {\n        try {\n          const duckDB = await getDuckDB();\n          if (!duckDB) {\n            throw new Error('DuckDB instance is not initialized');\n          }\n          if (dbTableName && sql) {\n            // connect to the database\n            const conn = await duckDB.connect();\n\n            // Execute the provided SQL query\n            const arrowResult = await conn.query(sql);\n\n            // convert arrowResult to a JSON object\n            const jsonResult = arrowResult.toArray().map(row => convertArrowRowToObject(row));\n\n            // use processFileData to process the rowObject\n            const processedData = await processFileData({\n              content: {fileName: newDatasetName, data: jsonResult},\n              fileCache: []\n            });\n\n            // add the new dataset to the map\n            dispatch(\n              addDataToMap({\n                datasets: processedData,\n                options: {autoCreateLayers: true, centerMap: true}\n              })\n            );\n\n            // delete the table from the database\n            await conn.query(`DROP TABLE ${dbTableName}`);\n\n            // close the connection\n            await conn.close();\n          }\n        } catch (error) {\n          console.error(error);\n          setError(error instanceof Error ? error.message : 'Unknown error occurred');\n        } finally {\n          queryInProgress.current = null;\n        }\n      })();\n\n      // Wait for the query to complete\n      await queryInProgress.current;\n    };\n\n    addTable();\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  return error ? <div style={{color: 'red', fontSize: '8px'}}>{error}</div> : null;\n}\n"],"mappings":"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","ignoreList":[]}