mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
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:
parent
ce55a96125
commit
41e324fd51
@ -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>
|
||||||
|
@ -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} />
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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 />
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user