UNPKG

kepler.gl

Version:

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

253 lines (247 loc) 37.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getQueryTool = getQueryTool; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _react = _interopRequireWildcard(require("react")); var _reactRedux = require("react-redux"); var _actions = require("@kepler.gl/actions"); var _duckdb = require("@openassistant/duckdb"); var _utils = require("./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 _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return 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 function getQueryTool(datasets, layers) { // context for query tools var getValues = /*#__PURE__*/function () { var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(datasetName, variableName) { var values; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: values = (0, _utils.getValuesFromDataset)(datasets, layers, datasetName, variableName); return _context.abrupt("return", values); case 2: case "end": return _context.stop(); } }, _callee); })); return function getValues(_x, _x2) { return _ref.apply(this, arguments); }; }(); // customize a filterDataset tool from localQuery tool var filterDataset = _objectSpread(_objectSpread({}, _duckdb.localQuery), {}, { description: "filter the user dataset by using a select SQL query in duckdb and save the result as a new dataset. Please note:\n1. REQUIRED: In the SQL query, please use a sub-query to add an auto-increment column 'row_index' to the original dataset.\n2. The SQL query should return the selected row_index values.\n3. Please only use the variable user mentioned for variableNames.\nFor example: 'SELECT row_index FROM (SELECT row_number() OVER () AS row_index, * FROM dataset_name) WHERE Count > 0'\n", context: _objectSpread(_objectSpread({}, _duckdb.localQuery.context), {}, { getValues: getValues }), component: FilterDatasetComponent }); // customize a generic query tool from localQuery tool var genericQuery = _objectSpread(_objectSpread({}, _duckdb.localQuery), {}, { description: "execute a generic select SQL query in duckdb to answer user's question. Please note:\n1. This tool is NOT for filtering the user dataset.\n2. This tool does NOT support geometry column and geometric operations.\n3. The variableNames should not be empty. If it is not provided, then pick a variable name from the dataset.\n4. There is no need to add a sub-query to add an auto-increment column 'row_index' to the original dataset.\n", context: _objectSpread(_objectSpread({}, _duckdb.localQuery.context), {}, { getValues: getValues }) }); return { filterDataset: filterDataset, genericQuery: genericQuery }; } function FilterDatasetComponent(_ref2) { var columnData = _ref2.columnData, datasetName = _ref2.datasetName, sql = _ref2.sql, dbTableName = _ref2.dbTableName, filteredDatasetName = _ref2.filteredDatasetName; var datasets = (0, _reactRedux.useSelector)(function (state) { return state.demo.keplerGl.map.visState.datasets; }); var layers = (0, _reactRedux.useSelector)(function (state) { return state.demo.keplerGl.map.visState.layers; }); 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 filteredDatasetName is already in the datasets var newDatasetId = Object.keys(datasets).find(function (dataId) { return datasets[dataId].label === filteredDatasetName; }); // if the filteredDatasetName is already in the datasets, return if (newDatasetId) return; var query = /*#__PURE__*/function () { var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() { return _regenerator["default"].wrap(function _callee3$(_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: if (!queryInProgress.current) { _context3.next = 3; break; } _context3.next = 3; return queryInProgress.current; case 3: // Create a new promise for this query queryInProgress.current = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() { var duckDB, safeDbTableName, conn, arrowResult, result, filteredDataset; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: _context2.prev = 0; _context2.next = 3; return (0, _duckdb.getDuckDB)(); case 3: duckDB = _context2.sent; if (duckDB) { _context2.next = 6; break; } throw new Error('DuckDB instance is not initialized'); case 6: if (!(columnData && dbTableName && sql)) { _context2.next = 21; break; } // use double quotes for the table name safeDbTableName = "".concat(dbTableName); // connect to the database _context2.next = 10; return duckDB.connect(); case 10: conn = _context2.sent; _context2.next = 13; return conn.query(sql); case 13: arrowResult = _context2.sent; // convert the arrow result to a json array result = arrowResult.toArray().map(function (row) { return row.toJSON(); }); // delete the table from the database _context2.next = 17; return conn.query("DROP TABLE ".concat(safeDbTableName)); case 17: _context2.next = 19; return conn.close(); case 19: // filter the dataset with the query result filteredDataset = filterDataset(datasets, layers, datasetName, result, filteredDatasetName); if (filteredDataset) { // add the new dataset to the map dispatch((0, _actions.addDataToMap)({ datasets: [filteredDataset], options: { autoCreateLayers: true, centerMap: false } })); } case 21: _context2.next = 27; break; case 23: _context2.prev = 23; _context2.t0 = _context2["catch"](0); console.error(_context2.t0); setError(_context2.t0 instanceof Error ? _context2.t0.message : 'Unknown error occurred'); case 27: _context2.prev = 27; queryInProgress.current = null; return _context2.finish(27); case 30: case "end": return _context2.stop(); } }, _callee2, null, [[0, 23, 27, 30]]); }))(); // Wait for the query to complete _context3.next = 6; return queryInProgress.current; case 6: case "end": return _context3.stop(); } }, _callee3); })); return function query() { return _ref3.apply(this, arguments); }; }(); query(); // eslint-disable-next-line react-hooks/exhaustive-deps }, []); return error ? /*#__PURE__*/_react["default"].createElement("div", { style: { color: 'red', fontSize: '8px' } }, error) : null; } function filterDataset(datasets, layers, datasetName, filteredRows, filteredDatasetName) { // find datasetId from datasets var datasetId = Object.keys(datasets).find(function (dataId) { return datasets[dataId].label === datasetName; }); if (!datasetId) return; // filter the original dataset var originalDataset = datasets[datasetId]; var fields = originalDataset.fields; var rows; if (originalDataset.type === 'vector-tile') { var columnData = []; var _iterator = _createForOfIteratorHelper(fields), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var field = _step.value; // get the values from the vector tile layer var values = (0, _utils.getValuesFromVectorTileLayer)(datasetId, layers, field); columnData.push(values); } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } rows = filteredRows.map(function (rowIndex) { return columnData.map(function (column) { return column[Number(rowIndex['row_index']) - 1]; }); }); } else { rows = filteredRows.map(function (rowIndex) { return fields.map(function (field) { return originalDataset.getValue(field.name, Number(rowIndex['row_index']) - 1); }); }); } // create a new dataset with the filtered data var newDataset = { info: { id: filteredDatasetName, label: filteredDatasetName }, data: { fields: fields, rows: rows } }; return newDataset; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_actions","_duckdb","_utils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_createForOfIteratorHelper","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","done","value","f","TypeError","o","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","getQueryTool","datasets","layers","getValues","_ref","_asyncToGenerator2","_regenerator","mark","_callee","datasetName","variableName","values","wrap","_callee$","_context","prev","getValuesFromDataset","abrupt","stop","_x","_x2","filterDataset","localQuery","description","context","component","FilterDatasetComponent","genericQuery","_ref2","columnData","sql","dbTableName","filteredDatasetName","useSelector","state","demo","keplerGl","map","visState","queryInProgress","useRef","dispatch","useDispatch","_useState","useState","_useState2","_slicedToArray2","error","setError","useEffect","newDatasetId","find","dataId","label","query","_ref3","_callee3","_callee3$","_context3","current","_callee2","duckDB","safeDbTableName","conn","arrowResult","result","filteredDataset","_callee2$","_context2","getDuckDB","sent","Error","concat","connect","toArray","row","toJSON","close","addDataToMap","options","autoCreateLayers","centerMap","t0","console","message","finish","createElement","style","color","fontSize","filteredRows","datasetId","originalDataset","fields","rows","type","_iterator","_step","field","getValuesFromVectorTileLayer","err","rowIndex","column","Number","getValue","newDataset","info","id","data"],"sources":["../../src/tools/query-tool.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useEffect, useRef, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport {Datasets} from '@kepler.gl/table';\nimport {Layer} from '@kepler.gl/layers';\nimport {ProtoDataset} from '@kepler.gl/types';\nimport {addDataToMap} from '@kepler.gl/actions';\nimport {getDuckDB, localQuery, LocalQueryTool} from '@openassistant/duckdb';\n\nimport {getValuesFromDataset, getValuesFromVectorTileLayer} from './utils';\nimport {State} from '../components/ai-assistant-manager';\n\nexport function getQueryTool(datasets: Datasets, layers: Layer[]) {\n  // context for query tools\n  const getValues = async (datasetName: string, variableName: string) => {\n    const values = getValuesFromDataset(datasets, layers, datasetName, variableName);\n    return values;\n  };\n\n  // customize a filterDataset tool from localQuery tool\n  const filterDataset: LocalQueryTool = {\n    ...localQuery,\n    description: `filter the user dataset by using a select SQL query in duckdb and save the result as a new dataset. Please note:\n1. REQUIRED: In the SQL query, please use a sub-query to add an auto-increment column 'row_index' to the original dataset.\n2. The SQL query should return the selected row_index values.\n3. Please only use the variable user mentioned for variableNames.\nFor example: 'SELECT row_index  FROM (SELECT row_number() OVER () AS row_index, * FROM dataset_name) WHERE Count > 0'\n`,\n    context: {\n      ...localQuery.context,\n      getValues\n    },\n    component: FilterDatasetComponent\n  };\n\n  // customize a generic query tool from localQuery tool\n  const genericQuery: LocalQueryTool = {\n    ...localQuery,\n    description: `execute a generic select SQL query in duckdb to answer user's question. Please note:\n1. This tool is NOT for filtering the user dataset.\n2. This tool does NOT support geometry column and geometric operations.\n3. The variableNames should not be empty. If it is not provided, then pick a variable name from the dataset.\n4. There is no need to add a sub-query to add an auto-increment column 'row_index' to the original dataset.\n`,\n    context: {\n      ...localQuery.context,\n      getValues\n    }\n  };\n\n  return {\n    filterDataset,\n    genericQuery\n  };\n}\n\nfunction FilterDatasetComponent({columnData, datasetName, sql, dbTableName, filteredDatasetName}) {\n  const datasets = useSelector((state: State) => state.demo.keplerGl.map.visState.datasets);\n  const layers = useSelector((state: State) => state.demo.keplerGl.map.visState.layers);\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 filteredDatasetName is already in the datasets\n    const newDatasetId = Object.keys(datasets).find(\n      dataId => datasets[dataId].label === filteredDatasetName\n    );\n    // if the filteredDatasetName is already in the datasets, return\n    if (newDatasetId) return;\n\n    const query = 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 (columnData && dbTableName && sql) {\n            // use double quotes for the table name\n            const safeDbTableName = `${dbTableName}`;\n\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 the arrow result to a json array\n            const result = arrowResult.toArray().map(row => row.toJSON());\n\n            // delete the table from the database\n            await conn.query(`DROP TABLE ${safeDbTableName}`);\n\n            // close the connection\n            await conn.close();\n\n            // filter the dataset with the query result\n            const filteredDataset = filterDataset(\n              datasets,\n              layers,\n              datasetName,\n              result,\n              filteredDatasetName\n            );\n\n            if (filteredDataset) {\n              // add the new dataset to the map\n              dispatch(\n                addDataToMap({\n                  datasets: [filteredDataset],\n                  options: {autoCreateLayers: true, centerMap: false}\n                })\n              );\n            }\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    query();\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\nfunction filterDataset(\n  datasets: Datasets,\n  layers: Layer[],\n  datasetName: string,\n  filteredRows: Record<string, number>[],\n  filteredDatasetName: string\n) {\n  // find datasetId from datasets\n  const datasetId = Object.keys(datasets).find(dataId => datasets[dataId].label === datasetName);\n  if (!datasetId) return;\n\n  // filter the original dataset\n  const originalDataset = datasets[datasetId];\n\n  const fields = originalDataset.fields;\n\n  let rows: unknown[][];\n\n  if (originalDataset.type === 'vector-tile') {\n    const columnData: unknown[][] = [];\n    for (const field of fields) {\n      // get the values from the vector tile layer\n      const values = getValuesFromVectorTileLayer(datasetId, layers, field);\n      columnData.push(values);\n    }\n    rows = filteredRows.map(rowIndex =>\n      columnData.map(column => column[Number(rowIndex['row_index']) - 1])\n    );\n  } else {\n    rows = filteredRows.map(rowIndex =>\n      fields.map(field => originalDataset.getValue(field.name, Number(rowIndex['row_index']) - 1))\n    );\n  }\n\n  // create a new dataset with the filtered data\n  const newDataset: ProtoDataset = {\n    info: {\n      id: filteredDatasetName,\n      label: filteredDatasetName\n    },\n    data: {\n      fields,\n      rows\n    }\n  };\n\n  return newDataset;\n}\n"],"mappings":"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","ignoreList":[]}