From 13ed5991179a497545cc5ed0ce98bb6a336c1b6a Mon Sep 17 00:00:00 2001 From: Rafi Zadanly Date: Tue, 16 May 2023 14:39:49 +0700 Subject: Delay Render components --- src/core/components/elements/DelayRender/DelayRender.js | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 src/core/components/elements/DelayRender/DelayRender.js (limited to 'src/core/components/elements') diff --git a/src/core/components/elements/DelayRender/DelayRender.js b/src/core/components/elements/DelayRender/DelayRender.js new file mode 100644 index 00000000..c0ff0fc0 --- /dev/null +++ b/src/core/components/elements/DelayRender/DelayRender.js @@ -0,0 +1,17 @@ +const { useState, useEffect } = require('react') + +const DelayRender = ({ delay, children }) => { + const [showComponent, setShowComponent] = useState(false) + + useEffect(() => { + const timeout = setTimeout(() => { + setShowComponent(true) + }, delay) + + return () => clearTimeout(timeout) + }, [delay]) + + return showComponent && children +} + +export default DelayRender -- cgit v1.2.3