Add comments support for Beaudar(表达)

This commit is contained in:
hongjr03 2024-01-18 19:58:01 +08:00
parent 40234ff23a
commit badb1bbdfe
3 changed files with 55 additions and 13 deletions

View File

@ -51,6 +51,12 @@ params:
issueTerm: pathname issueTerm: pathname
label: label:
beaudar:
repo:
issueTerm: pathname
label:
theme:
remark42: remark42:
host: host:
site: site:

View File

@ -91,6 +91,12 @@ params:
issueTerm: pathname issueTerm: pathname
label: label:
beaudar:
repo:
issueTerm: pathname
label:
theme:
remark42: remark42:
host: host:
site: site:

View File

@ -1,16 +1,46 @@
<script src="https://beaudar.lipk.org/client.js" <script
repo="{{ .Site.Params.comments.beaudar.repo }}" src="https://beaudar.lipk.org/client.js"
issue-term="{{ .Site.Params.comments.beaudar.issueTerm }}" repo="{{ .Site.Params.comments.beaudar.repo }}"
{{ with .Site.Params.comments.beaudar.label }} issue-term="{{ .Site.Params.comments.beaudar.issueTerm }}"
label="{{ . }}" {{ with .Site.Params.comments.beaudar.label }}
{{ end }} label="{{ . }}"
crossorigin="anonymous" {{ end }}
async theme="{{ .Site.Params.comments.beaudar.theme }}"
> crossorigin="anonymous"
</script> async
></script>
<style> <style>
.beaudar { .beaudar {
max-width: unset; 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"
);
} }
</style> }
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>