From e32f185248a768a074658eb12d377bd0a1337b71 Mon Sep 17 00:00:00 2001 From: Jeremy Tuloup Date: Wed, 16 Oct 2024 09:54:15 +0200 Subject: [PATCH] Move handling of the file browser settings to a separate plugin --- packages/tree-extension/src/index.ts | 70 ++++++++++++++++++++-------- 1 file changed, 51 insertions(+), 19 deletions(-) diff --git a/packages/tree-extension/src/index.ts b/packages/tree-extension/src/index.ts index 2fb092bfa2..b2f5582c96 100644 --- a/packages/tree-extension/src/index.ts +++ b/packages/tree-extension/src/index.ts @@ -186,6 +186,56 @@ const fileActions: JupyterFrontEndPlugin = { }, }; +/** + * A plugin to set the default file browser settings. + */ +const fileBrowserSettings: JupyterFrontEndPlugin = { + id: '@jupyter-notebook/tree-extension:settings', + description: 'Set up the default file browser settings', + requires: [IDefaultFileBrowser, ISettingRegistry], + autoStart: true, + activate: ( + app: JupyterFrontEnd, + browser: IDefaultFileBrowser, + settingRegistry: ISettingRegistry + ) => { + /** + * File browser default configuration. + */ + const defaultFileBrowserConfig = { + navigateToCurrentDirectory: false, + singleClickNavigation: true, + showLastModifiedColumn: true, + showFileSizeColumn: true, + showHiddenFiles: false, + showFileCheckboxes: true, + sortNotebooksFirst: true, + showFullPath: false, + }; + + // apply defaults + let key: keyof typeof defaultFileBrowserConfig; + for (key in defaultFileBrowserConfig) { + browser[key] = defaultFileBrowserConfig[key]; + } + + void settingRegistry.load(FILE_BROWSER_PLUGIN_ID).then((settings) => { + function onSettingsChanged(settings: ISettingRegistry.ISettings): void { + let key: keyof typeof defaultFileBrowserConfig; + for (key in defaultFileBrowserConfig) { + const value = settings.get(key).user as boolean; + // only set the setting if it is defined by the user + if (value === undefined) { + browser[key] = value; + } + } + } + settings.changed.connect(onSettingsChanged); + onSettingsChanged(settings); + }); + }, +}; + /** * A plugin to add the file filter toggle command to the palette */ @@ -360,25 +410,6 @@ const notebookTreeWidget: JupyterFrontEndPlugin = { nbTreeWidget.tabBar.addTab(running.title); } - const settings = settingRegistry.load(FILE_BROWSER_PLUGIN_ID); - Promise.all([settings, app.restored]) - .then(([settings]) => { - // Set Notebook 7 defaults if there is no user setting override - [ - 'showFileCheckboxes', - 'showFileSizeColumn', - 'sortNotebooksFirst', - 'showFullPath', - ].forEach((setting) => { - if (settings.user[setting] === undefined) { - void settings.set(setting, true); - } - }); - }) - .catch((reason: Error) => { - console.error(reason.message); - }); - app.shell.add(nbTreeWidget, 'main', { rank: 100 }); // add a separate tab for each setting editor @@ -419,6 +450,7 @@ const notebookTreeWidget: JupyterFrontEndPlugin = { const plugins: JupyterFrontEndPlugin[] = [ createNew, fileActions, + fileBrowserSettings, fileFilterCommand, loadPlugins, openFileBrowser,