mirror of
				https://github.com/BBaoVanC/bobatheme.git
				synced 2025-10-20 13:33:28 -05:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			master
			...
			wip-print-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| fa1fb5d0ba | 
							
								
								
									
										2
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| [submodule "assets/jam"] | [submodule "assets/jam"] | ||||||
| 	path = assets/jam | 	path = assets/jam | ||||||
| 	url = https://github.com/BBaoVanC/jam.git | 	url = https://github.com/michaelampr/jam.git | ||||||
| 	branch = master | 	branch = master | ||||||
|   | |||||||
| @@ -24,17 +24,7 @@ series: | |||||||
| resources: | resources: | ||||||
|   - name: feature |   - name: feature | ||||||
|     src: something.webp |     src: something.webp | ||||||
|     title: >- |     title: Some image (image format can be anything; webp is just an example) | ||||||
|       Fallback title if one is not provided when calling figure shortcode with |  | ||||||
|       this listed as the src |  | ||||||
|     params: |  | ||||||
|       alt: Write an accessible description of this image. Don't over-write. |  | ||||||
|  |  | ||||||
|   - src: demonstration.webp |  | ||||||
|     params: |  | ||||||
|       alt: >- |  | ||||||
|         Annotate an image without giving it an explicit name (the filename is |  | ||||||
|         simply used as the `name` instead). |  | ||||||
|  |  | ||||||
| --- | --- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -158,22 +158,69 @@ pre > code { | |||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
| /* Common distances/sizes {{{ */ | /* Basic elements {{{ */ | ||||||
|  |  | ||||||
| :root { | html { | ||||||
|   --page-margin: 16px; |   scroll-behavior: smooth; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ | @media screen and (prefers-reduced-motion: reduce) { | ||||||
|  |     html { | ||||||
|  |         scroll-behavior: auto; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | body { | ||||||
|  |   background-color: var(--background-0); | ||||||
|  |   color: var(--text-0); | ||||||
|  |   overflow-wrap: break-word; | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* Common elements {{{ */ | .main-container { | ||||||
|  |   margin: 20px auto; | ||||||
|  |   padding: 0 20px; | ||||||
|  |   max-width: 760px; /* 720px + 20px for left & right padding */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | footer { | ||||||
|  |   margin: 20px 0; | ||||||
|  |   text-align: center; | ||||||
|  |   font-size: smaller; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | footer p { | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| img, | img, | ||||||
| video { | video { | ||||||
|   max-width: 100%; |   max-width: 100%; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .post-media > figure.border img, | ||||||
|  | .post-media > figure.border video { | ||||||
|  |   padding: 5px; | ||||||
|  |   border: 7px solid var(--figure-border); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | figure.border img, | ||||||
|  | figure.border video { | ||||||
|  |   padding: 5px; | ||||||
|  |   border: 2px solid var(--figure-border); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | figure { | ||||||
|  |   margin: auto; | ||||||
|  |   display: inline-block; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | figcaption { | ||||||
|  |   font-style: italic; | ||||||
|  |   font-size: small; | ||||||
|  |   text-align: center; | ||||||
|  | } | ||||||
|  |  | ||||||
| a { | a { | ||||||
|   color: var(--link-0); |   color: var(--link-0); | ||||||
|   text-decoration: inherit; |   text-decoration: inherit; | ||||||
| @@ -193,31 +240,39 @@ hr { | |||||||
|   border: 1px solid var(--background-3); |   border: 1px solid var(--background-3); | ||||||
| } | } | ||||||
|  |  | ||||||
| table.simple { | @media (min-width: 720px) { | ||||||
|  |   .full-width-hr { | ||||||
|  |     /* see also: the related-posts section too */ | ||||||
|  |     margin-left: calc(-100vw / 2 + 760px / 2); | ||||||
|  |     margin-right: calc(-100vw / 2 + 760px / 2); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | table.markdown { | ||||||
|   border-collapse: collapse; |   border-collapse: collapse; | ||||||
|   border: 2px solid var(--text-1); |   border: 2px solid var(--text-1); | ||||||
| } | } | ||||||
|  |  | ||||||
| table.simple thead { | table.markdown thead { | ||||||
|   background-color: var(--background-2); |   background-color: var(--background-2); | ||||||
|   color: var(--text-2); |   color: var(--text-2); | ||||||
|   border-bottom: 2px solid var(--text-1); |   border-bottom: 2px solid var(--text-1); | ||||||
| } | } | ||||||
|  |  | ||||||
| table.simple th, | table.markdown th, | ||||||
| table.simple td { | table.markdown td { | ||||||
|   padding: 8px; |   padding: 8px; | ||||||
| } | } | ||||||
|  |  | ||||||
| table.simple :is(th, td) + :is(th, td) { | table.markdown :is(th, td) + :is(th, td) { | ||||||
|   border-left: 2px solid var(--text-1); |   border-left: 2px solid var(--text-1); | ||||||
| } | } | ||||||
|  |  | ||||||
| table.simple tbody tr:nth-child(odd) { | table.markdown tbody tr:nth-child(odd) { | ||||||
|   background-color: var(--background-0); |   background-color: var(--background-0); | ||||||
|   color: var(--text-0); |   color: var(--text-0); | ||||||
| } | } | ||||||
| table.simple tbody tr:nth-child(even) { | table.markdown tbody tr:nth-child(even) { | ||||||
|   background-color: var(--background-1); |   background-color: var(--background-1); | ||||||
|   color: var(--text-1); |   color: var(--text-1); | ||||||
| } | } | ||||||
| @@ -236,58 +291,77 @@ table.simple tbody tr:nth-child(even) { | |||||||
|  |  | ||||||
| /* Icons */ | /* Icons */ | ||||||
| .icon { | .icon { | ||||||
|   width: 1em; |   width: 20px; | ||||||
|   height: 1em; |   height: 20px; | ||||||
|   color: var(--text-1); |   color: var(--text-1); | ||||||
|   text-align: center; |   text-align: center; | ||||||
|   display: inline; |   display: inline; | ||||||
|   vertical-align: sub; |   vertical-align: middle; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* workarounds for some icons from jam-icons being non-square aspect ratio */ | h1 svg.icon { | ||||||
| .icon-code { |   width: 30px; | ||||||
|   width: 1.25em; |   height: 30px; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Baseof formatting {{{ */ | /* Heading formatting (article section titles) {{{ */ | ||||||
|  |  | ||||||
| html { | /* this is also used i.e. in page-title */ | ||||||
|   scroll-behavior: smooth; | .heading-link { | ||||||
|  |   color: inherit; | ||||||
|  |   font-weight: bold; | ||||||
| } | } | ||||||
|  |  | ||||||
| @media screen and (prefers-reduced-motion: reduce) { | .heading-link svg { | ||||||
|     html { |   width: 15px; | ||||||
|         scroll-behavior: auto; |   height: 15px; | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| body { | /* }}} */ | ||||||
|   background-color: var(--background-0); |  | ||||||
|   color: var(--text-0); | /* Top bar formatting {{{ */ | ||||||
|   overflow-wrap: break-word; |  | ||||||
|   margin: 0; | .top { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row; | ||||||
|  |   flex-wrap: wrap; | ||||||
|  |   justify-content: space-between; | ||||||
|  |   background-color: var(--background-1); | ||||||
| } | } | ||||||
|  |  | ||||||
| .main-container { | .header { | ||||||
|   margin: var(--page-margin) auto; |   flex-grow: 1; | ||||||
|   /* use padding because otherwise there's no way to have margin be both auto, and a minimum value */ |   margin: 8px 16px; | ||||||
|   padding: 0 var(--page-margin); |   font-size: 1.25em; | ||||||
|   max-width: calc(720px + 2 * var(--page-margin)); /* padding is included in the element's width */ |   display: flex; | ||||||
|  |   align-items: center; | ||||||
| } | } | ||||||
|  |  | ||||||
| .site-footer { | .navbar { | ||||||
|   margin: var(--page-margin) 0; |   display: flex; | ||||||
|   text-align: center; |   flex-wrap: wrap; | ||||||
|   font-size: smaller; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .site-footer p { | .navbar-item { | ||||||
|   margin: 0; |   padding: 12px 16px; | ||||||
|  |   white-space: nowrap; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .navbar-item:hover { | ||||||
|  |   background-color: var(--background-2); | ||||||
|  |   text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .navbar-item.active { | ||||||
|  |   font-weight: bold; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* }}} */ | ||||||
|  |  | ||||||
|  | /* Skip to main content {{{ */ | ||||||
| #skip-to-main { | #skip-to-main { | ||||||
|   position: absolute; |   position: absolute; | ||||||
|   padding: 8px; |   padding: 8px; | ||||||
| @@ -301,59 +375,12 @@ body { | |||||||
| #main-content:target { | #main-content:target { | ||||||
|   animation: none; /* prevent it from turning yellow */ |   animation: none; /* prevent it from turning yellow */ | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ |  | ||||||
|  |  | ||||||
| /* Top bar formatting {{{ */ |  | ||||||
|  |  | ||||||
| .top { |  | ||||||
|   display: flex; |  | ||||||
|   flex-direction: row; |  | ||||||
|   flex-wrap: wrap; |  | ||||||
|   justify-content: space-between; |  | ||||||
|   background-color: var(--background-1); |  | ||||||
|   /* padding can't be here because then the first navbar element will be shifted too far over, |  | ||||||
|    * or it will need its hover background to be chopped off on the left */ |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .top-brand { |  | ||||||
|   flex-grow: 1; |  | ||||||
|   margin: 8px var(--page-margin); |  | ||||||
|   font-size: 1.25em; |  | ||||||
|   display: flex; |  | ||||||
|   align-items: center; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .top-brand > a { |  | ||||||
|   color: inherit; |  | ||||||
|   font-weight: bold; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .top-navbar { |  | ||||||
|   display: flex; |  | ||||||
|   flex-wrap: wrap; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .top-navbar-item { |  | ||||||
|   padding: 12px var(--page-margin); |  | ||||||
|   white-space: nowrap; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .top-navbar-item:hover { |  | ||||||
|   background-color: var(--background-2); |  | ||||||
|   text-decoration: none; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .top-navbar-item--active { |  | ||||||
|   font-weight: bold; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
| /* Breadcrumb navigation {{{ */ | /* Breadcrumb navigation {{{ */ | ||||||
|  |  | ||||||
| .breadcrumb { | .breadcrumb { | ||||||
|   margin: var(--page-margin) 0; |   margin: 20px 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| .breadcrumb ul { | .breadcrumb ul { | ||||||
| @@ -420,26 +447,33 @@ body { | |||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
| /* Summary card formatting {{{ */ | /* List layout {{{ */ | ||||||
|  |  | ||||||
| .summary-card { | /* flexbox container for sections and main page list */ | ||||||
|  | .list-page-container { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   gap: 40px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .page-list { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   list-style: none; | ||||||
|  |   padding: 0; | ||||||
|  |   gap: 40px; | ||||||
|  |   margin-top: 16px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .page-list > .page { | ||||||
|   padding: 24px; |   padding: 24px; | ||||||
|   border-radius: 12px; |   border-radius: 12px; | ||||||
|   background-color: var(--background-1); |   background-color: var(--background-1); | ||||||
|   color: var(--text-1); |   color: var(--text-1); | ||||||
| } | } | ||||||
|  |  | ||||||
| .summary-card-title { | .page > .page-title { | ||||||
|   margin-top: 0; |   margin-top: 0; | ||||||
|   margin-bottom: 10px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .summary-card-title a { |  | ||||||
|   color: inherit; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .summary-card-title h1 { |  | ||||||
|   margin: 0; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /* hugo just can't handle this feature | /* hugo just can't handle this feature | ||||||
| @@ -450,6 +484,14 @@ body { | |||||||
| } | } | ||||||
| */ | */ | ||||||
|  |  | ||||||
|  | .page-title { | ||||||
|  |   margin-bottom: 10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .page-title h1 { | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| .page-metadata { | .page-metadata { | ||||||
|   margin-bottom: 24px; |   margin-bottom: 24px; | ||||||
| } | } | ||||||
| @@ -463,82 +505,20 @@ body { | |||||||
|   margin-top: 10px; |   margin-top: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
| :is( | .post-media { | ||||||
|   .page-metadata-section:is(.categories, .tags, .series), |   margin-top: 15px; | ||||||
|   .page-metadata-item.authors |  | ||||||
| ) > a:not(:last-child):after { |  | ||||||
|   color: var(--text-0); |  | ||||||
|   content: ","; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /* for formatting of the featured image/media, see the .featured-media class */ | .page-description { | ||||||
|  |  | ||||||
| .summary-card-description { |  | ||||||
|   margin-top: 10px; |   margin-top: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .summary-card-readmore { | .readmore { | ||||||
|   margin-top: 5px; |   margin-top: 5px; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
| /* Figures, and featured media component (used in page.html and summary-card) {{{ */ |  | ||||||
|  |  | ||||||
| figure > .figure-media { |  | ||||||
|   padding: 5px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| figure > .figure-media.border { |  | ||||||
|   border: 2px solid var(--figure-border); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| figure { |  | ||||||
|   display: block; |  | ||||||
|   text-align: center; |  | ||||||
|   margin: 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| figcaption { |  | ||||||
|   font-style: italic; |  | ||||||
|   font-size: small; |  | ||||||
|   text-align: center; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .featured-media { |  | ||||||
|   margin-top: 15px; |  | ||||||
| } |  | ||||||
| .featured-media > figure > .figure-media { |  | ||||||
|   border: 7px solid var(--figure-border); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* }}} */ |  | ||||||
|  |  | ||||||
| /* List layout {{{ */ |  | ||||||
|  |  | ||||||
| .page-list { |  | ||||||
|   display: flex; |  | ||||||
|   flex-direction: column; |  | ||||||
|   list-style: none; |  | ||||||
|   padding: 0; |  | ||||||
|   gap: 40px; |  | ||||||
|   margin-top: 16px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .page-title { |  | ||||||
|   margin-bottom: 10px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .page-title a { |  | ||||||
|   color: inherit; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .page-title h1 { |  | ||||||
|   margin: 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* }}} */ |  | ||||||
|  |  | ||||||
| /* Taxonomy list layout {{{ */ | /* Taxonomy list layout {{{ */ | ||||||
|  |  | ||||||
| .taxonomy-list a, | .taxonomy-list a, | ||||||
| @@ -589,11 +569,17 @@ figcaption { | |||||||
|  |  | ||||||
| /* Series list layout {{{ */ | /* Series list layout {{{ */ | ||||||
|  |  | ||||||
| .page-list--series { | .page-list.series { | ||||||
|  |   display: flex; | ||||||
|   gap: 80px; |   gap: 80px; | ||||||
|  |   flex-flow: row wrap; | ||||||
|  |   list-style: none; | ||||||
|  |   color: var(--text-0); | ||||||
|  |   padding: 8px; | ||||||
|  |   border-radius: 16px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .page-list--series-inner { | .page-list.series-inner { | ||||||
|   gap: 10px; |   gap: 10px; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|   flex-flow: row wrap; |   flex-flow: row wrap; | ||||||
| @@ -602,7 +588,7 @@ figcaption { | |||||||
|   padding: 8px; |   padding: 8px; | ||||||
|   border-radius: 16px; |   border-radius: 16px; | ||||||
| } | } | ||||||
| .page-list--series-inner > .summary-card { | .page-list.series-inner > .page { | ||||||
|   flex: 1; |   flex: 1; | ||||||
|   min-width: 49%; |   min-width: 49%; | ||||||
| } | } | ||||||
| @@ -612,7 +598,6 @@ figcaption { | |||||||
| /* Subsections on list pages {{{ */ | /* Subsections on list pages {{{ */ | ||||||
|  |  | ||||||
| .sections { | .sections { | ||||||
|   margin-bottom: 60px; |  | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   gap: 10px; |   gap: 10px; | ||||||
| @@ -623,9 +608,6 @@ figcaption { | |||||||
|   color: var(--text-1); |   color: var(--text-1); | ||||||
|   border-radius: 12px; |   border-radius: 12px; | ||||||
|   padding: 1px 25px; |   padding: 1px 25px; | ||||||
|   display: flex; |  | ||||||
|   flex-direction: row; |  | ||||||
|   justify-content: space-between; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .section:hover { | .section:hover { | ||||||
| @@ -649,23 +631,17 @@ figcaption { | |||||||
|   margin-bottom: 5px; |   margin-bottom: 5px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .section-arrow { | .view-section { | ||||||
|   margin-block: auto; |   margin-top: 5px; | ||||||
|   max-height: fit-content; |  | ||||||
|   float: right; |  | ||||||
| } |  | ||||||
| .section-arrow > .icon { |  | ||||||
|   height: 48px; |  | ||||||
|   width: 48px; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Components exclusive to content/single pages {{{ */ | /* Content (single) formatting {{{ */ | ||||||
|  |  | ||||||
| .series-box { | .series-box { | ||||||
|   background-color: var(--background-1); |   background-color: var(--background-1); /* remember to update print styling */ | ||||||
|   color: var(--text-1); |   color: var(--text-1); | ||||||
|   padding: 8px 16px; |   padding: 8px 16px; | ||||||
|   border-radius: 8px; |   border-radius: 8px; | ||||||
| @@ -673,7 +649,7 @@ figcaption { | |||||||
| } | } | ||||||
|  |  | ||||||
| .table-of-contents { | .table-of-contents { | ||||||
|   background-color: var(--background-1); |   background-color: var(--background-1); /* remember to update print styling */ | ||||||
|   color: var(--text-1); |   color: var(--text-1); | ||||||
|   padding: 8px 20px; |   padding: 8px 20px; | ||||||
|   border-radius: 8px; |   border-radius: 8px; | ||||||
| @@ -700,7 +676,6 @@ figcaption { | |||||||
|   display: flex; |   display: flex; | ||||||
|   gap: 8px; |   gap: 8px; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   font-size: 32px; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .share-buttons a { | .share-buttons a { | ||||||
| @@ -715,7 +690,8 @@ figcaption { | |||||||
| } | } | ||||||
|  |  | ||||||
| .share-buttons svg { | .share-buttons svg { | ||||||
|   display: block; |   width: 32px; | ||||||
|  |   height: 32px; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* https://stackoverflow.com/a/72073682/19003757 */ | /* https://stackoverflow.com/a/72073682/19003757 */ | ||||||
| @@ -726,6 +702,19 @@ figcaption { | |||||||
| } | } | ||||||
| */ | */ | ||||||
|  |  | ||||||
|  | /* See also formating */ | ||||||
|  | .see-also { | ||||||
|  |   background-color: var(--background-1); /* remember to update print styling */ | ||||||
|  |   color: var(--text-1); | ||||||
|  |   padding: 8px 12px; | ||||||
|  |   border-radius: 8px; | ||||||
|  |   margin: 10px 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .see-also p { | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* Previous and next page buttons {{{ */ | /* Previous and next page buttons {{{ */ | ||||||
|  |  | ||||||
| .prevnext { | .prevnext { | ||||||
| @@ -776,68 +765,26 @@ figcaption { | |||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
| /* Related posts section {{{ */ |  | ||||||
|  |  | ||||||
| /* set the margins on the contents instead of the parent .related-posts |  | ||||||
|  * so that the posts in the list clip off the edge of the screen, |  | ||||||
|  * which makes a more obvious indicator that it's scrollable |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| .related-posts > hr, |  | ||||||
| .related-posts > h2 { |  | ||||||
|   margin: var(--page-margin); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .related-posts .summary-card { |  | ||||||
|   min-width: 300px; |  | ||||||
|   max-width: 300px; |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .related-posts .summary-card:first-child { |  | ||||||
|   margin-left: var(--page-margin); |  | ||||||
| } |  | ||||||
| .related-posts .summary-card:last-child { |  | ||||||
|   margin-right: var(--page-margin); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .related-posts .page-list { |  | ||||||
|   display: flex; |  | ||||||
|   flex-direction: row; |  | ||||||
|   gap: 20px; |  | ||||||
|   overflow-x: auto; |  | ||||||
|   margin-bottom: var(--page-margin); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* }}} */ |  | ||||||
|  |  | ||||||
| /* }}} */ |  | ||||||
|  |  | ||||||
| /* Content components (can appear both in single and list pages) {{{ */ |  | ||||||
|  |  | ||||||
| /* Code & code blocks {{{ */ | /* Code & code blocks {{{ */ | ||||||
| .code-block { | .code-block { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   margin: 16px 0; |   margin: 16px 0; | ||||||
|   background-color: var(--background-1); |   background-color: var(--background-1); /* remember to update print styling */ | ||||||
|   border-radius: 8px; |   border-radius: 8px; | ||||||
| } | } | ||||||
| .code-block > .code-header { | .code-block > .code-header { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: row; |   flex-direction: row; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   background-color: var(--background-2); |   background-color: var(--background-2); /* remember to update print styling */ | ||||||
|   padding: 4px 8px; |   padding: 4px 8px; | ||||||
|   border-top-left-radius: 8px; |   border-top-left-radius: 8px; | ||||||
|   border-top-right-radius: 8px; |   border-top-right-radius: 8px; | ||||||
|   height: 2em; |  | ||||||
| } |  | ||||||
| .code-block > .code-header > * { |  | ||||||
|   margin: auto 0; |  | ||||||
| } | } | ||||||
| .code-block > .code-header > .code-type { | .code-block > .code-header > .code-type { | ||||||
|   border-top-left-radius: 8px; |   border-top-left-radius: 8px; | ||||||
|  |   margin: auto 0; | ||||||
| } | } | ||||||
| /* TODO: make the code copy button prettier */ | /* TODO: make the code copy button prettier */ | ||||||
| .code-block > .code-header > .code-copy-button { | .code-block > .code-header > .code-copy-button { | ||||||
| @@ -910,6 +857,7 @@ aside { | |||||||
|   margin-bottom: 0; |   margin-bottom: 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* remember to update print styling for all the following asides */ | ||||||
| aside.note { | aside.note { | ||||||
|   background-color: var(--background-blue-1); |   background-color: var(--background-blue-1); | ||||||
| } | } | ||||||
| @@ -931,23 +879,44 @@ aside.quote { | |||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
| /* See also formating */ | /* }}} */ | ||||||
| .see-also { |  | ||||||
|   background-color: var(--background-1); | /* Related posts section {{{ */ | ||||||
|   color: var(--text-1); |  | ||||||
|   padding: 8px 12px; | .full-width-page-list { | ||||||
|   border-radius: 8px; |   /* make left/right 0 margin so it takes up full width */ | ||||||
|   margin: 10px 0; |   margin: 25px 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| .see-also p { | .related-posts > hr, | ||||||
|   margin: 0; | .related-posts > h1 { | ||||||
|  |   margin-left: 20px; | ||||||
|  |   margin-right: 20px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .related-posts .page { | ||||||
|  |   min-width: 300px; | ||||||
|  |   max-width: 300px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .related-posts .page:first-child { | ||||||
|  |   margin-left: 20px; | ||||||
|  | } | ||||||
|  | .related-posts .page:last-child { | ||||||
|  |   margin-right: 20px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .related-posts .page-list { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row; | ||||||
|  |   gap: 20px; | ||||||
|  |   overflow-x: scroll; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* @media specializations {{{ */ | /* @media specializations {{{ */ | ||||||
|  |  | ||||||
| /* Light mode */ | /* Light mode */ | ||||||
| @@ -961,10 +930,8 @@ aside.quote { | |||||||
| /* Print compatibility {{{ */ | /* Print compatibility {{{ */ | ||||||
| @media print { | @media print { | ||||||
|   .top > .navbar, |   .top > .navbar, | ||||||
|   .content-heading-link, |   .section-header-link, | ||||||
|   .post-meta-edit-history, |   .post-meta-edit-history, | ||||||
|   .post-meta-view-markdown, |  | ||||||
|   .code-copy-button, |  | ||||||
|   .prevnext, |   .prevnext, | ||||||
|   .share-buttons, |   .share-buttons, | ||||||
|   .related-posts { |   .related-posts { | ||||||
| @@ -1006,6 +973,19 @@ aside.quote { | |||||||
|   .table-of-contents.print { |   .table-of-contents.print { | ||||||
|     display: block; |     display: block; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   /* replace background colors with borders {{{ */ | ||||||
|  |   .series-box { | ||||||
|  |   } | ||||||
|  |   .table-of-contents { | ||||||
|  |   } | ||||||
|  |   .see-also { | ||||||
|  |   } | ||||||
|  |   .code-block { | ||||||
|  |   } | ||||||
|  |   .code-block > .code-header { | ||||||
|  |   } | ||||||
|  |   /* all the asides */ | ||||||
| } | } | ||||||
|  |  | ||||||
| /* }}} */ | /* }}} */ | ||||||
|   | |||||||
| @@ -1,132 +0,0 @@ | |||||||
| .comments > h2 { |  | ||||||
|     margin-bottom: 0; |  | ||||||
| } |  | ||||||
| .comments .email-address-notice { |  | ||||||
|     margin: 0; |  | ||||||
|     font-size: smaller; |  | ||||||
| } |  | ||||||
| .comments .enable-javascript-notice { |  | ||||||
|     font-style: italic; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* Isso styling */ |  | ||||||
| h4.isso-thread-heading { |  | ||||||
|     color: var(--text-0); |  | ||||||
|     margin-bottom: 8px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-comment:not(:first-of-type), |  | ||||||
| .isso-follow-up .isso-comment { |  | ||||||
|     border-color: var(--background-3); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-author, |  | ||||||
| .isso-page-author-suffix, |  | ||||||
| .isso-comment-footer, |  | ||||||
| .isso-comment-footer .isso-votes { |  | ||||||
|     color: var(--text-gray-0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-comment-header .isso-spacer, |  | ||||||
| .isso-spacer:hover, |  | ||||||
| .isso-permalink, |  | ||||||
| .isso-permalink:hover { |  | ||||||
|     color: var(--text-gray-1) !important; |  | ||||||
| } |  | ||||||
| a.isso-author:hover, |  | ||||||
| .isso-permalink:hover { |  | ||||||
|     text-decoration: underline !important; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-comment.isso-is-page-author > .isso-text-wrapper { |  | ||||||
|     background-color: var(--background-accent-1); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-feedlink:hover, |  | ||||||
| .isso-reply { |  | ||||||
|     color: var(--link-0) !important; |  | ||||||
|     text-shadow: unset !important; |  | ||||||
| } |  | ||||||
| .isso-reply:hover { |  | ||||||
|     text-decoration: underline; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-text pre, |  | ||||||
| .isso-text :not(pre) > code { |  | ||||||
|     background-color: var(--background-2); |  | ||||||
|     border: none; |  | ||||||
|     padding: 2px 4px; |  | ||||||
|     border-radius: 5px; |  | ||||||
|     /* thanks isso.css for setting this to 85% for whatever reason */ |  | ||||||
|     font-size: 0.75em; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-input-wrapper input, |  | ||||||
| .isso-post-action > input, |  | ||||||
| .isso-textarea, |  | ||||||
| .isso-preview { |  | ||||||
|     color: var(--text-1); |  | ||||||
|     background-color: var(--background-1); |  | ||||||
|     border-color: var(--background-2) !important; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-input-wrapper input:focus, |  | ||||||
| .isso-textarea:focus { |  | ||||||
|     border-color: var(--background-3) !important; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-post-action > input:hover { |  | ||||||
|     background-color: var(--background-2); |  | ||||||
| } |  | ||||||
| .isso-post-action > input:focus, |  | ||||||
| .isso-post-action > input:active { |  | ||||||
|     background-color: var(--background-3); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-textarea { |  | ||||||
|     margin-bottom: 4px; |  | ||||||
| } |  | ||||||
| .isso-input-wrapper { |  | ||||||
|     display: inline-flex; |  | ||||||
|     flex-direction: column; |  | ||||||
|     margin-right: 4px; |  | ||||||
|     max-width: 25%; |  | ||||||
| } |  | ||||||
| .isso-input-wrapper input { |  | ||||||
|     order: 1; |  | ||||||
| } |  | ||||||
| .isso-input-wrapper label { |  | ||||||
|     order: 2; |  | ||||||
|     font-size: small; |  | ||||||
| } |  | ||||||
| .isso-post-action { |  | ||||||
|     margin-left: 4px; |  | ||||||
|     margin-top: 0; |  | ||||||
| } |  | ||||||
| @media screen and (max-width: 600px) { |  | ||||||
|     .isso-input-wrapper { |  | ||||||
|         display: block; |  | ||||||
|         max-width: 100%; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @media print { |  | ||||||
|     .comments { |  | ||||||
|         break-before: always; |  | ||||||
|     } |  | ||||||
|     .isso-comment { |  | ||||||
|         max-width: unset; |  | ||||||
|     } |  | ||||||
|     .isso-text-wrapper { |  | ||||||
|         break-inside: avoid; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     .isso-postbox, |  | ||||||
|     .isso-feedlink { |  | ||||||
|         display: none; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .isso-target { |  | ||||||
|     animation: target-fade 10s ease-out; /* defined in bobatheme */ |  | ||||||
| } |  | ||||||
| @@ -1,4 +0,0 @@ | |||||||
| .page-meta-comments-counter, |  | ||||||
| .code-copy-button { |  | ||||||
|   display: none; |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| /* put on body so it overrides the defaults set in :root by pagefind.css */ |  | ||||||
| body { |  | ||||||
|     /* https://pagefind.app/docs/ui-usage/#customising-the-styles */ |  | ||||||
|     --pagefind-ui-background: var(--background-1); |  | ||||||
|     --pagefind-ui-border: var(--background-2); |  | ||||||
|     --pagefind-ui-primary: var(--link-0); |  | ||||||
|     --pagefind-ui-tag: var(--background-1); |  | ||||||
|     --pagefind-ui-text: var(--text-1); |  | ||||||
| } |  | ||||||
| @@ -1,3 +1,3 @@ | |||||||
| function share_event(service) { | function share_event(service) { | ||||||
|     plausible("Share", {props: {Network: service}}); |     // this function does nothing by default | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								exampleSite/hugo.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								exampleSite/hugo.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | baseURL: https://example.com | ||||||
|  | theme: bobatheme | ||||||
|  | defaultContentLanguage: en | ||||||
|  | copyright: '© 2021 bbaovanc <a rel="license" href="http://creativecommons.org/licenses/by-sa/4.0/">CC BY-SA 4.0</a>' | ||||||
|  | sectionPagesMenu: main | ||||||
|  | enableRobotsTXT: true | ||||||
|  | paginate: 5 | ||||||
|  | enableGitInfo: true | ||||||
|  |  | ||||||
|  | taxonomies: | ||||||
|  |   _merge: deep | ||||||
|  |  | ||||||
|  | markup: # this just keeps the bobatheme markup styling | ||||||
|  |   _merge: deep | ||||||
|  |  | ||||||
|  | params: | ||||||
|  |   author: | ||||||
|  |     name: bbaovanc | ||||||
|  |  | ||||||
|  |   # these are for the OpenGraph/Twitter embeds in Hugo | ||||||
|  |   description: Example website for bobatheme | ||||||
|  |  | ||||||
|  |   # these are for favicons in bobatheme (disabled by default) | ||||||
|  |   # faviconSVG: favicon.svg | ||||||
|  |   # appleTouchPNG: apple-touch-icon.png | ||||||
|  |  | ||||||
|  |   # show reading time (enabled by default) | ||||||
|  |   # readingtime: true | ||||||
|  |  | ||||||
|  |   # used for "View source" (unset by default) | ||||||
|  |   # gitFileURL: https://github.com/BBaoVanC/bobatheme/blob/master | ||||||
|  |   # gitFileIcon: github-circle | ||||||
|  |   # gitHistoryURL: https://github.com/BBaoVanC/bobatheme/commits/master | ||||||
|  |  | ||||||
|  |   # social media share icons | ||||||
|  |   # shareButtons: | ||||||
|  |   #   twitter: true | ||||||
|  |   #   facebook: true | ||||||
|  |   #   linkedin: true | ||||||
|  |   #   reddit: true | ||||||
|  |   #   telegram: true | ||||||
|  |   #   print: true | ||||||
|  |  | ||||||
|  |   # show "Latest Posts" section at bottom of content pages | ||||||
|  |   # latestPostsOnContent: true | ||||||
|  |  | ||||||
|  |   # footer: >- | ||||||
|  |   #   Some example text for the footer. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # see https://gohugo.io/about/hugo-and-gdpr/#all-privacy-settings | ||||||
|  | # you probably want to keep this default | ||||||
|  | privacy: | ||||||
|  |   _merge: deep | ||||||
|  |  | ||||||
|  | languages: | ||||||
|  |   en: | ||||||
|  |     languageName: English | ||||||
|  |     title: Example Website | ||||||
|  |     weight: 1 | ||||||
							
								
								
									
										12
									
								
								hugo.yaml
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								hugo.yaml
									
									
									
									
									
								
							| @@ -2,12 +2,6 @@ markup: | |||||||
|   highlight: |   highlight: | ||||||
|     noClasses: false |     noClasses: false | ||||||
|     lineNos: true |     lineNos: true | ||||||
|   goldmark: |  | ||||||
|     parser: |  | ||||||
|       attribute: |  | ||||||
|         block: true |  | ||||||
|         # this is enabled by default already |  | ||||||
|         #title: true |  | ||||||
|  |  | ||||||
| params: | params: | ||||||
|   readingtime: true |   readingtime: true | ||||||
| @@ -18,15 +12,11 @@ taxonomies: | |||||||
|   author: authors |   author: authors | ||||||
|   series: series |   series: series | ||||||
|  |  | ||||||
| outputs: |  | ||||||
|   page: |  | ||||||
|     - html |  | ||||||
|  |  | ||||||
| privacy: | privacy: | ||||||
|   googleAnalytics: |   googleAnalytics: | ||||||
|     disable: true |     disable: true | ||||||
|  |  | ||||||
|   x: |   twitter: | ||||||
|     enableDNT: true |     enableDNT: true | ||||||
|  |  | ||||||
|   vimeo: |   vimeo: | ||||||
|   | |||||||
| @@ -7,8 +7,6 @@ table_of_contents: | |||||||
|  |  | ||||||
| browser_no_video_support: | browser_no_video_support: | ||||||
|   other: "Your browser does not support video." |   other: "Your browser does not support video." | ||||||
| browser_no_video_support_link: |  | ||||||
|   other: "Click here to download it instead." |  | ||||||
|  |  | ||||||
| latest_posts: | latest_posts: | ||||||
|   other: "Latest Posts" |   other: "Latest Posts" | ||||||
| @@ -45,8 +43,6 @@ post_count: | |||||||
| # Navigation | # Navigation | ||||||
| read_more: | read_more: | ||||||
|   other: "Read more" |   other: "Read more" | ||||||
| see_posts: |  | ||||||
|   other: "See posts" |  | ||||||
|  |  | ||||||
| related_posts: | related_posts: | ||||||
|   other: "Related Posts" |   other: "Related Posts" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| <h{{ .Level }} id="{{ .Anchor | safeURL }}" class="section-heading"> | <h{{ .Level }} id="{{ .Anchor | safeURL }}" class="section-heading"> | ||||||
|     {{ .Text | safeHTML }} |     {{ .Text | safeHTML }} | ||||||
|     <a class="content-heading-link" href="#{{ .Anchor | safeURL }}"> |     <a class="heading-link" href="#{{ .Anchor | safeURL }}"> | ||||||
|         <span aria-label="{{ i18n "aria_heading_link" }}"> |         <span aria-label="{{ i18n "aria_heading_link" }}"> | ||||||
|             {{ partial "icon.html" "link" }} |             {{ partial "icon.html" "link" }} | ||||||
|         </span> |         </span> | ||||||
| @@ -18,9 +18,14 @@ | |||||||
|                     THIS TEXT SHOULD NOT SHOW. YUZSIQGHE (that string is so I can grep for it) |                     THIS TEXT SHOULD NOT SHOW. YUZSIQGHE (that string is so I can grep for it) | ||||||
|                 {{ end }} |                 {{ end }} | ||||||
|             </main> |             </main> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         {{ block "post-body" . }} | ||||||
|  |             {{/* currently this is only used for related posts */}} | ||||||
|  |         {{ end }} | ||||||
| 
 | 
 | ||||||
|         {{ if or .Site.Copyright .Site.Params.footer }} |         {{ if or .Site.Copyright .Site.Params.footer }} | ||||||
|                 <footer class="site-footer"> |             <footer> | ||||||
|                 {{ with .Site.Copyright }} |                 {{ with .Site.Copyright }} | ||||||
|                     {{ . | safeHTML }} |                     {{ . | safeHTML }} | ||||||
|                 {{ end }} |                 {{ end }} | ||||||
| @@ -30,11 +35,6 @@ | |||||||
|                 {{ end }} |                 {{ end }} | ||||||
|             </footer> |             </footer> | ||||||
|         {{ end }} |         {{ end }} | ||||||
|         </div> |  | ||||||
| 
 |  | ||||||
|         {{ block "post-body" . }} |  | ||||||
|             {{/* currently this is only used for related posts */}} |  | ||||||
|         {{ end }} |  | ||||||
|     </body> |     </body> | ||||||
| 
 | 
 | ||||||
| </html> | </html> | ||||||
							
								
								
									
										25
									
								
								layouts/_default/list.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								layouts/_default/list.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | {{ define "main" }} | ||||||
|  |     <h1> | ||||||
|  |         {{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||||
|  |         {{ .Title | markdownify }} | ||||||
|  |         {{ partial "rss-link.html" . }} | ||||||
|  |     </h1> | ||||||
|  |  | ||||||
|  |     {{ with .Content }} | ||||||
|  |         {{ . }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     <div class="list-page-container"> | ||||||
|  |         {{ with .Sections }} | ||||||
|  |             <div class="sections"> | ||||||
|  |                 {{ range . }} | ||||||
|  |                     {{ .Render "summary" }} | ||||||
|  |                 {{ end }} | ||||||
|  |             </div> | ||||||
|  |         {{ end }} | ||||||
|  |  | ||||||
|  |         {{ partial "page-list.html" .Paginator.Pages }} | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     {{ partial "pagination.html" . }} | ||||||
|  | {{ end }} | ||||||
							
								
								
									
										88
									
								
								layouts/_default/single.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								layouts/_default/single.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | |||||||
|  | {{ define "main" }} | ||||||
|  |     <div class="page-title"> | ||||||
|  |         <h1> | ||||||
|  |             {{ .Title | markdownify }} | ||||||
|  |             {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||||
|  |         </h1> | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|  |     {{ partial "page-metadata/post-full.html" . }} | ||||||
|  |     {{ partial "series-box.html" . }} | ||||||
|  |  | ||||||
|  |     {{ if .Params.Toc }} | ||||||
|  |         <div class="table-of-contents" aria-label="{{ i18n "aria_table_of_contents" }}"> | ||||||
|  |             <details> | ||||||
|  |                 <summary>{{ i18n "table_of_contents" }}</summary> | ||||||
|  |                 {{ .TableOfContents }} | ||||||
|  |             </details> | ||||||
|  |         </div> | ||||||
|  |         <div class="table-of-contents print"> | ||||||
|  |             {{ i18n "table_of_contents" }} | ||||||
|  |             {{ .TableOfContents }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ with .Resources.GetMatch "feature" }} | ||||||
|  |         <div class="post-media"> | ||||||
|  |             {{ partial "figure.html" (dict "src" .) }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     <article class="post-content"> | ||||||
|  |         {{ .Content }} | ||||||
|  |     </article> | ||||||
|  |  | ||||||
|  |     {{ partial "series-box.html" . }} | ||||||
|  |  | ||||||
|  |     {{ if or .NextInSection .PrevInSection }} | ||||||
|  |         <div class="prevnext"> | ||||||
|  |             {{ with .NextInSection }} | ||||||
|  |                 <a class="prev" href="{{ .Permalink }}"> | ||||||
|  |                     <div class="prev-caption"> | ||||||
|  |                         ← {{ i18n "newer_post" }} | ||||||
|  |                     </div> | ||||||
|  |                     <div class="prev-post"> | ||||||
|  |                         {{ .Title | markdownify }} | ||||||
|  |                     </div> | ||||||
|  |                 </a> | ||||||
|  |             {{ else }} | ||||||
|  |                 <div class="prev"></div> | ||||||
|  |             {{ end }} | ||||||
|  |  | ||||||
|  |             {{ with .PrevInSection }} | ||||||
|  |                 <a class="next" href="{{ .Permalink }}"> | ||||||
|  |                     <div class="next-caption"> | ||||||
|  |                         {{ i18n "older_post" }} → | ||||||
|  |                     </div> | ||||||
|  |                     <div class="next-post"> | ||||||
|  |                         {{ .Title | markdownify }} | ||||||
|  |                     </div> | ||||||
|  |                 </a> | ||||||
|  |             {{ else }} | ||||||
|  |                 <div class="next"></div> | ||||||
|  |             {{ end }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.shareButtons }} | ||||||
|  |         {{ partial "share.html" . }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Params.comments }} | ||||||
|  |         <div class="comments"> | ||||||
|  |             {{ partial "comments.html" . }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | {{ define "post-body" }} | ||||||
|  |     {{ $related := .Site.RegularPages.Related . | first 10 }} | ||||||
|  |     {{ with $related }} | ||||||
|  |         <div class="related-posts"> | ||||||
|  |             <hr> | ||||||
|  |             <h1>{{ i18n "related_posts" }}</h1> | ||||||
|  |             {{ partial "page-list.html" . }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  | {{ end }} | ||||||
							
								
								
									
										21
									
								
								layouts/_default/summary.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								layouts/_default/summary.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | <h2 class="page-title"> | ||||||
|  |     {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||||
|  |     <a class="heading-link" href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||||
|  |     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||||
|  | </h2> | ||||||
|  |  | ||||||
|  | {{ partial "page-metadata/post-short.html" . }} | ||||||
|  |  | ||||||
|  | {{ with .Resources.GetMatch "feature" }} | ||||||
|  |     <div class="post-media"> | ||||||
|  |         {{ partial "figure.html" (dict "src" .) }} | ||||||
|  |     </div> | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | <div class="page-description"> | ||||||
|  |     {{ partial "description-or-summary.html" . }} | ||||||
|  | </div> | ||||||
|  |  | ||||||
|  | <div class="readmore"> | ||||||
|  |     <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> | ||||||
|  | </div> | ||||||
| @@ -1,20 +0,0 @@ | |||||||
| {{/* put comments CSS here instead of in <head> so that it doesn't get |  | ||||||
|    * loaded unnecessarily on regular pages |  | ||||||
|    */}} |  | ||||||
| {{ with resources.Get "css/comments.css" | fingerprint "sha512" }} |  | ||||||
|     <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> |  | ||||||
| {{ end }} |  | ||||||
|  |  | ||||||
| <h2>Comments</h2> |  | ||||||
| <p class="email-address-notice"> |  | ||||||
|     If you provide an email address, you can enable notifications for |  | ||||||
|     replies to your comment. It will not be shown publicly. |  | ||||||
| </p> |  | ||||||
|  |  | ||||||
| <noscript> |  | ||||||
|     <p class="enable-javascript-notice"> |  | ||||||
|         Enable JavaScript to see the comment section. |  | ||||||
|     </p> |  | ||||||
| </noscript> |  | ||||||
|  |  | ||||||
| <section id="isso-thread" data-title="{{ .Title }}"></section> |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| {{ if eq .ResourceType "image" }} |  | ||||||
|     {{/* TODO: figure out whether loading="lazy" should be set because MDN |  | ||||||
|        *       claims that images won't work with JS disabled since it would |  | ||||||
|        *       make tracking possible, but my experience says otherwise |  | ||||||
|        */}} |  | ||||||
|     <img class="figure-media" src="{{ .Permalink }}" {{ with .Params.alt }}alt="{{ . }}"{{ end }} /> |  | ||||||
| {{ else if eq .ResourceType "video" }} |  | ||||||
|     <video class="figure-media" controls preload="metadata"> |  | ||||||
|         {{ with .Params.alt }} |  | ||||||
|             {{ warnf "video does not support alt text, '%s'" . }} |  | ||||||
|         {{ end }} |  | ||||||
|         <source src="{{ .Permalink }}" /> |  | ||||||
|         {{ i18n "browser_no_video_support" }} |  | ||||||
|         <a href="{{ .Permalink }}" target="_blank" rel="noopener"> |  | ||||||
|             {{ i18n "browser_no_video_support_link" }} |  | ||||||
|         </a> |  | ||||||
|     </video> |  | ||||||
| {{ else }} |  | ||||||
|     {{/* TODO: could consider implementing more types, listed at: |  | ||||||
|        * https://www.iana.org/assignments/media-types/media-types.xhtml |  | ||||||
|        */}} |  | ||||||
|     {{ errorf "Handling %q resource not supported" .ResourceType }} |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| {{ with .Resources.Get "feature" }} |  | ||||||
|     <div class="featured-media"> |  | ||||||
|         <figure> |  | ||||||
|             {{ partial "embed-resource.html" . }} |  | ||||||
|             {{ with .Title }} |  | ||||||
|                 <figcaption>{{ . | markdownify }}</figcaption> |  | ||||||
|             {{ end }} |  | ||||||
|         </figure> |  | ||||||
|     </div> |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,106 +0,0 @@ | |||||||
| <head> |  | ||||||
|     <meta charset="UTF-8"> |  | ||||||
|     <meta name="viewport" content="width=device-width, initial-scale=1"> |  | ||||||
|     {{ hugo.Generator }} |  | ||||||
|  |  | ||||||
|     {{ with resources.Get "css/bobastyle.css" | fingerprint "sha512" }} |  | ||||||
|         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ with resources.Get "css/noscript.css" | fingerprint "sha512" }} |  | ||||||
|         <noscript> |  | ||||||
|             <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> |  | ||||||
|         </noscript> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ with resources.Get "css/syntax.css" | fingerprint "sha512" }} |  | ||||||
|         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous" media="print" onload="this.media='all'"> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ with resources.Get "css/syntax-light.css" | fingerprint "sha512" }} |  | ||||||
|         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous" media="print" onload="this.media='all'"> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ with resources.Get "js/bobatheme.js" | fingerprint "sha512" }} |  | ||||||
|         <script defer src="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ if not hugo.IsServer }} |  | ||||||
|         <script defer data-domain="bbaovanc.com" src="https://plausible.bbaovanc.com/js/bobalytics.outbound-links.js"></script> |  | ||||||
|         <script>window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) }</script> |  | ||||||
|         {{ with resources.Get "js/share-event.js" | fingerprint "sha512" }} |  | ||||||
|             <script defer src="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> |  | ||||||
|         {{ end }} |  | ||||||
|     {{ end }} |  | ||||||
|     {{ $isso_url := .Permalink }} |  | ||||||
|     {{ if .IsTranslated }} |  | ||||||
|         {{ with index .AllTranslations 0 }} |  | ||||||
|             {{ $isso_url = .Permalink }} |  | ||||||
|         {{ end }} |  | ||||||
|     {{ end }} |  | ||||||
|     <script defer src="https://isso.bbaovanc.com/js/embed.min.js" |  | ||||||
|             data-isso-id="{{ $isso_url }}" |  | ||||||
|             data-isso-default-lang="{{ .Language.Lang }}" |  | ||||||
|             data-isso-css="true" |  | ||||||
|             data-isso-max-comments-top="inf" |  | ||||||
|             data-isso-max-comments-nested="inf" |  | ||||||
|             data-isso-reveal-on-click="5" |  | ||||||
|             {{/* |  | ||||||
|             data-isso-avatar-bg="#111" |  | ||||||
|             data-isso-avatar-fg="#9abf88 #5698c4 #e279a3 #9163b6 ..." |  | ||||||
|             */}} |  | ||||||
|             data-isso-vote="true" |  | ||||||
|             {{/* |  | ||||||
|             data-isso-vote-levels="" |  | ||||||
|             */}} |  | ||||||
|             data-isso-feed="true" |  | ||||||
|             data-isso-require-email="false" |  | ||||||
|             data-isso-reply-notifications="true" |  | ||||||
|             data-isso-reply-notifications-default-enabled="true" |  | ||||||
|  |  | ||||||
|             {{ with (.GetTerms "authors") }} |  | ||||||
|                 {{ $authorHashes := slice }} |  | ||||||
|                 {{ range . }} |  | ||||||
|                     {{ with .Params.issoUserID }} |  | ||||||
|                         {{ $authorHashes = $authorHashes | append . }} |  | ||||||
|                     {{ end }} |  | ||||||
|                 {{ end }} |  | ||||||
|  |  | ||||||
|                 data-isso-page-author-hashes="{{ delimit $authorHashes "," }}" |  | ||||||
|             {{ end }} |  | ||||||
|             > |  | ||||||
|     </script> |  | ||||||
|  |  | ||||||
|     {{ if eq .Layout "search" }} |  | ||||||
|         {{ with resources.Get "css/search.css" | fingerprint "sha512" }} |  | ||||||
|             <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> |  | ||||||
|         {{ end }} |  | ||||||
|  |  | ||||||
|         <link rel="stylesheet" type="text/css" href="{{ absURL "pagefind/pagefind-ui.css" }}" crossorigin="anonymous"> |  | ||||||
|         <script src="{{ absURL "pagefind/pagefind-ui.js" }}" crossorigin="anonymous"></script> |  | ||||||
|         <script> |  | ||||||
|             window.addEventListener('DOMContentLoaded', (event) => { |  | ||||||
|                 new PagefindUI({ element: "#search-box", showSubResults: true }); |  | ||||||
|             }); |  | ||||||
|         </script> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ with .Site.Params.faviconSVG }} |  | ||||||
|         <link rel="icon" href="{{ . | absURL }}" /> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ with .Site.Params.appleTouchPNG }} |  | ||||||
|         <link rel="apple-touch-icon" href="{{ . | absURL }}" /> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     <title>{{ .Render "head_title" }}</title> |  | ||||||
|  |  | ||||||
|     {{ range .Site.Params.rel_me }} |  | ||||||
|         <link rel="me" href="{{ . }}" /> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ partial "seo-tags/opengraph.html" . }} |  | ||||||
|     {{ partial "seo-tags/twitter-cards.html" . }} |  | ||||||
|     {{ partial "seo-tags/schema.html" . }} |  | ||||||
|     {{ partial "seo-tags/link.html" . }} |  | ||||||
|     {{ partial "seo-tags/author.html" . }} |  | ||||||
|  |  | ||||||
|     <meta name="language" content="{{ .Language.Lang }}"> |  | ||||||
|     <meta name="description" content="{{ (partial "seo-description.html" .) | plainify }}"> |  | ||||||
| </head> |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| {{ with .GetTerms "authors" }} |  | ||||||
|     <span class="page-metadata-item authors" aria-label="{{ i18n "aria_post_meta_authors" }}"> |  | ||||||
|         {{ partial "icon.html" "user-circle" }} |  | ||||||
|  |  | ||||||
|         {{ range . }} |  | ||||||
|             <a href="{{ .Permalink }}" data-pagefind-filter="author">{{ .LinkTitle }}</a> |  | ||||||
|         {{ end }} |  | ||||||
|     </span> |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| <span class="page-metadata-item page-meta-comments-counter" aria-label="comments counter"> |  | ||||||
|     {{ partial "icon.html" "message" }} |  | ||||||
|     {{/* TODO: figure out if there's a nicer way to generate this URL |  | ||||||
|        * the current issue is that we can't use RelRef, since content view means that we don't |  | ||||||
|        * have access to the original page context |  | ||||||
|        */}} |  | ||||||
|     <a href="{{ .RelPermalink }}#isso-thread">comments</a> |  | ||||||
| </span> |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| {{ with (.GetTerms "series") }} |  | ||||||
|     <div class="page-metadata-section series" aria-label="{{ i18n "aria_post_meta_series" }}"> |  | ||||||
|         {{ partial "icon.html" "files" }} |  | ||||||
|         {{ range . }} |  | ||||||
|             <a href="{{ .Permalink }}" data-pagefind-filter="series">{{ .LinkTitle }}</a> |  | ||||||
|         {{ end }} |  | ||||||
|     </div> |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,154 +0,0 @@ | |||||||
| {{- $validFormats := slice "default" "terse" }} |  | ||||||
|  |  | ||||||
| {{- $msg1 := "When passing a map to the internal pagination template, one of the elements must be named 'page', and it must be set to the context of the current page." }} |  | ||||||
| {{- $msg2 := "The 'format' specified in the map passed to the internal pagination template is invalid. Valid choices are: %s." }} |  | ||||||
|  |  | ||||||
| {{- $page := . }} |  | ||||||
| {{- $format := "default" }} |  | ||||||
|  |  | ||||||
| {{- if reflect.IsMap . }} |  | ||||||
|   {{- with .page }} |  | ||||||
|     {{- $page = . }} |  | ||||||
|   {{- else }} |  | ||||||
|     {{- errorf $msg1 }} |  | ||||||
|   {{- end }} |  | ||||||
|   {{- with .format }} |  | ||||||
|     {{- $format = lower . }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end }} |  | ||||||
|  |  | ||||||
| {{- if in $validFormats $format }} |  | ||||||
|   {{- if gt $page.Paginator.TotalPages 1 }} |  | ||||||
|     <ul class="pagination pagination-{{ $format }}"> |  | ||||||
|       {{- partial (printf "inline/pagination/%s.html" $format) $page }} |  | ||||||
|     </ul> |  | ||||||
|   {{- end }} |  | ||||||
| {{- else }} |  | ||||||
|   {{- errorf $msg2 (delimit $validFormats ", ") }} |  | ||||||
| {{- end -}} |  | ||||||
|  |  | ||||||
| {{/* Format: default |  | ||||||
| {{/* --------------------------------------------------------------------- */}} |  | ||||||
| {{- define "_partials/inline/pagination/default.html" }} |  | ||||||
|   {{- with .Paginator }} |  | ||||||
|     {{- $currentPageNumber := .PageNumber }} |  | ||||||
|  |  | ||||||
|     {{- with .First }} |  | ||||||
|       {{- if ne $currentPageNumber .PageNumber }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="First" class="page-link" role="button"><span aria-hidden="true">««</span></a> |  | ||||||
|       </li> |  | ||||||
|       {{- else }} |  | ||||||
|       <li class="page-item disabled"> |  | ||||||
|         <a aria-disabled="true" aria-label="First" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">««</span></a> |  | ||||||
|       </li> |  | ||||||
|       {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- with .Prev }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="Previous" class="page-link" role="button"><span aria-hidden="true">«</span></a> |  | ||||||
|       </li> |  | ||||||
|     {{- else }} |  | ||||||
|       <li class="page-item disabled"> |  | ||||||
|         <a aria-disabled="true" aria-label="Previous" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">«</span></a> |  | ||||||
|       </li> |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- $slots := 5 }} |  | ||||||
|     {{- $start := math.Max 1 (sub .PageNumber (math.Floor (div $slots 2))) }} |  | ||||||
|     {{- $end := math.Min .TotalPages (sub (add $start $slots) 1) }} |  | ||||||
|     {{- if lt (add (sub $end $start) 1) $slots }} |  | ||||||
|       {{- $start = math.Max 1 (add (sub $end $slots) 1) }} |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- range $k := seq $start $end }} |  | ||||||
|       {{- if eq $.Paginator.PageNumber $k }} |  | ||||||
|       <li class="page-item active"> |  | ||||||
|         <a aria-current="page" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a> |  | ||||||
|       </li> |  | ||||||
|       {{- else }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ (index $.Paginator.Pagers (sub $k 1)).URL }}" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a> |  | ||||||
|       </li> |  | ||||||
|       {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- with .Next }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="Next" class="page-link" role="button"><span aria-hidden="true">»</span></a> |  | ||||||
|       </li> |  | ||||||
|     {{- else }} |  | ||||||
|       <li class="page-item disabled"> |  | ||||||
|         <a aria-disabled="true" aria-label="Next" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">»</span></a> |  | ||||||
|       </li> |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- with .Last }} |  | ||||||
|       {{- if ne $currentPageNumber .PageNumber }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="Last" class="page-link" role="button"><span aria-hidden="true">»»</span></a> |  | ||||||
|       </li> |  | ||||||
|       {{- else }} |  | ||||||
|       <li class="page-item disabled"> |  | ||||||
|         <a aria-disabled="true" aria-label="Last" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">»»</span></a> |  | ||||||
|       </li> |  | ||||||
|       {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end -}} |  | ||||||
|  |  | ||||||
| {{/* Format: terse |  | ||||||
| {{/* --------------------------------------------------------------------- */}} |  | ||||||
| {{- define "_partials/inline/pagination/terse.html" }} |  | ||||||
|   {{- with .Paginator }} |  | ||||||
|     {{- $currentPageNumber := .PageNumber }} |  | ||||||
|  |  | ||||||
|     {{- with .First }} |  | ||||||
|       {{- if ne $currentPageNumber .PageNumber }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="First" class="page-link" role="button"><span aria-hidden="true">««</span></a> |  | ||||||
|       </li> |  | ||||||
|       {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- with .Prev }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="Previous" class="page-link" role="button"><span aria-hidden="true">«</span></a> |  | ||||||
|       </li> |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- $slots := 3 }} |  | ||||||
|     {{- $start := math.Max 1 (sub .PageNumber (math.Floor (div $slots 2))) }} |  | ||||||
|     {{- $end := math.Min .TotalPages (sub (add $start $slots) 1) }} |  | ||||||
|     {{- if lt (add (sub $end $start) 1) $slots }} |  | ||||||
|       {{- $start = math.Max 1 (add (sub $end $slots) 1) }} |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- range $k := seq $start $end }} |  | ||||||
|       {{- if eq $.Paginator.PageNumber $k }} |  | ||||||
|       <li class="page-item active"> |  | ||||||
|         <a aria-current="page" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a> |  | ||||||
|       </li> |  | ||||||
|       {{- else }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ (index $.Paginator.Pagers (sub $k 1)).URL }}" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a> |  | ||||||
|       </li> |  | ||||||
|       {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- with .Next }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="Next" class="page-link" role="button"><span aria-hidden="true">»</span></a> |  | ||||||
|       </li> |  | ||||||
|     {{- end }} |  | ||||||
|  |  | ||||||
|     {{- with .Last }} |  | ||||||
|       {{- if ne $currentPageNumber .PageNumber }} |  | ||||||
|       <li class="page-item"> |  | ||||||
|         <a href="{{ .URL }}" aria-label="Last" class="page-link" role="button"><span aria-hidden="true">»»</span></a> |  | ||||||
|       </li> |  | ||||||
|       {{- end }} |  | ||||||
|     {{- end }} |  | ||||||
|   {{- end }} |  | ||||||
| {{- end -}} |  | ||||||
| @@ -1,6 +0,0 @@ | |||||||
| {{ if gt .Paginator.TotalPages 1 }} |  | ||||||
|     <nav class="pagination"> |  | ||||||
|         {{/* https://github.com/gohugoio/hugo/blob/a88b488181279befd50e1d127f9f67604f2f9854/tpl/tplimpl/embedded/templates/_partials/pagination.html */}} |  | ||||||
|         {{ partial "pagination-hugo.html" . }} |  | ||||||
|     </nav> |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,43 +0,0 @@ | |||||||
| {{/* we do not need to duplicate what's already covered by OpenGraph tags |  | ||||||
|    * see: https://demo.bbaovanc.com/test/remove-twitter-tags/blog/swapfile-guide/ |  | ||||||
|    * so, no twitter:image/title/description |  | ||||||
|    */}} |  | ||||||
| {{ $images := $.Resources.ByType "image" }} |  | ||||||
| {{ $featured := $images.GetMatch "*feature*" }} |  | ||||||
| {{ if not $featured }} |  | ||||||
|     {{ $featured = $images.GetMatch "{*cover*,*thumbnail*}" }} |  | ||||||
| {{ end }} |  | ||||||
|  |  | ||||||
| {{ with $featured }} |  | ||||||
|     {{ $ratio := 0 }} |  | ||||||
|     {{ if gt .Width .Height }} |  | ||||||
|         {{ $ratio = div (float .Width) .Height }} |  | ||||||
|     {{ else }} |  | ||||||
|         {{ $ratio = div (float .Height) .Width }} |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ if lt $ratio 1.75 }} |  | ||||||
|         <meta name="twitter:card" content="summary_large_image"> |  | ||||||
|     {{ else }} |  | ||||||
|         <meta name="twitter:card" content="summary"> |  | ||||||
|     {{ end }} |  | ||||||
| {{ else }} |  | ||||||
|     <meta name="twitter:card" content="summary"> |  | ||||||
| {{ end }} |  | ||||||
|  |  | ||||||
| {{/* twitter:site is the site author; twitter:creator is page author |  | ||||||
|    * https://developer.x.com/en/docs/x-for-websites/cards/guides/getting-started |  | ||||||
|    * "Card and Content Attribution" |  | ||||||
|    */}} |  | ||||||
| {{ with .Site.Params.social.twitter }} |  | ||||||
|     <meta name="twitter:site" content="@{{ . }}"> |  | ||||||
| {{ else }} |  | ||||||
|     {{ errorf "a twitter username is required for twitter cards to work" }} |  | ||||||
| {{ end }} |  | ||||||
| {{ with .GetTerms "authors" }} |  | ||||||
|     {{ range . }} |  | ||||||
|         {{ with .Params.twitter }} |  | ||||||
|             <meta name="twitter:creator" content="@{{ . }}"> |  | ||||||
|         {{ end }} |  | ||||||
|     {{ end }} |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,17 +0,0 @@ | |||||||
| <figure> |  | ||||||
|     {{ $resource_title := "" }} |  | ||||||
|     {{ with .Get "src" }} |  | ||||||
|         {{ with $.Page.Resources.Get . }} |  | ||||||
|             {{ $resource_title = .Title }} |  | ||||||
|             {{ partial "embed-resource.html" . }} |  | ||||||
|         {{ else }} |  | ||||||
|             {{ errorf "resource %q not found" . }} |  | ||||||
|         {{ end }} |  | ||||||
|     {{ else }} |  | ||||||
|         {{ .Inner }} |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ with or (.Get "caption") (.Get 0) $resource_title }} |  | ||||||
|         <figcaption>{{ (replace . "\\bt" "`") | markdownify }}</figcaption> |  | ||||||
|     {{ end }} |  | ||||||
| </figure> |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| {{/* https://github.com/gohugoio/hugo/issues/13823#issuecomment-3015270202 */}} |  | ||||||
| {{ with .Get 0 -}} |  | ||||||
|     {{ with $.Page.GetPage . -}} |  | ||||||
|         {{ .RenderShortcodes -}} |  | ||||||
|     {{ else with $.Page.Resources.Get . -}} |  | ||||||
|         {{ .RenderShortcodes -}} |  | ||||||
|     {{ else with resources.Get . -}} |  | ||||||
|         {{ .Content -}} |  | ||||||
|     {{ else -}} |  | ||||||
|         {{ errorf "The %q shortcode was unable to find %q. See %s" $.Name . $.Position -}} |  | ||||||
|     {{ end -}} |  | ||||||
| {{ else -}} |  | ||||||
|     {{ errorf "The %q shortcode requires a positional parameter indicating the logical path of the file to include. See %s" .Name .Position -}} |  | ||||||
| {{ end -}} |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| {{ with .Get 0 }} |  | ||||||
|     {{ with $.Page.Resources.Get . }} |  | ||||||
|         {{ partial "embed-resource.html" . }} |  | ||||||
|     {{ else }} |  | ||||||
|         {{ errorf "resource %q not found" . }} |  | ||||||
|     {{ end }} |  | ||||||
| {{ else }} |  | ||||||
|     {{ errorf "resource name not provided as first parameter" }} |  | ||||||
| {{ end }} |  | ||||||
| @@ -11,7 +11,9 @@ | |||||||
|     <div class="page-list"> |     <div class="page-list"> | ||||||
|         {{ with .Paginator.Pages }} |         {{ with .Paginator.Pages }} | ||||||
|             {{ range . }} |             {{ range . }} | ||||||
|  |                 <article class="page"> | ||||||
|                     {{ .Render "summary" }} |                     {{ .Render "summary" }} | ||||||
|  |                 </article> | ||||||
|             {{ end }} |             {{ end }} | ||||||
|         {{ else }} |         {{ else }} | ||||||
|             <div> |             <div> | ||||||
| @@ -1,18 +1,14 @@ | |||||||
| <article class="summary-card"> | <h2 class="page-title"> | ||||||
|     <h2 class="summary-card-title"> |     <a class="heading-link" href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||||
|         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> |  | ||||||
|     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} |     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||||
| </h2> | </h2> | ||||||
|  |  | ||||||
| {{ partial "page-metadata/author.html" . }} | {{ partial "page-metadata/author.html" . }} | ||||||
|  |  | ||||||
|     {{ with .Summary }} | <div class="page-description"> | ||||||
|         <div class="summary-card-description"> |     {{ partial "description-or-summary.html" . }} | ||||||
|             {{ . }} |  | ||||||
| </div> | </div> | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     <div class="summary-card-readmore"> | <div class="readmore"> | ||||||
|         <a href="{{ .Permalink }}">{{ i18n "see_posts" }} →</a> |     <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> | ||||||
| </div> | </div> | ||||||
| </article> |  | ||||||
|   | |||||||
| @@ -1 +0,0 @@ | |||||||
| {{ (print .Title "'s Posts | " .Site.Title) | plainify }} |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| {{ (print .Title " | " .Site.Title) | plainify }} |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| {{ .Site.Title | plainify }} |  | ||||||
| @@ -3,11 +3,11 @@ | |||||||
|         <article class="homepage-content"> |         <article class="homepage-content"> | ||||||
|             {{ . }} |             {{ . }} | ||||||
|         </article> |         </article> | ||||||
|  |         <hr> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|     {{ if .Site.Params.homepageLatestPosts }} |     {{ if .Site.Params.homepageLatestPosts }} | ||||||
|         <hr> |         <div class="homepage-latest-posts"> | ||||||
|         <section class="homepage-latest-posts"> |  | ||||||
|             <h1> |             <h1> | ||||||
|                 {{ i18n "latest_posts" }} |                 {{ i18n "latest_posts" }} | ||||||
|                 {{ partial "rss-link.html" . }} |                 {{ partial "rss-link.html" . }} | ||||||
| @@ -16,6 +16,6 @@ | |||||||
|             {{ partial "page-list.html" (.Paginate .Site.RegularPages).Pages }} |             {{ partial "page-list.html" (.Paginate .Site.RegularPages).Pages }} | ||||||
|  |  | ||||||
|             {{ partial "pagination.html" . }} |             {{ partial "pagination.html" . }} | ||||||
|         </section> |         </div> | ||||||
|     {{ end }} |     {{ end }} | ||||||
| {{ end }} | {{ end }} | ||||||
|   | |||||||
| @@ -1,86 +0,0 @@ | |||||||
| {{ define "main" }} |  | ||||||
|     <article> |  | ||||||
|         <div class="page-title"> |  | ||||||
|             <h1> |  | ||||||
|                 {{ .Title | markdownify }} |  | ||||||
|                 {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} |  | ||||||
|             </h1> |  | ||||||
|         </div> |  | ||||||
|  |  | ||||||
|         {{ partial "page-metadata/post-full.html" . }} |  | ||||||
|         {{ partial "series-box.html" . }} |  | ||||||
|  |  | ||||||
|         {{ if .Params.Toc }} |  | ||||||
|             <section class="table-of-contents" aria-label="{{ i18n "aria_table_of_contents" }}"> |  | ||||||
|                 <details> |  | ||||||
|                     <summary>{{ i18n "table_of_contents" }}</summary> |  | ||||||
|                     {{ .TableOfContents }} |  | ||||||
|                 </details> |  | ||||||
|             </section> |  | ||||||
|             <div class="table-of-contents print"> |  | ||||||
|                 {{ i18n "table_of_contents" }} |  | ||||||
|                 {{ .TableOfContents }} |  | ||||||
|             </div> |  | ||||||
|         {{ end }} |  | ||||||
|  |  | ||||||
|         {{ partial "featured-media.html" . }} |  | ||||||
|  |  | ||||||
|         <div class="post-content" data-pagefind-body> |  | ||||||
|             {{ .Content }} |  | ||||||
|         </div> |  | ||||||
|  |  | ||||||
|         {{ partial "series-box.html" . }} |  | ||||||
|  |  | ||||||
|         {{ if or .NextInSection .PrevInSection }} |  | ||||||
|             <nav class="prevnext"> |  | ||||||
|                 {{ with .NextInSection }} |  | ||||||
|                     <a class="prev" href="{{ .Permalink }}"> |  | ||||||
|                         <div class="prev-caption"> |  | ||||||
|                             ← {{ i18n "newer_post" }} |  | ||||||
|                         </div> |  | ||||||
|                         <div class="prev-post"> |  | ||||||
|                             {{ .Title | markdownify }} |  | ||||||
|                         </div> |  | ||||||
|                     </a> |  | ||||||
|                 {{ else }} |  | ||||||
|                     <div class="prev"></div> |  | ||||||
|                 {{ end }} |  | ||||||
|  |  | ||||||
|                 {{ with .PrevInSection }} |  | ||||||
|                     <a class="next" href="{{ .Permalink }}"> |  | ||||||
|                         <div class="next-caption"> |  | ||||||
|                             {{ i18n "older_post" }} → |  | ||||||
|                         </div> |  | ||||||
|                         <div class="next-post"> |  | ||||||
|                             {{ .Title | markdownify }} |  | ||||||
|                         </div> |  | ||||||
|                     </a> |  | ||||||
|                 {{ else }} |  | ||||||
|                     <div class="next"></div> |  | ||||||
|                 {{ end }} |  | ||||||
|             </nav> |  | ||||||
|         {{ end }} |  | ||||||
|  |  | ||||||
|         {{ if .Site.Params.shareButtons }} |  | ||||||
|             {{ partial "share.html" . }} |  | ||||||
|         {{ end }} |  | ||||||
|  |  | ||||||
|         {{ if .Params.comments }} |  | ||||||
|             <section class="comments"> |  | ||||||
|                 {{ partial "comments.html" . }} |  | ||||||
|             </section> |  | ||||||
|         {{ end }} |  | ||||||
|     </article> |  | ||||||
| {{ end }} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| {{ define "post-body" }} |  | ||||||
|     {{ $related := .Site.RegularPages.Related . | first 10 }} |  | ||||||
|     {{ with $related }} |  | ||||||
|         <div class="related-posts"> |  | ||||||
|             <hr> |  | ||||||
|             <h2>{{ i18n "related_posts" }}</h2> |  | ||||||
|             {{ partial "page-list.html" . }} |  | ||||||
|         </div> |  | ||||||
|     {{ end }} |  | ||||||
| {{ end }} |  | ||||||
							
								
								
									
										4
									
								
								layouts/partials/additional-head.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								layouts/partials/additional-head.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | {{/* | ||||||
|  |     Create a file named `layouts/partials/additional-head.html` at your site root to | ||||||
|  |     add extra tags into <head>. Page variables are passed. | ||||||
|  | */}} | ||||||
							
								
								
									
										4
									
								
								layouts/partials/comments.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								layouts/partials/comments.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | {{/* | ||||||
|  |     Create a file named `layouts/partials/comments.html` at your site root to | ||||||
|  |     add a comment system. Page variables are passed. | ||||||
|  | */}} | ||||||
							
								
								
									
										7
									
								
								layouts/partials/description-or-summary.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								layouts/partials/description-or-summary.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | {{ with .Description }} | ||||||
|  |     <p>{{ . | markdownify }}</p> | ||||||
|  | {{ else }} | ||||||
|  |     {{ with .Summary }} | ||||||
|  |         {{ . }} | ||||||
|  |     {{ end }} | ||||||
|  | {{ end }} | ||||||
							
								
								
									
										28
									
								
								layouts/partials/figure.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								layouts/partials/figure.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | {{ $hidecaption := index . "hidecaption" }} | ||||||
|  |  | ||||||
|  | {{ if index . "noborder" }} | ||||||
|  |     <figure> | ||||||
|  | {{ else }} | ||||||
|  |     <figure class="border"> | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  |     {{ with index . "src" }} | ||||||
|  |         {{ $media := . }} | ||||||
|  |         {{ if eq .MediaType.MainType "image" }} | ||||||
|  |             <img src="{{ $media.Permalink }}" alt="{{ $media.Title }}" loading="lazy" /> | ||||||
|  |         {{ else if eq .MediaType.MainType "video" }} | ||||||
|  |             <video controls preload="metadata"> | ||||||
|  |                 <source src="{{ $media.Permalink }}" alt="{{ $media.Title }}"> | ||||||
|  |                 {{ i18n "browser_no_video_support" }} | ||||||
|  |             </video> | ||||||
|  |         {{ end }} | ||||||
|  |  | ||||||
|  |         {{ if not $hidecaption }} | ||||||
|  |             {{ with $media.Title }} | ||||||
|  |                 <figcaption> | ||||||
|  |                     {{ . | markdownify }} | ||||||
|  |                 </figcaption> | ||||||
|  |             {{ end }} | ||||||
|  |         {{ end }} | ||||||
|  |     {{ end }} | ||||||
|  | </figure> | ||||||
							
								
								
									
										46
									
								
								layouts/partials/head.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								layouts/partials/head.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | |||||||
|  | <head> | ||||||
|  |     <meta charset="UTF-8"> | ||||||
|  |     <meta name="viewport" content="width=device-width, initial-scale=1"> | ||||||
|  |     {{ hugo.Generator }} | ||||||
|  |  | ||||||
|  |     {{ with resources.Get "css/bobastyle.css" | fingerprint "sha512" }} | ||||||
|  |         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> | ||||||
|  |     {{ end }} | ||||||
|  |     {{ with resources.Get "css/syntax.css" | fingerprint "sha512" }} | ||||||
|  |         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous" media="print" onload="this.media='all'"> | ||||||
|  |     {{ end }} | ||||||
|  |     {{ with resources.Get "css/syntax-light.css" | fingerprint "sha512" }} | ||||||
|  |         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous" media="print" onload="this.media='all'"> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ with resources.Get "js/bobatheme.js" | fingerprint "sha512" }} | ||||||
|  |         <script defer src="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> | ||||||
|  |     {{ end }} | ||||||
|  |     {{ with resources.Get "js/share-event.js" | fingerprint "sha512" }} | ||||||
|  |         <script defer src="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ with .Site.Params.faviconSVG }} | ||||||
|  |         <link rel="icon" href="{{ . | absURL }}" /> | ||||||
|  |     {{ end }} | ||||||
|  |     {{ with .Site.Params.appleTouchPNG }} | ||||||
|  |         <link rel="apple-touch-icon" href="{{ . | absURL }}" /> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .IsHome }} | ||||||
|  |         <title>{{ .Site.Title | plainify }}</title> | ||||||
|  |     {{ else }} | ||||||
|  |         <title>{{ (print .Title " | " .Site.Title) | plainify }}</title> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ partial "seo-tags/opengraph.html" . }} | ||||||
|  |     {{ partial "seo-tags/twitter-cards.html" . }} | ||||||
|  |     {{ partial "seo-tags/schema.html" . }} | ||||||
|  |     {{ partial "seo-tags/link.html" . }} | ||||||
|  |     {{ partial "seo-tags/author.html" . }} | ||||||
|  |  | ||||||
|  |     <meta name="language" content="{{ .Language.Lang }}"> | ||||||
|  |     <meta name="description" content="{{ (partial "seo-description.html" .) | plainify }}"> | ||||||
|  |  | ||||||
|  |     {{ partial "additional-head.html" . }} | ||||||
|  | </head> | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| {{- $icon_resource := resources.Get (printf "jam/icons/%s.svg" .) -}} | {{- $icon_resource := resources.Get (printf "jam/icons/%s.svg" .) -}} | ||||||
| {{- $icon := $icon_resource.Content -}} | {{- $icon := $icon_resource.Content -}} | ||||||
| {{- $icon = replaceRE `<svg` (printf `<svg class="icon icon-%s"` .) $icon -}} | {{- $icon = replaceRE `<svg` `<svg class="icon"` $icon -}} | ||||||
| {{- $icon = replaceRE `</svg>` (printf `<title>%s icon</title></svg>` .) $icon -}} | {{- $icon = replaceRE `</svg>` (printf `<title>%s icon</title></svg>` .) $icon -}} | ||||||
| {{- $icon = replaceRE `(width|height)="[0-9]*"` "" $icon -}} | {{- $icon = replaceRE `(width|height)="[0-9]*"` "" $icon -}} | ||||||
| {{- $icon | safeHTML -}} | {{- $icon | safeHTML -}} | ||||||
| @@ -1,7 +1,9 @@ | |||||||
| <div class="page-list"> | <div class="page-list"> | ||||||
|     {{ with . }} |     {{ with . }} | ||||||
|         {{ range . }} |         {{ range . }} | ||||||
|  |             <article class="page"> | ||||||
|                 {{ .Render "summary" }} |                 {{ .Render "summary" }} | ||||||
|  |             </article> | ||||||
|         {{ end }} |         {{ end }} | ||||||
|     {{ else }} |     {{ else }} | ||||||
|         <div> |         <div> | ||||||
							
								
								
									
										16
									
								
								layouts/partials/page-metadata/item/authors.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								layouts/partials/page-metadata/item/authors.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | {{ with .Params.authors }} | ||||||
|  |     <span class="page-metadata-item" aria-label="{{ i18n "aria_post_meta_authors" }}"> | ||||||
|  |         {{ partial "icon.html" "user-circle" }} | ||||||
|  |  | ||||||
|  |         {{ if index $.Site.Taxonomies "authors" }} | ||||||
|  |             {{ $authors := slice }} | ||||||
|  |             {{ range . }} | ||||||
|  |                 {{ $url := (printf "authors/%s" (. | anchorize)) | absLangURL }} | ||||||
|  |                 {{ $authors = $authors | append (printf `<a href="%s">%s</a>` $url .) }} | ||||||
|  |             {{ end }} | ||||||
|  |             {{ delimit $authors ", " | safeHTML }} | ||||||
|  |         {{ else }} | ||||||
|  |             {{ delimit . ", " }} | ||||||
|  |         {{ end }} | ||||||
|  |     </span> | ||||||
|  | {{ end }} | ||||||
| @@ -6,8 +6,6 @@ | |||||||
| 
 | 
 | ||||||
|     <div class="page-metadata-section categories" aria-label="{{ i18n "aria_post_meta_categories" }}"> |     <div class="page-metadata-section categories" aria-label="{{ i18n "aria_post_meta_categories" }}"> | ||||||
|         {{ partial "icon.html" "folder" }} |         {{ partial "icon.html" "folder" }} | ||||||
|         {{ range . }} |         {{ delimit $categories ", " | safeHTML }} | ||||||
|             <a href="{{ .Permalink }}" data-pagefind-filter="category">{{ .LinkTitle }}</a> |  | ||||||
|         {{ end }} |  | ||||||
|     </div> |     </div> | ||||||
| {{ end }} | {{ end }} | ||||||
							
								
								
									
										11
									
								
								layouts/partials/page-metadata/item/series.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								layouts/partials/page-metadata/item/series.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | {{ with (.GetTerms "series") }} | ||||||
|  |     {{ $series := slice }} | ||||||
|  |     {{ range . }} | ||||||
|  |         {{ $series = $series | append (printf `<a href="%s">%s</a>` .Permalink .LinkTitle) }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     <div class="page-metadata-section series" aria-label="{{ i18n "aria_post_meta_series" }}"> | ||||||
|  |         {{ partial "icon.html" "files" }} | ||||||
|  |         {{ delimit $series ", " | safeHTML }} | ||||||
|  |     </div> | ||||||
|  | {{ end }} | ||||||
| @@ -1,10 +1,11 @@ | |||||||
| {{ with (.GetTerms "tags") }} | {{ with (.GetTerms "tags") }} | ||||||
|     {{ $tags := slice }} |     {{ $tags := slice }} | ||||||
|  |     {{ range . }} | ||||||
|  |         {{ $tags = $tags | append (printf `<a href="%s">%s</a>` .Permalink .LinkTitle) }} | ||||||
|  |     {{ end }} | ||||||
| 
 | 
 | ||||||
|     <div class="page-metadata-section tags" aria-label="{{ i18n "aria_post_meta_tags" }}"> |     <div class="page-metadata-section tags" aria-label="{{ i18n "aria_post_meta_tags" }}"> | ||||||
|         {{ partial "icon.html" "tag" }} |         {{ partial "icon.html" "tag" }} | ||||||
|         {{ range . }} |         {{ delimit $tags ", " | safeHTML }} | ||||||
|             <a href="{{ .Permalink }}" data-pagefind-filter="tag">{{ .LinkTitle }}</a> |  | ||||||
|         {{ end }} |  | ||||||
|     </div> |     </div> | ||||||
| {{ end }} | {{ end }} | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| {{ if or .Date .Params.authors .Site.Params.readingtime .Site.Params.gitFileURL }} | {{ if or .Date .Params.authors .Site.Params.readingtime .Site.Params.gitFileURL }} | ||||||
|     <section class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}"> |     <div class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}"> | ||||||
|         {{ if .Date }} |         {{ if .Date }} | ||||||
|             <span class="page-metadata-item" aria-label="{{ i18n "aria_post_meta_date" }}"> |             <span class="page-metadata-item" aria-label="{{ i18n "aria_post_meta_date" }}"> | ||||||
|                 {{ partial "icon.html" "calendar" }} |                 {{ partial "icon.html" "calendar" }} | ||||||
| @@ -20,10 +20,7 @@ | |||||||
|         {{ partial "page-metadata/item/authors.html" . }} |         {{ partial "page-metadata/item/authors.html" . }} | ||||||
|         {{ partial "page-metadata/item/readingtime.html" . }} |         {{ partial "page-metadata/item/readingtime.html" . }} | ||||||
|         {{ partial "page-metadata/item/edithistory.html" . }} |         {{ partial "page-metadata/item/edithistory.html" . }} | ||||||
|         {{ partial "page-metadata/item/comments-counter.html" . }} |  | ||||||
| 
 |  | ||||||
|         {{ partial "page-metadata/item/categories.html" . }} |         {{ partial "page-metadata/item/categories.html" . }} | ||||||
| 
 |  | ||||||
|         {{ partial "page-metadata/item/tags.html" . }} |         {{ partial "page-metadata/item/tags.html" . }} | ||||||
|     </section> |     </div> | ||||||
| {{ end }} | {{ end }} | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| {{ if or .Date .Params.authors .Site.Params.readingtime }} | {{ if or .Date .Params.authors .Site.Params.readingtime }} | ||||||
|     <section class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}"> |     <div class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}"> | ||||||
|         {{ if .Date }} |         {{ if .Date }} | ||||||
|             <span class="page-metadata-item" aria-label="date"> |             <span class="page-metadata-item" aria-label="date"> | ||||||
|                 {{ partial "icon.html" "calendar" }} |                 {{ partial "icon.html" "calendar" }} | ||||||
| @@ -9,10 +9,8 @@ | |||||||
| 
 | 
 | ||||||
|         {{ partial "page-metadata/item/authors.html" . }} |         {{ partial "page-metadata/item/authors.html" . }} | ||||||
|         {{ partial "page-metadata/item/readingtime.html" . }} |         {{ partial "page-metadata/item/readingtime.html" . }} | ||||||
|         {{ partial "page-metadata/item/comments-counter.html" . }} |  | ||||||
| 
 |  | ||||||
|         {{ partial "page-metadata/item/series.html" . }} |         {{ partial "page-metadata/item/series.html" . }} | ||||||
|         {{ partial "page-metadata/item/categories.html" . }} |         {{ partial "page-metadata/item/categories.html" . }} | ||||||
|         {{ partial "page-metadata/item/tags.html" . }} |         {{ partial "page-metadata/item/tags.html" . }} | ||||||
|     </section> |     </div> | ||||||
| {{ end }} | {{ end }} | ||||||
							
								
								
									
										5
									
								
								layouts/partials/pagination.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								layouts/partials/pagination.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | {{ if gt .Paginator.TotalPages 1 }} | ||||||
|  |     <nav class="pagination"> | ||||||
|  |         {{ template "_internal/pagination.html" . }} | ||||||
|  |     </nav> | ||||||
|  | {{ end }} | ||||||
							
								
								
									
										28
									
								
								layouts/partials/remote_figure.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								layouts/partials/remote_figure.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | {{ $hidecaption := index . "hidecaption" }} | ||||||
|  | {{ $type := index . "type" }} | ||||||
|  | {{ $src := index . "src" }} | ||||||
|  | {{ $alt := index . "alt" }} | ||||||
|  |  | ||||||
|  | {{ if index . "border" }} | ||||||
|  |     <figure class="border"> | ||||||
|  | {{ else }} | ||||||
|  |     <figure> | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if eq $type "image" }} | ||||||
|  |         <img src="{{ $src }}" alt="{{ $alt }}" loading="lazy" /> | ||||||
|  |     {{ else if eq $type "video" }} | ||||||
|  |         <video controls preload="metadata"> | ||||||
|  |             <source src="{{ $src }}" alt="{{ $alt }}"> | ||||||
|  |             {{ i18n "browser_no_video_support" }} | ||||||
|  |         </video> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if not $hidecaption }} | ||||||
|  |         {{ with $alt }} | ||||||
|  |             <figcaption> | ||||||
|  |                 {{ . | markdownify }} | ||||||
|  |             </figcaption> | ||||||
|  |         {{ end }} | ||||||
|  |     {{ end }} | ||||||
|  | </figure> | ||||||
| @@ -3,6 +3,16 @@ | |||||||
| <meta property="og:type" content="{{ if .IsPage }}article{{ else }}website{{ end }}"> | <meta property="og:type" content="{{ if .IsPage }}article{{ else }}website{{ end }}"> | ||||||
| <meta property="og:url" content="{{ .Permalink }}"> | <meta property="og:url" content="{{ .Permalink }}"> | ||||||
| 
 | 
 | ||||||
|  | {{ $images := $.Resources.ByType "image" }} | ||||||
|  | {{ $featured := $images.GetMatch "*feature*" }} | ||||||
|  | {{ if not $featured }} | ||||||
|  |     {{ $featured = $images.GetMatch "{*cover*,*thumbnail*}" }} | ||||||
|  | {{ end }} | ||||||
|  | 
 | ||||||
|  | {{ with $featured }} | ||||||
|  |     <meta property="og:image" content="{{ $featured.Permalink }}"> | ||||||
|  | {{ end }} | ||||||
|  | 
 | ||||||
| {{ with .Section }} | {{ with .Section }} | ||||||
|     <meta property="article:section" content="{{ . }}"> |     <meta property="article:section" content="{{ . }}"> | ||||||
| {{ end }} | {{ end }} | ||||||
| @@ -23,42 +33,16 @@ | |||||||
|     <meta property="og:locale" content="{{ . }}"> |     <meta property="og:locale" content="{{ . }}"> | ||||||
| {{ end }} | {{ end }} | ||||||
| 
 | 
 | ||||||
| {{ with .Site.Title }} | {{ with .Site.Params.title }} | ||||||
|     <meta property="og:site_name" content="{{ . }}"> |     <meta property="og:site_name" content="{{ . }}"> | ||||||
| {{ end }} | {{ end }} | ||||||
| 
 | 
 | ||||||
| {{ $images := $.Resources.ByType "image" }} |  | ||||||
| {{ $featured := $images.GetMatch "*feature*" }} |  | ||||||
| {{ if not $featured }} |  | ||||||
|     {{ $featured = $images.GetMatch "{*cover*,*thumbnail*}" }} |  | ||||||
| {{ end }} |  | ||||||
| 
 |  | ||||||
| {{ with $featured }} |  | ||||||
|     <meta property="og:image" content="{{ $featured.Permalink }}"> |  | ||||||
|     {{ with .Params.alt }} |  | ||||||
|         <meta property="og:image:alt" content="{{ . }}"> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ with .MediaType }} |  | ||||||
|         <meta property="og:image:type" content="{{ . }}"> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ with .Width }} |  | ||||||
|         <meta property="og:image:width" content="{{ . }}"> |  | ||||||
|     {{ end }} |  | ||||||
|     {{ with .Height }} |  | ||||||
|         <meta property="og:image:height" content="{{ . }}"> |  | ||||||
|     {{ end }} |  | ||||||
| {{ end }} |  | ||||||
| 
 |  | ||||||
| {{ $videos := $.Resources.ByType "video" }} | {{ $videos := $.Resources.ByType "video" }} | ||||||
| {{ $featured_video := $videos.GetMatch "*feature*" }} | {{ $featured_video := $videos.GetMatch "*feature*" }} | ||||||
| {{ if not $featured_video }} | {{ if not $featured_video }} | ||||||
|     {{ $featured_video = $videos.GetMatch "{*cover*,*thumbnail*}" }} |     {{ $featured_video = $videos.GetMatch "{*cover*,*thumbnail*}" }} | ||||||
| {{ end }} | {{ end }} | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| {{ with $featured_video }} | {{ with $featured_video }} | ||||||
|     <meta property="og:video" content="{{ $featured_video.Permalink | absURL }}"> |     <meta property="og:video" content="{{ $featured_video.Permalink | absURL }}"> | ||||||
|     {{ with .MediaType }} |  | ||||||
|         <meta property="og:video:type" content="{{ . }}"> |  | ||||||
|     {{ end }} |  | ||||||
| {{ end }} | {{ end }} | ||||||
							
								
								
									
										29
									
								
								layouts/partials/seo-tags/twitter-cards.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								layouts/partials/seo-tags/twitter-cards.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | {{ $images := $.Resources.ByType "image" }} | ||||||
|  | {{ $featured := $images.GetMatch "*feature*" }} | ||||||
|  | {{ if not $featured }} | ||||||
|  |     {{ $featured = $images.GetMatch "{*cover*,*thumbnail*}" }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ with $featured }} | ||||||
|  |     {{ $ratio := 0 }} | ||||||
|  |     {{ if gt .Width .Height }} | ||||||
|  |         {{ $ratio = div (float .Width) .Height }} | ||||||
|  |     {{ else }} | ||||||
|  |         {{ $ratio = div (float .Height) .Width }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if lt $ratio 1.75 }} | ||||||
|  |         <meta name="twitter:card" content="summary_large_image"> | ||||||
|  |     {{ else }} | ||||||
|  |         <meta name="twitter:card" content="summary"> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     <meta name="twitter:image" content="{{ $featured.Permalink }}"> | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | <meta name="twitter:title" content="{{ .Title | plainify }}"> | ||||||
|  | <meta name="twitter:description" content="{{ (partial "seo-description.html" .) | plainify }}"> | ||||||
|  |  | ||||||
|  | {{ with .Site.Social.twitter }} | ||||||
|  |     <meta name="twitter:site" content="@{{ . }}"> | ||||||
|  | {{ end }} | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| <section class="share-buttons"> | <div class="share-buttons"> | ||||||
|     {{ if .Site.Params.shareButtons.twitter }} |     {{ if .Site.Params.shareButtons.twitter }} | ||||||
|         <a class="twitter-share" |         <a class="twitter-share" | ||||||
|            target="_blank" |            target="_blank" | ||||||
| @@ -66,4 +66,4 @@ | |||||||
|             {{- partial "icon.html" "printer" -}} |             {{- partial "icon.html" "printer" -}} | ||||||
|         </a> |         </a> | ||||||
|     {{ end }} |     {{ end }} | ||||||
| </section> | </div> | ||||||
| @@ -1,13 +1,13 @@ | |||||||
| <header class="top"> | <div class="top"> | ||||||
|     <div class="top-brand"> |     <header class="header"> | ||||||
|         <a href="{{ .Site.Home.Permalink | absLangURL }}"> |         <a class="heading-link" href="{{ .Site.Home.Permalink | absLangURL }}"> | ||||||
|             {{ .Site.Title | markdownify }} |             {{ .Site.Title | markdownify }} | ||||||
|         </a> |         </a> | ||||||
|     </div> |     </header> | ||||||
| 
 | 
 | ||||||
|     <nav class="top-navbar" aria-label="{{ i18n "aria_navbar" }}"> |     <nav class="navbar" aria-label="{{ i18n "aria_navbar" }}"> | ||||||
|         {{ with .Site.Home }} |         {{ with .Site.Home }} | ||||||
|             <a class="top-navbar-item{{ if $.IsHome }} top-navbar-item--active{{ end }}" href="{{ .Permalink | absLangURL }}">{{ .Title | markdownify }}</a> |             <a class="navbar-item{{ if $.IsHome }} active{{ end }}" href="{{ .Permalink | absLangURL }}">{{ .Title | markdownify }}</a> | ||||||
|         {{ end }} |         {{ end }} | ||||||
| 
 | 
 | ||||||
|         {{ range .Site.Menus.main }} |         {{ range .Site.Menus.main }} | ||||||
| @@ -16,9 +16,9 @@ | |||||||
|             {{ if or ($.HasMenuCurrent .Menu .) (eq .Page $) }} |             {{ if or ($.HasMenuCurrent .Menu .) (eq .Page $) }} | ||||||
|                 {{ $isActive = true }} |                 {{ $isActive = true }} | ||||||
|             {{ end }} |             {{ end }} | ||||||
|             <a class="top-navbar-item{{ if $isActive }} top-navbar-item--active{{ end }}" |             <a class="navbar-item{{ if $isActive }} active{{ end }}" | ||||||
|                {{ if strings.HasPrefix .URL "http" }}target="_blank" rel="noopener"{{ end }} |                {{ if strings.HasPrefix .URL "http" }}target="_blank" rel="noopener"{{ end }} | ||||||
|                href="{{ .URL }}">{{ .Name }}</a> |                href="{{ .URL }}">{{ .Name }}</a> | ||||||
|         {{ end }} |         {{ end }} | ||||||
|     </nav> |     </nav> | ||||||
| </header> | </div> | ||||||
| @@ -1,4 +1,2 @@ | |||||||
| User-Agent: * | User-Agent: * | ||||||
| Allow: / |  | ||||||
|  |  | ||||||
| Sitemap: {{ "sitemap.xml" | absLangURL }} | Sitemap: {{ "sitemap.xml" | absLangURL }} | ||||||
|   | |||||||
| @@ -1,3 +0,0 @@ | |||||||
| {{ define "main" }} |  | ||||||
|     <div id="search-box"></div> |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| {{ define "main" }} |  | ||||||
|     <h1> |  | ||||||
|         {{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }} |  | ||||||
|         {{ .Title | markdownify }} |  | ||||||
|         {{ partial "rss-link.html" . }} |  | ||||||
|     </h1> |  | ||||||
|  |  | ||||||
|     {{ with .Content }} |  | ||||||
|         {{ . }} |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ with .Sections }} |  | ||||||
|         <div class="sections"> |  | ||||||
|             {{ range . }} |  | ||||||
|                 {{ .Render "summary" }} |  | ||||||
|             {{ end }} |  | ||||||
|         </div> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ partial "page-list.html" .Paginator.Pages }} |  | ||||||
|  |  | ||||||
|     {{ partial "pagination.html" . }} |  | ||||||
| {{ end }} |  | ||||||
| @@ -1,20 +0,0 @@ | |||||||
| <a class="section-anchor" href="{{ .Permalink }}"> |  | ||||||
|     <div class="section"> |  | ||||||
|         <div> |  | ||||||
|             <h2 class="section-title"> |  | ||||||
|                 {{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }} |  | ||||||
|                 {{ .Title | markdownify }} |  | ||||||
|             </h2> |  | ||||||
|  |  | ||||||
|             {{ with .Summary }} |  | ||||||
|                 <div class="section-description"> |  | ||||||
|                     {{ . }} |  | ||||||
|                 </div> |  | ||||||
|             {{ end }} |  | ||||||
|         </div> |  | ||||||
|  |  | ||||||
|         <div class="section-arrow"> |  | ||||||
|             {{ partial "icon.html" "arrow-right" }} |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </a> |  | ||||||
							
								
								
									
										12
									
								
								layouts/section/summary.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								layouts/section/summary.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | <a class="section-anchor" href="{{ .Permalink }}"> | ||||||
|  |     <div class="section"> | ||||||
|  |         <h2 class="section-title"> | ||||||
|  |             {{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||||
|  |             {{ .Title | markdownify }} | ||||||
|  |         </h2> | ||||||
|  |  | ||||||
|  |         <div class="section-description"> | ||||||
|  |             {{ partial "description-or-summary.html" . }} | ||||||
|  |         </div> | ||||||
|  |     </div> | ||||||
|  | </a> | ||||||
| @@ -1,19 +1,19 @@ | |||||||
| {{ define "main" }} | {{ define "main" }} | ||||||
|     <div class="page-title"> |  | ||||||
|     <h1> |     <h1> | ||||||
|         {{ partial "icon.html" "files" }} |         {{ partial "icon.html" "files" }} | ||||||
|         {{ .Title | markdownify }} |         {{ .Title | markdownify }} | ||||||
|     </h1> |     </h1> | ||||||
|     </div> |  | ||||||
| 
 | 
 | ||||||
|     {{ with .Content }} |     {{ with .Content }} | ||||||
|         {{ . }} |         {{ . }} | ||||||
|     {{ end }} |     {{ end }} | ||||||
| 
 | 
 | ||||||
|     <div class="page-list page-list--series"> |     <div class="page-list series"> | ||||||
|         {{ with .Paginator.Pages }} |         {{ with .Paginator.Pages }} | ||||||
|             {{ range . }} |             {{ range . }} | ||||||
|  |                 <div class="page series"> | ||||||
|                     {{ .Render "summary" }} |                     {{ .Render "summary" }} | ||||||
|  |                 </div> | ||||||
|             {{ end }} |             {{ end }} | ||||||
|         {{ else }} |         {{ else }} | ||||||
|             <div> |             <div> | ||||||
| @@ -1,21 +1,19 @@ | |||||||
| <article class="summary-card"> | <h2 class="page-title"> | ||||||
|     <h2 class="summary-card-title"> |  | ||||||
|     {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} |     {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||||
|         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> |     <a class="heading-link" href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||||
|     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} |     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||||
| </h2> | </h2> | ||||||
|  |  | ||||||
| {{ partial "page-metadata/series.html" . }} | {{ partial "page-metadata/series.html" . }} | ||||||
|  |  | ||||||
|     {{ with .Summary }} | <div class="page-description"> | ||||||
|         <div class="summary-card-description"> |     {{ partial "description-or-summary.html" . }} | ||||||
|             {{ . }} |  | ||||||
| </div> | </div> | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     <div class="page-list page-list--series-inner"> | <div class="page-list series-inner"> | ||||||
|     {{ range .Data.Pages.Reverse }} |     {{ range .Data.Pages.Reverse }} | ||||||
|  |         <article class="page"> | ||||||
|             {{ .Render "summary" }} |             {{ .Render "summary" }} | ||||||
|  |         </article> | ||||||
|     {{ end }} |     {{ end }} | ||||||
| </div> | </div> | ||||||
| </article> |  | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								layouts/shortcodes/figure.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								layouts/shortcodes/figure.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | {{ $resource := .Page.Resources.GetMatch (.Get "src") }} | ||||||
|  |  | ||||||
|  | {{ $noborder := false }} | ||||||
|  | {{ if .Get "noborder" }} | ||||||
|  |     {{ $noborder = true }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $hidecaption := false }} | ||||||
|  | {{ if .Get "hidecaption" }} | ||||||
|  |     {{ $hidecaption = true }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  |     {{ partial "figure.html" (dict "src" $resource "noborder" $noborder "hidecaption" $hidecaption) }} | ||||||
|  | </p> | ||||||
							
								
								
									
										1
									
								
								layouts/shortcodes/full-width-hr.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								layouts/shortcodes/full-width-hr.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | <hr class="full-width-hr"> | ||||||
							
								
								
									
										20
									
								
								layouts/shortcodes/include.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								layouts/shortcodes/include.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | {{ $path := "" }} | ||||||
|  | {{ $markdown := false }} | ||||||
|  | {{ if .IsNamedParams }} | ||||||
|  |     {{ $path = .Get "path" }} | ||||||
|  |     {{ with .Get "markdown" }} | ||||||
|  |         {{ $markdown = . }} | ||||||
|  |     {{ end }} | ||||||
|  | {{ else }} | ||||||
|  |     {{ $path = .Get 0 }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ with ($path | readFile) }} | ||||||
|  |     {{ if $markdown }} | ||||||
|  |         {{ $path | readFile | $.Page.RenderString (dict "display" "block") }} | ||||||
|  |     {{ else }} | ||||||
|  |         {{ $path | readFile }} | ||||||
|  |     {{ end }} | ||||||
|  | {{ else }} | ||||||
|  |     {{ errorf "file not found: %s" $path }} | ||||||
|  | {{ end }} | ||||||
							
								
								
									
										13
									
								
								layouts/shortcodes/remote-figure.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								layouts/shortcodes/remote-figure.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | {{ $border := false }} | ||||||
|  | {{ if .Get "border" }} | ||||||
|  |     {{ $border = true }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $hidecaption := false }} | ||||||
|  | {{ if .Get "hidecaption" }} | ||||||
|  |     {{ $hidecaption = true }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  |     {{ partial "remote_figure.html" (dict "src" (.Get "src") "border" $border "hidecaption" $hidecaption "type" (.Get "type") "alt" (.Get "alt")) }} | ||||||
|  | </p> | ||||||
							
								
								
									
										10
									
								
								layouts/shortcodes/table.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								layouts/shortcodes/table.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | {{/* See https://willschenk.com/articles/2020/styling_tables_with_hugo/ */}} | ||||||
|  |  | ||||||
|  | {{ $class := "markdown" }} | ||||||
|  | {{ with .Get "class" }} | ||||||
|  |     {{ $class = delimit (slice $class .) " " }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $htmlTable := .Inner | .Page.RenderString (dict "display" "block") }} | ||||||
|  | {{ $new := printf `<table class="%s">` $class }} | ||||||
|  | {{ (replace $htmlTable "<table>" $new) | safeHTML }} | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| <article class="summary-card"> |  | ||||||
|     <h2 class="summary-card-title"> |  | ||||||
|         {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} |  | ||||||
|         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> |  | ||||||
|         {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} |  | ||||||
|     </h2> |  | ||||||
|  |  | ||||||
|     {{ partial "page-metadata/post-short.html" . }} |  | ||||||
|  |  | ||||||
|     {{ partial "featured-media.html" . }} |  | ||||||
|  |  | ||||||
|     {{ with .Summary }} |  | ||||||
|         <div class="summary-card-description"> |  | ||||||
|             {{ . }} |  | ||||||
|         </div> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     <div class="summary-card-readmore"> |  | ||||||
|         <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> |  | ||||||
|     </div> |  | ||||||
| </article> |  | ||||||
| @@ -28,7 +28,7 @@ | |||||||
|                             </a> |                             </a> | ||||||
|                             {{ partial "page-metadata/taxonomy.html" . }} |                             {{ partial "page-metadata/taxonomy.html" . }} | ||||||
|                         </div> |                         </div> | ||||||
|                         {{ .Summary }} |                         {{ partial "description-or-summary.html" . }} | ||||||
|                     </article> |                     </article> | ||||||
|                 {{ end }} |                 {{ end }} | ||||||
|             {{ end }} |             {{ end }} | ||||||
| @@ -8,7 +8,7 @@ description = "Simple Hugo theme for boba.best and bbaovanc.com" | |||||||
| homepage = "https://bbaovanc.com" | homepage = "https://bbaovanc.com" | ||||||
| tags = [] | tags = [] | ||||||
| features = [] | features = [] | ||||||
| min_version = "0.146.0" | min_version = "0.93.0" | ||||||
|  |  | ||||||
| [author] | [author] | ||||||
|   name = "bbaovanc" |   name = "bbaovanc" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user