include add to playlist action in quick search

This commit is contained in:
Kendall Garner
2026-05-19 20:06:15 -07:00
parent 2c1be99bd5
commit afbe8fac52
@@ -1,4 +1,8 @@
import type { MouseEvent } from 'react';
import { openContextModal } from '@mantine/modals';
import { CSSProperties, useCallback, useState } from 'react';
import { useTranslation } from 'react-i18next';
import styles from './library-command-item.module.css';
@@ -13,6 +17,7 @@ import { useCurrentServer } from '/@/renderer/store';
import { ActionIcon, ActionIconGroup } from '/@/shared/components/action-icon/action-icon';
import { Flex } from '/@/shared/components/flex/flex';
import { Text } from '/@/shared/components/text/text';
import { Tooltip } from '/@/shared/components/tooltip/tooltip';
import { ExplicitStatus, LibraryItem, Song } from '/@/shared/types/domain-types';
import { Play } from '/@/shared/types/types';
@@ -61,6 +66,7 @@ export const LibraryCommandItem = ({
}: LibraryCommandItemProps) => {
const { addToQueueByData, addToQueueByFetch } = usePlayer();
const server = useCurrentServer();
const { t } = useTranslation();
const handlePlay = useCallback(
(playType: Play) => {
@@ -103,6 +109,39 @@ export const LibraryCommandItem = ({
},
});
const handleOpenPlaylistModal = useCallback(() => {
const modalProps: {
albumId?: string[];
artistId?: string[];
songId?: string[];
} = {};
switch (itemType) {
case LibraryItem.ALBUM:
modalProps.albumId = [id];
break;
case LibraryItem.ALBUM_ARTIST:
case LibraryItem.ARTIST:
modalProps.artistId = [id];
break;
case LibraryItem.QUEUE_SONG:
case LibraryItem.SONG:
modalProps.songId = [id];
break;
default:
return;
}
openContextModal({
innerProps: {
...modalProps,
},
modal: 'addToPlaylist',
size: 'lg',
title: t('page.contextMenu.addToPlaylist'),
});
}, [id, itemType, t]);
const [isHovered, setIsHovered] = useState(false);
const showControls = isHighlighted || isHovered;
@@ -180,6 +219,29 @@ export const LibraryCommandItem = ({
)}
/>
</PlayTooltip>
<Tooltip disabled={disabled} label={t('action.addToPlaylist')}>
<ActionIcon
icon="playlistAdd"
onClick={(event) => {
event.stopPropagation();
event.preventDefault();
handleOpenPlaylistModal();
}}
onKeyDown={(e) => {
if (e.key === ' ' || e.key === 'Enter') {
e.preventDefault();
e.stopPropagation();
if (!disabled) {
handleOpenPlaylistModal();
}
} else if (e.key === 'Tab') {
e.stopPropagation();
}
}}
size="xs"
variant="default"
/>
</Tooltip>
</ActionIconGroup>
)}
</Flex>