Provides more desktop functionalities (Including bookmarks/sidebar elements and folder icons) and offers cross os support for Linux, Windows and OS X.
npm install --save @gyselroth/node-advanced-desktop
Set an icon for a given folder path. Note: On win32 an icon of type ico is required.
const { nodeIcon } = require('@gyselroth/node-advanced-desktop');
var icon = process.platform === 'win32' ? 'icon.ico' : 'icon.png';
nodeIcon.setFolderIcon('/my/path/to/folder', icon).then(() => {
console.log('folder icon set');
}).catch((error) => {
console.log('failure');
});
Adds an item, typically a folder, to the sidebar (folder bookmarks).
sidebar.ensureItem(path, context)
accepts a context as seccond argument whereas you may specify additional configuration.
Note: On win32 you are required to specify a clsId. You may also change the name of the sidebar entry on win32 using context.name (The default is the base folder name).
Additional notes for linux, if the linux distribution is supported depends what file manager is in use. Currently support for the followin file managers is implemented:
- nautilus
- nemo
const { sidebar } = require('@gyselroth/node-advanced-desktop');
var icon = process.platform === 'win32' ? 'icon.ico' : 'icon.png';
sidebar.ensureItem('/my/path/to/folder', {
clsId: "61736CCB-50DB-4095-BF4C-186BB668432C",
name: "foobar",
icon: icon
}).then(() => {
console.log('sidebar entry added');
}).catch((error) => {
console.log('failure');
});
This method will only add the element if it does not already exists.
List current sidebar items:
const { sidebar } = require('@gyselroth/node-advanced-desktop');
sidebar.getItems().then((list) => {
for(let item of list) {
console.log(item.path);
}
});