Update dialog

This commit is contained in:
Gregory Schier
2023-03-25 21:59:18 -07:00
parent 1589235b3f
commit def3c712c9
2 changed files with 28 additions and 13 deletions

View File

@@ -9,6 +9,7 @@ import { useUpdateAnyRequest } from '../hooks/useUpdateAnyRequest';
import { useUpdateRequest } from '../hooks/useUpdateRequest';
import type { HttpRequest } from '../lib/models';
import { Button } from './core/Button';
import { Dialog } from './core/Dialog';
import { IconButton } from './core/IconButton';
import { HStack, VStack } from './core/Stacks';
import { DropMarker } from './DropMarker';
@@ -32,6 +33,7 @@ export const Sidebar = memo(function Sidebar({ className }: Props) {
[unorderedRequests],
);
const [open, setOpen] = useState<boolean>(false);
return (
<div className="relative h-full">
<div
@@ -46,6 +48,10 @@ export const Sidebar = memo(function Sidebar({ className }: Props) {
<SidebarItems activeRequestId={activeRequest?.id} requests={requests} />
</VStack>
<HStack className="mx-1 pb-1" alignItems="center" justifyContent="end">
<Dialog open={open} onOpenChange={setOpen} title={'Cool Thing'}>
Hello?
</Dialog>
<IconButton title="" icon="magicWand" onClick={() => setOpen(true)} />
<ToggleThemeButton />
</HStack>
</div>

View File

@@ -1,7 +1,7 @@
import * as D from '@radix-ui/react-dialog';
import classnames from 'classnames';
import { motion } from 'framer-motion';
import type { ReactNode } from 'react';
import { Portal } from '../Portal';
import { IconButton } from './IconButton';
import { HStack, VStack } from './Stacks';
@@ -25,11 +25,15 @@ export function Dialog({
description,
}: Props) {
return (
<D.Root open={open} onOpenChange={onOpenChange}>
<D.Portal container={document.querySelector<HTMLElement>('#radix-portal')}>
<Portal name="dialog">
{open && (
<motion.div initial={{ opacity: 0 }} animate={{ opacity: 1 }}>
<D.Overlay className="fixed inset-0 bg-gray-600/60 dark:bg-black/50" />
<D.Content>
<div
aria-hidden
onClick={() => onOpenChange(false)}
className="fixed inset-0 bg-gray-600/60 dark:bg-black/50"
/>
<div>
<div
className={classnames(
className,
@@ -39,20 +43,25 @@ export function Dialog({
wide && 'w-[80vw] max-w-[50rem]',
)}
>
<D.Close asChild className="ml-auto absolute right-1 top-1">
<IconButton title="Close dialog" aria-label="Close" icon="x" size="sm" />
</D.Close>
<IconButton
onClick={() => onOpenChange(false)}
title="Close dialog"
aria-label="Close"
icon="x"
size="sm"
className="ml-auto absolute right-1 top-1"
/>
<VStack space={3}>
<HStack alignItems="center" className="pb-3">
<D.Title className="text-xl font-semibold">{title}</D.Title>
<div className="text-xl font-semibold">{title}</div>
</HStack>
{description && <D.Description>{description}</D.Description>}
{description && <div>{description}</div>}
<div>{children}</div>
</VStack>
</div>
</D.Content>
</div>
</motion.div>
</D.Portal>
</D.Root>
)}
</Portal>
);
}