
META-INF.resources.js.components.screen_reader_announcer.ScreenReaderAnnouncer.tsx Maven / Gradle / Ivy
/**
* SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
* SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
*/
import {useIsMounted} from '@liferay/frontend-js-react-web';
import React, {
AriaAttributes,
useCallback,
useImperativeHandle,
useState,
} from 'react';
type ScreenReaderAnnouncerProps = {
'aria-atomic'?: AriaAttributes['aria-atomic'];
'aria-live'?: AriaAttributes['aria-live'];
};
const ScreenReaderAnnouncer = React.forwardRef(
(
{'aria-atomic': ariaAtomic = false, 'aria-live': ariaLive = 'polite'},
ref
) => {
const [message, setMessage] = useState('');
const isMounted = useIsMounted();
const sendMessage = useCallback(
(message: string) => {
setMessage(message);
setTimeout(() => {
if (isMounted()) {
setMessage('');
}
}, 10000);
},
[isMounted]
);
useImperativeHandle(ref, () => ({sendMessage}));
return (
{message}
);
}
);
export default ScreenReaderAnnouncer;
© 2015 - 2025 Weber Informatics LLC | Privacy Policy