Compare commits
	
		
			18 Commits
		
	
	
		
			d9dcea0e41
			...
			main
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d313bdcc32 | |||
| 19ce16fabb | |||
| 62882e5943 | |||
| c50910bcec | |||
| e56e1e8e51 | |||
| 3938d190d5 | |||
| e7d8ece65d | |||
| d9a3c4b4a1 | |||
| 8834c6dc21 | |||
| 6353c33ae2 | |||
| 08b8041c43 | |||
| 9905066046 | |||
| 4e37655a16 | |||
| de272212ca | |||
| 8fac4841d4 | |||
| c52639e38f | |||
| 57208ea1c8 | |||
| 53705dcd34 | 
| @@ -4,6 +4,7 @@ import Masonry from "masonry-layout"; | |||||||
| const lightbox = new PhotoSwipeLightbox({ | const lightbox = new PhotoSwipeLightbox({ | ||||||
|   gallery: ".lightbox", |   gallery: ".lightbox", | ||||||
|   children: ".pswp-image", |   children: ".pswp-image", | ||||||
|  |   bgOpacity: 1, | ||||||
|   showAnimationDuration: 300, |   showAnimationDuration: 300, | ||||||
|   hideAnimationDuration: 300, |   hideAnimationDuration: 300, | ||||||
|   initialZoomLevel: "fit", |   initialZoomLevel: "fit", | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								assets/sass/blockquote.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								assets/sass/blockquote.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | blockquote { | ||||||
|  |   border-left: 0.15rem solid | ||||||
|  |     color-mix(in srgb, var(--text) 30%, var(--background)); | ||||||
|  |  | ||||||
|  |   .alert-heading { | ||||||
|  |     font-weight: bold; | ||||||
|  |     margin: 0 0 0.5rem 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .alert-emoji { | ||||||
|  |     margin-right: 0.5rem; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   p { | ||||||
|  |     margin: 0.5rem 0 0.5rem 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   p:last-child { | ||||||
|  |     margin: 0; | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										423
									
								
								assets/sass/code.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										423
									
								
								assets/sass/code.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,423 @@ | |||||||
|  | pre { | ||||||
|  |   color: var(--text); | ||||||
|  |   background-color: var(--background-50); | ||||||
|  |   padding: 1rem; | ||||||
|  |   border-radius: 0.5rem; | ||||||
|  |   overflow-x: auto; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* PreWrapper */ | ||||||
|  | .chroma { | ||||||
|  |   .line.prompt::before { | ||||||
|  |     content: "$ "; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Error */ | ||||||
|  |   .err { | ||||||
|  |     color: var(--accent-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LineLink */ | ||||||
|  |   .lnlinks { | ||||||
|  |     outline: none; | ||||||
|  |     text-decoration: none; | ||||||
|  |     color: inherit; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LineTableTD */ | ||||||
|  |   .lntd { | ||||||
|  |     vertical-align: top; | ||||||
|  |     padding: 0; | ||||||
|  |     margin: 0; | ||||||
|  |     border: 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LineTable */ | ||||||
|  |   .lntable { | ||||||
|  |     border-spacing: 0; | ||||||
|  |     padding: 0; | ||||||
|  |     margin: 0; | ||||||
|  |     border: 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LineHighlight */ | ||||||
|  |   .hl { | ||||||
|  |     background-color: var(--background-100); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LineNumbersTable */ | ||||||
|  |   .lnt { | ||||||
|  |     white-space: pre; | ||||||
|  |     -webkit-user-select: none; | ||||||
|  |     user-select: none; | ||||||
|  |     margin-right: 0.4em; | ||||||
|  |     padding: 0 0.4em 0 0.4em; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LineNumbers */ | ||||||
|  |   .ln { | ||||||
|  |     white-space: pre; | ||||||
|  |     -webkit-user-select: none; | ||||||
|  |     user-select: none; | ||||||
|  |     margin-right: 0.4em; | ||||||
|  |     padding: 0 0.4em 0 0.4em; | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Line */ | ||||||
|  |   .line { | ||||||
|  |     display: flex; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Keyword */ | ||||||
|  |   .k { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* KeywordConstant */ | ||||||
|  |   .kc { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* KeywordDeclaration */ | ||||||
|  |   .kd { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* KeywordNamespace */ | ||||||
|  |   .kn { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* KeywordPseudo */ | ||||||
|  |   .kp { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* KeywordReserved */ | ||||||
|  |   .kr { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* KeywordType */ | ||||||
|  |   .kt { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Name */ | ||||||
|  |   .nc { | ||||||
|  |     color: var(--accent-700); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameConstant */ | ||||||
|  |   .no { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameDecorator */ | ||||||
|  |   .nd { | ||||||
|  |     color: var(--secondary-800); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameEntity */ | ||||||
|  |   .ni { | ||||||
|  |     color: var(--accent-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameException */ | ||||||
|  |   .ne { | ||||||
|  |     color: var(--accent-700); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameLabel */ | ||||||
|  |   .nl { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameNamespace */ | ||||||
|  |   .nn { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameProperty */ | ||||||
|  |   .py { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameTag */ | ||||||
|  |   .nt { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameVariable */ | ||||||
|  |   .nv { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameVariableClass */ | ||||||
|  |   .vc { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameVariableGlobal */ | ||||||
|  |   .vg { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameVariableInstance */ | ||||||
|  |   .vi { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameVariableMagic */ | ||||||
|  |   .vm { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameFunction */ | ||||||
|  |   .nf { | ||||||
|  |     color: var(--secondary-800); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* NameFunctionMagic */ | ||||||
|  |   .fm { | ||||||
|  |     color: var(--secondary-800); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Literal */ | ||||||
|  |   .l { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralDate */ | ||||||
|  |   .ld { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralString */ | ||||||
|  |   .s { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringAffix */ | ||||||
|  |   .sa { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringBacktick */ | ||||||
|  |   .sb { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringChar */ | ||||||
|  |   .sc { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringDelimiter */ | ||||||
|  |   .dl { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringDoc */ | ||||||
|  |   .sd { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringDouble */ | ||||||
|  |   .s2 { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringEscape */ | ||||||
|  |   .se { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringHeredoc */ | ||||||
|  |   .sh { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringInterpol */ | ||||||
|  |   .si { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringOther */ | ||||||
|  |   .sx { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringRegex */ | ||||||
|  |   .sr { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringSingle */ | ||||||
|  |   .s1 { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralStringSymbol */ | ||||||
|  |   .ss { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumber */ | ||||||
|  |   .m { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumberBin */ | ||||||
|  |   .mb { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumberFloat */ | ||||||
|  |   .mf { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumberHex */ | ||||||
|  |   .mh { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumberInteger */ | ||||||
|  |   .mi { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumberIntegerLong */ | ||||||
|  |   .il { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* LiteralNumberOct */ | ||||||
|  |   .mo { | ||||||
|  |     color: var(--primary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Operator */ | ||||||
|  |   .o { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* OperatorWord */ | ||||||
|  |   .ow { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* Comment */ | ||||||
|  |   .c { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* CommentHashbang */ | ||||||
|  |   .ch { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* CommentMultiline */ | ||||||
|  |   .cm { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* CommentSingle */ | ||||||
|  |   .c1 { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* CommentSpecial */ | ||||||
|  |   .cs { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-weight: bold; | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* CommentPreproc */ | ||||||
|  |   .cp { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-weight: bold; | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* CommentPreprocFile */ | ||||||
|  |   .cpf { | ||||||
|  |     color: color-mix(in srgb, var(--text) 50%, var(--background-50)); | ||||||
|  |     font-weight: bold; | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericDeleted */ | ||||||
|  |   .gd { | ||||||
|  |     color: var(--accent-900); | ||||||
|  |     background-color: var(--accent-300); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericEmph */ | ||||||
|  |   .ge { | ||||||
|  |     font-style: italic; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericError */ | ||||||
|  |   .gr { | ||||||
|  |     color: var(--accent-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericHeading */ | ||||||
|  |   .gh { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericInserted */ | ||||||
|  |   .gi { | ||||||
|  |     color: var(--primary-800); | ||||||
|  |     background-color: var(--primary-200); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericOutput */ | ||||||
|  |   .go { | ||||||
|  |     color: color-mix(in srgb, var(--text) 70%, var(--background-50)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericPrompt */ | ||||||
|  |   .gp { | ||||||
|  |     color: color-mix(in srgb, var(--text) 70%, var(--background-50)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericStrong */ | ||||||
|  |   .gs { | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericSubheading */ | ||||||
|  |   .gu { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericTraceback */ | ||||||
|  |   .gt { | ||||||
|  |     color: var(--secondary-700); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* GenericUnderline */ | ||||||
|  |   .gl { | ||||||
|  |     text-decoration: underline; | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -1,143 +1,71 @@ | |||||||
| :root { | // https://www.realtimecolors.com/ | ||||||
|   --text: #050c0e; |  | ||||||
|   --background: #f1f8fa; |  | ||||||
|   --primary: #51a9c3; |  | ||||||
|   --secondary: #d88fb9; |  | ||||||
|   --accent: #ce7f71; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @media (prefers-color-scheme: dark) { | :root { | ||||||
|   :root { |   --text: #0d1416; | ||||||
|     --text: #f0f8fa; |   --background: #fdfdfd; | ||||||
|     --background: #050d0f; |   --primary: #669ca3; | ||||||
|     --primary: #3c94af; |   --secondary: #a5abc9; | ||||||
|     --secondary: #712853; |   --accent: #8d8cba; | ||||||
|     --accent: #8d3e30; |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| :root { | :root { | ||||||
|   --text-50: #ecf6f8; |   --text-50: #eff4f6; | ||||||
|   --text-100: #daecf1; |   --text-100: #dfe9ec; | ||||||
|   --text-200: #b4dae4; |   --text-200: #bfd4d9; | ||||||
|   --text-300: #8fc7d6; |   --text-300: #9fbec6; | ||||||
|   --text-400: #69b4c9; |   --text-400: #7ea8b4; | ||||||
|   --text-500: #44a1bb; |   --text-500: #5e92a1; | ||||||
|   --text-600: #368196; |   --text-600: #4b7581; | ||||||
|   --text-700: #296170; |   --text-700: #395860; | ||||||
|   --text-800: #1b414b; |   --text-800: #263b40; | ||||||
|   --text-900: #0e2025; |   --text-900: #131d20; | ||||||
|   --text-950: #071013; |   --text-950: #090f10; | ||||||
|  |  | ||||||
|   --background-50: #ecf6f8; |   --background-50: #f0f5f5; | ||||||
|   --background-100: #daecf1; |   --background-100: #e0ebeb; | ||||||
|   --background-200: #b4dae4; |   --background-200: #c2d6d6; | ||||||
|   --background-300: #8fc7d6; |   --background-300: #a3c2c2; | ||||||
|   --background-400: #69b4c9; |   --background-400: #85adad; | ||||||
|   --background-500: #44a1bb; |   --background-500: #669999; | ||||||
|   --background-600: #368196; |   --background-600: #527a7a; | ||||||
|   --background-700: #296170; |   --background-700: #3d5c5c; | ||||||
|   --background-800: #1b414b; |   --background-800: #293d3d; | ||||||
|   --background-900: #0e2025; |   --background-900: #141f1f; | ||||||
|   --background-950: #071013; |   --background-950: #0a0f0f; | ||||||
|  |  | ||||||
|   --primary-50: #ecf6f8; |   --primary-50: #eff5f5; | ||||||
|   --primary-100: #d9ecf2; |   --primary-100: #dfeaec; | ||||||
|   --primary-200: #b3d9e5; |   --primary-200: #bfd6d9; | ||||||
|   --primary-300: #8dc6d8; |   --primary-300: #9fc1c6; | ||||||
|   --primary-400: #67b4cb; |   --primary-400: #80adb3; | ||||||
|   --primary-500: #41a1be; |   --primary-500: #60989f; | ||||||
|   --primary-600: #348198; |   --primary-600: #4d7a80; | ||||||
|   --primary-700: #276072; |   --primary-700: #395b60; | ||||||
|   --primary-800: #1a404c; |   --primary-800: #263d40; | ||||||
|   --primary-900: #0d2026; |   --primary-900: #131e20; | ||||||
|   --primary-950: #071013; |   --primary-950: #0a0f10; | ||||||
|  |  | ||||||
|   --secondary-50: #f8ecf3; |   --secondary-50: #eff0f5; | ||||||
|   --secondary-100: #f2d9e8; |   --secondary-100: #dfe1ec; | ||||||
|   --secondary-200: #e4b4d0; |   --secondary-200: #bfc4d9; | ||||||
|   --secondary-300: #d78eb9; |   --secondary-300: #9fa6c6; | ||||||
|   --secondary-400: #ca68a1; |   --secondary-400: #8088b3; | ||||||
|   --secondary-500: #bd428a; |   --secondary-500: #606a9f; | ||||||
|   --secondary-600: #97356e; |   --secondary-600: #4d5580; | ||||||
|   --secondary-700: #712853; |   --secondary-700: #394060; | ||||||
|   --secondary-800: #4b1b37; |   --secondary-800: #262b40; | ||||||
|   --secondary-900: #260d1c; |   --secondary-900: #131520; | ||||||
|   --secondary-950: #13070e; |   --secondary-950: #0a0b10; | ||||||
|  |  | ||||||
|   --accent-50: #f8eeec; |   --accent-50: #efeff5; | ||||||
|   --accent-100: #f2ddd9; |   --accent-100: #dfdfec; | ||||||
|   --accent-200: #e5bbb3; |   --accent-200: #c0bfd9; | ||||||
|   --accent-300: #d8988d; |   --accent-300: #a09fc6; | ||||||
|   --accent-400: #cb7667; |   --accent-400: #8080b3; | ||||||
|   --accent-500: #be5441; |   --accent-500: #61609f; | ||||||
|   --accent-600: #984334; |   --accent-600: #4d4d80; | ||||||
|   --accent-700: #723227; |   --accent-700: #3a3960; | ||||||
|   --accent-800: #4c221a; |   --accent-800: #272640; | ||||||
|   --accent-900: #26110d; |   --accent-900: #131320; | ||||||
|   --accent-950: #130807; |   --accent-950: #0a0a10; | ||||||
| } |  | ||||||
|  |  | ||||||
| @media (prefers-color-scheme: dark) { |  | ||||||
|   :root { |  | ||||||
|     --text-50: #061113; |  | ||||||
|     --text-100: #0d2126; |  | ||||||
|     --text-200: #19424d; |  | ||||||
|     --text-300: #266373; |  | ||||||
|     --text-400: #338599; |  | ||||||
|     --text-500: #40a6bf; |  | ||||||
|     --text-600: #66b8cc; |  | ||||||
|     --text-700: #8cc9d9; |  | ||||||
|     --text-800: #b3dbe6; |  | ||||||
|     --text-900: #d9edf2; |  | ||||||
|     --text-950: #ecf6f9; |  | ||||||
|  |  | ||||||
|     --background-50: #061113; |  | ||||||
|     --background-100: #0d2126; |  | ||||||
|     --background-200: #19424d; |  | ||||||
|     --background-300: #266373; |  | ||||||
|     --background-400: #338599; |  | ||||||
|     --background-500: #40a6bf; |  | ||||||
|     --background-600: #66b8cc; |  | ||||||
|     --background-700: #8cc9d9; |  | ||||||
|     --background-800: #b3dbe6; |  | ||||||
|     --background-900: #d9edf2; |  | ||||||
|     --background-950: #ecf6f9; |  | ||||||
|  |  | ||||||
|     --primary-50: #071013; |  | ||||||
|     --primary-100: #0d2026; |  | ||||||
|     --primary-200: #1a404c; |  | ||||||
|     --primary-300: #276072; |  | ||||||
|     --primary-400: #348198; |  | ||||||
|     --primary-500: #41a1be; |  | ||||||
|     --primary-600: #67b4cb; |  | ||||||
|     --primary-700: #8dc6d8; |  | ||||||
|     --primary-800: #b3d9e5; |  | ||||||
|     --primary-900: #d9ecf2; |  | ||||||
|     --primary-950: #ecf6f8; |  | ||||||
|  |  | ||||||
|     --secondary-50: #13070e; |  | ||||||
|     --secondary-100: #260d1c; |  | ||||||
|     --secondary-200: #4b1b37; |  | ||||||
|     --secondary-300: #712853; |  | ||||||
|     --secondary-400: #97356e; |  | ||||||
|     --secondary-500: #bd428a; |  | ||||||
|     --secondary-600: #ca68a1; |  | ||||||
|     --secondary-700: #d78eb9; |  | ||||||
|     --secondary-800: #e4b4d0; |  | ||||||
|     --secondary-900: #f2d9e8; |  | ||||||
|     --secondary-950: #f8ecf3; |  | ||||||
|  |  | ||||||
|     --accent-50: #130807; |  | ||||||
|     --accent-100: #26110d; |  | ||||||
|     --accent-200: #4c221a; |  | ||||||
|     --accent-300: #723227; |  | ||||||
|     --accent-400: #984334; |  | ||||||
|     --accent-500: #be5441; |  | ||||||
|     --accent-600: #cb7667; |  | ||||||
|     --accent-700: #d8988d; |  | ||||||
|     --accent-800: #e5bbb3; |  | ||||||
|     --accent-900: #f2ddd9; |  | ||||||
|     --accent-950: #f8eeec; |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ a { | |||||||
| } | } | ||||||
|  |  | ||||||
| a:hover { | a:hover { | ||||||
|   color: var(--text-700); |   color: var(--text-800); | ||||||
| } | } | ||||||
|  |  | ||||||
| h1, | h1, | ||||||
| @@ -22,14 +22,27 @@ h3, | |||||||
| h4, | h4, | ||||||
| h5, | h5, | ||||||
| h6 { | h6 { | ||||||
|   margin: 0; |  | ||||||
|   font-weight: 500; |   font-weight: 500; | ||||||
|  |   overflow-wrap: break-word; | ||||||
|  |   word-break: break-word; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | hr { | ||||||
|  |   margin: 1rem 0 1rem 0; | ||||||
|  |   border: none; | ||||||
|  |   height: 0.15rem; | ||||||
|  |   background-color: color-mix(in srgb, var(--text) 30%, var(--background)); | ||||||
| } | } | ||||||
|  |  | ||||||
| figure { | figure { | ||||||
|   margin: 0; |   margin: 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | blockquote { | ||||||
|  |   margin: 1rem 0 1rem 0; | ||||||
|  |   padding: 0.5rem 1rem 0.5rem 1rem; | ||||||
|  | } | ||||||
|  |  | ||||||
| body { | body { | ||||||
|   margin: 0.5rem; |   margin: 0.5rem; | ||||||
|   min-height: calc(100vh - 1rem); |   min-height: calc(100vh - 1rem); | ||||||
| @@ -41,3 +54,43 @@ body { | |||||||
|     flex: 1; |     flex: 1; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | p { | ||||||
|  |   margin: 1.5rem 0 1.5rem 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | li { | ||||||
|  |   margin: 0.5rem 0 0.5rem 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | details { | ||||||
|  |   background-color: var(--background-50); | ||||||
|  |   padding: 1rem 1.5rem 1rem 1.5rem; | ||||||
|  |   border-radius: 0.5rem; | ||||||
|  |  | ||||||
|  |   p { | ||||||
|  |     margin: 0.5rem 0 0.5rem 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   summary { | ||||||
|  |     margin: 0.5rem; | ||||||
|  |     font-weight: bold; | ||||||
|  |     display: inline-flex; | ||||||
|  |     align-items: center; | ||||||
|  |     gap: 0.5rem; | ||||||
|  |     cursor: pointer; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   summary::before { | ||||||
|  |     content: ""; | ||||||
|  |     border-width: 0.4rem; | ||||||
|  |     border-style: solid; | ||||||
|  |     border-color: transparent transparent transparent var(--text); | ||||||
|  |     transition: transform 0.3s ease; | ||||||
|  |     transform-origin: 25% 50%; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   &[open] summary::before { | ||||||
|  |     transform: rotate(90deg); | ||||||
|  |   } | ||||||
|  | } | ||||||
|   | |||||||
							
								
								
									
										55
									
								
								assets/sass/details.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								assets/sass/details.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | main.with-details { | ||||||
|  |   max-width: $width-wide; | ||||||
|  |   margin: 0 auto; | ||||||
|  |   padding: 2rem; | ||||||
|  |  | ||||||
|  |   > .content { | ||||||
|  |     width: 100%; | ||||||
|  |     padding: 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   $width-sidebar: ($width-wide - $width-content) / 2 - 2rem; | ||||||
|  |   display: grid; | ||||||
|  |   grid-template-columns: $width-sidebar $width-content $width-sidebar; | ||||||
|  |   column-gap: 2rem; | ||||||
|  |  | ||||||
|  |   .title { | ||||||
|  |     font-size: 1.75rem; | ||||||
|  |     margin: 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .length { | ||||||
|  |     color: color-mix(in srgb, var(--text) 70%, var(--background)); | ||||||
|  |     margin: 0.5rem 0 0.5rem 0; | ||||||
|  |     font-size: 0.8rem; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media (max-width: $width-wide) { | ||||||
|  |   main.with-details { | ||||||
|  |     display: block; | ||||||
|  |     padding: 0; | ||||||
|  |  | ||||||
|  |     > .details { | ||||||
|  |       max-width: $width-content; | ||||||
|  |       margin: 0 auto; | ||||||
|  |       padding: 2rem; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     > .content { | ||||||
|  |       padding: 2rem; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media (max-width: $width-mobile) { | ||||||
|  |   main.with-details { | ||||||
|  |     > .details { | ||||||
|  |       padding: 1rem; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     > .content { | ||||||
|  |       padding: 0 1rem 1rem 1rem; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -13,7 +13,7 @@ | |||||||
|  |  | ||||||
|     font-size: 0.85rem; |     font-size: 0.85rem; | ||||||
|  |  | ||||||
|     color: color-mix(in srgb, var(--text) 30%, var(--background)); |     color: color-mix(in srgb, var(--text) 50%, var(--background)); | ||||||
|  |  | ||||||
|     a { |     a { | ||||||
|       color: inherit; |       color: inherit; | ||||||
| @@ -36,6 +36,7 @@ | |||||||
|         list-style: none; |         list-style: none; | ||||||
|  |  | ||||||
|         li { |         li { | ||||||
|  |           margin: 0; | ||||||
|           font-size: 0.85rem; |           font-size: 0.85rem; | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|   | |||||||
| @@ -3,25 +3,10 @@ | |||||||
|   margin: 0 auto; |   margin: 0 auto; | ||||||
|   padding: 2rem 2rem 0 2rem; |   padding: 2rem 2rem 0 2rem; | ||||||
|  |  | ||||||
|   h1 { |   .title { | ||||||
|  |     margin: 0; | ||||||
|     font-size: 2.5rem; |     font-size: 2.5rem; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   .meta { |  | ||||||
|     font-size: 0.8rem; |  | ||||||
|  |  | ||||||
|     .date { |  | ||||||
|       color: var(--text-600); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     .duration { |  | ||||||
|       color: color-mix(in srgb, var(--text) 50%, var(--background)); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .captioned-image { |  | ||||||
|     padding-top: 1.5rem; |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| .hero + .content { | .hero + .content { | ||||||
| @@ -30,6 +15,6 @@ | |||||||
|  |  | ||||||
| @media (max-width: $width-mobile) { | @media (max-width: $width-mobile) { | ||||||
|   .hero { |   .hero { | ||||||
|     padding: 1rem 1em 0 1rem; |     padding: 1rem 1rem 0 1rem; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ img { | |||||||
|  |  | ||||||
|   figcaption { |   figcaption { | ||||||
|     text-align: center; |     text-align: center; | ||||||
|     padding-top: 0.5rem; |     padding-top: 1rem; | ||||||
|     color: color-mix(in srgb, var(--text) 50%, var(--background)); |     color: color-mix(in srgb, var(--text) 70%, var(--background)); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,86 +1,31 @@ | |||||||
| main.with-meta { |  | ||||||
|   max-width: $width-wide; |  | ||||||
|   margin: 0 auto; |  | ||||||
|   padding: 2rem; |  | ||||||
|  |  | ||||||
|   > .content { |  | ||||||
|     padding: 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   $width-sidebar: ($width-wide - $width-content) / 2 - 2rem; |  | ||||||
|   display: grid; |  | ||||||
|   grid-template-columns: $width-sidebar $width-content $width-sidebar; |  | ||||||
|   column-gap: 2rem; |  | ||||||
|  |  | ||||||
|   h1 { |  | ||||||
|     font-size: 1.75rem; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .length { |  | ||||||
|     color: color-mix(in srgb, var(--text) 50%, var(--background)); |  | ||||||
|     margin: 0.25rem 0; |  | ||||||
|     font-size: 0.8rem; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @media (max-width: $width-wide) { |  | ||||||
|   main.with-meta { |  | ||||||
|     display: block; |  | ||||||
|     padding: 0; |  | ||||||
|  |  | ||||||
|     > .meta { |  | ||||||
|       max-width: $width-content; |  | ||||||
|       margin: 0 auto; |  | ||||||
|       padding: 2rem; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     > .content { |  | ||||||
|       padding: 2rem; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @media (max-width: $width-mobile) { |  | ||||||
|   main.with-meta { |  | ||||||
|     > .meta { |  | ||||||
|       padding: 1rem; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     > .content { |  | ||||||
|       padding: 0 1rem 1rem 1rem; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| .list { | .list { | ||||||
|   .post { |   .post { | ||||||
|     display: block; |     display: block; | ||||||
|     color: inherit; |  | ||||||
|  |     > a { | ||||||
|  |       color: inherit; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     > a:hover { | ||||||
|  |       color: var(--text-800); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     &:not(:first-child) { |     &:not(:first-child) { | ||||||
|       margin-top: 4rem; |       margin: 4rem 0 4rem 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     .title { |     .title { | ||||||
|  |       margin: 0; | ||||||
|       font-size: 2.25rem; |       font-size: 2.25rem; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     .meta { |     .summary { | ||||||
|       font-size: 0.8rem; |       margin: 0.5rem 0 0.5rem 0; | ||||||
|  |  | ||||||
|       .date { |  | ||||||
|         color: var(--text-600); |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       .duration { |  | ||||||
|         color: color-mix(in srgb, var(--text) 50%, var(--background)); |  | ||||||
|       } |  | ||||||
|     } |     } | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .post:hover .title, |     .heading-anchor { | ||||||
|   .post:hover .summary { |       display: none; | ||||||
|     color: var(--text-800); |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -88,7 +33,11 @@ main.with-meta { | |||||||
|   .list { |   .list { | ||||||
|     .post { |     .post { | ||||||
|       &:not(:first-child) { |       &:not(:first-child) { | ||||||
|         margin-top: 2rem; |         margin: 2rem 0 2rem 0; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       .title { | ||||||
|  |         font-size: 1.5rem; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -8,13 +8,19 @@ $width-wide: 75rem; | |||||||
|  |  | ||||||
| @import "heading"; | @import "heading"; | ||||||
| @import "image"; | @import "image"; | ||||||
|  | @import "blockquote"; | ||||||
|  | @import "code"; | ||||||
|  | @import "table"; | ||||||
|  | @import "meta"; | ||||||
|  |  | ||||||
|  | @import "details"; | ||||||
| @import "list"; | @import "list"; | ||||||
| @import "gallery"; | @import "gallery"; | ||||||
|  |  | ||||||
| @import "header"; | @import "header"; | ||||||
| @import "content"; |  | ||||||
| @import "hero"; | @import "hero"; | ||||||
|  | @import "content"; | ||||||
|  | @import "postnav"; | ||||||
| @import "footer"; | @import "footer"; | ||||||
|  |  | ||||||
| @import "photoswipe"; | @import "photoswipe"; | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								assets/sass/meta.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								assets/sass/meta.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | .meta { | ||||||
|  |   margin: 1rem 0 1rem 0; | ||||||
|  |   font-size: 0.8rem; | ||||||
|  |  | ||||||
|  |   .date { | ||||||
|  |     color: var(--text); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .tag { | ||||||
|  |     color: var(--primary-600); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .tag:hover { | ||||||
|  |     color: var(--primary-800); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .duration { | ||||||
|  |     color: color-mix(in srgb, var(--text) 70%, var(--background)); | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -18,13 +18,13 @@ | |||||||
|   position: fixed; |   position: fixed; | ||||||
|   bottom: 0; |   bottom: 0; | ||||||
|   width: 100%; |   width: 100%; | ||||||
|   height: 5rem; |   height: auto; | ||||||
|   padding: 1rem 2rem; |   padding: 1rem 2rem; | ||||||
|   text-align: center; |   text-align: center; | ||||||
|   line-height: 1.5rem; |   line-height: 1.5rem; | ||||||
|  |  | ||||||
|   .meta { |   .meta { | ||||||
|     font-size: 0.7rem; |     margin: 0; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   a { |   a { | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								assets/sass/postnav.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								assets/sass/postnav.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | |||||||
|  | .postnav { | ||||||
|  |   max-width: $width-content; | ||||||
|  |   margin: 0 auto; | ||||||
|  |   padding: 2rem; | ||||||
|  |  | ||||||
|  |   display: flex; | ||||||
|  |   justify-content: space-between; | ||||||
|  |   gap: 1rem; | ||||||
|  |  | ||||||
|  |   a { | ||||||
|  |     flex: 50%; | ||||||
|  |     color: inherit; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   a:hover { | ||||||
|  |     color: var(--text-800); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   p { | ||||||
|  |     margin: 0.5rem 0 0.5rem 0; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .caption { | ||||||
|  |     font-weight: 500; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .title { | ||||||
|  |     overflow-wrap: break-word; | ||||||
|  |     word-break: break-word; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .next { | ||||||
|  |     text-align: right; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .previous .caption::before { | ||||||
|  |     content: "‹ "; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .next .caption::after { | ||||||
|  |     content: " ›"; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .content + .postnav { | ||||||
|  |   padding-top: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media (max-width: $width-mobile) { | ||||||
|  |   .postnav { | ||||||
|  |     padding: 1rem; | ||||||
|  |  | ||||||
|  |     flex-direction: column; | ||||||
|  |  | ||||||
|  |     a { | ||||||
|  |       flex: auto; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								assets/sass/table.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								assets/sass/table.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | .table-wrapper { | ||||||
|  |   overflow-x: auto; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | table { | ||||||
|  |   width: 100%; | ||||||
|  |   border-collapse: collapse; | ||||||
|  |  | ||||||
|  |   thead th { | ||||||
|  |     border-bottom: 0.1rem solid | ||||||
|  |       color-mix(in srgb, var(--text) 20%, var(--background)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   tr + tr td { | ||||||
|  |     border-top: 0.1rem solid | ||||||
|  |       color-mix(in srgb, var(--text) 10%, var(--background)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   th, | ||||||
|  |   td { | ||||||
|  |     padding: 0.5rem; | ||||||
|  |     border-right: 0.1rem solid | ||||||
|  |       color-mix(in srgb, var(--text) 10%, var(--background)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   th:last-child, | ||||||
|  |   td:last-child { | ||||||
|  |     border-right: none; | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										26
									
								
								layouts/_default/_markup/render-blockquote.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								layouts/_default/_markup/render-blockquote.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | {{ $emoji := dict | ||||||
|  |   "caution" ":exclamation:" | ||||||
|  |   "warning" ":warning:" | ||||||
|  |   "important" ":information_source:" | ||||||
|  |   "tip" ":bulb:" | ||||||
|  | }} | ||||||
|  | {{- if eq .Type "alert" -}} | ||||||
|  |   <blockquote class="alert alert-{{ .AlertType }}"> | ||||||
|  |     <p class="alert-heading"> | ||||||
|  |       <span class="alert-emoji"> | ||||||
|  |         {{- transform.Emojify (index $emoji .AlertType) -}} | ||||||
|  |       </span> | ||||||
|  |       {{ if .AlertTitle }} | ||||||
|  |         {{- .AlertTitle -}} | ||||||
|  |       {{ else }} | ||||||
|  |         {{- .AlertType | title -}} | ||||||
|  |       {{ end }} | ||||||
|  |     </p> | ||||||
|  |     {{- .Text -}} | ||||||
|  |   </blockquote> | ||||||
|  | {{- else -}} | ||||||
|  |   <blockquote> | ||||||
|  |     {{- .Text -}} | ||||||
|  |   </blockquote> | ||||||
|  | {{- end -}} | ||||||
|  | {{- /* chomp trailing newline */ -}} | ||||||
							
								
								
									
										4
									
								
								layouts/_default/_markup/render-codeblock-bash.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								layouts/_default/_markup/render-codeblock-bash.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | {{ $result := transform.HighlightCodeBlock . }} | ||||||
|  | {{ $pattern := `(?s)<span class="line"([^>]*)>(\s*<span[^>]*>)?\$ (.*?)(</span>\s*)</span>` }} | ||||||
|  | {{ $processed := replaceRE $pattern `<span class="line prompt"$1>$2$3$4</span>` $result.Wrapped }} | ||||||
|  | {{ $processed | safeHTML }} | ||||||
| @@ -2,3 +2,4 @@ | |||||||
|   {{ .Text | safeHTML }} |   {{ .Text | safeHTML }} | ||||||
|   <a href="#{{- .Anchor | safeURL -}}" class="heading-anchor">#</a> |   <a href="#{{- .Anchor | safeURL -}}" class="heading-anchor">#</a> | ||||||
| </h{{ .Level }}> | </h{{ .Level }}> | ||||||
|  | {{- /* chomp trailing newline */ -}} | ||||||
|   | |||||||
| @@ -1,6 +1,3 @@ | |||||||
| {{ partial "components/image/index.html" (dict | {{ $data := partial "components/image/process.html" (dict "page" .Page "src" .Destination) }} | ||||||
|   "src" .Destination | {{ partial "components/image/index.html" (merge $data (dict "caption" .Text "title" .Title)) }} | ||||||
|   "caption" .Text | {{- /* chomp trailing newline */ -}} | ||||||
|   "alt" .Title |  | ||||||
|   ) |  | ||||||
| }} |  | ||||||
|   | |||||||
| @@ -5,5 +5,6 @@ | |||||||
|     target="_blank" rel="noopener" |     target="_blank" rel="noopener" | ||||||
|   {{ end }} |   {{ end }} | ||||||
| > | > | ||||||
|   {{ .Text | safeHTML }} |   {{- .Text -}} | ||||||
| </a> | </a> | ||||||
|  | {{- /* chomp trailing newline */ -}} | ||||||
|   | |||||||
							
								
								
									
										41
									
								
								layouts/_default/_markup/render-table.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								layouts/_default/_markup/render-table.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | |||||||
|  | <div class="table-wrapper"> | ||||||
|  |   <table | ||||||
|  |     {{- range $k, $v := .Attributes }} | ||||||
|  |       {{- if $v }} | ||||||
|  |         {{- printf " %s=%q" $k $v | safeHTMLAttr }} | ||||||
|  |       {{- end }} | ||||||
|  |     {{- end }} | ||||||
|  |   > | ||||||
|  |     <thead> | ||||||
|  |       {{- range .THead }} | ||||||
|  |         <tr> | ||||||
|  |           {{- range . }} | ||||||
|  |             <th | ||||||
|  |               {{- with .Alignment }} | ||||||
|  |                 {{- printf " style=%q" (printf "text-align: %s" .) | safeHTMLAttr }} | ||||||
|  |               {{- end -}} | ||||||
|  |             > | ||||||
|  |               {{- .Text -}} | ||||||
|  |             </th> | ||||||
|  |           {{- end }} | ||||||
|  |         </tr> | ||||||
|  |       {{- end }} | ||||||
|  |     </thead> | ||||||
|  |     <tbody> | ||||||
|  |       {{- range .TBody }} | ||||||
|  |         <tr> | ||||||
|  |           {{- range . }} | ||||||
|  |             <td | ||||||
|  |               {{- with .Alignment }} | ||||||
|  |                 {{- printf " style=%q" (printf "text-align: %s" .) | safeHTMLAttr }} | ||||||
|  |               {{- end -}} | ||||||
|  |             > | ||||||
|  |               {{- .Text -}} | ||||||
|  |             </td> | ||||||
|  |           {{- end }} | ||||||
|  |         </tr> | ||||||
|  |       {{- end }} | ||||||
|  |     </tbody> | ||||||
|  |   </table> | ||||||
|  | </div> | ||||||
|  | {{- /* chomp trailing newline */ -}} | ||||||
| @@ -1,8 +1,8 @@ | |||||||
| {{ define "main" }} | {{ define "main" }} | ||||||
|   {{ $withMeta := default true .Params.withMeta }} |   {{ $details := default true .Params.details }} | ||||||
|   <main class="{{- if $withMeta -}}with-meta{{- end -}}"> |   <main class="{{- if $details -}}with-details{{- end -}}"> | ||||||
|     {{ if $withMeta }} |     {{ if $details }} | ||||||
|       {{ partial "components/list/meta.html" . }} |       {{ partial "components/list/details.html" . }} | ||||||
|     {{ end }} |     {{ end }} | ||||||
|     <div class="content"> |     <div class="content"> | ||||||
|       {{ partial "posts/list.html" . }} |       {{ partial "posts/list.html" . }} | ||||||
|   | |||||||
| @@ -1,8 +1,13 @@ | |||||||
| {{ define "main" }} | {{ define "main" }} | ||||||
|   <main> |   <main> | ||||||
|     {{ partial "components/hero/default.html" . }} |     {{ partial "components/hero/index.html" . }} | ||||||
|     <div class="content"> |     <div class="content"> | ||||||
|       {{ .Content }} |       {{ .Content }} | ||||||
|  |  | ||||||
|  |       {{ if (default true .Params.comments) }} | ||||||
|  |         {{ partial "comments.html" . }} | ||||||
|  |       {{ end }} | ||||||
|     </div> |     </div> | ||||||
|  |     {{ partial "components/postnav/index.html" . }} | ||||||
|   </main> |   </main> | ||||||
| {{ end }} | {{ end }} | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								layouts/_shortcodes/contents.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								layouts/_shortcodes/contents.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | <details class="toc"> | ||||||
|  |   <summary>Post Contents</summary> | ||||||
|  |   {{ .Page.TableOfContents }} | ||||||
|  | </details> | ||||||
|  | {{- /* chomp trailing newline */ -}} | ||||||
							
								
								
									
										25
									
								
								layouts/_shortcodes/exif-image.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								layouts/_shortcodes/exif-image.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | {{ $src := "" }} | ||||||
|  | {{ if .IsNamedParams }} | ||||||
|  |   {{ $src = .Get "src" }} | ||||||
|  | {{ else }} | ||||||
|  |   {{ $src = .Get 0 }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $title := "" }} | ||||||
|  | {{ if .IsNamedParams }} | ||||||
|  |   {{ $title = .Get "title" }} | ||||||
|  | {{ else }} | ||||||
|  |   {{ $title = .Get 1 }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $alt := "" }} | ||||||
|  | {{ if .IsNamedParams }} | ||||||
|  |   {{ $alt = .Get "alt" }} | ||||||
|  | {{ else }} | ||||||
|  |   {{ $alt = .Get 1 }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $data := partial "components/image/process.html" (dict "page" .Page "src" $src) }} | ||||||
|  | {{ $caption := partial "components/image/exif.html" $data.original }} | ||||||
|  | {{ partial "components/image/index.html" (merge $data (dict "caption" $caption "title" $title "alt" $alt)) }} | ||||||
|  | {{- /* chomp trailing newline */ -}} | ||||||
							
								
								
									
										1
									
								
								layouts/_shortcodes/sub.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								layouts/_shortcodes/sub.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | <sub>{{ .Get 0 | markdownify }}</sub> {{- /* chomp trailing newline */ -}} | ||||||
							
								
								
									
										1
									
								
								layouts/_shortcodes/sup.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								layouts/_shortcodes/sup.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | <sup>{{ .Get 0 | markdownify }}</sup> {{- /* chomp trailing newline */ -}} | ||||||
| @@ -1,10 +1,16 @@ | |||||||
| {{ define "main" }} | {{ define "main" }} | ||||||
|   {{ $withMeta := default true .Params.withMeta }} |   {{ $details := default true .Params.details }} | ||||||
|   <main class="{{- if $withMeta -}}with-meta{{- end -}}"> |   <main class="{{- if $details -}}with-details{{- end -}}"> | ||||||
|     {{ if $withMeta }} |     {{ if $details }} | ||||||
|       {{ partial "components/list/meta.html" . }} |       {{ partial "components/list/details.html" . }} | ||||||
|     {{ end }} |     {{ end }} | ||||||
|     <div class="{{- if $withMeta -}}content{{- else -}}content wide{{- end -}}"> |     <div | ||||||
|  |       class="{{- if $details -}} | ||||||
|  |         content | ||||||
|  |       {{- else -}} | ||||||
|  |         content wide | ||||||
|  |       {{- end -}}" | ||||||
|  |     > | ||||||
|       {{ partial "gallery/list.html" . }} |       {{ partial "gallery/list.html" . }} | ||||||
|     </div> |     </div> | ||||||
|   </main> |   </main> | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								layouts/partials/comments.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								layouts/partials/comments.html
									
									
									
									
									
										Normal file
									
								
							| @@ -1,9 +0,0 @@ | |||||||
| <section class="hero"> |  | ||||||
|   <h1>{{ .Title }}</h1> |  | ||||||
|   <div class="meta"> |  | ||||||
|     <span class="date">{{ .Date | time.Format ":date_medium" }}</span> |  | ||||||
|     · |  | ||||||
|     <span class="duration">{{ printf "%d MIN READ" .ReadingTime }}</span> |  | ||||||
|   </div> |  | ||||||
|   {{ partial "components/image/index.html" .Params.hero }} |  | ||||||
| </section> |  | ||||||
							
								
								
									
										17
									
								
								layouts/partials/components/hero/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								layouts/partials/components/hero/index.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | <section class="hero"> | ||||||
|  |   <h1 class="title">{{ .Title }}</h1> | ||||||
|  |   {{ partial "components/meta/index.html" . }} | ||||||
|  |  | ||||||
|  |   {{ $hero := partial "components/hero/process.html" .Params.hero }} | ||||||
|  |   {{ if $hero.src }} | ||||||
|  |     {{ $data := partial "components/image/process.html" (dict "page" .Page "src" $hero.src) }} | ||||||
|  |  | ||||||
|  |     {{ $final := merge $data $hero }} | ||||||
|  |     {{ if $hero.exif }} | ||||||
|  |       {{ $caption := partial "components/image/exif.html" $data.original }} | ||||||
|  |       {{ $final = merge $final (dict "caption" $caption) }} | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ partial "components/image/index.html" $final }} | ||||||
|  |   {{ end }} | ||||||
|  | </section> | ||||||
							
								
								
									
										17
									
								
								layouts/partials/components/hero/process.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								layouts/partials/components/hero/process.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | {{- $src := "" -}} | ||||||
|  | {{- $caption := "" -}} | ||||||
|  | {{- $title := "" -}} | ||||||
|  | {{- $alt := "" -}} | ||||||
|  | {{- $exif := false -}} | ||||||
|  |  | ||||||
|  | {{- if reflect.IsMap . -}} | ||||||
|  |   {{- $src = .src -}} | ||||||
|  |   {{- $caption = .caption -}} | ||||||
|  |   {{- $title = .title -}} | ||||||
|  |   {{- $alt = .alt -}} | ||||||
|  |   {{- $exif = .exif | default false -}} | ||||||
|  | {{- else -}} | ||||||
|  |   {{- $src = . -}} | ||||||
|  | {{- end -}} | ||||||
|  |  | ||||||
|  | {{- return dict "src" $src "caption" $caption "title" $title "alt" $alt "exif" $exif -}} | ||||||
							
								
								
									
										22
									
								
								layouts/partials/components/image/exif.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								layouts/partials/components/image/exif.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | {{ $exif := .Exif.Tags }} | ||||||
|  |  | ||||||
|  | {{ $make := $exif.Make }} | ||||||
|  | {{ $model := $exif.Model }} | ||||||
|  |  | ||||||
|  | {{ $lensMake := $exif.LensMake }} | ||||||
|  | {{ $lensModel := $exif.LensModel }} | ||||||
|  |  | ||||||
|  | {{ $lens := "" }} | ||||||
|  | {{ if ne $make $lensMake }} | ||||||
|  |   {{ $lens = printf "%s %s" $lensMake $lensModel }} | ||||||
|  | {{ else }} | ||||||
|  |   {{ $lens = $lensModel }} | ||||||
|  | {{ end }} | ||||||
|  |  | ||||||
|  | {{ $focal := printf "%.1f" (float $exif.FocalLength) }} | ||||||
|  | {{ $focal35 := printf "%.1f" (float $exif.FocalLengthIn35mmFormat) }} | ||||||
|  | {{ $shutter := printf "%d" $exif.ExposureTime }} | ||||||
|  | {{ $aperture := printf "%d" $exif.FNumber }} | ||||||
|  | {{ $iso := printf "%d" $exif.ISO }} | ||||||
|  |  | ||||||
|  | {{ return printf "%s %s, %s @ %s mm (%s mm), %s s, f/%s, ISO %s" $make $model $lens $focal $focal35 $shutter $aperture $iso }} | ||||||
| @@ -1,24 +1,26 @@ | |||||||
| {{ $imageData := partial "components/image/reflect.html" . }} | {{- $caption := .caption | default "" -}} | ||||||
| {{- with $imageData.image -}} | {{- $title := .title | default $caption | plainify -}} | ||||||
|   <figure class="captioned-image lightbox"> | {{- $alt := .alt | default $title | plainify -}} | ||||||
|     <a |  | ||||||
|       href="{{- .RelPermalink -}}" |  | ||||||
|       data-pswp-src="{{- .RelPermalink -}}" | <figure class="captioned-image lightbox"> | ||||||
|       data-pswp-width="{{- .Width -}}" |   <a | ||||||
|       data-pswp-height="{{- .Height -}}" |     href="{{- .full.RelPermalink -}}" | ||||||
|       class="pswp-image" |     data-pswp-src="{{- .full.RelPermalink -}}" | ||||||
|     > |     data-pswp-width="{{- .full.Width -}}" | ||||||
|       <img |     data-pswp-height="{{- .full.Height -}}" | ||||||
|         src="{{- .RelPermalink -}}" |     class="pswp-image" | ||||||
|         width="{{- .Width -}}" |   > | ||||||
|         height="{{- .Height -}}" |     <img | ||||||
|         loading="lazy" |       src="{{- .thumb.RelPermalink -}}" | ||||||
|         {{ with $imageData.title }}title="{{- . -}}"{{ end }} |       width="{{- .thumb.Width -}}" | ||||||
|         {{ with $imageData.alt }}alt="{{- . -}}"{{ end }} |       height="{{- .thumb.Height -}}" | ||||||
|       /> |       loading="lazy" | ||||||
|     </a> |       {{ with $title }}title="{{- . -}}"{{ end }} | ||||||
|     {{ with $imageData.caption }} |       {{ with $alt }}alt="{{- . -}}"{{ end }} | ||||||
|       <figcaption>{{ . }}</figcaption> |     /> | ||||||
|     {{ end }} |   </a> | ||||||
|   </figure> |   {{ with $caption }} | ||||||
| {{- end -}} |     <figcaption>{{ . | safeHTML }}</figcaption> | ||||||
|  |   {{ end }} | ||||||
|  | </figure> | ||||||
|   | |||||||
							
								
								
									
										27
									
								
								layouts/partials/components/image/process.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								layouts/partials/components/image/process.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | {{- $page := .page -}} | ||||||
|  | {{- $src := .src -}} | ||||||
|  |  | ||||||
|  | {{- $original := "" -}} | ||||||
|  |  | ||||||
|  | {{- $isRemote := strings.HasPrefix $src "http" -}} | ||||||
|  | {{- if $isRemote -}} | ||||||
|  |   {{- $remote := resources.GetRemote $src -}} | ||||||
|  |   {{- $original = resources.Copy (printf "static/3rd-party/%s" $remote.Name) $remote -}} | ||||||
|  | {{- else -}} | ||||||
|  |   {{- $original = ($page.Resources.Get $src) | default (resources.Get $src) -}} | ||||||
|  | {{- end -}} | ||||||
|  |  | ||||||
|  | {{- $rotate := images.AutoOrient -}} | ||||||
|  |  | ||||||
|  | {{- $processFull := images.Process "webp q90" -}} | ||||||
|  | {{- $full := $original | images.Filter (slice $rotate $processFull) -}} | ||||||
|  |  | ||||||
|  | {{- $processThumb := "" -}} | ||||||
|  | {{- if gt $original.Width 2000 -}} | ||||||
|  |   {{- $processThumb = images.Process "resize 2000x webp q75" -}} | ||||||
|  | {{- else -}} | ||||||
|  |   {{- $processThumb = images.Process "webp q75" -}} | ||||||
|  | {{- end -}} | ||||||
|  | {{- $thumb := $original | images.Filter (slice $rotate $processThumb) -}} | ||||||
|  |  | ||||||
|  | {{- return dict "original" $original "full" $full "thumb" $thumb -}} | ||||||
| @@ -1,31 +0,0 @@ | |||||||
| {{- $input := . -}} |  | ||||||
|  |  | ||||||
| {{- $src := $input -}} |  | ||||||
| {{- $caption := "" -}} |  | ||||||
| {{- $title := "" -}} |  | ||||||
| {{- $alt := "" -}} |  | ||||||
|  |  | ||||||
| {{- if reflect.IsMap $input -}} |  | ||||||
|   {{- $src = $input.src | default "" -}} |  | ||||||
|   {{- $caption = $input.caption | default "" -}} |  | ||||||
|   {{- $title = $input.title | default $caption | default "" -}} |  | ||||||
|   {{- $alt = $input.alt | default $title | default "" -}} |  | ||||||
| {{- end -}} |  | ||||||
|  |  | ||||||
| {{ $result := dict "image" nil "caption" $caption "title" $title "alt" $alt }} |  | ||||||
|  |  | ||||||
| {{- if $src -}} |  | ||||||
|   {{- $isRemote := strings.HasPrefix $src "http" -}} |  | ||||||
|   {{- $image := "" -}} |  | ||||||
|  |  | ||||||
|   {{- if $isRemote -}} |  | ||||||
|     {{- $remote := resources.GetRemote $src -}} |  | ||||||
|     {{- $image = resources.Copy (printf "static/3rd-party/%s" $remote.Name) $remote -}} |  | ||||||
|   {{- else -}} |  | ||||||
|     {{- $image = resources.Get $src -}} |  | ||||||
|   {{- end -}} |  | ||||||
|  |  | ||||||
|   {{- $result = (dict "image" $image "caption" $caption "title" $title "alt" $alt) -}} |  | ||||||
| {{- end -}} |  | ||||||
|  |  | ||||||
| {{- return $result -}} |  | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| <section class="meta"> | <section class="details"> | ||||||
|   <h1>{{ .Page.Title }}</h1> |   <h1 class="title">{{ .Page.Title }}</h1> | ||||||
|   <p class="length">A {{ .Kind }} with {{ len .Pages }} items</p> |   <p class="length">A {{ .Kind }} with {{ len .Pages }} items</p> | ||||||
|   {{ .Content }} |   {{ .Content }} | ||||||
| </section> | </section> | ||||||
							
								
								
									
										22
									
								
								layouts/partials/components/meta/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								layouts/partials/components/meta/index.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | <div class="meta"> | ||||||
|  |   <span class="date">{{ .Date | time.Format ":date_medium" }}</span> | ||||||
|  |  | ||||||
|  |   {{ if eq .Kind "page" }} | ||||||
|  |     {{ range .Params.tags }} | ||||||
|  |       · | ||||||
|  |       <a href="/tags/{{ . | urlize }}" class="tag">{{ . }}</a> | ||||||
|  |     {{ end }} | ||||||
|  |  | ||||||
|  |     {{ if ge .ReadingTime 1 }} | ||||||
|  |       · | ||||||
|  |       <span class="duration"> | ||||||
|  |         {{ printf "%d min. read" .ReadingTime }} | ||||||
|  |       </span> | ||||||
|  |     {{ end }} | ||||||
|  |   {{ else }} | ||||||
|  |     {{ $count := len .Pages }} | ||||||
|  |     <span class="duration"> | ||||||
|  |       {{ printf "%d %s" $count (cond (eq $count 1) "item" "items") }} | ||||||
|  |     </span> | ||||||
|  |   {{ end }} | ||||||
|  | </div> | ||||||
							
								
								
									
										26
									
								
								layouts/partials/components/postnav/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								layouts/partials/components/postnav/index.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | {{ $pages := .CurrentSection.Pages.ByDate.Reverse }} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <div class="postnav"> | ||||||
|  |   {{ with $pages.Prev . }} | ||||||
|  |     {{ if eq .Kind "page" }} | ||||||
|  |       <a href="{{ .RelPermalink }}"> | ||||||
|  |         <div class="previous"> | ||||||
|  |           <p class="caption">Previous Post</p> | ||||||
|  |           <p class="title">{{ .Title }}</p> | ||||||
|  |         </div> | ||||||
|  |       </a> | ||||||
|  |     {{ end }} | ||||||
|  |   {{ end }} | ||||||
|  |  | ||||||
|  |   {{ with $pages.Next . }} | ||||||
|  |     {{ if eq .Kind "page" }} | ||||||
|  |       <a href="{{ .RelPermalink }}"> | ||||||
|  |         <div class="next"> | ||||||
|  |           <p class="caption">Next Post</p> | ||||||
|  |           <p class="title">{{ .Title }}</p> | ||||||
|  |         </div> | ||||||
|  |       </a> | ||||||
|  |     {{ end }} | ||||||
|  |   {{ end }} | ||||||
|  | </div> | ||||||
| @@ -2,34 +2,36 @@ | |||||||
|   <div class="grid-sizer"></div> |   <div class="grid-sizer"></div> | ||||||
|   {{ range sort .Pages "Date" "desc" }} |   {{ range sort .Pages "Date" "desc" }} | ||||||
|     {{ if not .Params.private }} |     {{ if not .Params.private }} | ||||||
|       {{ $page := . }} |       {{ $hero := partial "components/hero/process.html" .Params.hero }} | ||||||
|       {{ $imageData := partial "components/image/reflect.html" .Params.hero }} |       {{ if $hero.src }} | ||||||
|       {{ with $imageData.image }} |         {{ $data := partial "components/image/process.html" (dict "page" . "src" $hero.src) }} | ||||||
|  |  | ||||||
|  |         {{- $caption := .Title -}} | ||||||
|  |         {{- $title := $hero.title | default $caption | plainify -}} | ||||||
|  |         {{- $alt := $hero.alt | default $title | plainify -}} | ||||||
|  |  | ||||||
|  |  | ||||||
|         <div class="image grid-item"> |         <div class="image grid-item"> | ||||||
|           <a |           <a | ||||||
|             href="{{- $page.RelPermalink -}}" |             href="{{- .RelPermalink -}}" | ||||||
|             data-pswp-src="{{- .RelPermalink -}}" |             data-pswp-src="{{- $data.full.RelPermalink -}}" | ||||||
|             data-pswp-width="{{- .Width -}}" |             data-pswp-width="{{- $data.full.Width -}}" | ||||||
|             data-pswp-height="{{- .Height -}}" |             data-pswp-height="{{- $data.full.Height -}}" | ||||||
|             class="pswp-image" |             class="pswp-image" | ||||||
|           > |           > | ||||||
|             <img |             <img | ||||||
|               src="{{- .RelPermalink -}}" |               src="{{- $data.thumb.RelPermalink -}}" | ||||||
|               width="{{- .Width -}}" |               width="{{- $data.thumb.Width -}}" | ||||||
|               height="{{- .Height -}}" |               height="{{- $data.thumb.Height -}}" | ||||||
|               loading="lazy" |               loading="lazy" | ||||||
|               {{ with $imageData.title }}title="{{- . -}}"{{ end }} |               {{ with $title }}title="{{- . -}}"{{ end }} | ||||||
|               {{ with $imageData.alt }}alt="{{- . -}}"{{ end }} |               {{ with $alt }}alt="{{- . -}}"{{ end }} | ||||||
|             /> |             /> | ||||||
|           </a> |           </a> | ||||||
|           <div class="pswp-caption-content"> |           <div class="pswp-caption-content"> | ||||||
|             <div> |             <div> | ||||||
|               {{ upper $page.Title }} |               <a href="{{- .RelPermalink -}}">{{ $caption }}</a> | ||||||
|               <div class="meta"> |               {{ partial "components/meta/index.html" . }} | ||||||
|                 {{ $page.Date | time.Format ":date_medium" }} |  | ||||||
|                 · |  | ||||||
|                 <a href="{{- $page.RelPermalink -}}">View Post</a> |  | ||||||
|               </div> |  | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|   | |||||||
| @@ -1,15 +1,13 @@ | |||||||
| <div class="list"> | <div class="list"> | ||||||
|   {{ range sort .Pages "Date" "desc" }} |   {{ range sort .Pages "Date" "desc" }} | ||||||
|     {{ if not .Params.private }} |     {{ if not .Params.private }} | ||||||
|       <a href="{{- .RelPermalink -}}" class="post"> |       <div class="post"> | ||||||
|         <h1 class="title">{{ .Title }}</h1> |         <a href="{{- .RelPermalink -}}"> | ||||||
|         <div class="summary">{{ .Summary }}</div> |           <h1 class="title">{{ .Title }}</h1> | ||||||
|         <div class="meta"> |           <div class="summary">{{ .Summary | plainify }}</div> | ||||||
|           <span class="date">{{ .Date | time.Format ":date_medium" }}</span> |         </a> | ||||||
|           · |         {{ partial "components/meta/index.html" . }} | ||||||
|           <span class="duration">{{ printf "%d MIN READ" .ReadingTime }}</span> |       </div> | ||||||
|         </div> |  | ||||||
|       </a> |  | ||||||
|     {{ end }} |     {{ end }} | ||||||
|   {{ end }} |   {{ end }} | ||||||
| </div> | </div> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user