UNPKG

@adaptabletools/adaptable

Version:

Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements

109 lines (108 loc) 4.13 kB
/** * @ReduxAction Tool Panels have been set in AdapTable ToolPanel Component */ export const TOOLPANEL_SET_TOOLPANELS = 'TOOLPANEL_SET_TOOLPANELS'; /** * @ReduxAction A Tool Panel has been made visible */ export const TOOLPANEL_SHOW_TOOLPANEL = 'TOOLPANEL_SHOW_TOOLPANEL'; /** * @ReduxAction A Tool Panel has been hidden */ export const TOOLPANEL_HIDE_TOOLPANEL = 'TOOLPANEL_HIDE_TOOLPANEL'; /** * @ReduxAction A Tool Panel has been expanded */ export const TOOLPANEL_EXPAND_TOOLPANEL = 'TOOLPANEL_EXPAND_TOOLPANEL'; /** * @ReduxAction A Tool Panel has been collapsed */ export const TOOLPANEL_COLLAPSE_TOOLPANEL = 'TOOLPANEL_COLLAPSE_TOOLPANEL'; /** * @ReduxAction Module Buttons have set in AdapTable ToolPanel Component header */ export const TOOLPANEL_SET_MODULE_BUTTONS = 'TOOLPANEL_SET_MODULE_BUTTONS'; /** * @ReduxAction AdapTable ToolPanel Component is ready */ export const TOOLPANEL_READY = 'TOOLPANEL_READY'; export const ToolPanelSetToolPanels = (toolPanels) => ({ type: TOOLPANEL_SET_TOOLPANELS, toolPanels, }); export const ToolPanelShowToolPanel = (toolPanel) => ({ type: TOOLPANEL_SHOW_TOOLPANEL, toolPanel, }); export const ToolPanelHideToolPanel = (toolPanel) => ({ type: TOOLPANEL_HIDE_TOOLPANEL, toolPanel, }); export const ToolPanelExpandToolPanel = (toolPanel) => ({ type: TOOLPANEL_EXPAND_TOOLPANEL, toolPanel, }); export const ToolPanelCollapseToolPanel = (toolPanel) => ({ type: TOOLPANEL_COLLAPSE_TOOLPANEL, toolPanel, }); export const ToolPanelSetModuleButtons = (moduleButtons) => ({ type: TOOLPANEL_SET_MODULE_BUTTONS, moduleButtons: moduleButtons, }); export const ToolPanelReady = (toolPanelState) => ({ type: TOOLPANEL_READY, toolPanelState, }); const initialState = { // default ToolPanels are set in ToolPanelModule.updateOldConfig() because we have to evaluate the ToolPanelOptions (for CustomToolPanel) ToolPanels: undefined, ModuleButtons: ['SettingsPanel'], }; export const ToolPanelReducer = (state = initialState, action) => { const setToolPanels = (state, toolPanels = []) => { return { ...state, ToolPanels: [...toolPanels] }; }; switch (action.type) { case TOOLPANEL_SET_TOOLPANELS: { const actionTyped = action; const toolPanels = actionTyped.toolPanels; return setToolPanels(state, toolPanels); } case TOOLPANEL_SHOW_TOOLPANEL: { const actionTyped = action; const toolPanelDefinition = { Name: actionTyped.toolPanel, VisibilityMode: 'collapsed', }; const toolPanels = [toolPanelDefinition, ...(state.ToolPanels ?? [])]; return setToolPanels(state, toolPanels); } case TOOLPANEL_HIDE_TOOLPANEL: { const actionTyped = action; const toolPanels = (state.ToolPanels ?? []).filter((a) => a.Name !== actionTyped.toolPanel); return setToolPanels(state, toolPanels); } case TOOLPANEL_EXPAND_TOOLPANEL: { const actionTyped = action; const toolPanelDefinitions = state.ToolPanels?.map((toolPanelDefinition) => toolPanelDefinition.Name === actionTyped.toolPanel ? { ...toolPanelDefinition, VisibilityMode: 'expanded' } : toolPanelDefinition); return setToolPanels(state, toolPanelDefinitions); } case TOOLPANEL_COLLAPSE_TOOLPANEL: { const actionTyped = action; const toolPanelDefinitions = state.ToolPanels?.map((toolPanelDefinition) => toolPanelDefinition.Name === actionTyped.toolPanel ? { ...toolPanelDefinition, VisibilityMode: 'collapsed' } : toolPanelDefinition); return setToolPanels(state, toolPanelDefinitions); } case TOOLPANEL_SET_MODULE_BUTTONS: { const actionTyped = action; const moduleButtons = actionTyped.moduleButtons; return Object.assign({}, state, { ModuleButtons: moduleButtons }); } default: return state; } };