import React, { useState, useEffect, useCallback } from 'react' import { useTheme } from 'next-themes' import siteMetadata from '@/data/siteMetadata' interface Props { mapping: string } const Giscus = ({ mapping }: Props) => { const [enableLoadComments, setEnabledLoadComments] = useState(true) const { theme, resolvedTheme } = useTheme() const commentsTheme = siteMetadata.comment.giscusConfig.themeURL === '' ? theme === 'dark' || resolvedTheme === 'dark' ? siteMetadata.comment.giscusConfig.darkTheme : siteMetadata.comment.giscusConfig.theme : siteMetadata.comment.giscusConfig.themeURL const COMMENTS_ID = 'comments-container' const LoadComments = useCallback(() => { setEnabledLoadComments(false) const script = document.createElement('script') script.src = 'https://giscus.app/client.js' script.setAttribute('data-repo', siteMetadata.comment.giscusConfig.repo) script.setAttribute('data-repo-id', siteMetadata.comment.giscusConfig.repositoryId) script.setAttribute('data-category', siteMetadata.comment.giscusConfig.category) script.setAttribute('data-category-id', siteMetadata.comment.giscusConfig.categoryId) script.setAttribute('data-mapping', mapping) script.setAttribute('data-reactions-enabled', siteMetadata.comment.giscusConfig.reactions) script.setAttribute('data-emit-metadata', siteMetadata.comment.giscusConfig.metadata) script.setAttribute('data-theme', commentsTheme) script.setAttribute('crossorigin', 'anonymous') script.async = true const comments = document.getElementById(COMMENTS_ID) if (comments) comments.appendChild(script) return () => { const comments = document.getElementById(COMMENTS_ID) if (comments) comments.innerHTML = '' } }, [commentsTheme, mapping]) // Reload on theme change useEffect(() => { const iframe = document.querySelector('iframe.giscus-frame') if (!iframe) return LoadComments() }, [LoadComments]) return (
{enableLoadComments && }
) } export default Giscus