2024-10-13 14:26:50 +00:00
<!DOCTYPE html>
2024-12-07 23:18:07 +00:00
< html lang = "en" dir = "ltr" itemscope itemtype = "http://schema.org/Article" data-r-output-format = "print" >
2024-10-13 14:26:50 +00:00
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "height=device-height, width=device-width, initial-scale=1.0, minimum-scale=1.0" >
2024-12-30 19:05:25 +00:00
< meta name = "generator" content = "Hugo 0.140.2" >
2025-01-02 21:41:58 +00:00
< meta name = "generator" content = "Relearn 7.3.0+4f9b02f2e43556319e73b38edde19e1d262757c1" >
2024-10-13 14:26:50 +00:00
< meta name = "description" content = "Customize files for advanced usage" >
< meta name = "author" content = "Sören Weber" >
< meta name = "twitter:card" content = "summary_large_image" >
< meta name = "twitter:image" content = "https://mcshelby.github.io/hugo-theme-relearn/images/hero.png" >
< meta name = "twitter:title" content = "Customization :: Hugo Relearn Theme" >
< meta name = "twitter:description" content = "Customize files for advanced usage" >
< meta property = "og:url" content = "https://mcshelby.github.io/hugo-theme-relearn/configuration/customization/index.html" >
< meta property = "og:site_name" content = "Hugo Relearn Theme" >
< meta property = "og:title" content = "Customization :: Hugo Relearn Theme" >
< meta property = "og:description" content = "Customize files for advanced usage" >
< meta property = "og:locale" content = "en" >
< meta property = "og:type" content = "website" >
< meta property = "og:image" content = "https://mcshelby.github.io/hugo-theme-relearn/images/hero.png" >
< meta itemprop = "name" content = "Customization :: Hugo Relearn Theme" >
< meta itemprop = "description" content = "Customize files for advanced usage" >
< meta itemprop = "wordCount" content = "40" >
< meta itemprop = "image" content = "https://mcshelby.github.io/hugo-theme-relearn/images/hero.png" >
< meta itemprop = "keywords" content = "Reference" >
< title > Customization :: Hugo Relearn Theme< / title >
< link href = "https://mcshelby.github.io/hugo-theme-relearn/configuration/customization/index.html" rel = "alternate" hreflang = "x-default" >
< link href = "https://mcshelby.github.io/hugo-theme-relearn/configuration/customization/index.html" rel = "alternate" hreflang = "en" >
< link href = "https://mcshelby.github.io/hugo-theme-relearn/pir/configuration/customization/index.html" rel = "alternate" hreflang = "art-x-pir" >
< link href = "https://mcshelby.github.io/hugo-theme-relearn/configuration/customization/index.html" rel = "canonical" type = "text/html" title = "Customization :: Hugo Relearn Theme" >
< link href = "/hugo-theme-relearn/configuration/customization/index.xml" rel = "alternate" type = "application/rss+xml" title = "Customization :: Hugo Relearn Theme" >
2025-01-02 21:41:58 +00:00
< link href = "/hugo-theme-relearn/images/logo.svg?1735854104" rel = "icon" type = "image/svg+xml" >
< link href = "/hugo-theme-relearn/css/fontawesome-all.min.css?1735854104" rel = "stylesheet" media = "print" onload = "this.media='all';this.onload=null;" > < noscript > < link href = "/hugo-theme-relearn/css/fontawesome-all.min.css?1735854104" rel = "stylesheet" > < / noscript >
< link href = "/hugo-theme-relearn/css/auto-complete.css?1735854104" rel = "stylesheet" media = "print" onload = "this.media='all';this.onload=null;" > < noscript > < link href = "/hugo-theme-relearn/css/auto-complete.css?1735854104" rel = "stylesheet" > < / noscript >
< link href = "/hugo-theme-relearn/css/perfect-scrollbar.min.css?1735854104" rel = "stylesheet" >
< link href = "/hugo-theme-relearn/css/theme.min.css?1735854104" rel = "stylesheet" >
< link href = "/hugo-theme-relearn/css/format-print.min.css?1735854104" rel = "stylesheet" id = "R-format-style" >
2024-10-13 14:26:50 +00:00
< script >
window.relearn = window.relearn || {};
window.relearn.relBasePath='..\/..';
window.relearn.relBaseUri='..\/..\/..';
window.relearn.absBaseUri='https:\/\/mcshelby.github.io\/hugo-theme-relearn';
2024-12-07 23:18:07 +00:00
window.relearn.min = `.min`;
2024-10-13 14:26:50 +00:00
window.relearn.disableAnchorCopy=false;
window.relearn.disableAnchorScrolling=false;
// variant stuff
2024-12-07 23:18:07 +00:00
window.relearn.themevariants = [ 'relearn-auto', 'relearn-light', 'relearn-dark', 'relearn-bright', 'zen-auto', 'zen-light', 'zen-dark', 'retro-auto', 'neon', 'learn', 'blue', 'green', 'red' ];
window.relearn.customvariantname = "my-custom-variant";
window.relearn.changeVariant = function(variant) {
var oldVariant = document.documentElement.dataset.rThemeVariant;
window.localStorage.setItem(window.relearn.absBaseUri + "/variant", variant);
document.documentElement.dataset.rThemeVariant = variant;
if (oldVariant != variant) {
document.dispatchEvent( new CustomEvent('themeVariantLoaded', { detail: { variant, oldVariant } }) );
}
}
window.relearn.markVariant = function() {
var variant = window.localStorage.getItem(window.relearn.absBaseUri + "/variant");
var select = document.querySelector("#R-select-variant");
if (select) {
select.value = variant;
}
}
window.relearn.initVariant = function() {
var variant = window.localStorage.getItem(window.relearn.absBaseUri + "/variant") ?? "";
if( variant == window.relearn.customvariantname ){
}else if( !variant || !window.relearn.themevariants.includes(variant) ){
variant = window.relearn.themevariants[0];
window.localStorage.setItem(window.relearn.absBaseUri + "/variant", variant);
}
document.documentElement.dataset.rThemeVariant = variant;
}
window.relearn.initVariant();
window.relearn.markVariant();
2024-10-13 14:26:50 +00:00
// translations
window.T_Copy_to_clipboard = `Copy to clipboard`;
window.T_Copied_to_clipboard = `Copied to clipboard!`;
window.T_Copy_link_to_clipboard = `Copy link to clipboard`;
window.T_Link_copied_to_clipboard = `Copied link to clipboard!`;
window.T_Reset_view = `Reset view`;
window.T_View_reset = `View reset!`;
window.T_No_results_found = `No results found for "{0}"`;
window.T_N_results_found = `{1} results found for "{0}"`;
< / script >
2025-01-02 21:41:58 +00:00
< script src = "/hugo-theme-relearn/js/variant.js?1735854104" > < / script >
2024-10-13 14:26:50 +00:00
< style >
#R-body img.bg-white {
background-color: white;
}
< / style >
< / head >
< body class = "mobile-support print disableInlineCopyToClipboard" data-url = "/hugo-theme-relearn/configuration/customization/index.html" >
< div id = "R-body" class = "default-animation" >
< div id = "R-body-overlay" > < / div >
< nav id = "R-topbar" >
< div class = "topbar-wrapper" >
< div class = "topbar-sidebar-divider" > < / div >
< div class = "topbar-area topbar-area-start" data-area = "start" >
< div class = "topbar-button topbar-button-sidebar" data-content-empty = "disable" data-width-s = "show" data-width-m = "hide" data-width-l = "hide" > < button class = "topbar-control" onclick = "toggleNav()" type = "button" title = "Menu (CTRL+ALT+n)" > < i class = "fa-fw fas fa-bars" > < / i > < / button >
< / div >
< div class = "topbar-button topbar-button-toc" data-content-empty = "hide" data-width-s = "show" data-width-m = "show" data-width-l = "show" > < button class = "topbar-control" onclick = "toggleTopbarFlyout(this)" type = "button" title = "Table of Contents (CTRL+ALT+t)" > < i class = "fa-fw fas fa-list-alt" > < / i > < / button >
< div class = "topbar-content" >
< div class = "topbar-content-wrapper" >
< / div >
< / div >
< / div >
< / div >
< ol class = "topbar-breadcrumbs breadcrumbs highlightable" itemscope itemtype = "http://schema.org/BreadcrumbList" > < li
itemscope itemtype="https://schema.org/ListItem" itemprop="itemListElement">< a itemprop = "item" href = "/hugo-theme-relearn/configuration/index.html" > < span itemprop = "name" > Configuration< / span > < / a > < meta itemprop = "position" content = "1" > > < / li > < li
itemscope itemtype="https://schema.org/ListItem" itemprop="itemListElement">< span itemprop = "name" > Customization< / span > < meta itemprop = "position" content = "2" > < / li >
< / ol >
< div class = "topbar-area topbar-area-end" data-area = "end" >
< div class = "topbar-button topbar-button-edit" data-content-empty = "disable" data-width-s = "area-more" data-width-m = "show" data-width-l = "show" > < a class = "topbar-control" href = "https://github.com/McShelby/hugo-theme-relearn/edit/main/exampleSite/content/configuration/customization/_index.en.md" target = "_self" title = "Edit (CTRL+ALT+w)" > < i class = "fa-fw fas fa-pen" > < / i > < / a >
< / div >
< div class = "topbar-button topbar-button-print" data-content-empty = "disable" data-width-s = "area-more" data-width-m = "show" data-width-l = "show" > < a class = "topbar-control" href = "/hugo-theme-relearn/configuration/customization/index.print.html" title = "Print whole chapter (CTRL+ALT+p)" > < i class = "fa-fw fas fa-print" > < / i > < / a >
< / div >
< div class = "topbar-button topbar-button-prev" data-content-empty = "disable" data-width-s = "show" data-width-m = "show" data-width-l = "show" > < a class = "topbar-control" href = "/hugo-theme-relearn/configuration/content/hidden/index.html" title = "Hidden Pages (🡐)" > < i class = "fa-fw fas fa-chevron-left" > < / i > < / a >
< / div >
< div class = "topbar-button topbar-button-next" data-content-empty = "disable" data-width-s = "show" data-width-m = "show" data-width-l = "show" > < a class = "topbar-control" href = "/hugo-theme-relearn/configuration/customization/partials/index.html" title = "Partials (🡒)" > < i class = "fa-fw fas fa-chevron-right" > < / i > < / a >
< / div >
< div class = "topbar-button topbar-button-more" data-content-empty = "hide" data-width-s = "show" data-width-m = "show" data-width-l = "show" > < button class = "topbar-control" onclick = "toggleTopbarFlyout(this)" type = "button" title = "More" > < i class = "fa-fw fas fa-ellipsis-v" > < / i > < / button >
< div class = "topbar-content" >
< div class = "topbar-content-wrapper" >
< div class = "topbar-area topbar-area-more" data-area = "more" >
< / div >
< / div >
< / div >
< / div >
< / div >
< / div >
< / nav >
< div id = "R-main-overlay" > < / div >
< main id = "R-body-inner" class = "highlightable configuration" tabindex = "-1" >
< div class = "flex-block-wrapper" >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "customization" > Customization< / h1 >
< div class = "children children-h2 children-sort-" >
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/partials/index.html" > Partials< / a > < / h2 > < p > Modifying partials to your needs< / p >
2025-01-01 21:14:36 +00:00
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/extending/index.html" > Extending Scripts< / a > < / h2 > < p > Add further code to your site< / p >
2024-10-13 14:26:50 +00:00
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/imageeffects/index.html" > Image Effects< / a > < / h2 > < p > How to extend image effects< / p >
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/topbar/index.html" > Topbar< / a > < / h2 > < p > How to extend the topbar< / p >
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/designs/index.html" > Page Designs< / a > < / h2 > < p > Extending page designs< / p >
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/outputformats/index.html" > Output Formats< / a > < / h2 > < p > Adding Custom Output Formats< / p >
< h2 > < a href = "/hugo-theme-relearn/configuration/customization/taxonomy/index.html" > Taxonomies< / a > < / h2 > < p > How to display custom taxonomies on your pages< / p >
< / div >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/reference/index.html" > Reference< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< section >
< h1 class = "a11y-only" > Subsections of Customization< / h1 >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "partials" > Partials< / h1 >
< h2 id = "usable-partials" > Usable Partials< / h2 >
< p > You can call other partials from < code > themes/hugo-relearn-themes/< / code > besides those in < code > themes/hugo-relearn-themes/layouts/partials/_relearn< / code > . However, using partials not mentioned as customizable below might make future updates more challenging.< / p >
< h2 id = "customizable-partials" > Customizable Partials< / h2 >
< p > The Relearn theme allows you to customize various parts of the theme by overriding partials. This makes the theme highly configurable.< / p >
< p > A good rule to follow: The less code a partial contains, the easier it will be to update the theme in the future.< / p >
< p > Here’ s a list of partials you can safely override:< / p >
< ul >
< li >
< p > < code > layouts/partials/content.html< / code > : The main content of a page. Override this to display additonal page metadata.< / p >
< / li >
< li >
< p > < code > layouts/partials/content-header.html< / code > : The header above the title. By default, it shows tags, but you can change this.< / p >
< / li >
< li >
< p > < code > layouts/partials/content-footer.html< / code > : The footer below the content. By default, it shows author info, modification dates, and categories. You can customize this.< / p >
< / li >
< li >
< p > < code > layouts/partials/custom-header.html< / code > : For adding custom CSS. Remember to include the < code > style< / code > HTML tag.< / p >
< / li >
< li >
< p > < code > layouts/partials/custom-footer.html< / code > : For adding custom JavaScript. Remember to include the < code > script< / code > HTML tag.< / p >
< / li >
< li >
< p > < code > layouts/partials/favicon.html< / code > : The favicon. You should definitely customize this.< / p >
< / li >
< li >
< p > < code > layouts/partials/heading.html< / code > : the page’ s title headings< / p >
< / li >
< li >
< p > < code > layouts/partials/heading-pre.html< / code > : Add content before the page’ s title headings. Remember to consider the < code > headingPre< / code > front matter.< / p >
< / li >
< li >
< p > < code > layouts/partials/heading-post.html< / code > : Add content after the page’ s title headings. Remember to consider the < code > headingPost< / code > front matter.< / p >
< / li >
< li >
< p > < code > layouts/partials/logo.html< / code > : The logo in the top left corner. You should customize this.< / p >
< / li >
< li >
< p > < code > layouts/partials/menu-pre.html< / code > : Add content before menu items. Remember to consider the < code > menuPre< / code > front matter.< / p >
< / li >
< li >
< p > < code > layouts/partials/menu-post.html< / code > : Add content after menu items. Remember to consider the < code > menuPost< / code > front matter.< / p >
< / li >
< li >
< p > < code > layouts/partials/menu-footer.html< / code > : The footer of the left menu.< / p >
< / li >
< / ul >
< p > You can override other partials from < code > themes/hugo-relearn-themes/< / code > , but be careful as this might make future updates more difficult.< / p >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "extending-scripts" > Extending Scripts< / h1 >
< p > A common question is how to add extra CSS styles or JavaScript to your site. This depends on what you need.< / p >
< h2 id = "adding-javascript-or-stylesheets-to-all-pages" > Adding JavaScript or Stylesheets to All Pages< / h2 >
< p > To add JavaScript files or CSS stylesheets to every page, you can include them in < code > layouts/partials/custom-header.html< / code > or < code > layouts/partials/custom-footer.html< / code > .< / p >
< p > However, this can make your site larger than necessary if these files are only needed on a few pages. The next section explains how to add dependencies only when needed.< / p >
< h2 id = "custom-shortcodes-with-dependencies" > Custom Shortcodes with Dependencies< / h2 >
< p > Some shortcodes need extra JavaScript and CSS files. The theme only loads these when the shortcode is used. You can use this for your own shortcodes too.< / p >
< p > For example, to create a shortcode called < code > myshortcode< / code > that needs the < code > jquery< / code > library:< / p >
< ol >
< li >
< p > Create the shortcode file < code > layouts/shortcodes/myshortcode.html< / code > and add the folloging line somewhere:< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "bc2bf2c5b88725f76ae9787d00eef4ce" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutsshortcodesmyshortcodehtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('bc2bf2c5b88725f76ae9787d00eef4ce','layoutsshortcodesmyshortcodehtml')"
2024-10-13 14:26:50 +00:00
>
< span class = "tab-nav-text" > layouts/shortcodes/myshortcode.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutsshortcodesmyshortcodehtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-go" data-lang = "go" > < span class = "line" > < span class = "cl" > < span class = "o" > ...< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > {{< / span > < span class = "o" > -< / span > < span class = "p" > .< / span > < span class = "nx" > Page< / span > < span class = "p" > .< / span > < span class = "nx" > Store< / span > < span class = "p" > .< / span > < span class = "nx" > Set< / span > < span class = "s" > " hasMyShortcode" < / span > < span class = "kc" > true< / span > < span class = "p" > }}< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "o" > ...< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
< li >
< p > < span class = "badge cstyle cyan badge-with-title" > < span class = "badge-title" > < i class = "fa-fw fas fa-gears" > < / i > < / span > < span class = "badge-content" > Option< / span > < / span > Add this to your < code > hugo.toml< / code > :< / p >
< div class = "tab-panel" data-tab-group = "config-code" >
< div class = "tab-nav" >
< div class = "tab-nav-title" > hugo.< / div >
< button
data-tab-item="toml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
onclick="switchTab('config-code','toml')"
>
< span class = "tab-nav-text" > toml< / span >
< / button >
< button
data-tab-item="yaml"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','yaml')"
>
< span class = "tab-nav-text" > yaml< / span >
< / button >
< button
data-tab-item="json"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','json')"
>
< span class = "tab-nav-text" > json< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="toml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > params< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > params< / span > < span class = "p" > .< / span > < span class = "nx" > relearn< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > params< / span > < span class = "p" > .< / span > < span class = "nx" > relearn< / span > < span class = "p" > .< / span > < span class = "nx" > dependencies< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > params< / span > < span class = "p" > .< / span > < span class = "nx" > relearn< / span > < span class = "p" > .< / span > < span class = "nx" > dependencies< / span > < span class = "p" > .< / span > < span class = "nx" > myshortcode< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > name< / span > < span class = "p" > =< / span > < span class = "s1" > ' MyShortcode' < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="yaml"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-yaml" data-lang = "yaml" > < span class = "line" > < span class = "cl" > < span class = "nt" > params< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > relearn< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > dependencies< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > myshortcode< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > MyShortcode< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="json"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-json" data-lang = "json" > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " params" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " relearn" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " dependencies" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " myshortcode" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " name" < / span > < span class = "p" > :< / span > < span class = "s2" > " MyShortcode" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< / li >
< li >
< p > Create loader file < code > layouts/partials/dependencies/myshortcode.html< / code > :< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "97a2211e9043c7d13f9b1a1b9bd3d6af" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialsdependenciesmyshortcodehtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('97a2211e9043c7d13f9b1a1b9bd3d6af','layoutspartialsdependenciesmyshortcodehtml')"
2024-10-13 14:26:50 +00:00
>
< span class = "tab-nav-text" > layouts/partials/dependencies/myshortcode.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialsdependenciesmyshortcodehtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-go" data-lang = "go" > < span class = "line" > < span class = "cl" > < span class = "p" > {{< / span > < span class = "o" > -< / span > < span class = "k" > if< / span > < span class = "nx" > eq< / span > < span class = "p" > .< / span > < span class = "nx" > location< / span > < span class = "s" > " footer" < / span > < span class = "p" > }}< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nx" > script< / span > < span class = "nx" > src< / span > < span class = "p" > =< / span > < span class = "s" > " https://www.unpkg.com/jquery/dist/jquery.js" < / span > < span class = "p" > > < < / span > < span class = "o" > /< / span > < span class = "nx" > script< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > {{< / span > < span class = "o" > -< / span > < span class = "nx" > end< / span > < span class = "p" > }}< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
< / ol >
< p > Important notes:< / p >
< ul >
< li > Character casing is relevant!< / li >
< li > The < code > name< / code > in < code > hugo.toml< / code > must match the < code > Store< / code > key used in the shortcode file, prefixed with a < code > has< / code > .< / li >
< li > The key of < code > relearn.dependencies< / code > must match the loader file name.< / li >
< / ul >
< p > See the < code > math< / code > , < code > mermaid< / code > , and < code > openapi< / code > shortcodes for examples.< / p >
2024-12-01 21:17:58 +00:00
< details open class = " box cstyle notices note" >
2024-12-29 19:15:31 +00:00
< summary class = "box-label" tabindex = "-1" >
2024-11-30 18:11:32 +00:00
< i class = "fa-fw fas fa-exclamation-circle" > < / i >
Note
< / summary >
2024-10-13 14:26:50 +00:00
< div class = "box-content" >
< p > For advanced customization, you can use the dependency loader in your own partials:< / p >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-go" data-lang = "go" > < span class = "line" > < span class = "cl" > < span class = "p" > {{< / span > < span class = "o" > -< / span > < span class = "nx" > partial< / span > < span class = "s" > " dependencies.gotmpl" < / span > < span class = "p" > (< / span > < span class = "nx" > dict< / span > < span class = "s" > " page" < / span > < span class = "p" > .< / span > < span class = "s" > " location" < / span > < span class = "s" > " mylocation" < / span > < span class = "p" > )< / span > < span class = "p" > }}< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
2024-11-30 18:11:32 +00:00
< / details >
2024-10-13 14:26:50 +00:00
< p > Give a unique name for the < code > location< / code > parameter when you call it, so you can distinguish your loaders behavior depending on the location it was called from.< / p >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/howto/index.html" > Howto< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "image-effects" > Image Effects< / h1 >
< p > This page shows you, how to configure custom < a href = "/hugo-theme-relearn/authoring/markdown/index.html#image-effects" > image effects< / a > on top of existing ones.< / p >
< p > This setting can also < a href = "/hugo-theme-relearn/authoring/imageeffects/index.html" > be overridden by your front matter< / a > .< / p >
< p > If you don’ t configure anything in your < code > hugo.toml< / code > , the image effects default to< / p >
< h2 id = "default-values" > Default Values< / h2 >
< div class = "tab-panel" data-tab-group = "config-code" >
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="toml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
onclick="switchTab('config-code','toml')"
>
< span class = "tab-nav-text" > toml< / span >
< / button >
< button
data-tab-item="yaml"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','yaml')"
>
< span class = "tab-nav-text" > yaml< / span >
< / button >
< button
data-tab-item="json"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','json')"
>
< span class = "tab-nav-text" > json< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="toml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > imageEffects< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > border< / span > < span class = "p" > =< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > lazy< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > lightbox< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > shadow< / span > < span class = "p" > =< / span > < span class = "kc" > false< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="yaml"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-yaml" data-lang = "yaml" > < span class = "line" > < span class = "cl" > < span class = "nt" > imageEffects< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > border< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > false< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > lazy< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > lightbox< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > shadow< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > false< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="json"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-json" data-lang = "json" > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " imageEffects" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " border" < / span > < span class = "p" > :< / span > < span class = "kc" > false< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " lazy" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " lightbox" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " shadow" < / span > < span class = "p" > :< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< h2 id = "configuration" > Configuration< / h2 >
< p > < span class = "badge cstyle cyan badge-with-title" > < span class = "badge-title" > < i class = "fa-fw fas fa-gears" > < / i > < / span > < span class = "badge-content" > Option< / span > < / span > You can change these settings in your < code > hugo.toml< / code > and add arbitrary custom effects as boolean values (like < code > bg-white< / code > in the below snippet).< / p >
< div class = "tab-panel" data-tab-group = "config-code" >
< div class = "tab-nav" >
< div class = "tab-nav-title" > hugo.< / div >
< button
data-tab-item="toml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
onclick="switchTab('config-code','toml')"
>
< span class = "tab-nav-text" > toml< / span >
< / button >
< button
data-tab-item="yaml"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','yaml')"
>
< span class = "tab-nav-text" > yaml< / span >
< / button >
< button
data-tab-item="json"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','json')"
>
< span class = "tab-nav-text" > json< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="toml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > params< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > params< / span > < span class = "p" > .< / span > < span class = "nx" > imageEffects< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > bg-white< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > border< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > lazy< / span > < span class = "p" > =< / span > < span class = "kc" > false< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="yaml"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-yaml" data-lang = "yaml" > < span class = "line" > < span class = "cl" > < span class = "nt" > params< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > imageEffects< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > bg-white< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > border< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > lazy< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > false< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="json"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-json" data-lang = "json" > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " params" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " imageEffects" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " bg-white" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " border" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " lazy" < / span > < span class = "p" > :< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< p > This would result in< / p >
< div class = "tab-panel" data-tab-group = "config-code" >
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="toml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
onclick="switchTab('config-code','toml')"
>
< span class = "tab-nav-text" > toml< / span >
< / button >
< button
data-tab-item="yaml"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','yaml')"
>
< span class = "tab-nav-text" > yaml< / span >
< / button >
< button
data-tab-item="json"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','json')"
>
< span class = "tab-nav-text" > json< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="toml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > imageEffects< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > bg-white< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > border< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > lazy< / span > < span class = "p" > =< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > lightbox< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > shadow< / span > < span class = "p" > =< / span > < span class = "kc" > false< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="yaml"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-yaml" data-lang = "yaml" > < span class = "line" > < span class = "cl" > < span class = "nt" > imageEffects< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > bg-white< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > border< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > lazy< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > false< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > lightbox< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > shadow< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > false< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="json"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-json" data-lang = "json" > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " imageEffects" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " bg-white" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " border" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " lazy" < / span > < span class = "p" > :< / span > < span class = "kc" > false< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " lightbox" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " shadow" < / span > < span class = "p" > :< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< h3 id = "example" > Example< / h3 >
< p > With this configuration in effect, the following URL< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "ddc1127041f96d795abbaaae26a6e308" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="markdown"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('ddc1127041f96d795abbaaae26a6e308','markdown')"
2024-10-13 14:26:50 +00:00
>
< span class = "tab-nav-text" > Markdown< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="markdown"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-markdown" data-lang = "markdown" > < span class = "line" > < span class = "cl" > ![< span class = "nt" > Minion< / span > ](< span class = "na" > https://octodex.github.com/images/minion.png< / span > )< / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < p > would result in< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "7691985481ad679a2842c681cf7e0119" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="html"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('7691985481ad679a2842c681cf7e0119','html')"
2024-10-13 14:26:50 +00:00
>
< span class = "tab-nav-text" > HTML< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="html"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > img< / span > < span class = "na" > src< / span > < span class = "o" > =< / span > < span class = "s" > " https://octodex.github.com/images/minion.png" < / span > < span class = "na" > loading< / span > < span class = "o" > =< / span > < span class = "s" > " lazy" < / span > < span class = "na" > alt< / span > < span class = "o" > =< / span > < span class = "s" > " Minion" < / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " bg-white border nolazy lightbox noshadow" < / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < h2 id = "styling-effects" > Styling Effects< / h2 >
< p > If the resulting effect value is< / p >
< ul >
< li > < code > true< / code > : add a class with the effect’ s name< / li >
< li > < code > false< / code > : add a class with the effect’ s name and a “ no” prefix< / li >
< / ul >
< p > Styles for default effects are contained in the theme. Add styles for your custom effects to < code > layouts/partials/content-header.html< / code > .< / p >
< p > For the above example you could add styles for both boolean cases:< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "e0683394635b08e6145202e01583a871" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialscontent-headerhtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('e0683394635b08e6145202e01583a871','layoutspartialscontent-headerhtml')"
2024-10-13 14:26:50 +00:00
>
< span class = "tab-nav-text" > layouts/partials/content-header.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialscontent-headerhtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > img< / span > < span class = "p" > .< / span > < span class = "nc" > bg-white< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "k" > background-color< / span > < span class = "p" > :< / span > < span class = "kc" > white< / span > < span class = "p" > ;< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > img< / span > < span class = "p" > .< / span > < span class = "nc" > nobg-white< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "k" > background-color< / span > < span class = "p" > :< / span > < span class = "kc" > transparent< / span > < span class = "p" > ;< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/howto/index.html" > Howto< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "topbar" > Topbar< / h1 >
< p > The theme comes with a reasonably configured topbar. You can learn how to < a href = "/hugo-theme-relearn/authoring/frontmatter/topbar/index.html" > configure the defaults in this section< / a > .< / p >
2025-01-02 21:41:58 +00:00
< p > < a href = "#R-image-e5256e0a2df22ce42610de496a3bc7e7" class = "lightbox-link" > < img alt = "topbar on mobile devices" class = "bg-white border lazy lightbox noshadow figure-image" loading = "lazy" src = "/hugo-theme-relearn/configuration/customization/topbar/topbar-closed.png" style = " height: auto; width: auto;" > < / a >
< a href = "javascript:history.back();" class = "lightbox-back" id = "R-image-e5256e0a2df22ce42610de496a3bc7e7" > < img alt = "topbar on mobile devices" class = "bg-white border lazy lightbox noshadow lightbox-image" loading = "lazy" src = "/hugo-theme-relearn/configuration/customization/topbar/topbar-closed.png" > < / a > < / p >
2024-10-13 14:26:50 +00:00
< p > Nevertheless, your requirements may differ from this configuration. Luckily, the theme has you covered as the topbar, its buttons, and the functionality behind these buttons are fully configurable by you.< / p >
2024-12-01 21:17:58 +00:00
< details open class = " box cstyle notices tip" >
2024-12-29 19:15:31 +00:00
< summary class = "box-label" tabindex = "-1" >
2024-11-30 18:11:32 +00:00
< i class = "fa-fw fas fa-lightbulb" > < / i >
Tip
< / summary >
2024-10-13 14:26:50 +00:00
< div class = "box-content" >
< p > All mentioned file names below can be clicked and show you the implementation for a better understanding.< / p >
< / div >
2024-11-30 18:11:32 +00:00
< / details >
2024-10-13 14:26:50 +00:00
< h2 id = "areas" > Areas< / h2 >
< p > The default configuration comes with three predefined areas that may contain an arbitrary set of buttons.< / p >
2025-01-02 21:41:58 +00:00
< p > < a href = "#R-image-037134e9ac1c5ab5b6ae9ad2f89455f6" class = "lightbox-link" > < img alt = "topbar with default areas marked" class = "bg-white border lazy lightbox noshadow figure-image" loading = "lazy" src = "/hugo-theme-relearn/configuration/customization/topbar/topbar-areas.png" style = " height: auto; width: auto;" > < / a >
< a href = "javascript:history.back();" class = "lightbox-back" id = "R-image-037134e9ac1c5ab5b6ae9ad2f89455f6" > < img alt = "topbar with default areas marked" class = "bg-white border lazy lightbox noshadow lightbox-image" loading = "lazy" src = "/hugo-theme-relearn/configuration/customization/topbar/topbar-areas.png" > < / a > < / p >
2024-10-13 14:26:50 +00:00
< ul >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/area/start.html" rel = "external" target = "_self" > < strong > start< / strong > < / a > : shown between menu and breadcrumb< / li >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/area/end.html" rel = "external" target = "_self" > < strong > end< / strong > < / a > : shown on the opposite breadcrumb side in comparison to the < em > start< / em > area< / li >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/area/more.html" rel = "external" target = "_self" > < strong > more< / strong > < / a > : shown when pressing the < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-ellipsis-v" > < / i > < / span > < / span > < em > more< / em > button in the topbar< / li >
< / ul >
< p > While you cannot add additional areas in the topbar, you are free to configure additional buttons that behave like the < em > more< / em > button, providing further user-defined areas.< / p >
< h2 id = "buttons" > Buttons< / h2 >
< p > The theme ships with the following predefined buttons (from left to right in the screenshot):< / p >
< ul >
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-bars" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/sidebar.html" rel = "external" target = "_self" > < strong > sidebar< / strong > < / a > : opens the sidebar flyout if in mobile layout< / li >
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-list-alt" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/toc.html" rel = "external" target = "_self" > < strong > toc< / strong > < / a > : < a href = "/hugo-theme-relearn/authoring/frontmatter/topbar/index.html#table-of-contents" > opens the table of contents in an overlay< / a > < / li >
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-pen" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/edit.html" rel = "external" target = "_self" > < strong > edit< / strong > < / a > : browses to the editable page if the < code > editURL< / code > < a href = "/hugo-theme-relearn/authoring/frontmatter/topbar/index.html#edit-button" > parameter is set< / a > < / li >
2024-12-31 13:33:32 +00:00
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fab fa-markdown" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/markdown.html" rel = "external" target = "_self" > < strong > markdown< / strong > < / a > : browses to the chapter’ s markdown source if < a href = "/hugo-theme-relearn/configuration/sitemanagement/outputformats/index.html#markdown-support" > markdown support< / a > was activated< / li >
2024-10-13 14:26:50 +00:00
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-print" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/print.html" rel = "external" target = "_self" > < strong > print< / strong > < / a > : browses to the chapter’ s printable page if < a href = "/hugo-theme-relearn/configuration/sitemanagement/outputformats/index.html#print-support" > print support< / a > was activated< / li >
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-chevron-left" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/prev.html" rel = "external" target = "_self" > < strong > prev< / strong > < / a > : browses to the < a href = "/hugo-theme-relearn/authoring/frontmatter/topbar/index.html#arrow-navigation" > previous page< / a > if there is one< / li >
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-chevron-right" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/next.html" rel = "external" target = "_self" > < strong > next< / strong > < / a > : browses to the [next page]authoring/frontmatter/topbar(#arrow-navigation) if there is one< / li >
< li > < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-ellipsis-v" > < / i > < / span > < / span > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/more.html" rel = "external" target = "_self" > < strong > more< / strong > < / a > : opens the overlay for the < em > more< / em > area< / li >
< / ul >
< p > Not all buttons are displayed at every given time. This is configurable (see below if interested).< / p >
< h2 id = "redefining-areas" > Redefining Areas< / h2 >
< p > Each predefined area and button comes in its own file. By that, it is easy for you to overwrite an area file in your installation, reusing only the buttons you like.< / p >
< p > E.g., you can redefine the predefined < em > end< / em > area by adding the file < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/area/end.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/area/end.html< / code > < / a > in your installation (not in the theme itself) to remove all but the < em > more< / em > button.< / p >
< p > The below example sets an explicit value for the < code > onempty< / code > parameter, overriding the specific default value for this button (these defaults vary depending on the button). The parameter causes the < em > more< / em > button to always be displayed instead of hiding once its content is empty.< / p >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-go" data-lang = "go" > < span class = "line" > < span class = "cl" > < span class = "p" > {{< / span > < span class = "nx" > partial< / span > < span class = "s" > " topbar/button/more.html" < / span > < span class = "p" > (< / span > < span class = "nx" > dict< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s" > " page" < / span > < span class = "p" > .< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s" > " onempty" < / span > < span class = "s" > " disable" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > )}}< / span > < / span > < / span > < / code > < / pre > < / div >
< h2 id = "defining-own-buttons" > Defining Own Buttons< / h2 >
< h3 id = "button-types" > Button Types< / h3 >
< p > The theme distinguishes between two types of buttons:< / p >
< ul >
< li > < a href = "/hugo-theme-relearn/configuration/customization/topbar/index.html#button" > < strong > button< / strong > < / a > : a clickable button that either browses to another site, triggers a user-defined script or opens an overlay containing user-defined content< / li >
< li > < a href = "/hugo-theme-relearn/configuration/customization/topbar/index.html#area-button" > < strong > area-button< / strong > < / a > : the template for the < span class = "btn cstyle transparent" > < span > < i class = "fa-fw fas fa-ellipsis-v" > < / i > < / span > < / span > < em > more< / em > button, to define your own area overlay buttons< / li >
< / ul >
< h3 id = "button-parameter" > Button Parameter< / h3 >
< h4 id = "screen-widths-and-actions" > Screen Widths and Actions< / h4 >
< p > Depending on the screen width, you can configure how the button should behave. Screen width is divided into three classes:< / p >
< ul >
< li > < strong > s< / strong > : (controlled by the < code > onwidths< / code > parameter) mobile layout where the menu sidebar is hidden< / li >
< li > < strong > m< / strong > : (controlled by the < code > onwidthm< / code > parameter) desktop layout with visible sidebar while the content area width still resizes< / li >
< li > < strong > l< / strong > : (controlled by the < code > onwidthl< / code > parameter) desktop layout with visible sidebar once the content area reached its maximum width< / li >
< / ul >
< p > For each width class, you can configure one of the following actions:< / p >
< ul >
< li > < code > show< / code > : the button is displayed in its given area< / li >
< li > < code > hide< / code > : the button is removed< / li >
< li > < code > area-XXX< / code > : the button is moved from its given area into the area < code > XXX< / code > ; for example, this is used to move buttons to the < em > more< / em > area overlay in the mobile layout< / li >
< / ul >
< h4 id = "hiding-and-disabling-stuff" > Hiding and Disabling Stuff< / h4 >
< p > While hiding a button depending on the screen size can be configured with the above-described < em > hide< / em > action, you may want to hide the button on certain other conditions as well.< / p >
< p > For example, the < em > print< / em > button in its default configuration should only be displayed if print support was configured. This is done in your button template by checking the conditions first before displaying the button (see < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/print.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/button/print.html< / code > < / a > ).< / p >
< p > Another preferred condition for hiding a button is if the displayed overlay is empty. This is the case for the < em > toc< / em > (see < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/toc.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/button/toc.html< / code > < / a > ) as well as the < em > more< / em > button (see < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/more.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/button/more.html< / code > < / a > ) and controlled by the parameter < code > onempty< / code > .< / p >
< p > This parameter can have one of the following values:< / p >
< ul >
< li > < code > disable< / code > : the button is displayed in a disabled state if the overlay is empty< / li >
< li > < code > hide< / code > : the button is removed if the overlay is empty< / li >
< / ul >
< p > If you want to disable a button containing < em > no overlay< / em > , this can be achieved by an empty < code > href< / code > parameter. An example can be seen in the < em > prev< / em > button (see < code > layouts/partials/topbar/button/prev.html< / code > ) where the URL for the previous site may be empty.< / p >
< h2 id = "reference" > Reference< / h2 >
< h3 id = "button" > Button< / h3 >
< p > Contains the basic button functionality and is used as a base implementation for all other buttons (< a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/func/button.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/func/button.html< / code > < / a > ).< / p >
< p > Call this from your own button templates if you want to implement a button without an overlay like the < em > print< / em > button (< a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/print.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/button/print.html< / code > < / a > ) or with an overlay containing arbitrary content like the < em > toc< / em > button (< a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/toc.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/button/toc.html< / code > < / a > ).< / p >
< p > For displaying an area in the button’ s overlay, see < a href = "/hugo-theme-relearn/configuration/customization/topbar/index.html#area-button" > Area-Button< / a > .< / p >
< h4 id = "parameter" > Parameter< / h4 >
< table >
< thead >
< tr >
2024-10-24 14:30:52 +00:00
< th > Name< / th >
< th > Default< / th >
< th > Notes< / th >
2024-10-13 14:26:50 +00:00
< / tr >
< / thead >
< tbody >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > page< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory reference to the page.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > class< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory unique class name for this button. Displaying two buttons with the same value for < strong > class< / strong > is undefined.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > href< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Either the destination URL for the button or JavaScript code to be executed on click.< br > < br > - If starting with < code > javascript:< / code > all following text will be executed in your browser< br > - Every other string will be interpreted as URL< br > - If empty, the button will be displayed in a disabled state regardless of its < strong > content< / strong > < / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > icon< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > < a href = "/hugo-theme-relearn/shortcodes/icon/index.html#finding-an-icon" > Font Awesome icon name< / a > .< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onempty< / strong > < / td >
< td > < code > disable< / code > < / td >
< td > Defines what to do with the button if the content parameter was set but ends up empty:< br > < br > - < code > disable< / code > : The button is displayed in a disabled state.< br > - < code > hide< / code > : The button is removed.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidths< / strong > < / td >
< td > < code > show< / code > < / td >
< td > The action that should be executed if the site is displayed in the given width:< br > < br > - < code > show< / code > : The button is displayed in its given area< br > - < code > hide< / code > : The button is removed.< br > - < code > area-XXX< / code > : The button is moved from its given area into the area < code > XXX< / code > .< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthm< / strong > < / td >
< td > < code > show< / code > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthl< / strong > < / td >
< td > < code > show< / code > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > hint< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Arbitrary text displayed in the tooltip.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > title< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Arbitrary text for the button.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > content< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Arbitrary HTML to put into the content overlay. This parameter may be empty. In this case, no overlay will be generated.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< / tbody >
< / table >
< h3 id = "area-button" > Area-Button< / h3 >
< p > Contains the basic functionality to display area overlay buttons (< a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/func/area-button.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/func/area-button.html< / code > < / a > ).< / p >
< p > Call this from your own button templates if you want to implement a button with an area overlay like the < em > more< / em > button (< a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button/more.html" rel = "external" target = "_self" > < code > layouts/partials/topbar/button/more.html< / code > < / a > ).< / p >
< h4 id = "parameter-1" > Parameter< / h4 >
< table >
< thead >
< tr >
2024-10-24 14:30:52 +00:00
< th > Name< / th >
< th > Default< / th >
< th > Notes< / th >
2024-10-13 14:26:50 +00:00
< / tr >
< / thead >
< tbody >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > page< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory reference to the page.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > area< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory unique area name for this area. Displaying two areas with the same value for < strong > area< / strong > is undefined.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > icon< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > < a href = "/hugo-theme-relearn/shortcodes/icon/index.html#finding-an-icon" > Font Awesome icon name< / a > .< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onempty< / strong > < / td >
< td > < code > disable< / code > < / td >
< td > Defines what to do with the button if the content overlay is empty:< br > < br > - < code > disable< / code > : The button is displayed in a disabled state.< br > - < code > hide< / code > : The button is removed.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidths< / strong > < / td >
< td > < code > show< / code > < / td >
< td > The action that should be executed if the site is displayed in the given width:< br > < br > - < code > show< / code > : The button is displayed in its given area< br > - < code > hide< / code > : The button is removed.< br > - < code > area-XXX< / code > : The button is moved from its given area into the area < code > XXX< / code > .< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthm< / strong > < / td >
< td > < code > show< / code > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthl< / strong > < / td >
< td > < code > show< / code > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > hint< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Arbitrary text displayed in the tooltip.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > title< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Arbitrary text for the button.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< / tbody >
< / table >
< h3 id = "predefined-buttons" > Predefined Buttons< / h3 >
< p > The predefined buttons by the theme (all other buttons besides the < em > more< / em > and < em > toc< / em > button in < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button" rel = "external" target = "_self" > < code > layouts/partials/topbar/button< / code > < / a > ).< / p >
< p > Call these from your own redefined area templates if you want to use default button behavior.< / p >
< p > The < em > < varying> < / em > parameter values are different for each button and configured for standard behavior as seen on this page.< / p >
< h4 id = "parameter-2" > Parameter< / h4 >
< table >
< thead >
< tr >
2024-10-24 14:30:52 +00:00
< th > Name< / th >
< th > Default< / th >
< th > Notes< / th >
2024-10-13 14:26:50 +00:00
< / tr >
< / thead >
< tbody >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > page< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory reference to the page.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidths< / strong > < / td >
< td > < em > < varying> < / em > < / td >
< td > The action that should be executed if the site is displayed in the given width:< br > < br > - < code > show< / code > : The button is displayed in its given area< br > - < code > hide< / code > : The button is removed.< br > - < code > area-XXX< / code > : The button is moved from its given area into the area < code > XXX< / code > .< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthm< / strong > < / td >
< td > < em > < varying> < / em > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthl< / strong > < / td >
< td > < em > < varying> < / em > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< / tbody >
< / table >
< h3 id = "predefined-overlay-buttons" > Predefined Overlay-Buttons< / h3 >
< p > The predefined buttons by the theme that open an overlay (the < em > more< / em > and < em > toc< / em > button in < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/partials/topbar/button" rel = "external" target = "_self" > < code > layouts/partials/topbar/button< / code > < / a > ).< / p >
< p > Call these from your own redefined area templates if you want to use default button behavior utilizing overlay functionality.< / p >
< p > The < em > < varying> < / em > parameter values are different for each button and configured for standard behavior as seen on this page.< / p >
< h4 id = "parameter-3" > Parameter< / h4 >
< table >
< thead >
< tr >
2024-10-24 14:30:52 +00:00
< th > Name< / th >
< th > Default< / th >
< th > Notes< / th >
2024-10-13 14:26:50 +00:00
< / tr >
< / thead >
< tbody >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > page< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory reference to the page.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onempty< / strong > < / td >
< td > < code > disable< / code > < / td >
< td > Defines what to do with the button if the content overlay is empty:< br > < br > - < code > disable< / code > : The button is displayed in a disabled state.< br > - < code > hide< / code > : The button is removed.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidths< / strong > < / td >
< td > < em > < varying> < / em > < / td >
< td > The action that should be executed if the site is displayed in the given width:< br > < br > - < code > show< / code > : The button is displayed in its given area< br > - < code > hide< / code > : The button is removed.< br > - < code > area-XXX< / code > : The button is moved from its given area into the area < code > XXX< / code > .< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthm< / strong > < / td >
< td > < em > < varying> < / em > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > onwidthl< / strong > < / td >
< td > < em > < varying> < / em > < / td >
< td > See above.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< / tbody >
< / table >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/reference/index.html" > Reference< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "page-designs" > Page Designs< / h1 >
2024-12-31 17:03:38 +00:00
< p > Page designs are used to provide different layouts for a given output format. If you instead want to < a href = "/hugo-theme-relearn/configuration/customization/outputformats/index.html" > provide a new output format< / a > , the theme got you covered as well.< / p >
< p > A page is displayed by exactly one page design < em > for each output format< / em > , is represented by < a href = "https://gohugo.io/content-management/front-matter/#type" rel = "external" target = "_self" > Hugo’ s reserved < code > type< / code > front matter< / a > and uses < a href = "https://gohugo.io/templates/types/#content-view" rel = "external" target = "_self" > Hugo’ s content view mechanism< / a > .< / p >
2024-10-13 14:26:50 +00:00
< p > A page design usually consists of< / p >
< ul >
2024-12-31 17:03:38 +00:00
< li > < a href = "https://gohugo.io/templates/types/#content-view" rel = "external" target = "_self" > one or more content view files< / a > : depending on the output format taken from < a href = "/hugo-theme-relearn/configuration/customization/designs/index.html#partials" > the list below< / a > < / li >
< li > < a href = "https://gohugo.io/content-management/archetypes/" rel = "external" target = "_self" > an optional archetype file< / a > : a template for creating new Markdown files with the correct setting for the < code > type< / code > front matter and any furhter parameter< / li >
< li > optional CSS styles< / li >
2024-10-13 14:26:50 +00:00
< / ul >
2024-12-01 21:17:58 +00:00
< details open class = " box cstyle notices warning" >
2024-12-29 19:15:31 +00:00
< summary class = "box-label" tabindex = "-1" >
2024-11-30 18:11:32 +00:00
< i class = "fa-fw fas fa-exclamation-triangle" > < / i >
Warning
< / summary >
2024-10-13 14:26:50 +00:00
< div class = "box-content" >
2024-12-31 17:03:38 +00:00
< p > Don’ t use Hugo’ s reserved < code > type< / code > option in your modifications for other functionality!< / p >
2024-10-13 14:26:50 +00:00
< / div >
2024-11-30 18:11:32 +00:00
< / details >
2024-10-13 14:26:50 +00:00
< h2 id = "using-a-page-design" > Using a Page Design< / h2 >
2024-12-31 17:03:38 +00:00
< p > Regardless of shipped or custom page designs, you are < a href = "/hugo-theme-relearn/authoring/frontmatter/designs/index.html" > using them in the same way< / a > . Either by manually setting the < code > type< / code > front matter to the value of the page design or by using an archetype during creation of a new page.< / p >
< p > If no < code > type< / code > is set in your front matter or the page design doesn’ t exist for a given output format, the page is treated as if < code > type='default'< / code > was set.< / p >
< p > The Relearn theme ships with the page designs < code > home< / code > , < code > chapter< / code > , and < code > default< / code > for the HTML output format.< / p >
< p > The shipped < code > print< / code > and < code > markdown< / code > output formats only display using the < code > default< / code > page design.< / p >
< h2 id = "creating-a-page-design" > Creating a Page Design< / h2 >
< p > Suppose you are writing a documentation site for some software. Each time a new release is created, you are adding a new releasenotes page to your site. Those pages should contain a common disclaimer at the top. You neither want to copy the text into each new file nor want you to use a shortcode but create a page design called < code > releasenotes< / code > .< / p >
2024-10-13 14:26:50 +00:00
< ol >
< li >
2024-12-31 17:03:38 +00:00
< p > Choose a name (here, < code > releasenotes< / code > )< / p >
2024-10-13 14:26:50 +00:00
< / li >
< li >
2024-12-31 17:03:38 +00:00
< p > Create a content view file at < code > layouts/releasenotes/views/article.html< / code > < / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "563cc0049c52a825c99988f87d4c8ade" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
2024-12-31 17:03:38 +00:00
data-tab-item="layoutsreleasenotesviewsarticlehtml"
2024-10-13 14:26:50 +00:00
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('563cc0049c52a825c99988f87d4c8ade','layoutsreleasenotesviewsarticlehtml')"
2024-10-13 14:26:50 +00:00
>
2024-12-31 17:03:38 +00:00
< span class = "tab-nav-text" > layouts/releasenotes/views/article.html< / span >
2024-10-13 14:26:50 +00:00
< / button >
< / div >
< div class = "tab-content-container" >
< div
2024-12-31 17:03:38 +00:00
data-tab-item="layoutsreleasenotesviewsarticlehtml"
2024-10-13 14:26:50 +00:00
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
2024-12-31 17:03:38 +00:00
< div class = "highlight wrap-code" hl_Lines = "6-8" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > article< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " releasenotes" < / span > < span class = "p" > > < / span >
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > header< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " headline" < / span > < span class = "p" > > < / span >
2024-12-31 17:03:38 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " content-header.html" .}}
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > header< / span > < span class = "p" > > < / span >
2024-12-31 17:03:38 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " heading-pre.html" .}}{{partial " heading.html" .}}{{partial " heading-post.html" .}}
< / span > < / span > < span class = "line hl" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > p< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " disclaimer" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line hl" > < span class = "cl" > This software release comes without any warranty!
< / span > < / span > < span class = "line hl" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > p< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " article-content.html" .}}
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > footer< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " footline" < / span > < span class = "p" > > < / span >
2024-12-31 17:03:38 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " content-footer.html" .}}
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > footer< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > article< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
2024-12-31 17:03:38 +00:00
< / div > < p > The marked lines are your customizations, the rest of the file was copied over from the default implementation of < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/views/article.html" rel = "external" target = "_self" > < code > layouts/_default/views/article.html< / code > < / a > < / p >
< p > In this file, you can customize the page structure as needed. For HTML based output formats, typically you’ ll want to:< / p >
2024-10-13 14:26:50 +00:00
< ul >
< li > Set a < code > class< / code > at the < code > article< / code > element for custom CSS styles< / li >
2024-12-31 17:03:38 +00:00
< li > Call < code > {{ partial " article-content.html" . }}< / code > to show your page content< / li >
2024-10-13 14:26:50 +00:00
< / ul >
< / li >
< li >
2024-12-31 17:03:38 +00:00
< p > < em > Optional< / em > : create an archetype file at < code > archetypes/releasenotes.md< / code > < / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "d71193f90aa699519d6cf9a9187060ba" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
2024-12-31 17:03:38 +00:00
data-tab-item="archetypesreleasenotesmd"
2024-10-13 14:26:50 +00:00
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('d71193f90aa699519d6cf9a9187060ba','archetypesreleasenotesmd')"
2024-10-13 14:26:50 +00:00
>
2024-12-31 17:03:38 +00:00
< span class = "tab-nav-text" > archetypes/releasenotes.md< / span >
2024-10-13 14:26:50 +00:00
< / button >
< / div >
< div class = "tab-content-container" >
< div
2024-12-31 17:03:38 +00:00
data-tab-item="archetypesreleasenotesmd"
2024-10-13 14:26:50 +00:00
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
2024-12-31 17:03:38 +00:00
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "err" > +++< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > title< / span > < span class = "p" > =< / span > < span class = "s2" > " {{ replace .Name " < / span > < span class = "nx" > -< / span > < span class = "s2" > " " < / span > < span class = "s2" > " | title }}" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > type< / span > < span class = "p" > =< / span > < span class = "s2" > " releasenotes" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "err" > +++< / span >
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" >
2024-12-31 17:03:38 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > This< / span > < span class = "nx" > is< / span > < span class = "nx" > a< / span > < span class = "nx" > new< / span > < span class = "nx" > releasenote< / span > < span class = "p" > .< / span > < / span > < / span > < / code > < / pre > < / div >
2024-10-13 14:26:50 +00:00
< / div >
< / div >
< / div >
< / div > < / li >
< li >
2024-12-31 17:03:38 +00:00
< p > < em > Optional< / em > : add CSS in the file < code > layouts/partials/custom-header.html< / code > < / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "7633f69454d1a09c16d9d7d4137085f3" >
2024-10-13 14:26:50 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialscustom-headerhtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('7633f69454d1a09c16d9d7d4137085f3','layoutspartialscustom-headerhtml')"
2024-10-13 14:26:50 +00:00
>
< span class = "tab-nav-text" > layouts/partials/custom-header.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialscustom-headerhtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
2024-12-31 17:03:38 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > .< / span > < span class = "nc" > releasenotes< / span > < span class = "p" > .< / span > < span class = "nc" > disclaimer< / span > < span class = "p" > {< / span >
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "k" > background-color< / span > < span class = "p" > :< / span > < span class = "kc" > pink< / span > < span class = "p" > ;< / span >
2024-12-31 17:03:38 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "k" > font-size< / span > < span class = "p" > :< / span > < span class = "mi" > 72< / span > < span class = "kt" > rem< / span > < span class = "p" > ;< / span >
2024-10-13 14:26:50 +00:00
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
< / ol >
2024-12-31 17:03:38 +00:00
< h2 id = "partials" > Partials< / h2 >
< h3 id = "for-any-output-format" > For any Output Format< / h3 >
< p > These files are common for all output formats.< / p >
< ul >
< li > < code > layouts/< DESIGN> /baseof.< FORMAT> < / code > : < em > Optional< / em > : The top most file you could provide to completely redefine the whole design. No further partials will be called if you don’ call them yourself< / li >
< / ul >
< h3 id = "for-html-output-formats" > For HTML Output Formats< / h3 >
< p > If you want to keep the general HTML framework and only change specific parts, you can provide these files for the page desingn for the HTML output format independently of one another.< / p >
< ul >
< li > < code > layouts/< DESIGN> /views/article.html< / code > : < em > Optional< / em > : Controls how one page’ s content and title are displayed< / li >
< li > < code > layouts/< DESIGN> /views/body.html< / code > : < em > Optional< / em > : Determines what to contain in the content area (for example a single page, a list of pages, a tree of sub pages)< / li >
< li > < code > layouts/< DESIGN> /views/menu.html< / code > : < em > Optional< / em > : Defines the sidebar menu layout< / li >
< / ul >
< p > For a real-world example, check out the < code > changelog< / code > page design implementation< / p >
2024-10-13 14:26:50 +00:00
< ul >
2024-12-31 17:03:38 +00:00
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/exampleSite/layouts/changelog/views/article.html" rel = "external" target = "_self" > < code > exampleSite/layouts/changelog/views/article.html< / code > < / a > < / li >
2024-12-31 19:57:26 +00:00
< / ul >
< h2 id = "migration-to-relearn-7-or-higher" > Migration to Relearn 7 or higher< / h2 >
< p > Previous to Relearn 7, page designs were defined by a proprietary solution unique to the theme. Depending on your modifications you may have to change some or all of the following to migrate to Relearn 7’ s page designs.< / p >
< ul >
< li >
< p > In all your < code > *.md< / code > files, replace the < code > archetype< / code > front matter with < code > type< / code > ; the value stays the same; don’ t forget your archetype files if you have some< / p >
< / li >
< li >
< p > Move your files < code > layouts/partials/archetypes/< DESIGN> /article.html< / code > to < code > layouts/< DESIGN> /views/article.html< / code > < / p >
< p > The files will most likely require further modifications as they now receive the page as it context (dot < code > .< / code > ) instead of the < code > .page< / code > and < code > .content< / code > parameter.< / p >
< p > < strong > Old< / strong > :< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "7524ffe45f644d28cceac4ebd3e04de8" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialsarchetypesltdesigngtarticlehtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('7524ffe45f644d28cceac4ebd3e04de8','layoutspartialsarchetypesltdesigngtarticlehtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/partials/archetypes/< DESIGN> /article.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialsarchetypesltdesigngtarticlehtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" hl_Lines = "1-3 10 16" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line hl" > < span class = "cl" > {{- $page := .page }}
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- $content := .content }}
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- with $page }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > article< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " default" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > header< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " headline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-header.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > header< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " heading-pre.html" .}}{{partial " heading.html" .}}{{partial " heading-post.html" .}}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{ $content | safeHTML }}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > footer< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " footline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-footer.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > footer< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > article< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- end }}< / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < p > < strong > New< / strong > :< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "d119eb653c0337245df7dc2e6e8b2ae1" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutsltdesigngtviewsarticlehtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('d119eb653c0337245df7dc2e6e8b2ae1','layoutsltdesigngtviewsarticlehtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/< DESIGN> /views/article.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutsltdesigngtviewsarticlehtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" hl_Lines = "7" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > article< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " default" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > header< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " headline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-header.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > header< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " heading-pre.html" .}}{{partial " heading.html" .}}{{partial " heading-post.html" .}}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{ partial " article-content.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > footer< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " footline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-footer.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > footer< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > article< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
2024-10-13 14:26:50 +00:00
< / ul >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/howto/index.html" > Howto< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< article class = "default" >
< header class = "headline" >
< / header >
< h1 id = "output-formats" > Output Formats< / h1 >
2024-12-31 17:03:38 +00:00
< p > Hugo can display your content in different < a href = "https://gohugo.io/templates/output-formats/" rel = "external" target = "_self" > formats< / a > like HTML, JSON, Google AMP, etc. To do this, templates must be provided.< / p >
< p > The Relearn theme by default comes with templates for < a href = "/hugo-theme-relearn/configuration/sitemanagement/outputformats/index.html" > HTML, HTML for print, RSS and Markdown< / a > . If this is not enough, this page describes how you can create your own output formats.< / p >
< p > If you instead just want to < a href = "/hugo-theme-relearn/configuration/customization/designs/index.html" > customize the layout of an existing output format< / a > , the theme got you covered as well.< / p >
< h2 id = "creating-an-output-format" > Creating an Output Format< / h2 >
< p > Suppose you want to be able to send your articles as HTML formatted emails. The pages of these format need to be self contained so an email client can display the content without loading any further assets.< / p >
< p > Therefore we add a new output format called < code > email< / code > that outputs HTML and assembles a completely custom HTML document structure.< / p >
2024-10-13 14:26:50 +00:00
< ol >
2024-12-31 17:03:38 +00:00
< li >
< p > Add the output format to your < code > hugo.toml< / code > < / p >
< div class = "tab-panel" data-tab-group = "config-code" >
< div class = "tab-nav" >
< div class = "tab-nav-title" > hugo.< / div >
< button
data-tab-item="toml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
onclick="switchTab('config-code','toml')"
>
< span class = "tab-nav-text" > toml< / span >
< / button >
< button
data-tab-item="yaml"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','yaml')"
>
< span class = "tab-nav-text" > yaml< / span >
< / button >
< button
data-tab-item="json"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','json')"
>
< span class = "tab-nav-text" > json< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="toml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > outputFormats< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > outputFormats< / span > < span class = "p" > .< / span > < span class = "nx" > email< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > baseName< / span > < span class = "p" > =< / span > < span class = "s1" > ' index.email' < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > isHTML< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > mediaType< / span > < span class = "p" > =< / span > < span class = "s1" > ' text/html' < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > name< / span > < span class = "p" > =< / span > < span class = "s1" > ' email' < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > noUgly< / span > < span class = "p" > =< / span > < span class = "kc" > true< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > permalinkable< / span > < span class = "p" > =< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > outputs< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > home< / span > < span class = "p" > =< / span > < span class = "p" > [< / span > < span class = "s1" > ' html' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' rss' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' email' < / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > page< / span > < span class = "p" > =< / span > < span class = "p" > [< / span > < span class = "s1" > ' html' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' rss' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' email' < / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > section< / span > < span class = "p" > =< / span > < span class = "p" > [< / span > < span class = "s1" > ' html' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' rss' < / span > < span class = "p" > ,< / span > < span class = "s1" > ' email' < / span > < span class = "p" > ]< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="yaml"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-yaml" data-lang = "yaml" > < span class = "line" > < span class = "cl" > < span class = "nt" > outputFormats< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > email< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > baseName< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > index.email< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > isHTML< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > mediaType< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > text/html< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > email< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > noUgly< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > true< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > permalinkable< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "kc" > false< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > outputs< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > home< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > html< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > rss< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > email< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > page< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > html< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > rss< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > email< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > section< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > html< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > rss< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > - < span class = "l" > email< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="json"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-json" data-lang = "json" > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " outputFormats" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " email" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " baseName" < / span > < span class = "p" > :< / span > < span class = "s2" > " index.email" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " isHTML" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " mediaType" < / span > < span class = "p" > :< / span > < span class = "s2" > " text/html" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " name" < / span > < span class = "p" > :< / span > < span class = "s2" > " email" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " noUgly" < / span > < span class = "p" > :< / span > < span class = "kc" > true< / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " permalinkable" < / span > < span class = "p" > :< / span > < span class = "kc" > false< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > },< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " outputs" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " home" < / span > < span class = "p" > :< / span > < span class = "p" > [< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " html" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " rss" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " email" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > ],< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " page" < / span > < span class = "p" > :< / span > < span class = "p" > [< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " html" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " rss" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " email" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > ],< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " section" < / span > < span class = "p" > :< / span > < span class = "p" > [< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " html" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " rss" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s2" > " email" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< / li >
< li >
< p > Create a file < code > layouts/_default/baseof.email.html< / code > < / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "8cf06d3ee2931fcdb66f98762c082943" >
2024-12-31 17:03:38 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layouts_defaultbaseofemailhtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('8cf06d3ee2931fcdb66f98762c082943','layouts_defaultbaseofemailhtml')"
2024-12-31 17:03:38 +00:00
>
< span class = "tab-nav-text" > layouts/_default/baseof.email.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layouts_defaultbaseofemailhtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" hl_Lines = "15" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "cp" > < !DOCTYPE html> < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > html< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > head< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > title< / span > < span class = "p" > > < / span > {{ .Title }}< span class = "p" > < /< / span > < span class = "nt" > title< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "na" > type< / span > < span class = "o" > =< / span > < span class = "s" > " text/css" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "c" > /* add some styles here to make it pretty */< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "na" > type< / span > < span class = "o" > =< / span > < span class = "s" > " text/css" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "c" > /* add chroma style for code highlighting */< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span > < span class = "err" > {-< / span > < span class = "err" > " /assets/css/chroma-relearn-light.css" < / span > < span class = "err" > |< / span > < span class = "err" > readFile< / span > < span class = "err" > |< / span > < span class = "err" > safeCSS< / span > < span class = "p" > }< / span > < span class = "err" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > head< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > body< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > main< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- block " body" . }}{{ end }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > main< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > body< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > html< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < p > The marked < code > block< / code > construct above will cause the display of the article with a default HTML structure. In case you want to keep it really simple, you could replace this line with just < code > {{ .Content }}< / code > .< / p >
< / li >
< li >
< p > < em > Optional< / em > : create a file < code > layouts/_default/views/article.email.html< / code > < / p >
< p > In our case, we want to display a disclaimer in front of every article. To do this we have to define the output of an article ourself and rely on the above < code > block< / code > statement to call our template.< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "6f990ed6ed330d7d86ffa4092476b481" >
2024-12-31 17:03:38 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layouts_defaultviewsarticleemailhtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('6f990ed6ed330d7d86ffa4092476b481','layouts_defaultviewsarticleemailhtml')"
2024-12-31 17:03:38 +00:00
>
< span class = "tab-nav-text" > layouts/_default/views/article.email.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layouts_defaultviewsarticleemailhtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > article< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " email" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > blockquote< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > View this article on < span class = "p" > < < / span > < span class = "nt" > a< / span > < span class = "na" > href< / span > < span class = "o" > =< / span > < span class = "s" > " http://example.com{{ .RelPermalink }}" < / span > < span class = "p" > > < / span > our website< span class = "p" > < /< / span > < span class = "nt" > a< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > blockquote< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{ partial " article-content.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > article< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
< li >
< p > < em > Optional< / em > : create a file < code > layouts/_default/_markup_/render-image.email.html< / code > < / p >
< p > In our case, we want to convert each image into a base 64 encoded string to display it inline in the email without loading external assets.< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "ffcf71836ec91c46f7d884418e173939" >
2024-12-31 17:03:38 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layouts_defaultmarkuprender-imageemailhtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('ffcf71836ec91c46f7d884418e173939','layouts_defaultmarkuprender-imageemailhtml')"
2024-12-31 17:03:38 +00:00
>
< span class = "tab-nav-text" > layouts/_default/< em > markup< / em > /render-image.email.html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layouts_defaultmarkuprender-imageemailhtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > {{- $dest_url := urls.Parse .Destination }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- $dest_path := path.Clean ($dest_url.Path) }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- $img := .Page.Resources.GetMatch $dest_path }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- if and (not $img) .Page.File }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- $path := path.Join .Page.File.Dir $dest_path }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- $img = resources.Get $path }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- end }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- if $img }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- if (gt (len $img.Content) 1000000000) }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{/* currently resizing does not work for animated gifs :-( */}}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- $img = $img.Resize " 600x webp q75" }}
< / span > < / span > < span class = "line" > < span class = "cl" > {{- end }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > img< / span > < span class = "na" > src< / span > < span class = "o" > =< / span > < span class = "s" > " data:{{ $img.MediaType }};base64,{{ $img.Content | base64Encode }}" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- end }}< / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
2024-10-13 14:26:50 +00:00
< / ol >
2024-12-31 17:03:38 +00:00
< h2 id = "partials" > Partials< / h2 >
< h3 id = "for-html-output-formats" > For HTML Output Formats< / h3 >
< p > If you want to keep the general HTML framework and only change specific parts, you can provide these files for your output format independently of one another:< / p >
2024-10-13 14:26:50 +00:00
< ul >
2024-12-31 17:03:38 +00:00
< li > < code > layouts/_default/views/article.< FORMAT> .html< / code > : < em > Optional< / em > : Controls how a page’ s content and title are displayed< / li >
2024-12-31 19:57:26 +00:00
< li > < code > layouts/_default/views/body.< FORMAT> .html< / code > : < em > Optional< / em > : Determines what to contain in the content area (for example a single page, a list of pages, a tree of sub pages)< / li >
2024-12-31 17:03:38 +00:00
< li > < code > layouts/_default/views/menu.< FORMAT> .html< / code > : < em > Optional< / em > : Defines the sidebar menu layout< / li >
< li > < code > layouts/_default/views/storeOutputFormat.< FORMAT> .html< / code > : < em > Optional< / em > : Stores the output format name for use in the framework to let the body element been marked with an output format specific class< / li >
2024-10-13 14:26:50 +00:00
< / ul >
2024-12-31 17:03:38 +00:00
< p > For a real-world example, check out the < code > print< / code > output format implementation< / p >
2024-10-13 14:26:50 +00:00
< ul >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/views/body.print.html" rel = "external" target = "_self" > < code > layouts/_default/views/body.print.html< / code > < / a > < / li >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/views/menu.print.html" rel = "external" target = "_self" > < code > layouts/_default/views/menu.print.html< / code > < / a > < / li >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/views/storeOutputFormat.print.html" rel = "external" target = "_self" > < code > layouts/_default/views/storeOutputFormat.print.html< / code > < / a > < / li >
2024-12-31 17:03:38 +00:00
< / ul >
< h3 id = "for-non-html-output-formats" > For Non-HTML Output Formats< / h3 >
< ul >
< li > < code > layouts/_default/list.< FORMAT> < / code > : < em > Mandatory< / em > : Controls how sections are displayed< / li >
< li > < code > layouts/_default/single.< FORMAT> < / code > : < em > Mandatory< / em > : Controls how pages are displayed< / li >
< li > < code > layouts/_default/baseof.< FORMAT> < / code > : < em > Optional< / em > : Controls how sections and pages are displayed. If not provided, you have to provide your implementation in < code > list.< FORMAT> < / code > and < code > single.< FORMAT> < / code > < / li >
< / ul >
< p > For a real-world example, check out the < code > markdown< / code > output format implementation< / p >
< ul >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/baseof.md" rel = "external" target = "_self" > < code > layouts/_default/baseof.md< / code > < / a > < / li >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/list.md" rel = "external" target = "_self" > < code > layouts/_default/list.md< / code > < / a > < / li >
< li > < a href = "https://github.com/McShelby/hugo-theme-relearn/blob/main/layouts/_default/single.md" rel = "external" target = "_self" > < code > layouts/_default/single.md< / code > < / a > < / li >
2024-12-31 19:57:26 +00:00
< / ul >
< h2 id = "migration-to-relearn-7-or-higher" > Migration to Relearn 7 or higher< / h2 >
< p > Previous to Relearn 7, HTML output formats did not use the < code > baseof.html< / code > but now do.< / p >
< h3 id = "for-html-output-formats-1" > For HTML Output Formats< / h3 >
< ul >
< li >
< p > Move your files < code > layouts/partials/article.< FORMAT> .html< / code > to < code > layouts/_default/views/article.< FORMAT> .html< / code > < / p >
< p > The files will most likely require further modifications as they now receive the page as it context (dot < code > .< / code > ) instead of the < code > .page< / code > and < code > .content< / code > parameter.< / p >
< p > < strong > Old< / strong > :< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "dd3402aa12819fd976cd07ecc44e17ab" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialsarticleltformatgthtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('dd3402aa12819fd976cd07ecc44e17ab','layoutspartialsarticleltformatgthtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/partials/article.< FORMAT> .html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialsarticleltformatgthtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" hl_Lines = "1-3 10 16" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line hl" > < span class = "cl" > {{- $page := .page }}
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- $content := .content }}
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- with $page }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > article< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " default" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > header< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " headline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-header.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > header< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " heading-pre.html" .}}{{partial " heading.html" .}}{{partial " heading-post.html" .}}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{ $content | safeHTML }}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > footer< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " footline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-footer.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > footer< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > article< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- end }}< / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < p > < strong > New< / strong > :< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "c6cb13c37eb53d217316d9fd9ed367cb" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layouts_defaultviewsarticleltformatgthtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('c6cb13c37eb53d217316d9fd9ed367cb','layouts_defaultviewsarticleltformatgthtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/_default/views/article.< FORMAT> .html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layouts_defaultviewsarticleltformatgthtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" hl_Lines = "7" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > article< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " default" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > header< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " headline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-header.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > header< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{partial " heading-pre.html" .}}{{partial " heading.html" .}}{{partial " heading-post.html" .}}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{ partial " article-content.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > footer< / span > < span class = "na" > class< / span > < span class = "o" > =< / span > < span class = "s" > " footline" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > {{- partial " content-footer.html" . }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > footer< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > article< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
< / ul >
< h3 id = "for-non-html-output-formats-1" > For Non-HTML Output Formats< / h3 >
< ul >
< li >
< p > Merge your files < code > layouts/partials/header.< FORMAT> .html< / code > , < code > layouts/partials/footer.< FORMAT> .html< / code > to < code > layouts/_default/baseof.< FORMAT> .html< / code > < / p >
< p > < strong > Old< / strong > :< / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "31dd1b191cbb655ecb61b353189c252b" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialsheaderltformatgthtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('31dd1b191cbb655ecb61b353189c252b','layoutspartialsheaderltformatgthtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/partials/header.< FORMAT> .html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialsheaderltformatgthtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "cp" > < !DOCTYPE html> < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > html< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > head< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > title< / span > < span class = "p" > > < / span > {{ .Title }}< span class = "p" > < /< / span > < span class = "nt" > title< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "na" > type< / span > < span class = "o" > =< / span > < span class = "s" > " text/css" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "c" > /* add some styles here to make it pretty */< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "na" > type< / span > < span class = "o" > =< / span > < span class = "s" > " text/css" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "c" > /* add chroma style for code highlighting */< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span > < span class = "err" > {-< / span > < span class = "err" > " /assets/css/chroma-relearn-light.css" < / span > < span class = "err" > |< / span > < span class = "err" > readFile< / span > < span class = "err" > |< / span > < span class = "err" > safeCSS< / span > < span class = "p" > }< / span > < span class = "err" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > head< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > body< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > main< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
2025-01-02 21:41:58 +00:00
< / div > < div class = "tab-panel" data-tab-group = "8dc315073ef687416d30cd0b867467c3" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layoutspartialsfooterltformatgthtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('8dc315073ef687416d30cd0b867467c3','layoutspartialsfooterltformatgthtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/partials/footer.< FORMAT> .html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layoutspartialsfooterltformatgthtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > main< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > body< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > html< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < p > < strong > New< / strong > :< / p >
< p > The upper part of the file is from your < code > header.< FORMAT> .html< / code > and the lower part is from your < code > footer.< FORMAT> .html< / code > .< / p >
< p > The marked line needs to be added, so your output format uses a potential < code > layouts/_default/views/article.< FORMAT> .html< / code > < / p >
2025-01-02 21:41:58 +00:00
< div class = "tab-panel" data-tab-group = "160359c19f15b39fd8ec3dc1d7c54c3f" >
2024-12-31 19:57:26 +00:00
< div class = "tab-nav" >
< div class = "tab-nav-title" > ​ < / div >
< button
data-tab-item="layouts_defaultbaseofltformatgthtml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
2025-01-02 21:41:58 +00:00
onclick="switchTab('160359c19f15b39fd8ec3dc1d7c54c3f','layouts_defaultbaseofltformatgthtml')"
2024-12-31 19:57:26 +00:00
>
< span class = "tab-nav-text" > layouts/_default/baseof.< FORMAT> .html< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="layouts_defaultbaseofltformatgthtml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" hl_Lines = "15" > < pre tabindex = "0" class = "chroma" > < code class = "language-html" data-lang = "html" > < span class = "line" > < span class = "cl" > < span class = "cp" > < !DOCTYPE html> < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > html< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > head< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > title< / span > < span class = "p" > > < / span > {{ .Title }}< span class = "p" > < /< / span > < span class = "nt" > title< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "na" > type< / span > < span class = "o" > =< / span > < span class = "s" > " text/css" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "c" > /* add some styles here to make it pretty */< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > style< / span > < span class = "na" > type< / span > < span class = "o" > =< / span > < span class = "s" > " text/css" < / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "c" > /* add chroma style for code highlighting */< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span > < span class = "err" > {-< / span > < span class = "err" > " /assets/css/chroma-relearn-light.css" < / span > < span class = "err" > |< / span > < span class = "err" > readFile< / span > < span class = "err" > |< / span > < span class = "err" > safeCSS< / span > < span class = "p" > }< / span > < span class = "err" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > style< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > head< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > body< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < < / span > < span class = "nt" > main< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line hl" > < span class = "cl" > {{- block " body" . }}{{ end }}
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > main< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > body< / span > < span class = "p" > > < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > < /< / span > < span class = "nt" > html< / span > < span class = "p" > > < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div > < / li >
2024-10-13 14:26:50 +00:00
< / ul >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/howto/index.html" > Howto< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< article class = "default" >
< header class = "headline" >
< div class = "R-taxonomy taxonomy-tags cstyle tags" title = "Tags" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/tags/taxonomy/index.html" > Taxonomy< / a > < / li >
< / ul >
< / div >
< / header >
< h1 id = "taxonomies" > Taxonomies< / h1 >
< p > This page explains how to show custom taxonomies on your pages.< / p >
< p > For more details, check the official docs on < a href = "https://gohugo.io/content-management/taxonomies/#configure-taxonomies" rel = "external" target = "_self" > setting up custom taxonomies< / a > and < a href = "https://gohugo.io/content-management/taxonomies/#assign-terms-to-content" rel = "external" target = "_self" > using them in your content< / a > .< / p >
< h2 id = "default-behavior" > Default Behavior< / h2 >
< p > The Relearn theme automatically shows Hugo’ s < a href = "https://gohugo.io/content-management/taxonomies/#default-taxonomies" rel = "external" target = "_self" > default taxonomies< / a > < em > tags< / em > and < em > categories< / em > out of the box.< / p >
< ul >
< li > Tags appear at the top of the page in alphabetical order in form of baggage tags.< / li >
< li > Categories appear at the bottom of the page in alphabetical order as a list prefixed with an icon.< / li >
< / ul >
< p > Each item links to a page showing all articles with that term.< / p >
< h2 id = "setting-up-custom-taxonomies" > Setting Up Custom Taxonomies< / h2 >
< p > To add custom taxonomies, update your < code > hugo.toml< / code > file. You also have to add the default taxonomies if you want to use them.< / p >
< div class = "tab-panel" data-tab-group = "config-code" >
< div class = "tab-nav" >
< div class = "tab-nav-title" > hugo.< / div >
< button
data-tab-item="toml"
class="tab-nav-button tab-panel-style cstyle initial active" tabindex="-1"
onclick="switchTab('config-code','toml')"
>
< span class = "tab-nav-text" > toml< / span >
< / button >
< button
data-tab-item="yaml"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','yaml')"
>
< span class = "tab-nav-text" > yaml< / span >
< / button >
< button
data-tab-item="json"
class="tab-nav-button tab-panel-style cstyle initial"
onclick="switchTab('config-code','json')"
>
< span class = "tab-nav-text" > json< / span >
< / button >
< / div >
< div class = "tab-content-container" >
< div
data-tab-item="toml"
class="tab-content tab-panel-style cstyle initial active">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-toml" data-lang = "toml" > < span class = "line" > < span class = "cl" > < span class = "p" > [< / span > < span class = "nx" > taxonomies< / span > < span class = "p" > ]< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > category< / span > < span class = "p" > =< / span > < span class = "s1" > ' categories' < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > mycustomtag< / span > < span class = "p" > =< / span > < span class = "s1" > ' mycustomtags' < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nx" > tag< / span > < span class = "p" > =< / span > < span class = "s1" > ' tags' < / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="yaml"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-yaml" data-lang = "yaml" > < span class = "line" > < span class = "cl" > < span class = "nt" > taxonomies< / span > < span class = "p" > :< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > category< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > categories< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > mycustomtag< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > mycustomtags< / span > < span class = "w" >
< / span > < / span > < / span > < span class = "line" > < span class = "cl" > < span class = "w" > < / span > < span class = "nt" > tag< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l" > tags< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< div
data-tab-item="json"
class="tab-content tab-panel-style cstyle initial">
< div class = "tab-content-text" >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-json" data-lang = "json" > < span class = "line" > < span class = "cl" > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " taxonomies" < / span > < span class = "p" > :< / span > < span class = "p" > {< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " category" < / span > < span class = "p" > :< / span > < span class = "s2" > " categories" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " mycustomtag" < / span > < span class = "p" > :< / span > < span class = "s2" > " mycustomtags" < / span > < span class = "p" > ,< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "nt" > " tag" < / span > < span class = "p" > :< / span > < span class = "s2" > " tags" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > }< / span > < / span > < / span > < / code > < / pre > < / div >
< / div >
< / div >
< / div >
< / div >
< h2 id = "showing-custom-taxonomies" > Showing Custom Taxonomies< / h2 >
< p > To display your custom taxonomy terms, add this to your page (usually in < code > layouts/partials/content-footer.html< / code > ):< / p >
< div class = "highlight wrap-code" > < pre tabindex = "0" class = "chroma" > < code class = "language-go" data-lang = "go" > < span class = "line" > < span class = "cl" > < span class = "p" > {{< / span > < span class = "nx" > partial< / span > < span class = "s" > " term-list.html" < / span > < span class = "p" > (< / span > < span class = "nx" > dict< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s" > " page" < / span > < span class = "p" > .< / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s" > " taxonomy" < / span > < span class = "s" > " mycustomtags" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "s" > " icon" < / span > < span class = "s" > " layer-group" < / span >
< / span > < / span > < span class = "line" > < span class = "cl" > < span class = "p" > )< / span > < span class = "p" > }}< / span > < / span > < / span > < / code > < / pre > < / div >
< h3 id = "parameter" > Parameter< / h3 >
< table >
< thead >
< tr >
2024-10-24 14:30:52 +00:00
< th > Name< / th >
< th > Default< / th >
< th > Notes< / th >
2024-10-13 14:26:50 +00:00
< / tr >
< / thead >
< tbody >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > page< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Mandatory reference to the page.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > taxonomy< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > The plural name of the taxonomy to display as used in your front matter.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > class< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > Additional CSS classes set on the outermost generated HTML element.< br > < br > If set to < code > tags< / code > you will get the visuals for displaying the < em > tags< / em > taxonomy, otherwise it will be a simple list of links as for the < em > categories< / em > taxonomy.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > style< / strong > < / td >
< td > < code > primary< / code > < / td >
< td > The style scheme used if < strong > class< / strong > is < code > tags< / code > .< br > < br > - by severity: < code > caution< / code > , < code > important< / code > , < code > info< / code > , < code > note< / code > , < code > tip< / code > , < code > warning< / code > < br > - by brand color: < code > primary< / code > , < code > secondary< / code > , < code > accent< / code > < br > - by color: < code > blue< / code > , < code > cyan< / code > , < code > green< / code > , < code > grey< / code > , < code > magenta< / code > , < code > orange< / code > , < code > red< / code > < br > - by special color: < code > default< / code > , < code > transparent< / code > , < code > code< / code > < / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > color< / strong > < / td >
< td > see notes< / td >
< td > The < a href = "https://developer.mozilla.org/en-US/docs/Web/CSS/color_value" rel = "external" target = "_self" > CSS color value< / a > to be used if < strong > class< / strong > is < code > tags< / code > . If not set, the chosen color depends on the < strong > style< / strong > . Any given value will overwrite the default.< br > < br > - for severity styles: a nice matching color for the severity< br > - for all other styles: the corresponding color< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< tr >
2024-10-24 14:30:52 +00:00
< td > < strong > icon< / strong > < / td >
< td > < em > < empty> < / em > < / td >
< td > An optional < a href = "/hugo-theme-relearn/shortcodes/icon/index.html#finding-an-icon" > Font Awesome icon name< / a > set to the left of the list.< / td >
2024-10-13 14:26:50 +00:00
< / tr >
< / tbody >
< / table >
< footer class = "footline" >
< div class = "R-taxonomy taxonomy-categories cstyle" title = "Categories" style = "--VARIABLE-TAGS-BG-color: var(--INTERNAL-TAG-BG-color);" >
< i class = "fa-fw fas fa-layer-group" > < / i >
< ul >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/explanation/index.html" > Explanation< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/howto/index.html" > Howto< / a > < / li >
< li > < a class = "term-link" href = "/hugo-theme-relearn/categories/reference/index.html" > Reference< / a > < / li >
< / ul >
< / div >
< / footer >
< / article >
< / section >
< / div >
< / main >
< / div >
2025-01-02 21:41:58 +00:00
< script src = "/hugo-theme-relearn/js/clipboard.min.js?1735854104" defer > < / script >
< script src = "/hugo-theme-relearn/js/perfect-scrollbar.min.js?1735854104" defer > < / script >
< script src = "/hugo-theme-relearn/js/theme.js?1735854104" defer > < / script >
2024-10-13 14:26:50 +00:00
< / body >
< / html >