#74 - Integration with Bookmarks core plugin and support for indirect drag & drop arrangement

- restructured the context menu to a single submenu of `Custom sort:` configurable in settings
This commit is contained in:
SebastianMC 2023-10-22 18:52:36 +02:00
parent 8e6c8ded98
commit 39d7591ac1
2 changed files with 149 additions and 80 deletions

View File

@ -65,6 +65,7 @@ interface CustomSortPluginSettings {
notificationsEnabled: boolean
mobileNotificationsEnabled: boolean
automaticBookmarksIntegration: boolean
customSortContextSubmenu: boolean
bookmarksContextMenus: boolean
bookmarksGroupToConsumeAsOrderingReference: string
}
@ -75,6 +76,7 @@ const DEFAULT_SETTINGS: CustomSortPluginSettings = {
statusBarEntryEnabled: true,
notificationsEnabled: true,
mobileNotificationsEnabled: false,
customSortContextSubmenu: true,
automaticBookmarksIntegration: false,
bookmarksContextMenus: false,
bookmarksGroupToConsumeAsOrderingReference: 'sortspec'
@ -94,6 +96,8 @@ const ERROR_NOTICE_TIMEOUT: number = 10000
// the monkey-around package doesn't export the below type
type MonkeyAroundUninstaller = () => void
type ContextMenuProvider = (item: MenuItem) => void
export default class CustomSortPlugin extends Plugin {
settings: CustomSortPluginSettings
statusBarItemEl: HTMLElement
@ -340,16 +344,23 @@ export default class CustomSortPlugin extends Plugin {
})
);
this.registerEvent(
app.workspace.on("file-menu", (menu: Menu, file: TAbstractFile, source: string, leaf?: WorkspaceLeaf) => {
if (!this.settings.bookmarksContextMenus) return; // Don't show the context menus at all
const applyCustomSortMenuItem = (item: MenuItem) => {
item.setTitle('Apply custom sorting');
item.onClick(() => {
plugin.switchPluginStateTo(true, true)
})
};
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (!bookmarksPlugin) return; // Don't show context menu if bookmarks plugin not available and not enabled
const suspendCustomSortMenuItem = (item: MenuItem) => {
item.setTitle('Suspend custom sorting');
item.onClick(() => {
plugin.switchPluginStateTo(false, true)
})
};
const bookmarkThisMenuItem = (item: MenuItem) => {
item.setTitle('Custom sort: bookmark for sorting.');
item.setIcon('hashtag');
const getBookmarkThisMenuItemForFile = (file: TAbstractFile): ContextMenuProvider =>
(item: MenuItem) => {
item.setTitle('Bookmark it for sorting.');
item.onClick(() => {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
@ -358,9 +369,10 @@ export default class CustomSortPlugin extends Plugin {
}
});
};
const unbookmarkThisMenuItem = (item: MenuItem) => {
item.setTitle('Custom sort: UNbookmark from sorting.');
item.setIcon('hashtag');
const getUnbookmarkThisMenuItemForFile = (file: TAbstractFile): ContextMenuProvider =>
(item: MenuItem) => {
item.setTitle('UNbookmark it from sorting.');
item.onClick(() => {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
@ -369,9 +381,10 @@ export default class CustomSortPlugin extends Plugin {
}
});
};
const bookmarkAllMenuItem = (item: MenuItem) => {
item.setTitle('Custom sort: bookmark+siblings for sorting.');
item.setIcon('hashtag');
const getBookmarkAllMenuItemForFile = (file: TAbstractFile): ContextMenuProvider =>
(item: MenuItem) => {
item.setTitle('Bookmark it+siblings for sorting.');
item.onClick(() => {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
@ -381,9 +394,10 @@ export default class CustomSortPlugin extends Plugin {
}
});
};
const unbookmarkAllMenuItem = (item: MenuItem) => {
item.setTitle('Custom sort: UNbookmark+all siblings from sorting.');
item.setIcon('hashtag');
const getUnbookmarkAllMenuItemForFile = (file: TAbstractFile): ContextMenuProvider =>
(item: MenuItem) => {
item.setTitle('UNbookmark it+siblings from sorting.');
item.onClick(() => {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
@ -394,30 +408,9 @@ export default class CustomSortPlugin extends Plugin {
});
};
const itemAlreadyBookmarkedForSorting: boolean = bookmarksPlugin.isBookmarkedForSorting(file)
if (!itemAlreadyBookmarkedForSorting) {
menu.addItem(bookmarkThisMenuItem)
} else {
menu.addItem(unbookmarkThisMenuItem)
}
menu.addItem(bookmarkAllMenuItem)
menu.addItem(unbookmarkAllMenuItem)
})
)
if (requireApiVersion('1.4.11')) {
this.registerEvent(
// "files-menu" event was exposed in 1.4.11
// @ts-ignore
app.workspace.on("files-menu", (menu: Menu, files: TAbstractFile[], source: string, leaf?: WorkspaceLeaf) => {
if (!this.settings.bookmarksContextMenus) return; // Don't show the context menus at all
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (!bookmarksPlugin) return; // Don't show context menu if bookmarks plugin not available and not enabled
const bookmarkSelectedMenuItem = (item: MenuItem) => {
const getBookmarkSelectedMenuItemForFiles = (files: TAbstractFile[]): ContextMenuProvider =>
(item: MenuItem) => {
item.setTitle('Custom sort: bookmark selected for sorting.');
item.setIcon('hashtag');
item.onClick(() => {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
@ -428,9 +421,10 @@ export default class CustomSortPlugin extends Plugin {
}
});
};
const unbookmarkSelectedMenuItem = (item: MenuItem) => {
const getUnbookmarkSelectedMenuItemForFiles = (files: TAbstractFile[]): ContextMenuProvider =>
(item: MenuItem) => {
item.setTitle('Custom sort: UNbookmark selected from sorting.');
item.setIcon('hashtag');
item.onClick(() => {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
@ -442,8 +436,66 @@ export default class CustomSortPlugin extends Plugin {
});
};
menu.addItem(bookmarkSelectedMenuItem)
menu.addItem(unbookmarkSelectedMenuItem)
this.registerEvent(
app.workspace.on("file-menu", (menu: Menu, file: TAbstractFile, source: string, leaf?: WorkspaceLeaf) => {
if (!this.settings.customSortContextSubmenu) return; // Don't show the context menus at all
const customSortMenuItem = (item: MenuItem) => {
item.setTitle('Custom sort:');
item.setIcon('hashtag');
const submenu = item.setSubmenu()
submenu.addItem(applyCustomSortMenuItem)
submenu.addSeparator()
if (this.settings.bookmarksContextMenus) {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
const itemAlreadyBookmarkedForSorting: boolean = bookmarksPlugin.isBookmarkedForSorting(file)
if (!itemAlreadyBookmarkedForSorting) {
submenu.addItem(getBookmarkThisMenuItemForFile(file))
} else {
submenu.addItem(getUnbookmarkThisMenuItemForFile(file))
}
submenu.addItem(getBookmarkAllMenuItemForFile(file))
submenu.addItem(getUnbookmarkAllMenuItemForFile(file))
}
}
submenu.addItem(suspendCustomSortMenuItem)
};
menu.addItem(customSortMenuItem)
})
)
if (requireApiVersion('1.4.11')) {
this.registerEvent(
// "files-menu" event was exposed in 1.4.11
// @ts-ignore
app.workspace.on("files-menu", (menu: Menu, files: TAbstractFile[], source: string, leaf?: WorkspaceLeaf) => {
if (!this.settings.customSortContextSubmenu) return; // Don't show the context menus at all
const customSortMenuItem = (item: MenuItem) => {
item.setTitle('Custom sort:');
item.setIcon('hashtag');
const submenu = item.setSubmenu()
submenu.addItem(applyCustomSortMenuItem)
submenu.addSeparator()
if (this.settings.bookmarksContextMenus) {
const bookmarksPlugin = getBookmarksPlugin(plugin.settings.bookmarksGroupToConsumeAsOrderingReference)
if (bookmarksPlugin) {
submenu.addItem(getBookmarkSelectedMenuItemForFiles(files))
submenu.addItem(getUnbookmarkSelectedMenuItemForFiles(files))
}
}
submenu.addItem(suspendCustomSortMenuItem)
};
menu.addItem(customSortMenuItem)
})
)
}
@ -704,6 +756,16 @@ class CustomSortSettingTab extends PluginSettingTab {
await this.plugin.saveSettings();
}));
new Setting(containerEl)
.setName('Enable File Explorer context submenu`Custom sort:`')
.setDesc('Gives access to operations relevant for custom sorting, e.g. applying custom sorting.')
.addToggle(toggle => toggle
.setValue(this.plugin.settings.customSortContextSubmenu)
.onChange(async (value) => {
this.plugin.settings.customSortContextSubmenu = value;
await this.plugin.saveSettings();
}));
containerEl.createEl('h2', {text: 'Bookmarks integration'});
const bookmarksIntegrationDescription: DocumentFragment = sanitizeHTMLToDom(
'If enabled, order of files and folders in File Explorer will reflect the order '
@ -756,6 +818,9 @@ class CustomSortSettingTab extends PluginSettingTab {
.setValue(this.plugin.settings.bookmarksContextMenus)
.onChange(async (value) => {
this.plugin.settings.bookmarksContextMenus = value;
if (value) {
this.plugin.settings.customSortContextSubmenu = true; // automatically enable custom sort context submenu
}
await this.plugin.saveSettings();
}))
}

View File

@ -56,4 +56,8 @@ declare module 'obsidian' {
sortOrder: string
}
interface MenuItem {
setSubmenu: () => Menu;
}
}