mirror of
				https://github.com/BBaoVanC/bobatheme.git
				synced 2025-10-26 07:43:29 -05:00 
			
		
		
		
	Compare commits
	
		
			41 Commits
		
	
	
		
			v1.0.1
			...
			034ef462a2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 034ef462a2 | |||
| 56610009e9 | |||
| 76b0383c2c | |||
| 0877a9d400 | |||
| 2731d9795f | |||
| 87a6da5c41 | |||
| e450f3fbc7 | |||
| cba6dd0a2f | |||
| fa5c014a1b | |||
| a172b1ea21 | |||
| 93d9164c6a | |||
| 72ebcf134a | |||
| effd3a265b | |||
| d41f3facd7 | |||
| c82d5602bb | |||
| 219f97bc00 | |||
| 2f6d67a03f | |||
| e97d4f921d | |||
| 5ffca36b84 | |||
| f4c056b99c | |||
| 3713fdae5b | |||
| 1127795717 | |||
| 1db48c3101 | |||
| 430139d292 | |||
| ac9ca6f97e | |||
| 8cadf8e735 | |||
| 42a7e27d09 | |||
| 2371f1de13 | |||
| 81e141cef9 | |||
| 2113c7a4e9 | |||
| b14e0e90fd | |||
| 2742bac9ff | |||
| e8f9d1c5df | |||
| dff23045a8 | |||
| 4f450374cf | |||
| a3a7f50a5b | |||
| 2cc4f45d4f | |||
| 33d0f81444 | |||
| 5668feed1d | |||
| 586bea37d5 | |||
| 37c04460b5 | 
| @@ -2,6 +2,7 @@ | |||||||
|  |  | ||||||
| title: {{ replace .Name "-" " " | humanize }} | title: {{ replace .Name "-" " " | humanize }} | ||||||
| date: {{ .Date }} | date: {{ .Date }} | ||||||
|  | lastmod: {{ .Date }} | ||||||
| toc: true | toc: true | ||||||
| comments: true | comments: true | ||||||
| draft: true | draft: true | ||||||
| @@ -13,7 +14,7 @@ tags: | |||||||
|   - awesome |   - awesome | ||||||
|  |  | ||||||
| series: | series: | ||||||
|   - Archetype |   - archetype | ||||||
|  |  | ||||||
| # this will be shown for the article in list pages and in the page metadata | # this will be shown for the article in list pages and in the page metadata | ||||||
| # it can be either an image or video (this might change in the future, however) | # it can be either an image or video (this might change in the future, however) | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ | |||||||
|   --background-3: #282828; |   --background-3: #282828; | ||||||
|   --background-4: #333; |   --background-4: #333; | ||||||
|   --background-5: #444; |   --background-5: #444; | ||||||
|  |   --background-accent: #111d2f; | ||||||
|   --text-normal: #d3d3d3; |   --text-normal: #d3d3d3; | ||||||
|   --link-color: #4da6ff; |   --link-color: #4da6ff; | ||||||
|   --figure-border: #1b5b9b; |   --figure-border: #1b5b9b; | ||||||
| @@ -24,6 +25,7 @@ | |||||||
|     --background-3: #d8d8d8; |     --background-3: #d8d8d8; | ||||||
|     --background-4: #bbb; |     --background-4: #bbb; | ||||||
|     --background-5: #aaa; |     --background-5: #aaa; | ||||||
|  |     --background-accent: #aec9ee; | ||||||
|     --text-normal: #000; |     --text-normal: #000; | ||||||
|     --link-color: #0057bf; |     --link-color: #0057bf; | ||||||
|     --figure-border: #2e7bc9; |     --figure-border: #2e7bc9; | ||||||
| @@ -52,6 +54,7 @@ | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Post layout (in list pages) */ | /* Post layout (in list pages) */ | ||||||
| .list-page-content { | .list-page-content { | ||||||
|   display: flex; |   display: flex; | ||||||
| @@ -68,6 +71,10 @@ | |||||||
|   gap: 40px; |   gap: 40px; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .series-taxonomy ul { | ||||||
|  |   gap: 80px; | ||||||
|  | } | ||||||
|  |  | ||||||
| .page-list li, | .page-list li, | ||||||
| .series-taxonomy li { | .series-taxonomy li { | ||||||
|   padding-top: 8px; |   padding-top: 8px; | ||||||
| @@ -84,21 +91,25 @@ | |||||||
|   opacity: .75; |   opacity: .75; | ||||||
| } | } | ||||||
|  |  | ||||||
| .post-title { | .post-title, | ||||||
|  | .author-name { | ||||||
|   margin-bottom: 10px; |   margin-bottom: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .post-title a { | .post-title a, | ||||||
|  | .author-name a { | ||||||
|   color: inherit; |   color: inherit; | ||||||
|   text-decoration: inherit; |   text-decoration: inherit; | ||||||
| } | } | ||||||
|  |  | ||||||
| .post-meta-item { | .post-meta-item, | ||||||
|  | .author-meta-item { | ||||||
|   margin-right: 10px; |   margin-right: 10px; | ||||||
|   display: inline-block; |   display: inline-block; | ||||||
| } | } | ||||||
|  |  | ||||||
| .post-metadata { | .post-metadata, | ||||||
|  | .author-metadata { | ||||||
|   margin-bottom: 15px; |   margin-bottom: 15px; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -111,7 +122,8 @@ | |||||||
|   margin-top: 15px; |   margin-top: 15px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .post-description { | .post-description, | ||||||
|  | .author-description { | ||||||
|   margin-top: 10px; |   margin-top: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -149,7 +161,6 @@ | |||||||
|   gap: 10px; |   gap: 10px; | ||||||
|   flex-flow: row wrap; |   flex-flow: row wrap; | ||||||
|   list-style: none; |   list-style: none; | ||||||
|   padding: 0; |  | ||||||
|   background-color: var(--background); |   background-color: var(--background); | ||||||
|   padding: 8px; |   padding: 8px; | ||||||
|   border-radius: 16px; |   border-radius: 16px; | ||||||
| @@ -202,10 +213,6 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
| /* Header formatting (website title and article section headers) */ | /* Header formatting (website title and article section headers) */ | ||||||
| .top { |  | ||||||
|   margin: 20px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .header a, | .header a, | ||||||
| .section-header a { | .section-header a { | ||||||
|   color: inherit; |   color: inherit; | ||||||
| @@ -242,15 +249,106 @@ | |||||||
|   padding: 8px 15px; |   padding: 8px 15px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .content, |  | ||||||
| footer { | /* Related posts */ | ||||||
|   margin: 20px; | .full-width-page-list { | ||||||
|  |   /* make left/right 0 margin so it takes up full width */ | ||||||
|  |   margin: 25px 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| footer { | .full-width-page-list > hr, | ||||||
|   text-align: center; | .full-width-page-list > h1 { | ||||||
|  |   margin-left: 20px; | ||||||
|  |   margin-right: 20px; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .full-width-page-list li { | ||||||
|  |   min-width: 300px; | ||||||
|  |   max-width: 300px; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .full-width-page-list li:first-child { | ||||||
|  |   margin-left: 20px; | ||||||
|  | } | ||||||
|  | .full-width-page-list li:last-child { | ||||||
|  |   margin-right: 20px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media (max-width: 720px) { | ||||||
|  |   /* when the screen is smaller than max size, make sure that the .related div | ||||||
|  |    * still reaches the screen edge. then if the posts overflow and require | ||||||
|  |    * scrolling, you can see it cut off on the side of your phone screen | ||||||
|  |    */ | ||||||
|  |   .full-width-page-list { | ||||||
|  |     margin-left: -20px; | ||||||
|  |     margin-right: -20px; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media (min-width: 720px) { | ||||||
|  |   .full-width-page-list { | ||||||
|  |     /* this makes it full width -- 720px max-width on body it is exactly 720px | ||||||
|  |      * so .related takes up full width | ||||||
|  |      */ | ||||||
|  |     margin-left: calc(-100vw / 2 + 720px / 2); | ||||||
|  |     margin-right: calc(-100vw / 2 + 720px / 2); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .full-width-page-list .page-list ul { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row; | ||||||
|  |   gap: 20px; | ||||||
|  |   overflow-x: scroll; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Social media share buttons */ | ||||||
|  | .share-buttons { | ||||||
|  |   background: var(--background-2); | ||||||
|  |   margin: 25px 0; | ||||||
|  |   padding: 8px 0; | ||||||
|  |   border-radius: 8px; | ||||||
|  |   display: flex; | ||||||
|  |   gap: 8px; | ||||||
|  |   justify-content: center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .share-buttons a { | ||||||
|  |   background-color: var(--background-4); | ||||||
|  |   padding: 4px; | ||||||
|  |   border-radius: 8px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .share-buttons svg { | ||||||
|  |   width: 32px; | ||||||
|  |   height: 32px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* https://stackoverflow.com/a/72073682/19003757 */ | ||||||
|  | /* | ||||||
|  | .telegram-share > svg { | ||||||
|  |   transform: scale(1.5); | ||||||
|  |   margin: 9px -9px -9px 9px; | ||||||
|  | } | ||||||
|  | */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* See also formating */ | ||||||
|  | .see-also { | ||||||
|  |   background-color: var(--background-2); | ||||||
|  |   padding: 8px 12px; | ||||||
|  |   border-radius: 8px; | ||||||
|  |   margin: 10px 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .see-also p { | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Back to top */ | ||||||
| #back-to-top { | #back-to-top { | ||||||
|   position: fixed; |   position: fixed; | ||||||
|   float: right; |   float: right; | ||||||
| @@ -278,9 +376,6 @@ footer { | |||||||
|  |  | ||||||
| .navbar { | .navbar { | ||||||
|   display: flex; |   display: flex; | ||||||
| } |  | ||||||
|  |  | ||||||
| .navbar { |  | ||||||
|   flex-grow: 1; |   flex-grow: 1; | ||||||
|   overflow: auto; |   overflow: auto; | ||||||
| } | } | ||||||
| @@ -350,11 +445,25 @@ body { | |||||||
|   background-color: var(--background); |   background-color: var(--background); | ||||||
|   color: var(--text-normal); |   color: var(--text-normal); | ||||||
|   font-family: "Open Sans", "Noto Sans", sans-serif; |   font-family: "Open Sans", "Noto Sans", sans-serif; | ||||||
|   margin: auto; |   margin: 20px; | ||||||
|   max-width: 720px; |   max-width: 720px; | ||||||
|   overflow-wrap: break-word; |   overflow-wrap: break-word; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @media (min-width: 760px) { | ||||||
|  |   body { | ||||||
|  |     margin: 20px auto; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | footer { | ||||||
|  |   text-align: center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | footer p { | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| img, | img, | ||||||
| video { | video { | ||||||
|   max-width: 100%; |   max-width: 100%; | ||||||
| @@ -408,6 +517,27 @@ hr { | |||||||
|   border-color: var(--background-5); |   border-color: var(--background-5); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | table.markdown { | ||||||
|  |   border-collapse: collapse; | ||||||
|  |   border: 2px solid var(--text-normal); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .markdown thead { | ||||||
|  |   background-color: var(--background-4); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .markdown th, | ||||||
|  | .markdown td { | ||||||
|  |   padding: 8px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .markdown tbody tr:nth-child(odd) { | ||||||
|  |   background-color: var(--background); | ||||||
|  | } | ||||||
|  | .markdown tbody tr:nth-child(even) { | ||||||
|  |   background-color: var(--background-2); | ||||||
|  | } | ||||||
|  |  | ||||||
| * { | * { | ||||||
|   box-sizing: border-box; |   box-sizing: border-box; | ||||||
| } | } | ||||||
| @@ -504,9 +634,7 @@ li.disabled > .page-link:hover { | |||||||
|  |  | ||||||
| /* Breadcrumb navigation */ | /* Breadcrumb navigation */ | ||||||
| .breadcrumb { | .breadcrumb { | ||||||
|   margin-top: 40px; |   margin: 30px 0 20px; | ||||||
|   margin-bottom: 20px; |  | ||||||
|   margin-left: 20px; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .breadcrumb ul { | .breadcrumb ul { | ||||||
| @@ -572,7 +700,8 @@ li.disabled > .page-link:hover { | |||||||
|  |  | ||||||
|  |  | ||||||
| /* Light mode */ | /* Light mode */ | ||||||
| @media print, (prefers-color-scheme: light) { | @media print, | ||||||
|  | (prefers-color-scheme: light) { | ||||||
|   /* Basic elements */ |   /* Basic elements */ | ||||||
|   .section:hover { |   .section:hover { | ||||||
|     color: inherit; |     color: inherit; | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								assets/js/share-event.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								assets/js/share-event.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | function share_event(service) { | ||||||
|  |     // this function does nothing by default | ||||||
|  | } | ||||||
| @@ -4,8 +4,6 @@ markup: | |||||||
|     lineNos: true |     lineNos: true | ||||||
|  |  | ||||||
| params: | params: | ||||||
|   faviconICO: favicon.ico |  | ||||||
|   faviconPNG: favicon.png |  | ||||||
|   readingtime: true |   readingtime: true | ||||||
|  |  | ||||||
| taxonomies: | taxonomies: | ||||||
|   | |||||||
| @@ -20,9 +20,9 @@ params: | |||||||
|   # these are for the OpenGraph/Twitter embeds in Hugo |   # these are for the OpenGraph/Twitter embeds in Hugo | ||||||
|   description: Example website for bobatheme |   description: Example website for bobatheme | ||||||
|  |  | ||||||
|   # these are for favicons in bobatheme (defaults are shown here) |   # these are for favicons in bobatheme (disabled by default) | ||||||
|   # faviconICO: favicon.ico |   # faviconSVG: favicon.svg | ||||||
|   # faviconPNG: favicon.png |   # appleTouchPNG: apple-touch-icon.png | ||||||
|  |  | ||||||
|   # show reading time (enabled by default) |   # show reading time (enabled by default) | ||||||
|   # readingtime: true |   # readingtime: true | ||||||
| @@ -31,6 +31,24 @@ params: | |||||||
|   # gitFileURL: https://github.com/BBaoVanC/bobatheme/blob/master |   # gitFileURL: https://github.com/BBaoVanC/bobatheme/blob/master | ||||||
|   # gitFileIcon: github-circle |   # gitFileIcon: github-circle | ||||||
|  |  | ||||||
|  |   # display a "Latest Posts" section on the homepage below its content | ||||||
|  |   homepageLatestPosts: true | ||||||
|  |  | ||||||
|  |   # social media share icons | ||||||
|  |   # shareButtons: | ||||||
|  |   #   twitter: true | ||||||
|  |   #   facebook: true | ||||||
|  |   #   linkedin: true | ||||||
|  |   #   reddit: true | ||||||
|  |   #   telegram: 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 | # see https://gohugo.io/about/hugo-and-gdpr/#all-privacy-settings | ||||||
| # you probably want to keep this default | # you probably want to keep this default | ||||||
| privacy: | privacy: | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								i18n/en.yaml
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								i18n/en.yaml
									
									
									
									
									
								
							| @@ -8,6 +8,12 @@ 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." | ||||||
|  |  | ||||||
|  | latest_posts: | ||||||
|  |   other: "Latest Posts" | ||||||
|  |  | ||||||
|  | see_also: | ||||||
|  |   other: "SEE ALSO:" | ||||||
|  |  | ||||||
|  |  | ||||||
| # Meta items | # Meta items | ||||||
| long_date: | long_date: | ||||||
| @@ -35,8 +41,8 @@ post_count: | |||||||
| read_more: | read_more: | ||||||
|   other: "Read more" |   other: "Read more" | ||||||
|  |  | ||||||
| see_also: | related_posts: | ||||||
|   other: "See also" |   other: "Related Posts" | ||||||
|  |  | ||||||
| older_post: | older_post: | ||||||
|   other: "Older" |   other: "Older" | ||||||
|   | |||||||
| @@ -8,6 +8,9 @@ table_of_contents: | |||||||
| browser_no_video_support: | browser_no_video_support: | ||||||
|   other: "Tu navegador de internet no admite video." |   other: "Tu navegador de internet no admite video." | ||||||
|  |  | ||||||
|  | see_also: | ||||||
|  |   other: "Véase también:" | ||||||
|  |  | ||||||
|  |  | ||||||
| # Meta items | # Meta items | ||||||
| long_date: | long_date: | ||||||
| @@ -35,8 +38,8 @@ no_posts: | |||||||
| read_more: | read_more: | ||||||
|   other: "Leer más" |   other: "Leer más" | ||||||
|  |  | ||||||
| see_also: | related_posts: | ||||||
|   other: "Véase también" |   other: "Publicaciones similares" | ||||||
|  |  | ||||||
| older_post: | older_post: | ||||||
|   other: "Más antiguo" |   other: "Más antiguo" | ||||||
|   | |||||||
| @@ -14,17 +14,23 @@ | |||||||
|             {{ partial "breadcrumb.html" . }} |             {{ partial "breadcrumb.html" . }} | ||||||
|         {{ end }} |         {{ end }} | ||||||
|  |  | ||||||
|         <div class="content"> |         <main> | ||||||
|             {{ block "main" . }} |             {{ block "main" . }} | ||||||
|                 {{ .Content }} |                 THIS TEXT SHOULD NOT SHOW. YUZSIQGHE (that string is so I can grep for it) | ||||||
|             {{ end }} |             {{ end }} | ||||||
|         </div> |         </main> | ||||||
|  |  | ||||||
|         {{ with .Site.Copyright }} |         {{ if or .Site.Copyright .Site.Params.footer }} | ||||||
|  |             <hr> | ||||||
|             <footer> |             <footer> | ||||||
|                 <hr> |  | ||||||
|                 <small> |                 <small> | ||||||
|                     {{ . | safeHTML }} |                     {{ with .Site.Copyright }} | ||||||
|  |                         <p>{{ . | safeHTML }}</p> | ||||||
|  |                     {{ end }} | ||||||
|  |  | ||||||
|  |                     {{ with .Site.Params.footer }} | ||||||
|  |                         {{ . | $.RenderString (dict "display" "block") }} | ||||||
|  |                     {{ end }} | ||||||
|                 </small> |                 </small> | ||||||
|             </footer> |             </footer> | ||||||
|         {{ end }} |         {{ end }} | ||||||
|   | |||||||
| @@ -7,25 +7,7 @@ | |||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|     {{ partial "post-metadata/full.html" . }} |     {{ partial "post-metadata/full.html" . }} | ||||||
|  |     {{ partial "series-box.html" . }} | ||||||
|     {{ with (.GetTerms "series") }} |  | ||||||
|         {{ $series := slice }} |  | ||||||
|         {{ range . }} |  | ||||||
|             {{ $series = $series | append (printf `<a href="%s">%s</a>` .Permalink .LinkTitle) }} |  | ||||||
|         {{ end }} |  | ||||||
|  |  | ||||||
|         <div class="series-box"> |  | ||||||
|             {{ partial "icon.html" "info" }} |  | ||||||
|             {{ if gt (len $series) 1 }} |  | ||||||
|                 This post is part of multiple series: |  | ||||||
|             {{ else }} |  | ||||||
|                 This post is part of a series: |  | ||||||
|             {{ end }} |  | ||||||
|  |  | ||||||
|             {{ delimit $series ", " }} |  | ||||||
|         </div> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     {{ if .Params.Toc }} |     {{ if .Params.Toc }} | ||||||
|         <div class="table-of-contents" aria-label="{{ i18n "aria_table_of_contents" }}"> |         <div class="table-of-contents" aria-label="{{ i18n "aria_table_of_contents" }}"> | ||||||
| @@ -46,23 +28,11 @@ | |||||||
|         </div> |         </div> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|     {{ .Content }} |     <div class="post-content"> | ||||||
|  |         {{ .Content }} | ||||||
|  |     </div> | ||||||
|  |  | ||||||
|     {{ $related := .Site.RegularPages.Related . | first 5 }} |     {{ partial "series-box.html" . }} | ||||||
|     {{ with $related }} |  | ||||||
|         <div class="see-also"> |  | ||||||
|             <h2>{{ i18n "see_also" }}</h2> |  | ||||||
|  |  | ||||||
|             <ul> |  | ||||||
|                 {{ range . }} |  | ||||||
|                     <li> |  | ||||||
|                         {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} |  | ||||||
|                         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> |  | ||||||
|                     </li> |  | ||||||
|                 {{ end }} |  | ||||||
|             </ul> |  | ||||||
|         </div> |  | ||||||
|     {{ end }} |  | ||||||
|  |  | ||||||
|     {{ if or .NextInSection .PrevInSection }} |     {{ if or .NextInSection .PrevInSection }} | ||||||
|         <div class="prevnext"> |         <div class="prevnext"> | ||||||
| @@ -94,9 +64,32 @@ | |||||||
|         </div> |         </div> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.shareButtons }} | ||||||
|  |         {{ partial "share.html" . }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|     {{ if .Params.comments }} |     {{ if .Params.comments }} | ||||||
|         <div class="comments"> |         <div class="comments"> | ||||||
|             {{ partial "comments.html" . }} |             {{ partial "comments.html" . }} | ||||||
|         </div> |         </div> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ $related := .Site.RegularPages.Related . | first 10 }} | ||||||
|  |     {{ with $related }} | ||||||
|  |         <div class="related-posts full-width-page-list"> | ||||||
|  |             <hr> | ||||||
|  |             <h1>{{ i18n "related_posts" }}</h1> | ||||||
|  |             <div class="page-list"> | ||||||
|  |                 <ul> | ||||||
|  |                     {{ range . }} | ||||||
|  |                         <li>{{ .Render "summary/post" }}</li> | ||||||
|  |                     {{ end }} | ||||||
|  |                 </ul> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.latestPostsOnContent }} | ||||||
|  |         {{ partialCached "latest-posts.html" . }} | ||||||
|  |     {{ end }} | ||||||
| {{ end }} | {{ end }} | ||||||
|   | |||||||
| @@ -1,12 +1,12 @@ | |||||||
| <div class="post"> | <div class="author"> | ||||||
|     <h2 class="post-title"> |     <h2 class="author-name"> | ||||||
|         <a 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 "post-metadata/author.html" . }} |     {{ partial "post-metadata/author.html" . }} | ||||||
|  |  | ||||||
|     <div class="post-description"> |     <div class="author-description"> | ||||||
|         {{ partial "description-or-summary.html" . }} |         {{ partial "description-or-summary.html" . }} | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,2 +1,33 @@ | |||||||
| {{ define "main" }} | {{ define "main" }} | ||||||
|  |     {{ with .Content }} | ||||||
|  |         <div class="homepage-content"> | ||||||
|  |             {{ . }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.homepageLatestPosts }} | ||||||
|  |         <div class="homepage-latest-posts"> | ||||||
|  |             <hr> | ||||||
|  |             <h1> | ||||||
|  |                 {{ i18n "latest_posts" }} | ||||||
|  |                 {{ partial "rss-link.html" . }} | ||||||
|  |             </h1> | ||||||
|  |  | ||||||
|  |             {{ with (.Paginate .Site.RegularPages).Pages }} | ||||||
|  |                 <div class="page-list"> | ||||||
|  |                     <ul> | ||||||
|  |                         {{ range . }} | ||||||
|  |                             <li>{{ .Render "summary/post" }}</li> | ||||||
|  |                         {{ end }} | ||||||
|  |                     </ul> | ||||||
|  |                 </div> | ||||||
|  |             {{ else }} | ||||||
|  |                 <div> | ||||||
|  |                     {{ i18n "no_posts" }} | ||||||
|  |                 </div> | ||||||
|  |             {{ end }} | ||||||
|  |  | ||||||
|  |             {{ partial "pagination.html" . }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
| {{ 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. | ||||||
|  | */}} | ||||||
| @@ -11,7 +11,7 @@ | |||||||
|         {{ if eq .MediaType.MainType "image" }} |         {{ if eq .MediaType.MainType "image" }} | ||||||
|             <img src="{{ $media.Permalink }}" alt="{{ $media.Title }}" /> |             <img src="{{ $media.Permalink }}" alt="{{ $media.Title }}" /> | ||||||
|         {{ else if eq .MediaType.MainType "video" }} |         {{ else if eq .MediaType.MainType "video" }} | ||||||
|             <video controls> |             <video controls preload="metadata"> | ||||||
|                 <source src="{{ $media.Permalink }}" alt="{{ $media.Title }}"> |                 <source src="{{ $media.Permalink }}" alt="{{ $media.Title }}"> | ||||||
|                 {{ i18n "browser_no_video_support" }} |                 {{ i18n "browser_no_video_support" }} | ||||||
|             </video> |             </video> | ||||||
|   | |||||||
| @@ -12,15 +12,19 @@ | |||||||
|     {{ with resources.Get "css/syntax-light.css" | fingerprint "sha512" }} |     {{ with resources.Get "css/syntax-light.css" | fingerprint "sha512" }} | ||||||
|         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> |         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|     {{ with resources.Get "js/back-to-top.js" | fingerprint "sha512" }} |     {{ with resources.Get "js/back-to-top.js" | fingerprint "sha512" }} | ||||||
|         <script defer src="{{ .Permalink }}" type="text/javascript" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> |         <script defer src="{{ .Permalink }}" type="text/javascript" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |     {{ with resources.Get "js/share-event.js" | fingerprint "sha512" }} | ||||||
|     {{ with .Site.Params.faviconICO }} |         <script defer src="{{ .Permalink }}" type="text/javascript" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> | ||||||
|         <link rel="icon" type="image/x-icon" href="{{ . | absURL }}" /> |  | ||||||
|     {{ end }} |     {{ end }} | ||||||
|     {{ with .Site.Params.faviconPNG }} |  | ||||||
|         <link rel="icon" type="image/png" href="{{ . | absURL }}" /> |     {{ with .Site.Params.faviconSVG }} | ||||||
|  |         <link rel="icon" href="{{ . | absURL }}" /> | ||||||
|  |     {{ end }} | ||||||
|  |     {{ with .Site.Params.appleTouchPNG }} | ||||||
|  |         <link rel="apple-touch-icon" href="{{ . | absURL }}" /> | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|     {{ if .IsHome }} |     {{ if .IsHome }} | ||||||
| @@ -37,4 +41,6 @@ | |||||||
|  |  | ||||||
|     <meta name="language" content="{{ .Language.Lang }}"> |     <meta name="language" content="{{ .Language.Lang }}"> | ||||||
|     <meta name="description" content="{{ (partial "seo-tags/description.html" .) | plainify }}"> |     <meta name="description" content="{{ (partial "seo-tags/description.html" .) | plainify }}"> | ||||||
|  |  | ||||||
|  |     {{ partial "additional-head.html" . }} | ||||||
| </head> | </head> | ||||||
|   | |||||||
| @@ -1,5 +1 @@ | |||||||
| {{- $icon_resource := resources.Get (printf "jam/icons/%s.svg" .) -}} | {{ partialCached "icon_code.html" . . }} | ||||||
| {{- $icon := $icon_resource.Content -}} |  | ||||||
| {{- $icon = replaceRE `<svg` `<svg class="icon"` $icon -}} |  | ||||||
| {{- $icon = replaceRE `</svg>` (printf `<title>%s icon</title></svg>` .) $icon -}} |  | ||||||
| {{- $icon | safeHTML -}} |  | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								layouts/partials/icon_code.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								layouts/partials/icon_code.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | {{- $icon_resource := resources.Get (printf "jam/icons/%s.svg" .) -}} | ||||||
|  | {{- $icon := $icon_resource.Content -}} | ||||||
|  | {{- $icon = replaceRE `<svg` `<svg class="icon"` $icon -}} | ||||||
|  | {{- $icon = replaceRE `</svg>` (printf `<title>%s icon</title></svg>` .) $icon -}} | ||||||
|  | {{- $icon = replaceRE `(width|height)="[0-9]*"` "" $icon -}} | ||||||
|  | {{- $icon | safeHTML -}} | ||||||
							
								
								
									
										21
									
								
								layouts/partials/latest-posts.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								layouts/partials/latest-posts.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | <div class="latest-posts full-width-page-list"> | ||||||
|  |     <hr> | ||||||
|  |     <h1> | ||||||
|  |         {{ i18n "latest_posts" }} | ||||||
|  |         {{ partial "rss-link.html" .Site.Home }} | ||||||
|  |     </h1> | ||||||
|  |  | ||||||
|  |     {{ with .Site.RegularPages | first 5 }} | ||||||
|  |         <div class="page-list"> | ||||||
|  |             <ul> | ||||||
|  |                 {{ range . }} | ||||||
|  |                     <li>{{ .Render "summary/post" }}</li> | ||||||
|  |                 {{ end }} | ||||||
|  |             </ul> | ||||||
|  |         </div> | ||||||
|  |     {{ else }} | ||||||
|  |         <div> | ||||||
|  |             {{ i18n "no_posts" }} | ||||||
|  |         </div> | ||||||
|  |     {{ end }} | ||||||
|  | </div> | ||||||
| @@ -1,16 +1,16 @@ | |||||||
| <div class="post-metadata" aria-label="{{ i18n "aria_author_metadata" }}"> | <div class="author-metadata" aria-label="{{ i18n "aria_author_metadata" }}"> | ||||||
|     {{/* Calculate the total word count */}} |     {{/* Calculate the total word count */}} | ||||||
|     {{ $total_words := 0 }} |     {{ $total_words := 0 }} | ||||||
|     {{ range .Data.Pages }} |     {{ range .Data.Pages }} | ||||||
|         {{ $total_words = add $total_words .WordCount }} |         {{ $total_words = add $total_words .WordCount }} | ||||||
|     {{ end }} |     {{ end }} | ||||||
|  |  | ||||||
|     <span class="post-meta-item" aria-label="{{ i18n "aria_author_post_count" }}"> |     <span class="author-meta-item" aria-label="{{ i18n "aria_author_post_count" }}"> | ||||||
|         {{ partial "icon.html" "newspaper" }} |         {{ partial "icon.html" "newspaper" }} | ||||||
|         {{ i18n "post_count" (len .Data.Pages) }} |         {{ i18n "post_count" (len .Data.Pages) }} | ||||||
|     </span> |     </span> | ||||||
|  |  | ||||||
|     <span class="post-meta-item" aria-label="{{ i18n "aria_author_word_count" }}"> |     <span class="author-meta-item" aria-label="{{ i18n "aria_author_word_count" }}"> | ||||||
|         {{ partial "icon.html" "align-left" }} |         {{ partial "icon.html" "align-left" }} | ||||||
|         {{ i18n "wordcount" $total_words }} |         {{ i18n "wordcount" $total_words }} | ||||||
|     </span> |     </span> | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ | |||||||
|             </span> |             </span> | ||||||
|  |  | ||||||
|             {{/* TODO: make this be a tooltip */}} |             {{/* TODO: make this be a tooltip */}} | ||||||
|  |             {{/* DISABLED | ||||||
|             {{ if ne (time.Format "2006-01-02" .Lastmod) (time.Format "2006-01-02" .Date) }} |             {{ if ne (time.Format "2006-01-02" .Lastmod) (time.Format "2006-01-02" .Date) }} | ||||||
|                 <span class="post-meta-item" aria-label="{{ i18n "aria_post_meta_modified_date" }}"> |                 <span class="post-meta-item" aria-label="{{ i18n "aria_post_meta_modified_date" }}"> | ||||||
|                     {{ partial "icon.html" "pencil" }} |                     {{ partial "icon.html" "pencil" }} | ||||||
| @@ -17,6 +18,7 @@ | |||||||
|                     </time> |                     </time> | ||||||
|                     {{ end }} |                     {{ end }} | ||||||
|                 </span> |                 </span> | ||||||
|  |             */}} | ||||||
|         {{ end }} |         {{ end }} | ||||||
|  |  | ||||||
|         {{ partial "post-meta-item/authors.html" . }} |         {{ partial "post-meta-item/authors.html" . }} | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ | |||||||
|     {{ if eq $type "image" }} |     {{ if eq $type "image" }} | ||||||
|         <img src="{{ $src }}" alt="{{ $alt }}" /> |         <img src="{{ $src }}" alt="{{ $alt }}" /> | ||||||
|     {{ else if eq $type "video" }} |     {{ else if eq $type "video" }} | ||||||
|         <video controls> |         <video controls preload="metadata"> | ||||||
|             <source src="{{ $src }}" alt="{{ $alt }}"> |             <source src="{{ $src }}" alt="{{ $alt }}"> | ||||||
|             {{ i18n "browser_no_video_support" }} |             {{ i18n "browser_no_video_support" }} | ||||||
|         </video> |         </video> | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								layouts/partials/series-box.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								layouts/partials/series-box.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | {{ with (.GetTerms "series") }} | ||||||
|  |     {{ $series := slice }} | ||||||
|  |     {{ range . }} | ||||||
|  |         {{ $series = $series | append (printf `<a href="%s">%s</a>` .Permalink .LinkTitle) }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     <div class="series-box"> | ||||||
|  |         {{ partial "icon.html" "info" }} | ||||||
|  |         {{ if gt (len $series) 1 }} | ||||||
|  |             This post is part of multiple series: | ||||||
|  |         {{ else }} | ||||||
|  |             This post is part of a series: | ||||||
|  |         {{ end }} | ||||||
|  |  | ||||||
|  |         {{ delimit $series ", " }} | ||||||
|  |     </div> | ||||||
|  | {{ end }} | ||||||
							
								
								
									
										55
									
								
								layouts/partials/share.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								layouts/partials/share.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | <div class="share-buttons"> | ||||||
|  |     {{ if .Site.Params.shareButtons.twitter }} | ||||||
|  |         <a class="twitter-share" | ||||||
|  |            target="_blank" | ||||||
|  |            rel="noopener" | ||||||
|  |            onclick="share_event('Twitter');" | ||||||
|  |            href="https://twitter.com/intent/tweet?url={{ .Permalink }}&text={{ .Title }}&via=bbaovanc"> | ||||||
|  |             {{- partial "icon.html" "twitter" -}} | ||||||
|  |         </a> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.shareButtons.facebook }} | ||||||
|  |         <a class="facebook-share" | ||||||
|  |            target="_blank" | ||||||
|  |            rel="noopener" | ||||||
|  |            onclick="share_event('Facebook');" | ||||||
|  |            href="https://www.facebook.com/sharer.php?u={{ .Permalink }}"> | ||||||
|  |             {{- partial "icon.html" "facebook" -}} | ||||||
|  |         </a> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.shareButtons.linkedin }} | ||||||
|  |         <a class="linkedin-share" | ||||||
|  |            target="_blank" | ||||||
|  |            rel="noopener" | ||||||
|  |            onclick="share_event('LinkedIn');" | ||||||
|  |            href="https://www.linkedin.com/sharing/share-offsite/?url={{ .Permalink }}"> | ||||||
|  |             {{- partial "icon.html" "linkedin" -}} | ||||||
|  |         </a> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if .Site.Params.shareButtons.reddit }} | ||||||
|  |         <a class="reddit-share" | ||||||
|  |            target="_blank" | ||||||
|  |            rel="noopener" | ||||||
|  |            onclick="share_event('Reddit');" | ||||||
|  |            href="https://reddit.com/submit?url={{ .Permalink }}&title={{ .Title }}"> | ||||||
|  |             {{- partial "icon.html" "reddit" -}} | ||||||
|  |         </a> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{/* Telegram icon doesn't have `viewbox` set, which breaks the sizing. | ||||||
|  |             https://stackoverflow.com/q/72073399/19003757 | ||||||
|  |             https://github.com/michaelampr/jam/issues/39 | ||||||
|  |     {{ if .Site.Params.shareButtons.telegram }} | ||||||
|  |         <a class="telegram-share" | ||||||
|  |            target="_blank" | ||||||
|  |            rel="noopener" | ||||||
|  |            onclick="share_event('Telegram');" | ||||||
|  |            href="https://t.me/share/url?url={{ .Permalink }}&text={{ .Title }}"> | ||||||
|  |             {{- partial "icon.html" "telegram" -}} | ||||||
|  |         </a> | ||||||
|  |     {{ end }} | ||||||
|  |     */}} | ||||||
|  | </div> | ||||||
| @@ -13,7 +13,9 @@ | |||||||
|             {{ if or ($.HasMenuCurrent .Menu .) ($.IsMenuCurrent .Menu .) }} |             {{ if or ($.HasMenuCurrent .Menu .) ($.IsMenuCurrent .Menu .) }} | ||||||
|                 {{ $isActive = true }} |                 {{ $isActive = true }} | ||||||
|             {{ end }} |             {{ end }} | ||||||
|             <a class="navbar-item{{ if $isActive }} active{{ end }}" href="{{ .URL }}">{{ .Name }}</a> |             <a class="navbar-item{{ if $isActive }} active{{ end }}" | ||||||
|  |                {{ if strings.HasPrefix .URL "http" }}target="_blank" rel="noopener"{{ end }} | ||||||
|  |                href="{{ .URL }}">{{ .Name }}</a> | ||||||
|         {{ end }} |         {{ end }} | ||||||
|     </nav> |     </nav> | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								layouts/shortcodes/abbr.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								layouts/shortcodes/abbr.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | <abbr title="{{ .Get "title" }}">{{ .Inner }}</abbr> | ||||||
							
								
								
									
										7
									
								
								layouts/shortcodes/see-also.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								layouts/shortcodes/see-also.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | <div class="see-also"> | ||||||
|  |     {{ with .Site.GetPage (.Get 0) }} | ||||||
|  |         <p>{{ i18n "see_also" }} <a href="{{ .Permalink }}">{{ .Title }}</a></p> | ||||||
|  |     {{ else }} | ||||||
|  |         {{ errorf "Page could not be found for see-also shortcode: %s" .Position }} | ||||||
|  |     {{ end }} | ||||||
|  | </div> | ||||||
							
								
								
									
										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 | markdownify }} | ||||||
|  | {{ $new := printf `<table class="%s">` $class }} | ||||||
|  | {{ (replace $htmlTable "<table>" $new) | safeHTML }} | ||||||
		Reference in New Issue
	
	Block a user