PromucFlow_constructor/app/client/src/selectors/dataTreeSelectors.ts
Rishabh Rathod c440343586
chore: perf data tree shrink (#18361)
trimming dataTree object size by removing configs to make evaluation faster.
2022-12-02 18:15:11 +05:30

100 lines
2.7 KiB
TypeScript

import { createSelector } from "reselect";
import {
getActionsForCurrentPage,
getAppData,
getPluginDependencyConfig,
getPluginEditorConfigs,
getJSCollectionsForCurrentPage,
} from "./entitiesSelector";
import {
DataTree,
DataTreeFactory,
DataTreeWidget,
} from "entities/DataTree/dataTreeFactory";
import { getWidgetsForEval, getWidgetsMeta } from "sagas/selectors";
import "url-search-params-polyfill";
import { getPageList } from "./appViewSelectors";
import { AppState } from "@appsmith/reducers";
import { getSelectedAppThemeProperties } from "./appThemingSelectors";
import { LoadingEntitiesState } from "reducers/evaluationReducers/loadingEntitiesReducer";
import { get } from "lodash";
import { EvaluationError, getEvalErrorPath } from "utils/DynamicBindingUtils";
export const getUnevaluatedDataTree = createSelector(
getActionsForCurrentPage,
getJSCollectionsForCurrentPage,
getWidgetsForEval,
getWidgetsMeta,
getPageList,
getAppData,
getPluginEditorConfigs,
getPluginDependencyConfig,
getSelectedAppThemeProperties,
(
actions,
jsActions,
widgets,
widgetsMeta,
pageListPayload,
appData,
editorConfigs,
pluginDependencyConfig,
selectedAppThemeProperty,
) => {
const pageList = pageListPayload || [];
return DataTreeFactory.create({
actions,
jsActions,
widgets,
widgetsMeta,
pageList,
appData,
editorConfigs,
pluginDependencyConfig,
theme: selectedAppThemeProperty,
});
},
);
export const getEvaluationInverseDependencyMap = (state: AppState) =>
state.evaluations.dependencies.inverseDependencyMap;
export const getLoadingEntities = (state: AppState) =>
state.evaluations.loadingEntities;
export const getIsWidgetLoading = createSelector(
[getLoadingEntities, (_state: AppState, widgetName: string) => widgetName],
(loadingEntities: LoadingEntitiesState, widgetName: string) =>
loadingEntities.has(widgetName),
);
/**
* returns evaluation tree object
*
* @param state
*/
export const getDataTree = (state: AppState): DataTree =>
state.evaluations.tree;
export const getWidgetEvalValues = createSelector(
[getDataTree, (_state: AppState, widgetName: string) => widgetName],
(tree: DataTree, widgetName: string) => tree[widgetName] as DataTreeWidget,
);
// For autocomplete. Use actions cached responses if
// there isn't a response already
export const getDataTreeForAutocomplete = createSelector(
getDataTree,
(tree: DataTree) => {
return tree;
},
);
export const getPathEvalErrors = createSelector(
[
getDataTreeForAutocomplete,
(_: unknown, dataTreePath: string) => dataTreePath,
],
(dataTree: DataTree, dataTreePath: string) =>
get(dataTree, getEvalErrorPath(dataTreePath), []) as EvaluationError[],
);