Skip to content

Commit

Permalink
ADD REACT GISCUS
Browse files Browse the repository at this point in the history
  • Loading branch information
Gjeev committed Aug 17, 2024
1 parent c5dd93f commit 2db96fd
Show file tree
Hide file tree
Showing 5 changed files with 135 additions and 20 deletions.
71 changes: 67 additions & 4 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"dependencies": {
"@astrojs/check": "^0.9.1",
"@astrojs/rss": "^4.0.7",
"@giscus/react": "^3.0.0",
"@resvg/resvg-js": "^2.6.2",
"astro": "^4.13.0",
"fuse.js": "^7.0.0",
Expand Down
51 changes: 51 additions & 0 deletions src/components/Comments.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
import Giscus, { type Theme } from "@giscus/react";
import { GISCUS } from "@config";
import { useEffect, useState } from "react";

interface CommentsProps {
lightTheme?: Theme;
darkTheme?: Theme;
}

export default function Comments({
lightTheme = "light",
darkTheme = "dark",
}: CommentsProps) {
const [theme, setTheme] = useState(() => {
const currentTheme = localStorage.getItem("theme");
const browserTheme = window.matchMedia("(prefers-color-scheme: dark)")
.matches
? "dark"
: "light";

return currentTheme || browserTheme;
});

useEffect(() => {
const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)");
const handleChange = ({ matches }: MediaQueryListEvent) => {
setTheme(matches ? "dark" : "light");
};

mediaQuery.addEventListener("change", handleChange);

return () => mediaQuery.removeEventListener("change", handleChange);
}, []);

useEffect(() => {
const themeButton = document.querySelector("#theme-btn");
const handleClick = () => {
setTheme(prevTheme => (prevTheme === "dark" ? "light" : "dark"));
};

themeButton?.addEventListener("click", handleClick);

return () => themeButton?.removeEventListener("click", handleClick);
}, []);

return (
<div className="mt-8">
<Giscus theme={theme === "light" ? lightTheme : darkTheme} {...GISCUS} />
</div>
);
}
14 changes: 14 additions & 0 deletions src/config.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import type { Site, SocialObjects } from "./types";
import type { GiscusProps } from "@giscus/react";

export const SITE: Site = {
website: "https://astro-paper.pages.dev/", // replace this with your deployed domain
Expand Down Expand Up @@ -45,3 +46,16 @@ export const SOCIALS: SocialObjects = [
active: false,
},
];

export const GISCUS: GiscusProps = {
repo: "grassroots-musings/grassroots-musings.github.io",
repoId: "R_kgDOMknjLw",
category: "Announcements",
categoryId: "DIC_kwDOMknjL84ChvL5",
mapping: "title",
reactionsEnabled: "1",
emitMetadata: "0",
inputPosition: "top",
lang: "en",
loading: "lazy",
};
18 changes: 2 additions & 16 deletions src/layouts/PostDetails.astro
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import type { CollectionEntry } from "astro:content";
import { slugifyStr } from "@utils/slugify";
import ShareLinks from "@components/ShareLinks.astro";
import { SITE } from "@config";
import Comments from "@components/Comments.tsx";
export interface Props {
post: CollectionEntry<"blog">;
Expand Down Expand Up @@ -95,22 +96,7 @@ const layoutProps = {

<ShareLinks />
</div>
<script src="https://giscus.app/client.js"
data-repo="grassroots-musings/grassroots-musings.github.io"
data-repo-id="R_kgDOMknjLw"
data-category="Announcements"
data-category-id="DIC_kwDOMknjL84ChvL5"
data-mapping="title"
data-strict="0"
data-reactions-enabled="1"
data-emit-metadata="0"
data-input-position="top"
data-theme="light"
data-lang="en"
data-loading="lazy"
crossorigin="anonymous"
async>
</script>
<Comments client:only />
</main>
<Footer />
</Layout>
Expand Down

0 comments on commit 2db96fd

Please sign in to comment.