Files
supabase/packages/ui-patterns/Cmdk/CommandMenuShortcuts.tsx
Francesco Sansalvadore 6b0ea89f5b cmdk mobile improvements (#27815)
mobile cmdk new layout and animation
2024-07-10 10:30:07 +02:00

54 lines
1.6 KiB
TypeScript

import { IconArrowLeft } from 'ui/src/components/Icon/icons/IconArrowLeft'
import { BadgeExperimental } from './Command.Badges'
import { COMMAND_ROUTES } from './Command.constants'
import { CommandShortcut } from './Command.utils'
import { useCommandMenu } from './CommandMenuContext'
export default function CommandMenuShortcuts() {
const { setPages, pages, currentPage } = useCommandMenu()
return (
<div className="flex w-full gap-2 px-4 pt-4 pb-2 justify-items-start flex-row items-center justify-between">
<div className="flex gap-2 flex-row items-center">
<CommandShortcut onClick={() => setPages([])}>
<div className="flex items-center gap-2">
<IconArrowLeft width={15} height={15} />
</div>
</CommandShortcut>
{pages.map((page, index) => (
<CommandShortcut
type={page === currentPage ? 'breadcrumb' : 'default'}
key={page}
onClick={() => {
if (index === pages.length - 1) {
return
}
setPages(pages.slice(0, index - 1))
}}
>
{page}
</CommandShortcut>
))}
{currentPage && isExperimental(currentPage) && <BadgeExperimental />}
</div>
</div>
)
}
/**
* TODO: remove this function and store this info on each page
* Temporary function to determine whether or not to show 'Experimental' badge
*/
function isExperimental(page: string) {
switch (page) {
case COMMAND_ROUTES.AI:
case COMMAND_ROUTES.GENERATE_SQL:
return true
default:
return false
}
}