2023-09-26 22:12:38 +01:00
|
|
|
{{- $lang := site.Language.LanguageCode | default `en` -}}
|
2023-09-27 04:47:22 +09:00
|
|
|
|
2023-09-26 23:33:27 +01:00
|
|
|
{{- with site.Params.comments.giscus -}}
|
2023-09-27 04:47:22 +09:00
|
|
|
<script>
|
|
|
|
/*
|
|
|
|
* "preferred color scheme" theme in giscus works using "prefers-color-scheme" in media query.
|
|
|
|
* but, hugo's theme switch function works by using "color-theme" in local storage.
|
|
|
|
* This solution was created with reference to:
|
|
|
|
* https://github.com/giscus/giscus/issues/336#issuecomment-1214366281
|
|
|
|
*/
|
2024-12-26 21:29:21 +09:00
|
|
|
function getHugoTheme() {
|
2023-09-27 04:47:22 +09:00
|
|
|
return localStorage.getItem("color-theme");
|
|
|
|
}
|
2024-12-26 21:29:21 +09:00
|
|
|
|
|
|
|
function getGiscusTheme() {
|
|
|
|
let giscusTheme = "{{ (string .theme) | default `light` }}";
|
2025-08-06 08:01:00 +08:00
|
|
|
let hugoTheme = getHugoTheme();
|
|
|
|
if(hugoTheme == 'light') {
|
2024-12-26 21:29:21 +09:00
|
|
|
return giscusTheme.replace('dark', 'light');
|
2025-08-06 08:01:00 +08:00
|
|
|
}
|
|
|
|
if(hugoTheme == 'dark') {
|
2024-12-26 21:29:21 +09:00
|
|
|
return giscusTheme.replace('light', 'dark');
|
|
|
|
}
|
2025-08-06 08:01:00 +08:00
|
|
|
return giscusTheme;
|
2024-12-26 21:29:21 +09:00
|
|
|
}
|
2023-09-27 04:47:22 +09:00
|
|
|
|
|
|
|
function setGiscusTheme() {
|
|
|
|
function sendMessage(message) {
|
|
|
|
const iframe = document.querySelector('iframe.giscus-frame');
|
|
|
|
if (!iframe) return;
|
|
|
|
iframe.contentWindow.postMessage({ giscus: message }, 'https://giscus.app');
|
|
|
|
}
|
|
|
|
sendMessage({
|
|
|
|
setConfig: {
|
|
|
|
theme: getGiscusTheme(),
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
document.addEventListener('DOMContentLoaded', function () {
|
|
|
|
const giscusAttributes = {
|
|
|
|
"src": "https://giscus.app/client.js",
|
|
|
|
"data-repo": "{{ .repo }}",
|
|
|
|
"data-repo-id": "{{ .repoId }}",
|
|
|
|
"data-category": "{{ .category }}",
|
|
|
|
"data-category-id": "{{ .categoryId }}",
|
|
|
|
"data-mapping": "{{ .mapping | default `pathname` }}",
|
|
|
|
"data-strict": "{{ (string .strict) | default 0 }}",
|
|
|
|
"data-reactions-enabled": "{{ (string .reactionsEnabled) | default 1 }}",
|
|
|
|
"data-emit-metadata": "{{ (string .emitMetadata) | default 0 }}",
|
|
|
|
"data-input-position": "{{ .inputPosition | default `top` }}",
|
|
|
|
"data-theme": getGiscusTheme(),
|
|
|
|
"data-lang": "{{ .lang | default $lang }}",
|
|
|
|
"crossorigin": "anonymous",
|
|
|
|
"async": "",
|
|
|
|
};
|
|
|
|
|
|
|
|
// Dynamically create script tag
|
|
|
|
const giscusScript = document.createElement("script");
|
|
|
|
Object.entries(giscusAttributes).forEach(([key, value]) => giscusScript.setAttribute(key, value));
|
|
|
|
document.getElementById('giscus').appendChild(giscusScript);
|
|
|
|
|
|
|
|
// Update giscus theme when theme switcher is clicked
|
refactor(css): add prefix to component classes for consistency (#744)
* refactor(navbar): add hextra prefix to navbar and hamburger menu classes
- Updated CSS class names from `nav-container` to `hextra-nav-container` and `hamburger-menu` to `hextra-hamburger-menu` for improved clarity and consistency across the project.
- Adjusted related JavaScript and documentation to reflect the new class names.
* refactor(search): update class names for search components
- Renamed CSS classes from `search-wrapper`, `search-input`, `active`, `no-result`, `prefix`, `excerpt`, and `match` to `hextra-search-wrapper`, `hextra-search-input`, `hextra-search-active`, `hextra-search-no-result`, `hextra-search-prefix`, `hextra-search-excerpt`, and `hextra-search-match` for improved clarity and consistency.
- Updated JavaScript selectors to match the new class names, ensuring functionality remains intact.
- Adjusted HTML structure to reflect the new class naming convention.
* refactor(search): update search component class names for consistency
- Renamed existing search-related CSS classes to include the `hextra` prefix for improved clarity and consistency.
- Added optional nested classes for enhanced customization of the search UI, including titles, active states, and result snippets.
- Removed outdated breadcrumb section as no specific class is available.
* refactor(sidebar): rename sidebar classes for consistency
- Updated CSS and JavaScript to replace `sidebar-container` with `hextra-sidebar-container` and `sidebar-active-item` with `hextra-sidebar-active-item` for improved clarity and consistency across the project.
- Adjusted related documentation to reflect the new class names.
* refactor(language & theme): update class names for consistency
- Renamed language switcher and theme toggle classes to include the `hextra` prefix for improved clarity and consistency across the project.
- Updated related JavaScript selectors and documentation to reflect the new class names.
* refactor(css & html): rename classes for consistency and clarity
- Updated various CSS class names to include the `hextra` prefix, enhancing consistency across the project. This includes renaming classes such as `content` to `hextra-content`, `filename` to `hextra-code-filename`, and `steps` to `hextra-steps`.
- Adjusted related HTML and JavaScript to reflect the new class names, ensuring functionality and styling remain intact.
- Updated documentation to include the new class names for better clarity.
* refactor(language): update class names for language options
- Renamed the `language-options` class to `hextra-language-options` for consistency with the existing `hextra` prefix convention.
- Updated the corresponding HTML to reflect the new class name, ensuring clarity and uniformity across the project.
* refactor(css & html): rename classes for consistency and clarity
- Renamed CSS classes to include the `hextra` prefix, such as changing `subheading-anchor` to `hextra-subheading-anchor` and `footnotes` to `hextra-footnotes`, enhancing consistency across the project.
- Updated related HTML and documentation to reflect the new class names, ensuring clarity and uniformity.
* feat(typography): add styling for horizontal lines
- Introduced new styles for horizontal lines to enhance visual separation in content. The styles apply margin and border color adjustments, ensuring consistency with the overall design.
* feat(blog): add draft release announcement for Hextra v0.10.0
- Created a new markdown file for the draft release announcement of Hextra v0.10.0, including upgrade instructions and author details.
- The announcement is currently marked as a draft and may be updated before the official release.
* refactor(css & html): rename `hextra-content` class to `content` for consistency
- Updated the `hextra-content` class to simply `content` across various HTML files and CSS, enhancing clarity and consistency in the codebase.
- Adjusted the `package.json` script for the development server to include the `-F` flag for better functionality.
* refactor(typography & markdown): enhance table styling and markdown syntax
- Updated CSS for tables to improve styling, including adjustments to margins, borders, and text properties for better readability.
- Revised markdown documentation to standardize table formatting and improve clarity, including consistent syntax for headers and lists.
- Enhanced examples in the documentation to reflect the updated styling and ensure accurate representation of output.
* fix(blog): update text color for improved accessibility
- Modified the text color in the blog single layout to enhance readability in dark mode by adding a dark text color class.
- Ensured consistency in styling for better user experience across different themes.
* docs(blog): update draft release announcement for Hextra v0.10.0
- Revised the "What's New" section to include a TODO placeholder for future updates.
- Added a comprehensive migration guide detailing the CSS class prefix changes to enhance consistency and avoid conflicts.
- Updated the announcement to reflect the new class naming conventions for various components.
* chore: rebuild css
2025-08-13 22:55:38 +08:00
|
|
|
const toggles = document.querySelectorAll(".hextra-theme-toggle");
|
2023-09-26 22:12:38 +01:00
|
|
|
if (toggles) {
|
|
|
|
toggles.forEach(toggle => toggle.addEventListener('click', setGiscusTheme));
|
2023-09-27 04:47:22 +09:00
|
|
|
}
|
|
|
|
});
|
|
|
|
</script>
|
2023-09-26 22:12:38 +01:00
|
|
|
|
2023-09-27 04:47:22 +09:00
|
|
|
<div id="giscus"></div>
|
2023-09-26 23:33:27 +01:00
|
|
|
{{- else -}}
|
|
|
|
{{ warnf "giscus is not configured" }}
|
2023-09-27 04:47:22 +09:00
|
|
|
{{- end -}}
|