Compare commits

...

28 Commits

Author SHA1 Message Date
Mark Dumay
f4d59a0324 Merge pull request #1500 from gethinode/develop
Develop
2025-07-07 14:22:40 +02:00
Mark Dumay
6c068898a3 fix: ensure card icons have equal width 2025-07-07 14:15:30 +02:00
Mark Dumay
eec6697ff6 Merge branch 'main' into develop 2025-07-07 14:02:53 +02:00
Mark Dumay
26402fb5be fix: update build stats 2025-07-07 14:02:18 +02:00
Mark Dumay
e08aebf928 docs: adjust article layout 2025-07-07 14:02:01 +02:00
Mark Dumay
787ad2eb91 feat: make card icons configurable 2025-07-07 14:01:23 +02:00
Mark Dumay
8f137b0c54 feat: make article icons configurable 2025-07-07 14:00:41 +02:00
Mark Dumay
a979dd8d58 fix: adjust default values of card arguments 2025-07-07 14:00:03 +02:00
Mark Dumay
b77a125485 fix: correct card group argument initialization of icon-style 2025-07-07 13:59:27 +02:00
Mark Dumay
004da99765 docs: include additional card examples 2025-07-07 13:58:51 +02:00
Mark Dumay
907c8ac800 fix: improve rendering of card icons
Icon columns now resize properly when set to horizontal layout.
Padding and alignment have also been revised.
2025-07-07 13:20:54 +02:00
Mark Dumay
a8efc27771 Merge pull request #1499 from gethinode/develop
fix: correct separator argument definition
2025-07-06 14:29:27 +02:00
Mark Dumay
3bf8da3767 Merge branch 'main' into develop 2025-07-06 14:20:10 +02:00
Mark Dumay
131de0c064 fix: correct seperator argument definition 2025-07-06 14:16:52 +02:00
Mark Dumay
a914fe18e8 Merge pull request #1497 from gethinode/hugo-mod-dependencies
Update Hugo module dependencies
2025-07-06 13:45:08 +02:00
Mark Dumay
a855a41c13 Merge branch 'main' into hugo-mod-dependencies 2025-07-06 12:14:28 +02:00
Mark Dumay
c41cd0650e Merge pull request #1498 from gethinode/develop
Develop
2025-07-06 12:08:43 +02:00
Mark Dumay
a83bab6689 Merge branch 'main' into develop 2025-07-06 12:03:41 +02:00
Mark Dumay
03a099ae66 fix: correct hide-empty argument in articles content block 2025-07-06 12:03:07 +02:00
Mark Dumay
cd837cf116 feat: add panels content block 2025-07-06 11:51:37 +02:00
Mark Dumay
8cffd358aa feat: improve responsive behavior of nav control 2025-07-06 11:51:10 +02:00
Mark Dumay
0d33a15e98 fix: improve layout 2025-07-06 11:47:24 +02:00
Mark Dumay
9be691eb6b fix: adjust heading size of CTA 2025-07-06 11:46:58 +02:00
Mark Dumay
fd727228d7 fix: adjust size argument of section title 2025-07-06 11:46:42 +02:00
Mark Dumay
a9f1cd098d feat: include ordinal position of content blocks 2025-07-06 11:44:41 +02:00
markdumay
dc1c358cfa fix: update Hugo module dependencies 2025-07-06 03:34:33 +00:00
github-actions[bot]
0d24dc445d Merge pull request #1495 from gethinode/dependabot/npm_and_yarn/neostandard-0.12.2
Bump neostandard from 0.12.1 to 0.12.2
2025-07-04 13:41:07 +00:00
dependabot[bot]
f6f034252b Bump neostandard from 0.12.1 to 0.12.2
Bumps [neostandard](https://github.com/neostandard/neostandard) from 0.12.1 to 0.12.2.
- [Release notes](https://github.com/neostandard/neostandard/releases)
- [Changelog](https://github.com/neostandard/neostandard/blob/main/CHANGELOG.md)
- [Commits](https://github.com/neostandard/neostandard/compare/v0.12.1...v0.12.2)

---
updated-dependencies:
- dependency-name: neostandard
  dependency-version: 0.12.2
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
2025-07-04 13:35:15 +00:00
36 changed files with 2136 additions and 833 deletions

45
assets/js/nav.js Normal file
View File

@@ -0,0 +1,45 @@
function updateDropdown (element, id, label) {
const dropdown = document.getElementById(element)
if (dropdown != null) {
dropdown.querySelector('.dropdown-toggle').textContent = label
dropdown.querySelectorAll('.panel-dropdown .dropdown-item').forEach(item => {
item.classList.remove('active')
let target = item.getAttribute('data-link')
if (target != null) {
target = target.replace(/^#+/, '')
if (target === id) {
item.classList.add('active')
}
}
})
}
}
document.querySelectorAll('.panel-dropdown').forEach(trigger => {
trigger.addEventListener('hide.bs.dropdown', event => {
if (event.clickEvent != null) {
let target = event.clickEvent.srcElement.getAttribute('data-link')
if (target != null) {
trigger.querySelectorAll('.panel-dropdown .dropdown-item').forEach(item => {
item.classList.remove('active')
})
target = target.replace(/^#+/, '')
const btn = document.getElementById(target)
if (btn != null) {
event.clickEvent.srcElement.classList.add('active')
trigger.querySelector('.dropdown-toggle').textContent = event.clickEvent.srcElement.textContent
btn.click()
}
}
}
})
})
document.querySelectorAll('.nav-panel .nav-link').forEach(trigger => {
trigger.addEventListener('click', event => {
const companion = event.srcElement.parentElement.parentElement.getAttribute('data-companion')
if (companion != null) {
updateDropdown(companion, trigger.getAttribute('id'), trigger.textContent.trim())
}
})
})

View File

@@ -5,6 +5,7 @@
@import "modules/bookshop/components/cta/cta"; @import "modules/bookshop/components/cta/cta";
@import "modules/bookshop/components/faq/faq"; @import "modules/bookshop/components/faq/faq";
@import "modules/bookshop/components/hero/hero"; @import "modules/bookshop/components/hero/hero";
@import "modules/bookshop/components/panels/panels";
@import "modules/bookshop/components/releases/releases"; @import "modules/bookshop/components/releases/releases";
@import "modules/bookshop/components/separator/separator"; @import "modules/bookshop/components/separator/separator";
@import "modules/bookshop/components/video-message/video-message"; @import "modules/bookshop/components/video-message/video-message";

View File

@@ -27,6 +27,8 @@ blueprint:
more: more:
title: title:
link: link:
icon-rounded:
icon-style:
cols: cols:
padding: padding:
limit: limit:

View File

@@ -62,46 +62,53 @@
<!-- Main code --> <!-- Main code -->
{{ if not $error }} {{ if not $error }}
{{- partial "assets/section-title.html" (dict "heading" $args.heading "justify" $args.justify) -}} {{ if or (gt (len $pages) 0) (not $args.hideEmpty) }}
{{- partial "assets/section-title.html" (dict "heading" $args.heading "justify" $args.justify) -}}
{{ $partial := "assets/card-group.html" }} {{ $partial := "assets/card-group.html" }}
{{ $params := dict }} {{ $params := dict }}
{{- $params = merge $params (dict {{- $params = merge $params (dict
"page" page "page" page
"list" $pages "list" $pages
"limit" $args.limit "limit" $args.limit
"cols" $args.cols "cols" $args.cols
"icon-rounded" $args.iconRounded "icon-rounded" $args.iconRounded
"href" (cond $moreButton $moreLink "") "icon-style" $args.iconStyle
"href-title" (cond $moreButton $moreTitle "") "href" (cond $moreButton $moreLink "")
"href-force" (gt $result.total (len $result.pages)) "href-title" (cond $moreButton $moreTitle "")
)}} "href-force" (gt $result.total (len $result.pages))
)}}
{{ if $args.scroll }} {{ if $args.scroll }}
{{ $partial := "assets/stack.html" }} {{ $partial := "assets/stack.html" }}
{{ $params = merge $params (dict {{ $params = merge $params (dict
"header-style" "none" "header-style" "none"
"body-style" "title" "body-style" "title"
"footer-style" "none" "footer-style" "none"
"gutter" 1 "gutter" 1
"padding" 3 "padding" 3
"ratio" "1x1" "ratio" "1x1"
"orientation" "horizontal-sm" "orientation" "horizontal-sm"
"styles" (cond $args.bento $styles "") "styles" (cond $args.bento $styles "")
) -}} ) -}}
{{ else }} {{ else }}
{{ $params = merge $params (dict {{ $params = merge $params (dict
"header-style" $args.headerStyle "header-style" $args.headerStyle
"footer-style" $args.footerStyle "footer-style" $args.footerStyle
"padding" $args.padding "padding" $args.padding
"class" (or $args.class "border-0") "class" (or $args.class "border-0")
"icon-style" "fa-2x" "align" "start"
"align" "start" "orientation" $args.orientation
"orientation" $args.orientation "hook" "assets/live-card.html"
"hook" "assets/live-card.html" "pagination" $args.pagination
"pagination" $args.pagination "paginate" $paginate
"paginate" $paginate ) -}}
) -}} {{ end }}
{{ if gt (len $pages) 0 }}
{{ partial $partial $params }}
{{ else }}
{{- $padding := partial "utilities/GetPadding.html" -}}
<p class="pt-{{ $padding.y }}">{{- T "emptyList" }}.</p>
{{ end }}
{{ end }} {{ end }}
{{ partial $partial $params }}
{{ end }} {{ end }}

View File

@@ -17,6 +17,7 @@ blueprint:
width: width:
cols: cols:
icon-rounded: icon-rounded:
icon-style:
padding: padding:
background: background:
backdrop: backdrop:
@@ -32,3 +33,4 @@ blueprint:
class: class:
width: width:
justify: justify:
align:

View File

@@ -40,15 +40,15 @@
{{- partial "assets/card-group.html" (dict {{- partial "assets/card-group.html" (dict
"page" page "page" page
"list" $list "list" $list
"class" (printf "border-0 card-icon-primary d-%s-none %s" $breakpoint.prev $args.class) "class" (printf "border-0 card-icon-primary d-%s-none %s" $breakpoint.prev (or $args.class ""))
"cols" $args.cols "cols" $args.cols
"gutter" "4" "gutter" "4"
"padding" $args.padding "padding" $args.padding
"header-style" "none" "header-style" "none"
"footer-style" "none" "footer-style" "none"
"icon-rounded" $args.iconRounded "icon-rounded" $args.iconRounded
"icon-style" "fa-2x" "icon-style" (or $args.iconStyle "fa-2x")
"align" "start" "align" $args.align
"orientation" ($args.orientation | default "horizontal-sm") "orientation" ($args.orientation | default "horizontal-sm")
"hook" "assets/live-card.html" "hook" "assets/live-card.html"
) -}} ) -}}
@@ -56,15 +56,15 @@
{{- partial "assets/card-group.html" (dict {{- partial "assets/card-group.html" (dict
"page" page "page" page
"list" $list "list" $list
"class" (printf "border-0 card-icon-primary d-none d-%s-block %s" $breakpoint.prev $args.class) "class" (printf "border-0 card-icon-primary d-none d-%s-block %s" $breakpoint.prev (or $args.class ""))
"cols" $args.cols "cols" $args.cols
"gutter" "4" "gutter" "4"
"padding" $args.padding "padding" $args.padding
"header-style" "none" "header-style" "none"
"footer-style" "none" "footer-style" "none"
"icon-rounded" $args.iconRounded "icon-rounded" $args.iconRounded
"icon-style" "fa-2x" "icon-style" (or $args.iconStyle "fa-2x")
"align" "start" "align" $args.align
"orientation" ($args.orientation | default "stacked") "orientation" ($args.orientation | default "stacked")
"hook" "assets/live-card.html" "hook" "assets/live-card.html"
) -}} ) -}}

View File

@@ -0,0 +1,35 @@
# Metadata about this component, to be used in the CMS
spec:
structures:
- content_blocks
label: Panels
description: Introduction section
icon: check
tags: []
# Defines the structure of this component, as well as the default values
blueprint:
heading:
preheading:
heading:
content:
align:
width:
cols:
icon-rounded:
padding:
background:
backdrop:
color:
subtle:
elements:
- title:
icon:
image:
mode:
content:
tab-type:
ratio:
class:
width:
justify:

View File

@@ -0,0 +1,81 @@
{{/*
Copyright © 2025 The Hinode Team / Mark Dumay. All rights reserved.
Use of this source code is governed by The MIT License (MIT) that can be found in the LICENSE file.
Visit gethinode.com/license for more details.
*/}}
{{ $error := false }}
{{/* Initialize arguments */}}
{{ $args := partial "utilities/InitArgs.html" (dict "bookshop" "panels" "args" .)}}
{{ if or $args.err $args.warnmsg }}
{{ partial (cond $args.err "utilities/LogErr.html" "utilities/LogWarn.html") (dict
"partial" "component-library/components/panels/panels.hugo.html"
"warnid" "warn-invalid-arguments"
"msg" "Invalid arguments"
"details" ($args.errmsg | append $args.warnmsg)
"file" page.File
)}}
{{ $error = $args.err }}
{{ end }}
{{/* Initialize global arguments */}}
{{- $breakpoint := partial "utilities/GetBreakpoint.html" -}}
{{/* Initialize local variables */}}
{{ $list := slice }}
{{ $titles := slice }}
{{ $toc := slice }}
{{ $parentID := printf "panel-%v" (cond (isset . "_ordinal") (index . "_ordinal") (md5 (delimit (slice . now) "-"))) }}
{{ $inner := "" }}
{{ range $i, $element := $args.elements }}
{{ $toc = $toc | append (dict "href" "panel-0-1" "level" 2 "title" $element.title) }}
{{ $hero := partial "assets/hero.html" (dict
"page" page
"heading" (dict "title" $element.title "content" $element.content "width" 8 "size" 6)
"background" $args.background
"illustration" (dict "ratio" $args.ratio "icon" $element.icon "image" $element.image "mode" $element.mode)
"order" $args.order
"link-type" $args.linkType
"links" $args.links
"orientation" "horizontal"
"align" "start"
"width" 12
)
}}
{{- $output := partial "assets/nav-item.html" (dict
"page" page
"id" $i
"parent-id" $parentID
"fade" false
"title" $element.title
"show" (eq $i 0)
"raw" $hero
)
-}}
{{ $inner = printf "%s\n%s" $inner $output }}
{{ $titles = $titles | append $element.title }}
{{ end}}
{{ if not $error }}
{{- partial "assets/section-title.html" (dict "heading" $args.heading "justify" $args.justify) -}}
{{- partial "assets/nav.html" (dict
"id" (or $args.id $parentID)
"page" page
"nav-items" $inner
"nav-titles" $titles
"tab-type" $args.tabType
"vertical" $args.vertical
"word-wrap" $args.wordWrap
"class" $args.class
"pane" $args.pane
"width" $args.width
"responsive" $args.responsive
)
-}}
{{ end }}

View File

@@ -0,0 +1,3 @@
.panels .dropdown-toggle {
text-decoration: none !important;
}

View File

@@ -6,3 +6,5 @@ spec:
description: Inserts a horizontal page section separator description: Inserts a horizontal page section separator
icon: horizontal_rule icon: horizontal_rule
tags: [] tags: []
blueprint:

View File

@@ -4,7 +4,7 @@
Visit gethinode.com/license for more details. Visit gethinode.com/license for more details.
*/}} */}}
{{ $args := partial "utilities/InitArgs.html" (dict "structure" "separator" "args" .) }} {{ $args := partial "utilities/InitArgs.html" (dict "bookshop" "separator" "args" .) }}
{{ if or $args.err $args.warnmsg }} {{ if or $args.err $args.warnmsg }}
{{ partial (cond $args.err "utilities/LogErr.html" "utilities/LogWarn.html") (dict {{ partial (cond $args.err "utilities/LogErr.html" "utilities/LogWarn.html") (dict
"partial" "component-library/components/separator/separator.hugo.html" "partial" "component-library/components/separator/separator.hugo.html"

View File

@@ -12,6 +12,7 @@ arguments:
class: class:
color: color:
padding: padding:
default: 3
gutter: gutter:
release: v0.19.0 release: v0.19.0
header-style: header-style:
@@ -43,6 +44,7 @@ arguments:
icon-rounded: icon-rounded:
release: v1.0.0 release: v1.0.0
align: align:
default: start
wrapper: wrapper:
default: p-0 default: p-0
responsive: responsive:

View File

@@ -15,6 +15,7 @@ arguments:
parent: cascade parent: cascade
padding: padding:
parent: cascade parent: cascade
default: 3
gutter: gutter:
default: 0 default: 0
parent: cascade parent: cascade
@@ -45,6 +46,7 @@ arguments:
icon-rounded: icon-rounded:
release: v1.0.0 release: v1.0.0
align: align:
default: start
parent: cascade parent: cascade
release: v0.23.0 release: v0.23.0
scroll: scroll:

View File

@@ -15,6 +15,9 @@ arguments:
class: class:
body: body:
group: partial group: partial
raw:
group: partial
release: v1.3.0
navitem-type: navitem-type:
release: v1.0.0 release: v1.0.0
illustration: illustration:

View File

@@ -22,6 +22,8 @@ arguments:
release: v1.0.0 release: v1.0.0
class: class:
pane: pane:
responsive:
release: v1.4.0
width: width:
default: 12 default: 12
group: partial group: partial

View File

@@ -1,20 +0,0 @@
comment: >-
Inserts a horizontal page section separator.
arguments:
_bookshop_name:
type: string
optional: true
comment: Unique name of the bookshop component
group: partial
page:
type:
- '*hugolib.pageState'
- '*hugolib.pageForShortcode'
optional: true
comment: Context of the current page.
group: partial
theme:
type: string
optional: true
comment: Color theme to apply.
release: v1.0.0-alpha

View File

@@ -129,7 +129,7 @@
# themeFontPath = "https://fonts.googleapis.com/css2?family=Inter:wght@200;300;600&display=swap" # external path # themeFontPath = "https://fonts.googleapis.com/css2?family=Inter:wght@200;300;600&display=swap" # external path
themeFontPath = "/fonts" # local path themeFontPath = "/fonts" # local path
themeFontPreload = "/fonts/inter-v12-latin-regular.woff2" themeFontPreload = "/fonts/inter-v12-latin-regular.woff2"
purge = true purge = false
# toml-docs-end theme-colors # toml-docs-end theme-colors
[schema] [schema]

View File

@@ -56,6 +56,7 @@ content_blocks:
cols: 1 cols: 1
padding: 4 padding: 4
limit: 2 limit: 2
icon-style: fa-5x
header-style: none header-style: none
footer-style: tags footer-style: tags
orientation: horizontal-sm orientation: horizontal-sm

View File

@@ -25,9 +25,10 @@ content_blocks:
more: more:
title: More Posts title: More Posts
cols: 3 cols: 3
padding: 0 padding: 3
limit: 9 limit: 9
paginate: true paginate: true
cover: false cover: false
header-style: none header-style: none
class: border-1
--- ---

View File

@@ -24,14 +24,19 @@ The `cards` content block renders a group of content cards.
subtle: true subtle: true
orientation: stacked orientation: stacked
icon-rounded: true icon-rounded: true
class: text-center icon-style: fa-xs
padding: 0
align: start
elements: elements:
- title: First Card - title: First Card
icon: fas 1 icon: fas 1
content: Content of the first card
- title: Second Card - title: Second Card
icon: fas 2 icon: fas 2
content: Content of the second card
- title: Third Card - title: Third Card
icon: fas 3 icon: fas 3
content: Content of the third card
``` ```
{{< /example-bookshop >}} {{< /example-bookshop >}}
@@ -42,3 +47,145 @@ The `cards` content block renders a group of content cards.
The content block supports the following arguments: The content block supports the following arguments:
{{< args bookshop-cards >}} {{< args bookshop-cards >}}
## Examples
### Stacked cards with an image
Set the `image` attribute of each `element` to an image asset to render illustrated cards.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: cards
heading:
preheading: Preheading
title: Heading
content: Cards content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
orientation: stacked
class: bg-body
align: center
elements:
- title: First Card
image: /img/nat-9l98kFByiao-unsplash.jpg
- title: Second Card
image: /img/nat-9l98kFByiao-unsplash.jpg
- title: Third Card
image: /img/nat-9l98kFByiao-unsplash.jpg
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
### Horizontal cards with an image
Set the `orientation` attribute to `horizontal` to render horizontally oriented cards.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: cards
heading:
preheading: Preheading
title: Heading
content: Cards content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
orientation: horizontal
class: bg-body
align: center
elements:
- title: First Card
image: /img/nat-9l98kFByiao-unsplash.jpg
content: Content of the first card
- title: Second Card
image: /img/nat-9l98kFByiao-unsplash.jpg
content: Content of the second card
- title: Third Card
image: /img/nat-9l98kFByiao-unsplash.jpg
content: Content of the third card
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
### Stacked cards with an icon
Set the `icon` attribute of each `element` to an icon to render illustrated cards. Adjust the icon's styling with `icon-rounded` and `icon-style`.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: cards
heading:
preheading: Preheading
title: Heading
content: Cards content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
orientation: stacked
icon-style: fa-xs text-primary
align: start
padding: 0
elements:
- title: First Card
icon: fas 1
content: Content of the first card
- title: Second Card
icon: fas 2
content: Content of the second card
- title: Third Card
icon: fas 3
content: Content of the third card
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
### Horizontal cards with an icon
Set the `icon` attribute of each `element` to an icon to render illustrated cards. Adjust the icon's styling with `icon-rounded` and `icon-style`.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: cards
heading:
preheading: Preheading
title: Heading
content: Cards content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
orientation: horizontal
icon-rounded: true
icon-style: fa-2xs text-primary
align: start
padding: 0
elements:
- title: First Card
icon: fas 1
content: Content of the first card
- title: Second Card
icon: fas 2
content: Content of the second card
- title: Third Card
icon: fas 3
content: Content of the third card
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->

View File

@@ -0,0 +1,189 @@
---
_schema: default
title: Panels
description: Use the panels content block to display multiple toggable panels.
icon: fa folder
---
## Overview
The `panels` content block displays multiple panels that are toggled by a tab control.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: panels
heading:
preheading: Preheading
title: Heading
content: Panels content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
width: 12
tab-type: underline
ratio: 1x1
elements:
- title: First Panel
image: /img/sunrise.jpg
content: content 1
- title: Second Panel
image: /img/nat-9l98kFByiao-unsplash.jpg
content: content 2
- title: Third Panel
image: /img/pj-accetturo-XpD6Dkui-yg-unsplash.jpg
content: content 3
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
## Arguments
The content block supports the following arguments:
{{< args bookshop-panels >}}
## Examples
### Tabs
Set `tab-type` to `tabs` to adjust the panel controls.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: panels
heading:
preheading: Preheading
title: Heading
content: Panels content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
width: 12
tab-type: tabs
ratio: 1x1
elements:
- title: First Panel
image: /img/sunrise.jpg
content: content 1
- title: Second Panel
image: /img/nat-9l98kFByiao-unsplash.jpg
content: content 2
- title: Third Panel
image: /img/pj-accetturo-XpD6Dkui-yg-unsplash.jpg
content: content 3
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
### Pills
Set `tab-type` to `pills` to adjust the panel controls.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: panels
heading:
preheading: Preheading
title: Heading
content: Panels content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
width: 12
tab-type: pills
ratio: 1x1
elements:
- title: First Panel
image: /img/sunrise.jpg
content: content 1
- title: Second Panel
image: /img/nat-9l98kFByiao-unsplash.jpg
content: content 2
- title: Third Panel
image: /img/pj-accetturo-XpD6Dkui-yg-unsplash.jpg
content: content 3
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
### Underline
Set `tab-type` to `underline` to adjust the panel controls.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: panels
heading:
preheading: Preheading
title: Heading
content: Panels content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
width: 12
tab-type: underline
ratio: 1x1
elements:
- title: First Panel
image: /img/sunrise.jpg
content: content 1
- title: Second Panel
image: /img/nat-9l98kFByiao-unsplash.jpg
content: content 2
- title: Third Panel
image: /img/pj-accetturo-XpD6Dkui-yg-unsplash.jpg
content: content 3
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->
### Callout
Set `tab-type` to `callout` to adjust the panel controls.
<!-- markdownlint-disable MD037 -->
{{< example-bookshop lang="bookshop" >}}
```yml
- _bookshop_name: panels
heading:
preheading: Preheading
title: Heading
content: Panels content. It supports multiple lines.
align: start
background:
color: primary
subtle: true
width: 12
tab-type: callout
ratio: 1x1
elements:
- title: First Panel
image: /img/sunrise.jpg
content: content 1
- title: Second Panel
image: /img/nat-9l98kFByiao-unsplash.jpg
content: content 2
- title: Third Panel
image: /img/pj-accetturo-XpD6Dkui-yg-unsplash.jpg
content: content 3
```
{{< /example-bookshop >}}
<!-- markdownlint-enable MD037 -->

View File

@@ -70,7 +70,6 @@
], ],
"classes": [ "classes": [
"%!s(<nil>)", "%!s(<nil>)",
"%!s(MISSING)",
"about", "about",
"accordion", "accordion",
"accordion-body", "accordion-body",
@@ -90,6 +89,7 @@
"align-middle", "align-middle",
"align-self-center", "align-self-center",
"align-self-end", "align-self-end",
"align-self-start",
"anchor", "anchor",
"articles", "articles",
"background-container", "background-container",
@@ -144,6 +144,7 @@
"card-icon-primary", "card-icon-primary",
"card-icon-secondary", "card-icon-secondary",
"card-img-bg", "card-img-bg",
"card-img-h100",
"card-img-top", "card-img-top",
"card-img-wrap", "card-img-wrap",
"card-text", "card-text",
@@ -172,6 +173,7 @@
"col-6", "col-6",
"col-8", "col-8",
"col-9", "col-9",
"col-auto",
"col-lg-2", "col-lg-2",
"col-lg-4", "col-lg-4",
"col-lg-8", "col-lg-8",
@@ -230,9 +232,13 @@
"fa-2xs", "fa-2xs",
"fa-3", "fa-3",
"fa-4x", "fa-4x",
"fa-5x",
"fa-activity", "fa-activity",
"fa-address-card", "fa-address-card",
"fa-angle-left", "fa-angle-left",
"fa-angle-right",
"fa-angles-left",
"fa-angles-right",
"fa-arrow-left", "fa-arrow-left",
"fa-arrow-right", "fa-arrow-right",
"fa-bootstrap", "fa-bootstrap",
@@ -248,6 +254,7 @@
"fa-face-frown", "fa-face-frown",
"fa-facebook", "fa-facebook",
"fa-fluid", "fa-fluid",
"fa-folder",
"fa-fw", "fa-fw",
"fa-github", "fa-github",
"fa-globe", "fa-globe",
@@ -276,6 +283,7 @@
"fa-whatsapp", "fa-whatsapp",
"fa-wrapper", "fa-wrapper",
"fa-x-twitter", "fa-x-twitter",
"fa-xs",
"fab", "fab",
"fade", "fade",
"faq", "faq",
@@ -351,10 +359,12 @@
"main", "main",
"main-nav-toggler", "main-nav-toggler",
"mb-0", "mb-0",
"mb-1",
"mb-3", "mb-3",
"mb-4", "mb-4",
"mb-5", "mb-5",
"mb-lg-5", "mb-lg-5",
"me-1",
"me-3", "me-3",
"me-auto", "me-auto",
"mermaid", "mermaid",
@@ -364,6 +374,7 @@
"ms-3", "ms-3",
"ms-auto", "ms-auto",
"ms-md-3", "ms-md-3",
"mt-1",
"mt-2", "mt-2",
"mt-3", "mt-3",
"mt-4", "mt-4",
@@ -382,10 +393,13 @@
"my-md-0", "my-md-0",
"my-md-auto", "my-md-auto",
"nav", "nav",
"nav-callout",
"nav-item", "nav-item",
"nav-link", "nav-link",
"nav-panel",
"nav-pills", "nav-pills",
"nav-tabs", "nav-tabs",
"nav-underline",
"navbar", "navbar",
"navbar-brand", "navbar-brand",
"navbar-collapse", "navbar-collapse",
@@ -410,6 +424,12 @@
"p-3", "p-3",
"p-4", "p-4",
"p-md-4", "p-md-4",
"page-item",
"page-link",
"pagination",
"pagination-terse",
"panel-dropdown",
"panels",
"pb-3", "pb-3",
"pb-4", "pb-4",
"pb-5", "pb-5",
@@ -436,6 +456,7 @@
"ptw-sm-4", "ptw-sm-4",
"px-%!d(string=0)", "px-%!d(string=0)",
"px-2", "px-2",
"px-3",
"px-4", "px-4",
"px-xxl-0", "px-xxl-0",
"py-%!d(string=0)", "py-%!d(string=0)",
@@ -452,6 +473,7 @@
"rounded-5", "rounded-5",
"rounded-bottom", "rounded-bottom",
"rounded-pill", "rounded-pill",
"rounded-start",
"rounded-top", "rounded-top",
"row", "row",
"row-cols-1", "row-cols-1",
@@ -486,6 +508,7 @@
"table-border-bottom-wrap", "table-border-bottom-wrap",
"table-responsive-md", "table-responsive-md",
"table-wrap", "table-wrap",
"tabs-dropdown",
"tag-link", "tag-link",
"text-", "text-",
"text-bg-body-tertiary", "text-bg-body-tertiary",
@@ -585,6 +608,7 @@
"button", "button",
"button-group", "button-group",
"c4-diagram", "c4-diagram",
"callout",
"card", "card",
"card-group", "card-group",
"carousel", "carousel",
@@ -606,12 +630,25 @@
"data-tables", "data-tables",
"docs", "docs",
"documentation", "documentation",
"dropdown-nav-0",
"dropdown-panel-238964a04aea6f8244486a01aed3980e",
"dropdown-panel-2e7f06bd7d5712159e2b7e5ac229ee72",
"dropdown-panel-4ebb6a36beb73ac83f451cd6ec26838d",
"dropdown-panel-4fdf233f48f3ac0b803d8f61d31061f8",
"dropdown-panel-614a2684d4bdf8e5fe22a20d7d9c0a35",
"dropdown-panel-6d6a7601d2a9e04ae94f19b456563e16",
"dropdown-panel-741ce6efb5ef84856ecec7bb8244f44d",
"dropdown-panel-81fe53c7c723ca3d94d01401dc7e00c0",
"dropdown-panel-a446e03ac74b582fa6a24fefbc8dd1bf",
"dropdown-panel-c652a97140bc598c5580e01bdc444e65",
"elements-type", "elements-type",
"entity-relationship-diagram", "entity-relationship-diagram",
"example", "example",
"examples",
"exemple", "exemple",
"fa-address-card", "fa-address-card",
"fa-face-frown", "fa-face-frown",
"fa-folder",
"fa-square-check", "fa-square-check",
"fab-bootstrap", "fab-bootstrap",
"fab-docker", "fab-docker",
@@ -621,16 +658,24 @@
"fab-medium", "fab-medium",
"fab-whatsapp", "fab-whatsapp",
"fab-x-twitter", "fab-x-twitter",
"faq-9ef13ff2bd73b0e328491bd048c7a1ef", "faq-7533b3556b81a10b7e52b91bbf81d758",
"faq-9ef13ff2bd73b0e328491bd048c7a1ef-heading-faq-9ef13ff2bd73b0e328491bd048c7a1ef", "faq-7533b3556b81a10b7e52b91bbf81d758-heading-faq-7533b3556b81a10b7e52b91bbf81d758",
"faq-9ef13ff2bd73b0e328491bd048c7a1ef-item-0", "faq-7533b3556b81a10b7e52b91bbf81d758-item-0",
"faq-9ef13ff2bd73b0e328491bd048c7a1ef-item-1", "faq-7533b3556b81a10b7e52b91bbf81d758-item-1",
"faq-9ef13ff2bd73b0e328491bd048c7a1ef-item-2", "faq-7533b3556b81a10b7e52b91bbf81d758-item-2",
"faq-f9bb3b20a95e205fbad9e433c2899cbe",
"faq-f9bb3b20a95e205fbad9e433c2899cbe-heading-faq-f9bb3b20a95e205fbad9e433c2899cbe",
"faq-f9bb3b20a95e205fbad9e433c2899cbe-item-0",
"faq-f9bb3b20a95e205fbad9e433c2899cbe-item-1",
"faq-f9bb3b20a95e205fbad9e433c2899cbe-item-2",
"fas-1", "fas-1",
"fas-2", "fas-2",
"fas-3", "fas-3",
"fas-address-card", "fas-address-card",
"fas-angle-left", "fas-angle-left",
"fas-angle-right",
"fas-angles-left",
"fas-angles-right",
"fas-arrow-left", "fas-arrow-left",
"fas-arrow-right", "fas-arrow-right",
"fas-chevron-right", "fas-chevron-right",
@@ -659,6 +704,7 @@
"fichier", "fichier",
"fil-dariane", "fil-dariane",
"file", "file",
"first-panel",
"flowchart", "flowchart",
"footer-docs-collapse-15", "footer-docs-collapse-15",
"footer-docs-collapse-16", "footer-docs-collapse-16",
@@ -673,6 +719,8 @@
"gérer-les-préférences-des-cookies", "gérer-les-préférences-des-cookies",
"heading", "heading",
"heading-type", "heading-type",
"horizontal-cards-with-an-icon",
"horizontal-cards-with-an-image",
"how-do-we-use-cookies", "how-do-we-use-cookies",
"how-we-share-your-information", "how-we-share-your-information",
"icon", "icon",
@@ -711,6 +759,16 @@
"nav-0-btn-1", "nav-0-btn-1",
"nav-0-btn-2", "nav-0-btn-2",
"nav-nav-0", "nav-nav-0",
"nav-panel-238964a04aea6f8244486a01aed3980e",
"nav-panel-2e7f06bd7d5712159e2b7e5ac229ee72",
"nav-panel-4ebb6a36beb73ac83f451cd6ec26838d",
"nav-panel-4fdf233f48f3ac0b803d8f61d31061f8",
"nav-panel-614a2684d4bdf8e5fe22a20d7d9c0a35",
"nav-panel-6d6a7601d2a9e04ae94f19b456563e16",
"nav-panel-741ce6efb5ef84856ecec7bb8244f44d",
"nav-panel-81fe53c7c723ca3d94d01401dc7e00c0",
"nav-panel-a446e03ac74b582fa6a24fefbc8dd1bf",
"nav-panel-c652a97140bc598c5580e01bdc444e65",
"navbar", "navbar",
"navbar-0-collapse", "navbar-0-collapse",
"navbar-mode", "navbar-mode",
@@ -719,8 +777,69 @@
"navigation", "navigation",
"notification", "notification",
"overview", "overview",
"panel-238964a04aea6f8244486a01aed3980e-0",
"panel-238964a04aea6f8244486a01aed3980e-1",
"panel-238964a04aea6f8244486a01aed3980e-2",
"panel-238964a04aea6f8244486a01aed3980e-btn-0",
"panel-238964a04aea6f8244486a01aed3980e-btn-1",
"panel-238964a04aea6f8244486a01aed3980e-btn-2",
"panel-2e7f06bd7d5712159e2b7e5ac229ee72-0",
"panel-2e7f06bd7d5712159e2b7e5ac229ee72-1",
"panel-2e7f06bd7d5712159e2b7e5ac229ee72-2",
"panel-2e7f06bd7d5712159e2b7e5ac229ee72-btn-0",
"panel-2e7f06bd7d5712159e2b7e5ac229ee72-btn-1",
"panel-2e7f06bd7d5712159e2b7e5ac229ee72-btn-2",
"panel-4ebb6a36beb73ac83f451cd6ec26838d-0",
"panel-4ebb6a36beb73ac83f451cd6ec26838d-1",
"panel-4ebb6a36beb73ac83f451cd6ec26838d-2",
"panel-4ebb6a36beb73ac83f451cd6ec26838d-btn-0",
"panel-4ebb6a36beb73ac83f451cd6ec26838d-btn-1",
"panel-4ebb6a36beb73ac83f451cd6ec26838d-btn-2",
"panel-4fdf233f48f3ac0b803d8f61d31061f8-0",
"panel-4fdf233f48f3ac0b803d8f61d31061f8-1",
"panel-4fdf233f48f3ac0b803d8f61d31061f8-2",
"panel-4fdf233f48f3ac0b803d8f61d31061f8-btn-0",
"panel-4fdf233f48f3ac0b803d8f61d31061f8-btn-1",
"panel-4fdf233f48f3ac0b803d8f61d31061f8-btn-2",
"panel-614a2684d4bdf8e5fe22a20d7d9c0a35-0",
"panel-614a2684d4bdf8e5fe22a20d7d9c0a35-1",
"panel-614a2684d4bdf8e5fe22a20d7d9c0a35-2",
"panel-614a2684d4bdf8e5fe22a20d7d9c0a35-btn-0",
"panel-614a2684d4bdf8e5fe22a20d7d9c0a35-btn-1",
"panel-614a2684d4bdf8e5fe22a20d7d9c0a35-btn-2",
"panel-6d6a7601d2a9e04ae94f19b456563e16-0",
"panel-6d6a7601d2a9e04ae94f19b456563e16-1",
"panel-6d6a7601d2a9e04ae94f19b456563e16-2",
"panel-6d6a7601d2a9e04ae94f19b456563e16-btn-0",
"panel-6d6a7601d2a9e04ae94f19b456563e16-btn-1",
"panel-6d6a7601d2a9e04ae94f19b456563e16-btn-2",
"panel-741ce6efb5ef84856ecec7bb8244f44d-0",
"panel-741ce6efb5ef84856ecec7bb8244f44d-1",
"panel-741ce6efb5ef84856ecec7bb8244f44d-2",
"panel-741ce6efb5ef84856ecec7bb8244f44d-btn-0",
"panel-741ce6efb5ef84856ecec7bb8244f44d-btn-1",
"panel-741ce6efb5ef84856ecec7bb8244f44d-btn-2",
"panel-81fe53c7c723ca3d94d01401dc7e00c0-0",
"panel-81fe53c7c723ca3d94d01401dc7e00c0-1",
"panel-81fe53c7c723ca3d94d01401dc7e00c0-2",
"panel-81fe53c7c723ca3d94d01401dc7e00c0-btn-0",
"panel-81fe53c7c723ca3d94d01401dc7e00c0-btn-1",
"panel-81fe53c7c723ca3d94d01401dc7e00c0-btn-2",
"panel-a446e03ac74b582fa6a24fefbc8dd1bf-0",
"panel-a446e03ac74b582fa6a24fefbc8dd1bf-1",
"panel-a446e03ac74b582fa6a24fefbc8dd1bf-2",
"panel-a446e03ac74b582fa6a24fefbc8dd1bf-btn-0",
"panel-a446e03ac74b582fa6a24fefbc8dd1bf-btn-1",
"panel-a446e03ac74b582fa6a24fefbc8dd1bf-btn-2",
"panel-c652a97140bc598c5580e01bdc444e65-0",
"panel-c652a97140bc598c5580e01bdc444e65-1",
"panel-c652a97140bc598c5580e01bdc444e65-2",
"panel-c652a97140bc598c5580e01bdc444e65-btn-0",
"panel-c652a97140bc598c5580e01bdc444e65-btn-1",
"panel-c652a97140bc598c5580e01bdc444e65-btn-2",
"persona", "persona",
"pie-chart", "pie-chart",
"pills",
"projecten", "projecten",
"projects", "projects",
"projets", "projets",
@@ -730,14 +849,19 @@
"release", "release",
"requirement-chart", "requirement-chart",
"réduire", "réduire",
"second-panel",
"security", "security",
"sequence-diagram", "sequence-diagram",
"spinner", "spinner",
"stacked-cards-with-an-icon",
"stacked-cards-with-an-image",
"state-diagram", "state-diagram",
"sub", "sub",
"sup", "sup",
"sécurité", "sécurité",
"table", "table",
"tabs",
"third-panel",
"third-party-links--use-of-your-information", "third-party-links--use-of-your-information",
"timeline", "timeline",
"title", "title",
@@ -751,6 +875,7 @@
"tooltip", "tooltip",
"types-de-cookies-que-nous-utilisons", "types-de-cookies-que-nous-utilisons",
"types-of-cookies-we-use", "types-of-cookies-we-use",
"underline",
"user-journey", "user-journey",
"video", "video",
"video-type", "video-type",

2
go.mod
View File

@@ -18,7 +18,7 @@ require (
github.com/gethinode/mod-simple-datatables v1.1.7 // indirect github.com/gethinode/mod-simple-datatables v1.1.7 // indirect
github.com/gethinode/mod-simple-datatables/v2 v2.0.1 // indirect github.com/gethinode/mod-simple-datatables/v2 v2.0.1 // indirect
github.com/gethinode/mod-utils/v3 v3.3.1 // indirect github.com/gethinode/mod-utils/v3 v3.3.1 // indirect
github.com/gethinode/mod-utils/v4 v4.10.0 // indirect github.com/gethinode/mod-utils/v4 v4.11.0 // indirect
github.com/nextapps-de/flexsearch v0.0.0-20250606060143-c28f52c09b7a // indirect github.com/nextapps-de/flexsearch v0.0.0-20250606060143-c28f52c09b7a // indirect
github.com/twbs/bootstrap v5.3.7+incompatible // indirect github.com/twbs/bootstrap v5.3.7+incompatible // indirect
) )

2
go.sum
View File

@@ -460,6 +460,8 @@ github.com/gethinode/mod-utils/v4 v4.9.2 h1:lzcihwAsm8R2k2v+tWu5nfWvXMA8uRKi0nGI
github.com/gethinode/mod-utils/v4 v4.9.2/go.mod h1:bYmvRdAo4ICy5MpSGafDvO4p5bTDpsDKFCPL3bH0mN4= github.com/gethinode/mod-utils/v4 v4.9.2/go.mod h1:bYmvRdAo4ICy5MpSGafDvO4p5bTDpsDKFCPL3bH0mN4=
github.com/gethinode/mod-utils/v4 v4.10.0 h1:CfVa57r52wXd0bUqSJlpux2cloHQNBBe13aeqLJ8FXE= github.com/gethinode/mod-utils/v4 v4.10.0 h1:CfVa57r52wXd0bUqSJlpux2cloHQNBBe13aeqLJ8FXE=
github.com/gethinode/mod-utils/v4 v4.10.0/go.mod h1:bYmvRdAo4ICy5MpSGafDvO4p5bTDpsDKFCPL3bH0mN4= github.com/gethinode/mod-utils/v4 v4.10.0/go.mod h1:bYmvRdAo4ICy5MpSGafDvO4p5bTDpsDKFCPL3bH0mN4=
github.com/gethinode/mod-utils/v4 v4.11.0 h1:24RObT99j/jiQnCyHvXahJHIA8e8uQuBb1pUIRJOxpA=
github.com/gethinode/mod-utils/v4 v4.11.0/go.mod h1:bYmvRdAo4ICy5MpSGafDvO4p5bTDpsDKFCPL3bH0mN4=
github.com/nextapps-de/flexsearch v0.0.0-20230711092928-1243fd883ec3 h1:H/qVR5O4BXjRjD+5PZB+r4ug2BSJ2Of4RtwOntd+OKo= github.com/nextapps-de/flexsearch v0.0.0-20230711092928-1243fd883ec3 h1:H/qVR5O4BXjRjD+5PZB+r4ug2BSJ2Of4RtwOntd+OKo=
github.com/nextapps-de/flexsearch v0.0.0-20230711092928-1243fd883ec3/go.mod h1:5GdMfPAXzbA2gXBqTjC6l27kioSYzHlqDMh0+wyx7sU= github.com/nextapps-de/flexsearch v0.0.0-20230711092928-1243fd883ec3/go.mod h1:5GdMfPAXzbA2gXBqTjC6l27kioSYzHlqDMh0+wyx7sU=
github.com/nextapps-de/flexsearch v0.0.0-20240108021025-afd75f742f22 h1:re7L8FxbXQpnX8BgzkdUnDpsUmloGNyLmiy2ZCln8pg= github.com/nextapps-de/flexsearch v0.0.0-20240108021025-afd75f742f22 h1:re7L8FxbXQpnX8BgzkdUnDpsUmloGNyLmiy2ZCln8pg=

View File

@@ -156,7 +156,7 @@
"ratio" (partial "inline/style.html" (dict "styles" $args.styles "index" $index "key" "ratio" "default" $args.ratio)) "ratio" (partial "inline/style.html" (dict "styles" $args.styles "index" $index "key" "ratio" "default" $args.ratio))
"portrait" (partial "inline/style.html" (dict "styles" $args.styles "index" $index "key" "portrait" "default" $args.portrait)) "portrait" (partial "inline/style.html" (dict "styles" $args.styles "index" $index "key" "portrait" "default" $args.portrait))
"subtle" $args.subtle "subtle" $args.subtle
"icon-style" (or (index $element "$icon-style") $element.style) "icon-style" (or (index $element "icon-style") $element.style $args.iconStyle)
"align" $args.align "align" $args.align
"button" $args.button "button" $args.button
"button-label" (or (index $element "button-label") $element.buttonLabel) "button-label" (or (index $element "button-label") $element.buttonLabel)

View File

@@ -62,6 +62,26 @@
</small></p> </small></p>
{{- end -}} {{- end -}}
{{/* Inline partial to render the card's icon */}}
{{- define "_partials/inline/card-icon.html" -}}
{{ $padding := .padding }}
{{ $icon := .icon}}
{{ $rounded := .rounded }}
{{ $style := .style}}
{{ $stack := .stack }}
{{ $class := .class }}
<div class="card-icon{{ with $padding }} p-{{ . }}{{ end }}{{ if $rounded }} fa-stack {{ $style }} fa-fw {{ $stack }}{{ end }} {{ $class }}">
{{ if $rounded }}
{{- partial "assets/icon.html" (dict "icon" (printf "fas circle fa-stack-2x") "spacing" false) -}}
{{- partial "assets/icon.html" (dict "icon" (printf "%s fa-stack-1x fa-inverse" $icon) "spacing" false) -}}
{{ else }}
{{- partial "assets/icon.html" (dict "icon" (printf "%s %s fa-fw" $icon $style) "spacing" false) -}}
{{ end }}
</div>
{{- end -}}
{{/* Initialize global variables */}} {{/* Initialize global variables */}}
{{- $padding := partial "utilities/GetPadding.html" -}} {{- $padding := partial "utilities/GetPadding.html" -}}
@@ -110,7 +130,6 @@
{{- $icon := $args.icon -}} {{- $icon := $args.icon -}}
{{- $iconStyle := "" -}} {{- $iconStyle := "" -}}
{{- $anchor := $args.anchor }} {{- $anchor := $args.anchor }}
{{- $style := $args.style }}
{{- with $page -}} {{- with $page -}}
{{- if not $args.title }}{{ $title = .Title }}{{ end -}} {{- if not $args.title }}{{ $title = .Title }}{{ end -}}
@@ -126,10 +145,11 @@
{{- if not $args.anchor }}{{ $anchor = (or (and (reflect.IsMap .Params.Thumbnail) .Params.Thumbnail.anchor) "") }}{{ end -}} {{- if not $args.anchor }}{{ $anchor = (or (and (reflect.IsMap .Params.Thumbnail) .Params.Thumbnail.anchor) "") }}{{ end -}}
{{- end -}} {{- end -}}
{{- $style := $args.iconStyle }}
{{ if (hasPrefix $args.orientation "horizontal") }} {{ if (hasPrefix $args.orientation "horizontal") }}
{{ if not $args.style }}{{ $style = "fa-fluid fa-fw" }}{{ end }} {{ if not $args.iconStyle }}{{ $style = "fa-fluid fa-fw" }}{{ end }}
{{ else }} {{ else }}
{{ if not $args.style }}{{ $style = "fa-4x" }}{{ end }} {{ if not $args.iconStyle }}{{ $style = "fa-4x" }}{{ end }}
{{- $iconStyle = "pb-3" -}} {{- $iconStyle = "pb-3" -}}
{{ end }} {{ end }}
@@ -138,11 +158,19 @@
{{- if eq $args.body "none" }}{{ $title = "" }}{{ $description = "" }}{{ end -}} {{- if eq $args.body "none" }}{{ $title = "" }}{{ $description = "" }}{{ end -}}
{{ if site.Params.main.titleCase }}{{ $title = title $title }}{{ end }} {{ if site.Params.main.titleCase }}{{ $title = title $title }}{{ end }}
{{- $thumbnailArgs := dict
"src" $thumbnail
"portrait" $args.portrait
"anchor" $anchor
"sizes" $args.sizes
"title" (or $args.alt $title)
"loading" $args.loading
-}}
{{/* Main code */}} {{/* Main code */}}
{{ if or (ne $args.gutter "0") ($args.wrapper) }}<div class="g-{{ $args.gutter }} {{ $args.wrapper }}">{{ end }} {{ if or (ne $args.gutter "0") ($args.wrapper) }}<div class="g-{{ $args.gutter }} {{ $args.wrapper }} h-100">{{ end }}
{{ $stack := "fa-2x" }} {{ $stack := "" }}
{{- if hasPrefix $args.orientation "horizontal" -}} {{- if hasPrefix $args.orientation "horizontal" -}}
{{ $col1 := "" }} {{ $col1 := "" }}
@@ -157,61 +185,44 @@
{{ $col1 = "col-4 pe-0" }} {{ $col1 = "col-4 pe-0" }}
{{ $col2 = "col-8" }} {{ $col2 = "col-8" }}
{{ end }} {{ end }}
{{ else if $icon }}
{{ if eq $args.orientation "horizontal-sm" }}
{{ $stack = "fa-1x" }}
{{ $col1 = "col-4 col-md-2 pe-0" }}
{{ $col2 = "col-8 col-md-10" }}
{{ else }}
{{ $col1 = "col-4 pe-0" }}
{{ $col2 = "col-8" }}
{{ end }}
{{ end }} {{ end }}
{{/* Render horizontal card */}} {{/* Render horizontal card */}}
<div class="card {{ $colorStyle }}{{ $args.class }}"> <div class="card {{ $colorStyle }}{{ $args.class }}">
<div class="row g-0 row-cols-2 h-100{{ if $args.button }} pb-{{ $padding.y }}{{ end }}"> <div class="{{ if $thumbnail }}row-cols-2 row {{ end }} g-0 h-100{{ if $args.button }} pb-{{ $padding.y }}{{ end }}">
{{- if $thumbnail -}} {{- if $thumbnail -}}
<div class="{{ $col1 }}"> <div class="{{ $col1 }}">
{{ $fullHeight := "card-img-h100" }} {{ $fullHeight := "card-img-h100" }}
{{ $rounding := "rounded-start" }} {{ $rounding := "rounded-start" }}
{{ if eq (lower (path.Ext $thumbnail)) ".svg" }}{{ $fullHeight = "" }}{{ $rounding = "" }}{{ end }} {{ if eq (lower (path.Ext $thumbnail)) ".svg" }}{{ $fullHeight = "" }}{{ $rounding = "" }}{{ end }}
{{- partial $args.hook (dict {{- partial $args.hook (merge $thumbnailArgs (dict
"src" $thumbnail "wrapper" "card-img-wrap h-100 d-flex align-items-center"
"ratio" (or $ratio "auto")
"portrait" $args.portrait
"sizes" $args.sizes
"anchor" $anchor
"wrapper" "h-100 card-img-wrap d-flex align-items-center"
"class" (printf "card-img-bg %s %s" $rounding $fullHeight) "class" (printf "card-img-bg %s %s" $rounding $fullHeight)
"title" $title "ratio" (or $ratio "auto")
"loading" $args.loading )) -}}
) -}}
</div>
{{- else if $icon -}}
<div class="{{ $col1 }} p-{{ $args.padding }}">
<div class="card-icon {{ if $args.iconRounded }}fa-stack {{ $args.stack }} mx-auto{{ else }}fa-wrapper h-100 {{ end }} d-flex align-items-{{ $args.align}} justify-content-center {{ $iconStyle }}">
{{ if $args.iconRounded }}
{{- partial "assets/icon.html" (dict "icon" "fas circle fa-stack-2x") -}}
{{- partial "assets/icon.html" (dict "icon" (printf "%s fa-stack-1x fa-inverse" $icon)) -}}
{{ else }}
{{- partial "assets/icon.html" (dict "icon" (printf "%s %s" $icon $style)) -}}
{{ end }}
</div>
</div> </div>
{{- end -}} {{- end -}}
<div class="{{ $col2 }}"> <div class="{{ $col2 }}">
<div class="card-body d-flex p-{{ $args.padding }} flex-column h-100 flex-fill"> <div class="card-body p-{{ $args.padding }} h-100 hstack">
{{ if $page }} {{ if $icon }}
<div>{{ partial "inline/card-caption.html" (dict {{- partial "inline/card-icon.html" (dict
"page" $page "icon" $icon
"keywords" $args.headerStyle "padding" $args.padding
"color" $args.color "rounded" $args.iconRounded
) }} "style" $style
</div> "stack" $args.stack
"class" (printf "align-self-%s me-1 mt-1 col-auto" $args.align)
)}}
{{ end }} {{ end }}
<div class="flex-fill"> <div>
{{ if $page }}
<div>{{ partial "inline/card-caption.html" (dict
"page" $page
"keywords" $args.headerStyle
"color" $args.color
) }}
</div>
{{ end }}
{{- partial "inline/card-body.html" (dict {{- partial "inline/card-body.html" (dict
"title" $title "title" $title
"href" $href "href" $href
@@ -219,25 +230,25 @@
"description" $description "description" $description
"button" $args.button "button" $args.button
) -}} ) -}}
{{ if $page }}<div>{{ partial "inline/card-caption.html" (dict "page" $page "keywords" $args.footerStyle "color" $args.color) }}</div>{{ end }}
{{ if and $href $args.button }}
{{ $label := (or $args.buttonLabel $title) | default (T "readMore") }}
{{ $buttonClass := "card-button mb-n4" }}
{{ $buttonType := (or $args.linkType $args.buttonType) }}
{{ if eq $buttonType "link" }}{{ $buttonClass = "card-button card-button-link mb-n4" }}{{ end }}
<div class="d-flex align-items-end">
{{ partial "assets/button.html" (dict
"title" $label
"icon" "fas chevron-right"
"href" $href
"outline" true
"button-size" "sm"
"class" $buttonClass
"link-type" $buttonType
)}}
</div>
{{ end }}
</div> </div>
{{ if $page }}<div>{{ partial "inline/card-caption.html" (dict "page" $page "keywords" $args.footerStyle "color" $args.color) }}</div>{{ end }}
{{ if and $href $args.button }}
{{ $label := (or $args.buttonLabel $title) | default (T "readMore") }}
{{ $buttonClass := "card-button mb-n4" }}
{{ $buttonType := (or $args.linkType $args.buttonType) }}
{{ if eq $buttonType "link" }}{{ $buttonClass = "card-button card-button-link mb-n4" }}{{ end }}
<div class="d-flex align-items-end">
{{ partial "assets/button.html" (dict
"title" $label
"icon" "fas chevron-right"
"href" $href
"outline" true
"button-size" "sm"
"class" $buttonClass
"link-type" $buttonType
)}}
</div>
{{ end }}
</div> </div>
</div> </div>
</div> </div>
@@ -245,30 +256,23 @@
{{- else -}} {{- else -}}
{{/* Render stacked / default card */}} {{/* Render stacked / default card */}}
{{ $overlay := eq $args.orientation "overlay" }} {{ $overlay := eq $args.orientation "overlay" }}
<div class="card {{ $colorStyle }} {{ $args.class }} text-{{ $args.align }}"> <div class="card {{ $colorStyle }} {{ $args.class }} text-{{ $args.align }}{{ if not $thumbnail }} p-{{ $args.padding }}{{ end }}">
{{- if $thumbnail -}} {{- if $thumbnail -}}
{{- partial $args.hook (dict {{- partial $args.hook (merge $thumbnailArgs (dict
"src" $thumbnail
"ratio" (or $ratio "16x9")
"portrait" $args.portrait
"anchor" $anchor
"sizes" $args.sizes
"wrapper" "card-img-wrap" "wrapper" "card-img-wrap"
"class" "card-img-top card-img-bg" "class" "card-img-top card-img-bg"
"title" (or $args.alt $title) "ratio" (or $ratio "16x9")
"loading" $args.loading )) -}}
) -}}
{{- else if $icon -}} {{- else if $icon -}}
<div class="card-icon p-{{ $args.padding }} {{ $iconStyle }} text-{{ $args.align }} {{ if $args.iconRounded }}fa-stack {{ $args.stack }}{{ end }} w-100"> {{- partial "inline/card-icon.html" (dict
{{ if $args.iconRounded }} "icon" $icon
{{- partial "assets/icon.html" (dict "icon" (printf "fas circle fa-stack-2x %s")) -}} "rounded" $args.iconRounded
{{- partial "assets/icon.html" (dict "icon" (printf "%s fa-stack-1x fa-inverse" $icon)) -}} "style" $style
{{ else }} "stack" $args.stack
{{- partial "assets/icon.html" (dict "icon" (printf "%s %s" $icon $style)) -}} "class" (printf "mb-1 m-0 text-%s" $args.align)
{{ end }} )}}
</div>
{{- end -}} {{- end -}}
<div class="card-body d-flex flex-column p-{{ $args.padding }} {{ if $overlay }}card-img-overlay card-overlay-gradient p-4{{ end }}" {{ if $overlay }}data-bs-theme="dark"{{ end }}> <div class="card-body p-0 d-flex flex-column{{ if $thumbnail }} p-{{ $args.padding }}{{ end }}{{ if $overlay }}card-img-overlay card-overlay-gradient p-4{{ end }}" {{ if $overlay }}data-bs-theme="dark"{{ end }}>
{{ if $args.overlay }}<div class="flex-grow-1"></div>{{ end }} {{ if $args.overlay }}<div class="flex-grow-1"></div>{{ end }}
{{ if $page }}{{- partial "inline/card-caption.html" (dict "page" $page "keywords" $args.headerStyle "color" $args.color) -}}{{ end }} {{ if $page }}{{- partial "inline/card-caption.html" (dict "page" $page "keywords" $args.headerStyle "color" $args.color) -}}{{ end }}
{{- partial "inline/card-body.html" (dict "title" $title "href" $href "color" $args.color "description" $description) -}} {{- partial "inline/card-body.html" (dict "title" $title "href" $href "color" $args.color "description" $description) -}}
@@ -276,7 +280,7 @@
</div> </div>
{{ if $args.button }} {{ if $args.button }}
{{ $label := (or $args.buttonLabel $title) | default (T "readMore") }} {{ $label := (or $args.buttonLabel $title) | default (T "readMore") }}
<div class="row p-{{ $args.padding }}" > <div class="row" >
<div class="{{ if eq $args.orientation "horizontal-sm" }}col-4 col-md-2{{ else if eq $args.orientation "horizontal" }}col-4{{ end }}"></div> <div class="{{ if eq $args.orientation "horizontal-sm" }}col-4 col-md-2{{ else if eq $args.orientation "horizontal" }}col-4{{ end }}"></div>
<div class="col d-flex align-items-end {{ if eq $args.orientation "horizontal-sm" }}px-2{{ else if eq $args.orientation "horizontal"}}px-1 {{ else }}px-2 pt-1{{ end }}"> <div class="col d-flex align-items-end {{ if eq $args.orientation "horizontal-sm" }}px-2{{ else if eq $args.orientation "horizontal"}}px-1 {{ else }}px-2 pt-1{{ end }}">
{{ $buttonClass := "card-button" }} {{ $buttonClass := "card-button" }}
@@ -289,7 +293,7 @@
"button-size" "sm" "button-size" "sm"
"class" "card-button" "class" "card-button"
"class" $buttonClass "class" $buttonClass
"link-type" $args.buttonType "link-type" $buttonType
)}} )}}
</div> </div>
</div> </div>

View File

@@ -51,7 +51,7 @@
{{ partial "assets/hero.html" (dict {{ partial "assets/hero.html" (dict
"page" $args.page "page" $args.page
"heading" $heading "heading" (merge $heading (dict "size" 6))
"background" $args.background "background" $args.background
"illustration" $illustration "illustration" $illustration
"order" $args.order "order" $args.order

View File

@@ -114,7 +114,6 @@
{{ $title := partial "assets/section-title.html" (dict {{ $title := partial "assets/section-title.html" (dict
"heading" $heading "heading" $heading
"use-title" $args.useTitle "use-title" $args.useTitle
"size" $args.size
"links" $args.links "links" $args.links
"link-type" (or $args.linkType $args.type) "link-type" (or $args.linkType $args.type)
"class" "hero-title" "class" "hero-title"

View File

@@ -72,7 +72,7 @@
aria-labelledby="{{ $parentID }}-heading-{{ $args.id }}" aria-labelledby="{{ $parentID }}-heading-{{ $args.id }}"
data-bs-parent="#accordion-{{ $parentID }}" data-bs-parent="#accordion-{{ $parentID }}"
> >
<div class="accordion-body">{{ $args.body | $args.page.RenderString | safeHTML }}</div> <div class="accordion-body">{{ or $args.raw ($args.body | $args.page.RenderString) | safeHTML }}</div>
</div> </div>
</div> </div>
{{- else -}} {{- else -}}
@@ -82,9 +82,9 @@
role="tabpanel" role="tabpanel"
aria-labelledby="{{ $parentID }}-btn-{{ $args.id }}" aria-labelledby="{{ $parentID }}-btn-{{ $args.id }}"
tabindex="0" tabindex="0"
data-has-content="{{ gt (len $args.body) 0 }}" data-has-content="{{ or (gt (len (or $args.raw "")) 0) (gt (len $args.body) 0 ) }}"
> >
{{ $args.body | $args.page.RenderString | safeHTML }} {{ or $args.raw ($args.body | $args.page.RenderString) | safeHTML }}
</div> </div>
{{- end -}} {{- end -}}
{{- end -}} {{- end -}}

View File

@@ -6,6 +6,29 @@
{{- $error := false -}} {{- $error := false -}}
{{- define "_partials/inline/nav-dropdown.html" -}}
{{ $id := .id }}
{{ $class := .class }}
{{ $titles := .titles }}
{{ $wrap := .wrap }}
<div id="dropdown-{{ $id }}" class="dropdown panel-dropdown {{ $class }}">
<a class="link-secondary dropdown-toggle" type="button" data-bs-toggle="dropdown" aria-expanded="false">
{{ cond (gt (len $titles) 0) (index $titles 0) (T "sectionMenu") }}
</a>
<ul class="dropdown-menu">
{{- range $index, $item := $titles -}}
{{ $itemID := printf "%s-btn-%d" $id $index -}}
{{- $show := eq $index 0 -}}
<li>
<a class="dropdown-item {{ if not $wrap }} text-nowrap{{ end }}{{ if $show }} active{{ end }}"
data-link="#{{ $id }}-btn-{{ $index }}" type="button">{{ $item }}</a>
</li>
{{ end }}
</ul>
</div>
{{- end -}}
{{/* Initialize arguments */}} {{/* Initialize arguments */}}
{{- $args := partial "utilities/InitArgs.html" (dict "structure" "nav" "args" . "group" "partial") -}} {{- $args := partial "utilities/InitArgs.html" (dict "structure" "nav" "args" . "group" "partial") -}}
{{- if or $args.err $args.warnmsg -}} {{- if or $args.err $args.warnmsg -}}
@@ -19,46 +42,38 @@
{{- $error = $args.err -}} {{- $error = $args.err -}}
{{- end -}} {{- end -}}
{{/* Initialize global arguments */}}
{{- $padding := partial "utilities/GetPadding.html" -}}
{{- $breakpoint := partial "utilities/GetBreakpoint.html" -}}
{{/* Initialize local arguments */}} {{/* Initialize local arguments */}}
{{- $page := $args.page -}} {{- $page := $args.page -}}
{{- $id := $args.id | default "0" -}} {{- $id := $args.id | default "0" -}}
{{- $type := or $args.tabType $args.type -}} {{- $type := or $args.tabType $args.type -}}
{{- $wrap := or $args.wordWrap $args.wrap -}} {{- $wrap := or $args.wordWrap $args.wrap -}}
{{- $breakpoint := partial "utilities/GetBreakpoint.html" -}} {{- $titles := slice -}}
{{- range $args.list }}{{ $titles = $titles | append .Title }} {{ end -}}
{{- if reflect.IsSlice $args.navTitles }}{{ $titles = $titles | append $args.navTitles }}{{ end -}}
{{/* Main code */}} {{/* Main code */}}
<div class="col col-{{ $breakpoint.current }}-{{ $args.width }} mx-auto"> <div class="col col-{{ $breakpoint.current }}-{{ $args.width }} mx-auto">
{{ if $args.vertical }}<div class="d-flex align-items-start">{{ end }} {{ if $args.vertical }}<div class="d-flex align-items-start">{{ end }}
{{ if eq $type "callout" }} {{ if $args.responsive }}
<div class="d-lg-none"> {{ partial "inline/nav-dropdown.html" (dict
<div id="accordion-{{ $id }}" class="accordion mb-3{{ with $args.class }} {{ . }}{{ end }} nav-callout"> "id" $id
{{- range $index, $item := $args.list -}} "class" (printf "d-%s-none py-%d" $breakpoint.current $padding.y)
{{ partial "assets/nav-item.html" (dict "titles" $titles
"page" $args.page "wrap" $wrap
"id" $index ) }}
"parentID" $id
"fade" false
"header" $item.Title
"class" $args.class
"body" (or $item.Description $item.Content)
"show" false
"disabled" $item.disabled
"item_type" "accordion"
"illustration" (partial "utilities/GetIllustration.html" (dict "item" $item "size" "col-12"))
)
}}
{{ end -}}
{{- $args.navItems | safeHTML -}}
</div>
</div>
<div class="d-none d-lg-block">
{{ end }} {{ end }}
<div class="{{ if $args.responsive }}d-none d-{{ $breakpoint.current }}-block{{ end }}">
<ul <ul
class="nav{{ with $type }} nav-{{ . }}{{ end }}{{ with $args.class }} {{ . }}{{ end }}{{ if $args.vertical }} flex-column{{ end }}" class="nav nav-panel{{ with $type }} nav-{{ . }}{{ end -}}{{ with $args.class }} {{ . }}{{ end }}{{ if $args.vertical }} flex-column{{ end }} tabs-dropdown"
id="nav-{{ $id }}" id="nav-{{ $id }}"
role="tablist"{{ if $args.vertical }} role="tablist"
aria-orientation="vertical"{{ end }} {{ if $args.vertical }}aria-orientation="vertical"{{ end }}
data-companion="dropdown-{{ $id }}"
> >
{{- $titles := slice -}} {{- $titles := slice -}}
{{- range $args.list }}{{ $titles = $titles | append .Title }} {{ end -}} {{- range $args.list }}{{ $titles = $titles | append .Title }} {{ end -}}
@@ -73,7 +88,7 @@
class="nav-link{{ if not $wrap }} text-nowrap{{ end }}{{ if $show }} active{{ end }}{{ if $disabled }} disabled{{ end }}" class="nav-link{{ if not $wrap }} text-nowrap{{ end }}{{ if $show }} active{{ end }}{{ if $disabled }} disabled{{ end }}"
id="{{ $itemID }}" id="{{ $itemID }}"
data-bs-toggle="pill" data-bs-toggle="pill"
data-bs-target="#{{ $id }}-{{ $index }}" data-bs-target="#{{ $id }}-{{ $index }}"
type="button" type="button"
role="tab" role="tab"
aria-controls="{{ $id }}-{{ $index }}" aria-controls="{{ $id }}-{{ $index }}"
@@ -84,49 +99,9 @@
</li> </li>
{{ end -}} {{ end -}}
</ul> </ul>
</div>
<div class="tab-content {{ if eq $type "tabs" }}border p-3{{ else if $args.vertical }}ms-3{{ else }}mt-3{{ end }}"> <div class="tab-content {{ if in (slice "tabs" "callout") $type }}border p-3 bg-body {{ else if $args.vertical }}ms-3{{ else }}mt-3{{ end }}">
{{- range $index, $item := $args.list -}}
{{- $header := $item.Title -}}
{-{ $body := $item.Content -}}
{{- $show := eq $index 0 -}}
{{- $thumbnail := "" -}}
{{- if reflect.IsMap $item.Params.Thumbnail -}}
{{- $thumbnail = $item.Params.Thumbnail.url -}}
{{- else -}}
{{- $thumbnail = $item.Params.Thumbnail -}}
{{- end -}}
<div
class="tab-pane{{ if $show }} active{{ end }}"
id="nav-{{ $id }}-{{ $index }}"
role="tabpanel"
aria-labelledby="{{ $id }}-btn-{{ $index }}"
tabindex="0"
>
{{- if eq $args.pane "persona" -}}
{{- partial "assets/persona.html" (dict
"title" $item.Title
"class" $args.class
"color" $args.color
"href" $item.Params.href
"content" (partial "utilities/GetDescription.html" (dict "page" $item))
"thumbnail" $thumbnail
) -}}
{{- else -}}
{{- $illustration := (partial "utilities/GetIllustration.html" (dict "item" $item)) -}}
{{- if $illustration -}}
<div class="row">
<div class="col-12 col-lg-10 order-1 order-lg-0">{{- (or $item.Description $item.Content) -}}</div>
<div class="col-12 col-lg-2 order-0 order-lg-1">{{ $illustration | safeHTML }}</div>
</div>
{{- else -}}
{{- (or $item.Description $item.Content) -}}
{{ end }}
{{- end -}}
</div>
{{ end }}
{{- $args.navItems | safeHTML -}} {{- $args.navItems | safeHTML -}}
</div> </div>
{{- if eq $type "callout" }}</div>{{ end -}}
{{- if $args.vertical }}</div>{{ end -}} {{- if $args.vertical }}</div>{{ end -}}
</div> </div>

View File

@@ -19,7 +19,7 @@
{{- $padding := partial "utilities/GetPadding.html" -}} {{- $padding := partial "utilities/GetPadding.html" -}}
{{/* Initialize local arguments */}} {{/* Initialize local arguments */}}
{{- $size := (or $args.size site.Params.modules.bookshop.title.size) | default 4 -}} {{- $size := (or $args.heading.size site.Params.modules.bookshop.title.size) | default 4 -}}
{{- $arrangement := (or $args.arrangement site.Params.modules.bookshop.title.arrangement) | default "above" -}} {{- $arrangement := (or $args.arrangement site.Params.modules.bookshop.title.arrangement) | default "above" -}}
{{- $headingStyle := (or $args.headingStyle site.Params.modules.bookshop.title.headingStyle) | default "display" -}} {{- $headingStyle := (or $args.headingStyle site.Params.modules.bookshop.title.headingStyle) | default "display" -}}
{{- $contentStyle := (or $args.contentStyle site.Params.modules.bookshop.title.contentStyle) | default "lead text-muted" -}} {{- $contentStyle := (or $args.contentStyle site.Params.modules.bookshop.title.contentStyle) | default "lead text-muted" -}}

View File

@@ -7,7 +7,7 @@
{{ $error := false }} {{ $error := false }}
{{/* Initialize arguments */}} {{/* Initialize arguments */}}
{{ $args := partial "utilities/InitArgs.html" (dict "structure" "toc" "args" . "group" "partial")}} {{ $args := partial "utilities/InitArgs.html" (dict "structure" "toc" "args" . "group" "partial") }}
{{ if or $args.err $args.warnmsg }} {{ if or $args.err $args.warnmsg }}
{{ partial (cond $args.err "utilities/LogErr.html" "utilities/LogWarn.html") (dict {{ partial (cond $args.err "utilities/LogErr.html" "utilities/LogWarn.html") (dict
"partial" "assets/toc.html" "partial" "assets/toc.html"
@@ -31,8 +31,8 @@
{{- if and (not $error) (ge (len .) $minNumHeadings) }} {{- if and (not $error) (ge (len .) $minNumHeadings) }}
<div class="d-grid gap-2 mx-auto"> <div class="d-grid gap-2 mx-auto">
{{ partial "assets/button.html" (dict {{ partial "assets/button.html" (dict
"title" (T "toc") "title" (T "toc")
"color" "secondary" "color" "secondary"
"outline" "true" "outline" "true"
"class" "toc-button" "class" "toc-button"
"icon" "fas sort" "icon" "fas sort"

View File

@@ -17,7 +17,9 @@
{{/* Insert a default hero and article block (for list pages) when no content blocks are available */}} {{/* Insert a default hero and article block (for list pages) when no content blocks are available */}}
{{ if and .blocks (gt (len .blocks) 0 )}} {{ if and .blocks (gt (len .blocks) 0 )}}
{{ $blocks = .blocks }} {{ range $i, $b := .blocks }}
{{ $blocks = $blocks | append (merge (dict "_ordinal" $i) $b) }}
{{ end }}
{{ else if $default }} {{ else if $default }}
{{ $err := (hasPrefix $page.LinkTitle "404") }} {{ $err := (hasPrefix $page.LinkTitle "404") }}
{{ $pageTitle := $page.LinkTitle }} {{ $pageTitle := $page.LinkTitle }}

View File

@@ -31,12 +31,12 @@
{{- $header := or (partial "utilities/GetArgParent" (dict "page" . "arg" "header-style")) (partial "utilities/GetArgParent" (dict "page" . "arg" "header")) -}} {{- $header := or (partial "utilities/GetArgParent" (dict "page" . "arg" "header-style")) (partial "utilities/GetArgParent" (dict "page" . "arg" "header")) -}}
{{- $icon := .Get "icon" -}} {{- $icon := .Get "icon" -}}
{{- $iconRounded := or (partial "utilities/GetArgParent" (dict "page" . "arg" "icon-rounded")) (partial "utilities/GetArgParent" (dict "page" . "arg" "iconRounded")) -}} {{- $iconRounded := or (partial "utilities/GetArgParent" (dict "page" . "arg" "icon-rounded")) (partial "utilities/GetArgParent" (dict "page" . "arg" "iconRounded")) -}}
{{- $align := partial "utilities/GetArgParent" (dict "page" . "arg" "align") -}} {{- $align := partial "utilities/GetArgParent" (dict "page" . "arg" "align") | default "start" -}}
{{- $style := or (partial "utilities/GetArgParent" (dict "page" . "arg" "icon-style")) (partial "utilities/GetArgParent" (dict "page" . "arg" "style")) -}} {{- $style := or (partial "utilities/GetArgParent" (dict "page" . "arg" "icon-style")) (partial "utilities/GetArgParent" (dict "page" . "arg" "style")) -}}
{{- $subtle := partial "utilities/GetArgParent" (dict "page" . "arg" "subtle") -}} {{- $subtle := partial "utilities/GetArgParent" (dict "page" . "arg" "subtle") -}}
{{- $loading := .Get "loading" -}} {{- $loading := .Get "loading" -}}
{{- $orientation := partial "utilities/GetArgParent" (dict "page" . "arg" "orientation") -}} {{- $orientation := partial "utilities/GetArgParent" (dict "page" . "arg" "orientation") -}}
{{- $padding := partial "utilities/GetArgParent" (dict "page" . "arg" "padding") -}} {{- $padding := partial "utilities/GetArgParent" (dict "page" . "arg" "padding") | default 3 -}}
{{- $ratio := partial "utilities/GetArgParent" (dict "page" . "arg" "ratio") -}} {{- $ratio := partial "utilities/GetArgParent" (dict "page" . "arg" "ratio") -}}
{{- $page := .Page -}} {{- $page := .Page -}}
{{- $path := .Get "path" -}} {{- $path := .Get "path" -}}

1865
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -90,7 +90,7 @@
"eslint": "^9.30.1", "eslint": "^9.30.1",
"husky": "^9.1.7", "husky": "^9.1.7",
"markdownlint-cli2": "^0.18.1", "markdownlint-cli2": "^0.18.1",
"neostandard": "^0.12.1", "neostandard": "^0.12.2",
"netlify-plugin-hugo-cache-resources": "^0.2.1", "netlify-plugin-hugo-cache-resources": "^0.2.1",
"npm-run-all": "^4.1.5", "npm-run-all": "^4.1.5",
"postcss-cli": "^11.0.1", "postcss-cli": "^11.0.1",