From 584bd42f871d2e1618ca414749f09c38f0143a44 Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Wed, 18 May 2022 22:40:59 +0200 Subject: chore: handle settings change --- src/utils/hooks/use-code-blocks-theme.tsx | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 src/utils/hooks/use-code-blocks-theme.tsx (limited to 'src/utils/hooks/use-code-blocks-theme.tsx') diff --git a/src/utils/hooks/use-code-blocks-theme.tsx b/src/utils/hooks/use-code-blocks-theme.tsx new file mode 100644 index 0000000..beb7b29 --- /dev/null +++ b/src/utils/hooks/use-code-blocks-theme.tsx @@ -0,0 +1,22 @@ +import { usePrismTheme } from '@utils/providers/prism-theme'; +import { useRouter } from 'next/router'; +import { RefObject, useEffect, useState } from 'react'; +import useIsMounted from './use-is-mounted'; + +const useCodeBlocksTheme = (el: RefObject) => { + const [preElements, setPreElements] = useState>(); + const isMounted = useIsMounted(el); + const { setCodeBlocks } = usePrismTheme(); + const { asPath } = useRouter(); + + useEffect(() => { + const result = document.querySelectorAll('pre'); + setPreElements(result); + }, [asPath]); + + useEffect(() => { + isMounted && preElements && setCodeBlocks(preElements); + }, [isMounted, preElements, setCodeBlocks]); +}; + +export default useCodeBlocksTheme; -- cgit v1.2.3