From 535e11e229e95fbbef5f81c894a532770c8c1e84 Mon Sep 17 00:00:00 2001 From: Powerplex Date: Thu, 2 Nov 2023 16:16:32 +0100 Subject: [PATCH] fix(dialog): dialog prevent mouse events in controlled mode --- package-lock.json | 1 + .../dialog/src/DialogContent.styles.tsx | 28 +++++++---------- .../components/dialog/src/DialogContent.tsx | 30 ++++++++----------- 3 files changed, 23 insertions(+), 36 deletions(-) diff --git a/package-lock.json b/package-lock.json index 218ab29a3..fe7d80b55 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2401,6 +2401,7 @@ }, "node_modules/@clack/prompts/node_modules/is-unicode-supported": { "version": "1.3.0", + "extraneous": true, "inBundle": true, "license": "MIT", "engines": { diff --git a/packages/components/dialog/src/DialogContent.styles.tsx b/packages/components/dialog/src/DialogContent.styles.tsx index 665407aeb..29bf03170 100644 --- a/packages/components/dialog/src/DialogContent.styles.tsx +++ b/packages/components/dialog/src/DialogContent.styles.tsx @@ -1,33 +1,25 @@ import { cva, VariantProps } from 'class-variance-authority' -export const dialogContentWrapperStyles = cva([ - 'fixed inset-none z-modal flex items-center justify-center', - 'focus-visible:u-ring focus-visible:outline-none', -]) - export const dialogContentStyles = cva( - [ - ['relative', 'flex', 'flex-col'], - ['bg-surface'], - 'focus-visible:outline-none focus-visible:u-ring', - ], + ['z-modal flex flex-col bg-surface', 'focus-visible:outline-none focus-visible:u-ring'], { variants: { size: { - fullscreen: ['w-full', 'h-full'], - sm: ['max-w-sz-480'], - md: ['max-w-sz-672'], - lg: ['max-w-sz-864'], + fullscreen: 'fixed w-full h-full top-none left-none', + sm: 'max-w-sz-480', + md: 'max-w-sz-672', + lg: 'max-w-sz-864', }, }, compoundVariants: [ { size: ['sm', 'md', 'lg'], class: [ - ['w-full', 'max-h-[80%]'], - ['shadow-md', 'rounded-lg'], - ['data-[state=open]:animate-fade-in'], - ['data-[state=closed]:animate-fade-out'], + 'fixed top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2', + 'w-full max-h-[80%]', + 'shadow-md rounded-lg', + 'data-[state=open]:animate-fade-in', + 'data-[state=closed]:animate-fade-out', ], }, ], diff --git a/packages/components/dialog/src/DialogContent.tsx b/packages/components/dialog/src/DialogContent.tsx index 2579cba17..7c71f42ba 100644 --- a/packages/components/dialog/src/DialogContent.tsx +++ b/packages/components/dialog/src/DialogContent.tsx @@ -1,11 +1,7 @@ import * as RadixDialog from '@radix-ui/react-dialog' import { forwardRef, type ReactElement, type Ref, useEffect } from 'react' -import { - dialogContentStyles, - type DialogContentStylesProps, - dialogContentWrapperStyles, -} from './DialogContent.styles' +import { dialogContentStyles, type DialogContentStylesProps } from './DialogContent.styles' import { useDialog } from './DialogContext' export type ContentProps = RadixDialog.DialogContentProps & DialogContentStylesProps @@ -24,19 +20,17 @@ export const Content = forwardRef( }, [setIsFullScreen, size]) return ( -
- - {children} - -
+ + {children} + ) } )