perf(ui): disable useInert on modals

This hook forcibly updates _all_ portals with `data-hidden=true` when the modal opens - then reverts it when the modal closes. It's intended to help screen readers. Unfortunately, this absolutely tanks performance because we have many portals. React needs to do alot of layout calculations (not re-renders).

IMO this behaviour is a bug in chakra. The modals which generated the portals are hidden by default, so this data attr should really be set by default. Dunno why it isn't.
This commit is contained in:
psychedelicious 2024-08-28 16:49:19 +10:00
parent ce55a96125
commit 41e324fd51
15 changed files with 15 additions and 7 deletions

View File

@ -83,6 +83,7 @@ const ChangeBoardModal = () => {
acceptCallback={handleChangeBoard} acceptCallback={handleChangeBoard}
acceptButtonText={t('boards.move')} acceptButtonText={t('boards.move')}
cancelButtonText={t('boards.cancel')} cancelButtonText={t('boards.cancel')}
useInert={false}
> >
<Flex flexDir="column" gap={4}> <Flex flexDir="column" gap={4}>
<Text> <Text>

View File

@ -81,6 +81,7 @@ const DeleteImageModal = () => {
cancelButtonText={t('boards.cancel')} cancelButtonText={t('boards.cancel')}
acceptButtonText={t('controlnet.delete')} acceptButtonText={t('controlnet.delete')}
acceptCallback={handleDelete} acceptCallback={handleDelete}
useInert={false}
> >
<Flex direction="column" gap={3}> <Flex direction="column" gap={3}>
<ImageUsageMessage imageUsage={imageUsageSummary} /> <ImageUsageMessage imageUsage={imageUsageSummary} />

View File

@ -20,7 +20,7 @@ export const DynamicPromptsModal = memo(() => {
const { isOpen, onClose } = useDynamicPromptsModal(); const { isOpen, onClose } = useDynamicPromptsModal();
return ( return (
<Modal isOpen={isOpen} onClose={onClose} isCentered> <Modal isOpen={isOpen} onClose={onClose} isCentered useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent w="80vw" h="80vh" maxW="unset" maxH="unset"> <ModalContent w="80vw" h="80vh" maxW="unset" maxH="unset">
<ModalHeader>{t('dynamicPrompts.dynamicPrompts')}</ModalHeader> <ModalHeader>{t('dynamicPrompts.dynamicPrompts')}</ModalHeader>

View File

@ -123,6 +123,7 @@ const ModelListItem = ({ model }: ModelListItemProps) => {
title={t('modelManager.deleteModel')} title={t('modelManager.deleteModel')}
acceptCallback={handleModelDelete} acceptCallback={handleModelDelete}
acceptButtonText={t('modelManager.delete')} acceptButtonText={t('modelManager.delete')}
useInert={false}
> >
<Flex rowGap={4} flexDirection="column"> <Flex rowGap={4} flexDirection="column">
<Text fontWeight="bold">{t('modelManager.deleteMsg1')}</Text> <Text fontWeight="bold">{t('modelManager.deleteMsg1')}</Text>

View File

@ -67,6 +67,7 @@ export const ModelConvertButton = memo(({ modelConfig }: ModelConvertProps) => {
acceptButtonText={`${t('modelManager.convert')}`} acceptButtonText={`${t('modelManager.convert')}`}
isOpen={isOpen} isOpen={isOpen}
onClose={onClose} onClose={onClose}
useInert={false}
> >
<Flex flexDirection="column" rowGap={4}> <Flex flexDirection="column" rowGap={4}>
<Text fontSize="md">{t('modelManager.convertToDiffusersHelpText1')}</Text> <Text fontSize="md">{t('modelManager.convertToDiffusersHelpText1')}</Text>

View File

@ -47,6 +47,7 @@ const ClearFlowButton = () => {
onClose={onClose} onClose={onClose}
title={t('nodes.clearWorkflow')} title={t('nodes.clearWorkflow')}
acceptCallback={handleNewWorkflow} acceptCallback={handleNewWorkflow}
useInert={false}
> >
<Flex flexDir="column" gap={2}> <Flex flexDir="column" gap={2}>
<Text>{t('nodes.clearWorkflowDesc')}</Text> <Text>{t('nodes.clearWorkflowDesc')}</Text>

View File

@ -102,7 +102,7 @@ const WorkflowEditorSettings = ({ children }: Props) => {
<> <>
{children({ onOpen })} {children({ onOpen })}
<Modal isOpen={isOpen} onClose={onClose} size="2xl" isCentered> <Modal isOpen={isOpen} onClose={onClose} size="2xl" isCentered useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent> <ModalContent>
<ModalHeader>{t('nodes.workflowSettings')}</ModalHeader> <ModalHeader>{t('nodes.workflowSettings')}</ModalHeader>

View File

@ -22,6 +22,7 @@ export const ClearQueueConfirmationsAlertDialog = memo(() => {
title={t('queue.clearTooltip')} title={t('queue.clearTooltip')}
acceptCallback={clearQueue} acceptCallback={clearQueue}
acceptButtonText={t('queue.clear')} acceptButtonText={t('queue.clear')}
useInert={false}
> >
<Text>{t('queue.clearQueueAlertDialog')}</Text> <Text>{t('queue.clearQueueAlertDialog')}</Text>
<br /> <br />

View File

@ -67,7 +67,7 @@ export const StylePresetModal = () => {
}, [stylePresetModalState.prefilledFormData]); }, [stylePresetModalState.prefilledFormData]);
return ( return (
<Modal isOpen={stylePresetModalState.isModalOpen} onClose={handleCloseModal} isCentered size="2xl"> <Modal isOpen={stylePresetModalState.isModalOpen} onClose={handleCloseModal} isCentered size="2xl" useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent> <ModalContent>
<ModalHeader>{modalTitle}</ModalHeader> <ModalHeader>{modalTitle}</ModalHeader>

View File

@ -179,6 +179,7 @@ export const StylePresetListItem = ({ preset }: { preset: StylePresetRecordWithI
acceptCallback={handleDeletePreset} acceptCallback={handleDeletePreset}
acceptButtonText={t('common.delete')} acceptButtonText={t('common.delete')}
cancelButtonText={t('common.cancel')} cancelButtonText={t('common.cancel')}
useInert={false}
> >
<p>{t('stylePresets.deleteTemplate2')}</p> <p>{t('stylePresets.deleteTemplate2')}</p>
</ConfirmationAlertDialog> </ConfirmationAlertDialog>

View File

@ -53,7 +53,7 @@ const AboutModal = ({ children }: AboutModalProps) => {
{cloneElement(children, { {cloneElement(children, {
onClick: onOpen, onClick: onOpen,
})} })}
<Modal isOpen={isOpen} onClose={onClose} isCentered size="2xl"> <Modal isOpen={isOpen} onClose={onClose} isCentered size="2xl" useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent maxH="80vh" h="34rem"> <ModalContent maxH="80vh" h="34rem">
<ModalHeader>{t('accessibility.about')}</ModalHeader> <ModalHeader>{t('accessibility.about')}</ModalHeader>

View File

@ -70,7 +70,7 @@ const HotkeysModal = ({ children }: HotkeysModalProps) => {
{cloneElement(children, { {cloneElement(children, {
onClick: onOpen, onClick: onOpen,
})} })}
<Modal isOpen={isOpen} onClose={onClose} isCentered size="2xl"> <Modal isOpen={isOpen} onClose={onClose} isCentered size="2xl" useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent maxH="80vh" h="80vh"> <ModalContent maxH="80vh" h="80vh">
<ModalHeader>{t('hotkeys.keyboardShortcuts')}</ModalHeader> <ModalHeader>{t('hotkeys.keyboardShortcuts')}</ModalHeader>

View File

@ -62,7 +62,7 @@ export const LoadWorkflowFromGraphModal = () => {
onClose(); onClose();
}, [dispatch, onClose, workflowRaw]); }, [dispatch, onClose, workflowRaw]);
return ( return (
<Modal isOpen={isOpen} onClose={onClose} isCentered> <Modal isOpen={isOpen} onClose={onClose} isCentered useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent w="80vw" h="80vh" maxW="unset" maxH="unset"> <ModalContent w="80vw" h="80vh" maxW="unset" maxH="unset">
<ModalHeader>{t('workflows.loadFromGraph')}</ModalHeader> <ModalHeader>{t('workflows.loadFromGraph')}</ModalHeader>

View File

@ -46,6 +46,7 @@ export const NewWorkflowConfirmationAlertDialog = memo((props: Props) => {
onClose={onClose} onClose={onClose}
title={t('nodes.newWorkflow')} title={t('nodes.newWorkflow')}
acceptCallback={handleNewWorkflow} acceptCallback={handleNewWorkflow}
useInert={false}
> >
<Flex flexDir="column" gap={2}> <Flex flexDir="column" gap={2}>
<Text>{t('nodes.newWorkflowDesc')}</Text> <Text>{t('nodes.newWorkflowDesc')}</Text>

View File

@ -16,7 +16,7 @@ const WorkflowLibraryModal = () => {
const { t } = useTranslation(); const { t } = useTranslation();
const { isOpen, onClose } = useWorkflowLibraryModalContext(); const { isOpen, onClose } = useWorkflowLibraryModalContext();
return ( return (
<Modal isOpen={isOpen} onClose={onClose} isCentered> <Modal isOpen={isOpen} onClose={onClose} isCentered useInert={false}>
<ModalOverlay /> <ModalOverlay />
<ModalContent w="80%" h="80%" minW="unset" minH="unset" maxW="1200px" maxH="664px"> <ModalContent w="80%" h="80%" minW="unset" minH="unset" maxW="1200px" maxH="664px">
<ModalHeader>{t('workflows.workflowLibrary')}</ModalHeader> <ModalHeader>{t('workflows.workflowLibrary')}</ModalHeader>