PromucFlow_constructor/app/client/src/selectors/appViewSelectors.tsx

39 lines
1.5 KiB
TypeScript
Raw Normal View History

import { createSelector } from "reselect";
2019-11-08 11:02:00 +00:00
import { AppState, DataTree } from "../reducers";
import { AppViewReduxState } from "../reducers/uiReducers/appViewReducer";
import { AppViewerProps } from "../pages/AppViewer";
2019-11-08 11:02:00 +00:00
import { injectDataTreeIntoDsl } from "../utils/DynamicBindingUtils";
const getAppViewState = (state: AppState) => state.ui.appView;
2019-11-08 11:02:00 +00:00
const getDataTree = (state: AppState): DataTree => state.entities;
export const getCurrentLayoutId = (state: AppState, props: AppViewerProps) =>
state.ui.appView.currentLayoutId || props.match.params.layoutId;
export const getCurrentPageId = (state: AppState, props: AppViewerProps) =>
state.ui.appView.currentPageId || props.match.params.pageId;
2019-11-06 06:21:56 +00:00
export const getCurrentRoutePageId = (state: AppState, props: AppViewerProps) =>
props.match.params.pageId;
// For the viewer, this does not need to be wrapped in createCachedSelector, as it will not change in subsequent renders.
export const getCurrentPageLayoutDSL = createSelector(
getAppViewState,
2019-11-08 11:02:00 +00:00
getDataTree,
(view: AppViewReduxState, dataTree: DataTree) =>
injectDataTreeIntoDsl(dataTree, view.dsl),
);
export const getPageList = createSelector(
getAppViewState,
(view: AppViewReduxState) => (view.pages.length > 0 ? view.pages : undefined),
);
2019-11-06 06:21:56 +00:00
export const getIsFetchingPage = createSelector(
getAppViewState,
(view: AppViewReduxState) => view.isFetchingPage,
);
export const getCurrentDSLPageId = createSelector(
getAppViewState,
(view: AppViewReduxState) => view.currentPageId,
);