mirror of
https://github.com/mastodon/mastodon.git
synced 2026-05-04 20:37:56 -05:00
Some checks are pending
Check i18n / check-i18n (push) Waiting to run
Chromatic / Run Chromatic (push) Waiting to run
CodeQL / Analyze (actions) (push) Waiting to run
CodeQL / Analyze (javascript) (push) Waiting to run
CodeQL / Analyze (ruby) (push) Waiting to run
Check formatting / lint (push) Waiting to run
CSS Linting / lint (push) Waiting to run
JavaScript Linting / lint (push) Waiting to run
Ruby Linting / lint (push) Waiting to run
JavaScript Testing / test (push) Waiting to run
Historical data migration test / test (14-alpine) (push) Waiting to run
Historical data migration test / test (15-alpine) (push) Waiting to run
Historical data migration test / test (16-alpine) (push) Waiting to run
Historical data migration test / test (17-alpine) (push) Waiting to run
Ruby Testing / build (production) (push) Waiting to run
Ruby Testing / build (test) (push) Waiting to run
Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
Ruby Testing / test (3.2) (push) Blocked by required conditions
Ruby Testing / test (3.3) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (.ruby-version) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.2) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.3) (push) Blocked by required conditions
Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.3) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.3, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Co-authored-by: diondiondion <mail@diondiondion.com>
55 lines
1.6 KiB
TypeScript
55 lines
1.6 KiB
TypeScript
import { useEffect, useState } from 'react';
|
|
|
|
/**
|
|
* A helper component for managing the rendering of components that
|
|
* need to stay in the DOM a bit longer to finish their CSS exit animation.
|
|
*
|
|
* In the future, replace this component with plain CSS once that is feasible.
|
|
* This will require broader support for `transition-behavior: allow-discrete`
|
|
* and https://developer.mozilla.org/en-US/docs/Web/CSS/overlay.
|
|
*/
|
|
export const ExitAnimationWrapper: React.FC<{
|
|
/**
|
|
* Set this to true to indicate that the nested component should be rendered
|
|
*/
|
|
isActive: boolean;
|
|
/**
|
|
* How long the component should be rendered after `isActive` was set to `false`
|
|
*/
|
|
delayMs?: number;
|
|
/**
|
|
* Set this to true to also delay the entry of the nested component until after
|
|
* another one has exited full.
|
|
*/
|
|
withEntryDelay?: boolean;
|
|
/**
|
|
* Render prop that provides the nested component with the `delayedIsActive` flag
|
|
*/
|
|
children: (delayedIsActive: boolean) => React.ReactNode;
|
|
}> = ({ isActive = false, delayMs = 500, withEntryDelay, children }) => {
|
|
const [delayedIsActive, setDelayedIsActive] = useState(
|
|
isActive && !withEntryDelay,
|
|
);
|
|
|
|
useEffect(() => {
|
|
const withDelay = !isActive || withEntryDelay;
|
|
|
|
const timeout = setTimeout(
|
|
() => {
|
|
setDelayedIsActive(isActive);
|
|
},
|
|
withDelay ? delayMs : 0,
|
|
);
|
|
|
|
return () => {
|
|
clearTimeout(timeout);
|
|
};
|
|
}, [isActive, delayMs, withEntryDelay]);
|
|
|
|
if (!isActive && !delayedIsActive) {
|
|
return null;
|
|
}
|
|
|
|
return children(isActive && delayedIsActive);
|
|
};
|