2020-11-13 19:09:28 +02:00
|
|
|
// This extends the generic stateToWhenClauseContext (potentially shared by
|
|
|
|
// all apps) with additional properties specific to the desktop app. So in
|
|
|
|
// general, any desktop component should import this file, and not the lib
|
|
|
|
// one.
|
|
|
|
|
2021-09-04 19:11:29 +02:00
|
|
|
import { AppState } from '../../app.reducer';
|
2021-05-13 18:57:37 +02:00
|
|
|
import libStateToWhenClauseContext, { WhenClauseContextOptions } from '@joplin/lib/services/commands/stateToWhenClauseContext';
|
2020-11-13 19:09:28 +02:00
|
|
|
import layoutItemProp from '../../gui/ResizableLayout/utils/layoutItemProp';
|
|
|
|
|
2021-05-13 18:57:37 +02:00
|
|
|
export default function stateToWhenClauseContext(state: AppState, options: WhenClauseContextOptions = null) {
|
2020-11-13 19:09:28 +02:00
|
|
|
return {
|
2021-05-13 18:57:37 +02:00
|
|
|
...libStateToWhenClauseContext(state, options),
|
2020-11-13 19:09:28 +02:00
|
|
|
|
|
|
|
// UI elements
|
|
|
|
markdownEditorVisible: !!state.settings['editor.codeView'],
|
|
|
|
richTextEditorVisible: !state.settings['editor.codeView'],
|
|
|
|
markdownEditorPaneVisible: state.settings['editor.codeView'] && state.noteVisiblePanes.includes('editor'),
|
|
|
|
markdownViewerPaneVisible: state.settings['editor.codeView'] && state.noteVisiblePanes.includes('viewer'),
|
|
|
|
modalDialogVisible: !!Object.keys(state.visibleDialogs).length,
|
2021-01-12 14:28:55 +02:00
|
|
|
sidebarVisible: !!state.mainLayout && layoutItemProp(state.mainLayout, 'sideBar', 'visible'),
|
2020-11-13 19:09:28 +02:00
|
|
|
noteListHasNotes: !!state.notes.length,
|
2021-01-12 14:28:55 +02:00
|
|
|
|
|
|
|
// Deprecated
|
|
|
|
sideBarVisible: !!state.mainLayout && layoutItemProp(state.mainLayout, 'sideBar', 'visible'),
|
2020-11-13 19:09:28 +02:00
|
|
|
};
|
|
|
|
}
|