import { createSelector } from "reselect"; import { getActionsForCurrentPage } from "./entitiesSelector"; import { ActionDataState } from "reducers/entityReducers/actionsReducer"; import { getEvaluatedDataTree } from "utils/DynamicBindingUtils"; import { extraLibraries } from "jsExecution/JSExecutionManagerSingleton"; import { DataTree, DataTreeFactory } from "entities/DataTree/dataTreeFactory"; import { getWidgets, getWidgetsMeta } from "sagas/selectors"; import * as log from "loglevel"; import "url-search-params-polyfill"; import { getPageList } from "./appViewSelectors"; // TODO Commenting out for now as it is causing performance issues // function getQueryParams() { // const urlParams = new URLSearchParams(window.location.search); // const keys = urlParams.keys(); // let key = keys.next().value; // const queryParams: Record = {}; // while (key) { // queryParams[key] = urlParams.get(key) as string; // key = keys.next().value; // } // return queryParams; // } // // const getUrlParams = createSelector( // getQueryParams, // (queryParams: Record): DataTreeUrl => { // return { // host: window.location.host, // hostname: window.location.hostname, // queryParams: queryParams, // protocol: window.location.protocol, // pathname: window.location.pathname, // port: window.location.port, // href: window.location.href, // hash: window.location.hash, // }; // }, // ); // export const getUnevaluatedDataTree = createSelector( getActionsForCurrentPage, getWidgets, getWidgetsMeta, getPageList, (actions, widgets, widgetsMeta, pageListPayload) => { const pageList = pageListPayload || []; return DataTreeFactory.create({ actions, widgets, widgetsMeta, pageList, }); }, ); export const evaluateDataTree = createSelector( getUnevaluatedDataTree, (dataTree: DataTree): DataTree => { return getEvaluatedDataTree(dataTree); }, ); // For autocomplete. Use actions cached responses if // there isn't a response already export const getDataTreeForAutocomplete = createSelector( evaluateDataTree, getActionsForCurrentPage, (tree: DataTree, actions: ActionDataState) => { log.debug("Evaluating data tree to get autocomplete values"); const cachedResponses: Record = {}; if (actions && actions.length) { actions.forEach(action => { if (!(action.config.name in tree) && action.config.cacheResponse) { try { cachedResponses[action.config.name] = JSON.parse( action.config.cacheResponse, ); } catch (e) { cachedResponses[action.config.name] = action.config.cacheResponse; } } }); } const libs: Record = {}; extraLibraries.forEach(config => (libs[config.accessor] = config.lib)); return { ...tree, ...cachedResponses, ...libs }; }, );