Files
youtube-music/src/plugins/taskbar-mediacontrol/index.ts
2024-11-03 19:21:47 +09:00

120 lines
3.2 KiB
TypeScript

import { type NativeImage, nativeImage, nativeTheme } from 'electron';
import { Jimp, JimpMime } from 'jimp';
import playIcon from '@assets/media-icons-black/play.png?asset&asarUnpack';
import pauseIcon from '@assets/media-icons-black/pause.png?asset&asarUnpack';
import nextIcon from '@assets/media-icons-black/next.png?asset&asarUnpack';
import previousIcon from '@assets/media-icons-black/previous.png?asset&asarUnpack';
import { createPlugin } from '@/utils';
import getSongControls from '@/providers/song-controls';
import registerCallback, {
type SongInfo,
SongInfoEvent,
} from '@/providers/song-info';
import { mediaIcons } from '@/types/media-icons';
import { t } from '@/i18n';
export default createPlugin({
name: () => t('plugins.taskbar-mediacontrol.name'),
description: () => t('plugins.taskbar-mediacontrol.description'),
restartNeeded: true,
config: {
enabled: false,
},
async backend({ window }) {
let currentSongInfo: SongInfo;
const { playPause, next, previous } = getSongControls(window);
// Util
const getImagePath = (kind: keyof typeof mediaIcons): string => {
switch (kind) {
case 'play':
return playIcon;
case 'pause':
return pauseIcon;
case 'next':
return nextIcon;
case 'previous':
return previousIcon;
default:
return '';
}
};
const getNativeImage = async (
kind: keyof typeof mediaIcons,
): Promise<NativeImage> => {
const imagePath = getImagePath(kind);
if (imagePath) {
const jimpImageBuffer = await Jimp.read(imagePath).then((img) => {
if (imagePath && nativeTheme.shouldUseDarkColors) {
return img.invert().getBuffer(JimpMime.png);
}
return img.getBuffer(JimpMime.png);
});
return nativeImage.createFromBuffer(jimpImageBuffer);
}
// return empty image
return nativeImage.createEmpty();
};
const images = {
play: await getNativeImage('play'),
pause: await getNativeImage('pause'),
next: await getNativeImage('next'),
previous: await getNativeImage('previous'),
};
const setThumbar = (songInfo: SongInfo) => {
// Wait for song to start before setting thumbar
if (!songInfo?.title) {
return;
}
// Win32 require full rewrite of components
window.setThumbarButtons([
{
tooltip: 'Previous',
icon: images.previous,
click() {
previous();
},
},
{
tooltip: 'Play/Pause',
// Update icon based on play state
icon: songInfo.isPaused ? images.play : images.pause,
click() {
playPause();
},
},
{
tooltip: 'Next',
icon: images.next,
click() {
next();
},
},
]);
};
registerCallback((songInfo, event) => {
if (event !== SongInfoEvent.TimeChanged) {
// Update currentsonginfo for win.on('show')
currentSongInfo = songInfo;
// Update thumbar
setThumbar(songInfo);
}
});
// Need to set thumbar again after win.show
window.on('show', () => setThumbar(currentSongInfo));
},
});