153 lines
4.1 KiB
TypeScript
153 lines
4.1 KiB
TypeScript
import { useState } from 'react'
|
|
import { Box, SpanBox } from '../../elements/LayoutPrimitives'
|
|
import { LibraryItemNode } from '../../../lib/networking/queries/useGetLibraryItemsQuery'
|
|
import { LinkedItemCardAction } from './CardTypes'
|
|
import { Button } from '../../elements/Button'
|
|
import { theme } from '../../tokens/stitches.config'
|
|
import {
|
|
ArchiveBox,
|
|
DotsThree,
|
|
Notebook,
|
|
Tag,
|
|
Trash,
|
|
Tray,
|
|
} from 'phosphor-react'
|
|
import { CardMenu } from '../CardMenu'
|
|
import { UserBasicData } from '../../../lib/networking/queries/useGetViewerQuery'
|
|
import { useFloating, shift, offset } from '@floating-ui/react'
|
|
|
|
type LibraryHoverActionsProps = {
|
|
anchor: HTMLDivElement | null
|
|
viewer: UserBasicData
|
|
|
|
isHovered: boolean
|
|
|
|
item: LibraryItemNode
|
|
handleAction: (action: LinkedItemCardAction) => void
|
|
}
|
|
|
|
export const LibraryHoverActions = (props: LibraryHoverActionsProps) => {
|
|
const [menuOpen, setMenuOpen] = useState(false)
|
|
const { refs, floatingStyles } = useFloating({
|
|
elements: {
|
|
reference: props.anchor,
|
|
},
|
|
middleware: [
|
|
offset({
|
|
mainAxis: -44,
|
|
crossAxis: -10,
|
|
}),
|
|
],
|
|
placement: 'top-end',
|
|
})
|
|
|
|
return (
|
|
<Box ref={refs.setFloating} style={floatingStyles}>
|
|
<Box
|
|
css={{
|
|
// position: 'fixed',
|
|
// transform: 'translate(621px, 73px)',
|
|
|
|
// top: '5px',
|
|
// right: '155px',
|
|
// marginTop: '-33px',
|
|
// marginRight: '-162px',
|
|
overflow: 'clip',
|
|
|
|
height: '33px',
|
|
width: '162px',
|
|
bg: '$thBackground',
|
|
display: 'flex',
|
|
marginLeft: 'auto',
|
|
|
|
pt: '0px',
|
|
alignItems: 'center',
|
|
justifyContent: 'center',
|
|
border: '1px solid $thBackground5',
|
|
borderRadius: '5px',
|
|
|
|
gap: '5px',
|
|
px: '5px',
|
|
visibility: props.isHovered || menuOpen ? 'unset' : 'hidden',
|
|
'&:hover': {
|
|
boxShadow:
|
|
'0 1px 3px 0 rgba(0, 0, 0, 0.1),0 1px 2px 0 rgba(0, 0, 0, 0.06);',
|
|
},
|
|
}}
|
|
>
|
|
<Button
|
|
style="hoverActionIcon"
|
|
onClick={(event) => {
|
|
props.handleAction('open-notebook')
|
|
event.preventDefault()
|
|
}}
|
|
>
|
|
<Notebook
|
|
size={19}
|
|
color={theme.colors.thNotebookSubtle.toString()}
|
|
/>
|
|
</Button>
|
|
<Button
|
|
style="hoverActionIcon"
|
|
onClick={(event) => {
|
|
const action = props.item.isArchived ? 'unarchive' : 'archive'
|
|
props.handleAction(action)
|
|
event.preventDefault()
|
|
}}
|
|
>
|
|
{props.item.isArchived ? (
|
|
<Tray size={18} color={theme.colors.thNotebookSubtle.toString()} />
|
|
) : (
|
|
<ArchiveBox
|
|
size={18}
|
|
color={theme.colors.thNotebookSubtle.toString()}
|
|
/>
|
|
)}
|
|
</Button>
|
|
<Button
|
|
style="hoverActionIcon"
|
|
onClick={(event) => {
|
|
props.handleAction('delete')
|
|
event.preventDefault()
|
|
}}
|
|
>
|
|
<Trash size={18} color={theme.colors.thNotebookSubtle.toString()} />
|
|
</Button>
|
|
<Button
|
|
style="hoverActionIcon"
|
|
onClick={(event) => {
|
|
props.handleAction('set-labels')
|
|
event.preventDefault()
|
|
}}
|
|
>
|
|
<Tag size={18} color={theme.colors.thNotebookSubtle.toString()} />
|
|
</Button>
|
|
<CardMenu
|
|
item={props.item}
|
|
viewer={props.viewer}
|
|
onOpenChange={(open) => setMenuOpen(open)}
|
|
actionHandler={props.handleAction}
|
|
triggerElement={
|
|
<SpanBox
|
|
css={{
|
|
display: 'flex',
|
|
pt: '2.5px',
|
|
height: '33px',
|
|
'&:hover': {
|
|
bg: '$grayBgHover',
|
|
},
|
|
}}
|
|
>
|
|
<DotsThree
|
|
size={25}
|
|
weight="bold"
|
|
color={theme.colors.thNotebookSubtle.toString()}
|
|
/>
|
|
</SpanBox>
|
|
}
|
|
/>
|
|
</Box>
|
|
</Box>
|
|
)
|
|
}
|