mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-09 01:31:46 +00:00
82 lines
2.3 KiB
JavaScript
82 lines
2.3 KiB
JavaScript
const is = require('electron-is');
|
|
|
|
const { urgencyLevels, ToastStyles, snakeToCamel } = require('./utils');
|
|
const config = require('./config');
|
|
|
|
module.exports = (_win, options) => [
|
|
...(is.linux()
|
|
? [
|
|
{
|
|
label: 'Notification Priority',
|
|
submenu: urgencyLevels.map((level) => ({
|
|
label: level.name,
|
|
type: 'radio',
|
|
checked: options.urgency === level.value,
|
|
click: () => config.set('urgency', level.value),
|
|
})),
|
|
},
|
|
]
|
|
: []),
|
|
...(is.windows()
|
|
? [
|
|
{
|
|
label: 'Interactive Notifications',
|
|
type: 'checkbox',
|
|
checked: options.interactive,
|
|
// Doesn't update until restart
|
|
click: (item) => config.setAndMaybeRestart('interactive', item.checked),
|
|
},
|
|
{
|
|
// Submenu with settings for interactive notifications (name shouldn't be too long)
|
|
label: 'Interactive Settings',
|
|
submenu: [
|
|
{
|
|
label: 'Open/Close on tray click',
|
|
type: 'checkbox',
|
|
checked: options.trayControls,
|
|
click: (item) => config.set('trayControls', item.checked),
|
|
},
|
|
{
|
|
label: 'Hide Button Text',
|
|
type: 'checkbox',
|
|
checked: options.hideButtonText,
|
|
click: (item) => config.set('hideButtonText', item.checked),
|
|
},
|
|
{
|
|
label: 'Refresh on Play/Pause',
|
|
type: 'checkbox',
|
|
checked: options.refreshOnPlayPause,
|
|
click: (item) => config.set('refreshOnPlayPause', item.checked),
|
|
},
|
|
],
|
|
},
|
|
{
|
|
label: 'Style',
|
|
submenu: getToastStyleMenuItems(options),
|
|
},
|
|
]
|
|
: []),
|
|
{
|
|
label: 'Show notification on unpause',
|
|
type: 'checkbox',
|
|
checked: options.unpauseNotification,
|
|
click: (item) => config.set('unpauseNotification', item.checked),
|
|
},
|
|
];
|
|
|
|
function getToastStyleMenuItems(options) {
|
|
const array = Array.from({ length: Object.keys(ToastStyles).length });
|
|
|
|
// ToastStyles index starts from 1
|
|
for (const [name, index] of Object.entries(ToastStyles)) {
|
|
array[index - 1] = {
|
|
label: snakeToCamel(name),
|
|
type: 'radio',
|
|
checked: options.toastStyle === index,
|
|
click: () => config.set('toastStyle', index),
|
|
};
|
|
}
|
|
|
|
return array;
|
|
}
|