aboutsummaryrefslogtreecommitdiff
path: root/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html
diff options
context:
space:
mode:
Diffstat (limited to 'themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html')
-rw-r--r--themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html46
1 files changed, 46 insertions, 0 deletions
diff --git a/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html b/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html
new file mode 100644
index 0000000..761801f
--- /dev/null
+++ b/themes/hugo-theme-stack/layouts/partials/comments/provider/beaudar.html
@@ -0,0 +1,46 @@
+<script
+ src="https://beaudar.lipk.org/client.js"
+ repo="{{ .Site.Params.comments.beaudar.repo }}"
+ issue-term="{{ .Site.Params.comments.beaudar.issueTerm }}"
+ {{ with .Site.Params.comments.beaudar.label }}
+ label="{{ . }}"
+ {{ end }}
+ theme="{{ .Site.Params.comments.beaudar.theme }}"
+ crossorigin="anonymous"
+ async
+></script>
+
+<style>
+ .beaudar {
+ max-width: unset;
+ }
+</style>
+
+<script>
+ let beaudarLoaded = false;
+
+ function setBeaudarTheme(theme) {
+ let beaudar = document.querySelector(".beaudar iframe");
+ if (beaudar) {
+ beaudar.contentWindow.postMessage(
+ {
+ type: "set-theme",
+ theme: `github-${theme}`,
+ },
+ "https://beaudar.lipk.org"
+ );
+ }
+ }
+
+ addEventListener("message", (event) => {
+ if (event.origin !== "https://beaudar.lipk.org") return;
+ /// Called when Beaudar is ready
+ beaudarLoaded = true;
+ setBeaudarTheme(document.documentElement.dataset.scheme);
+ });
+
+ window.addEventListener("onColorSchemeChange", (e) => {
+ if (!beaudarLoaded) return;
+ setBeaudarTheme(e.detail);
+ });
+</script>