mirror of
				https://github.com/BBaoVanC/bobatheme.git
				synced 2025-10-22 14:03:30 -05:00 
			
		
		
		
	Compare commits
	
		
			29 Commits
		
	
	
		
			breadcrumb
			...
			ac580e1995
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| ac580e1995 | |||
| cee1cd3a82 | |||
| 3fae019148 | |||
| 8ef1e3840a | |||
| 629b3758b9 | |||
| 9412906b4f | |||
| f8cfad647f | |||
| b200623dca | |||
| 80f5994d96 | |||
| 342710a755 | |||
| 8eb642dbc8 | |||
| a4be8b395b | |||
| 47d6d02186 | |||
| a26ea62b60 | |||
| 7cff045cb3 | |||
| 9f080377e7 | |||
| fb40c8a4c3 | |||
| 0c248a4ca5 | |||
| 56d8a07893 | |||
| 8aab2ca693 | |||
| e46288dc45 | |||
| 637ffc12f5 | |||
| 2a40664bb6 | |||
| e34d2109ec | |||
| 54f89dad51 | |||
| 04b5017279 | |||
| a65a435b1d | |||
| 73dc916d5a | |||
| e8be3ae45b | 
| @@ -46,6 +46,7 @@ | ||||
|   --text-gray-1: #919191; /* lch(60, 0, X) */ | ||||
|  | ||||
|   --link-0: #3a94fb; /* lch(60, 60, 270) */ | ||||
|   --link-1: #4ea1ff; /* lch(65, 60, 270) -- out of sRGB */ | ||||
|  | ||||
|   --figure-border: #1f5593; /* lch(35, 40, 270) */ | ||||
|  | ||||
| @@ -116,6 +117,23 @@ | ||||
|  | ||||
|  | ||||
|  | ||||
| /* Fonts */ | ||||
| @font-face { | ||||
|   /*font-family: Jost;*/ | ||||
|   font-family: sans-serif; | ||||
|   font-display: swap; | ||||
|   font-style: normal; | ||||
|   src: url("/font/jost/Jost-VariableFont_wght.woff2") format("woff2"); | ||||
| } | ||||
| @font-face { | ||||
|   /*font-family: JetBrainsMono;*/ | ||||
|   font-family: monospace; | ||||
|   font-display: swap; | ||||
|   src: url("/font/jetbrainsmono/JetBrainsMono_wght.woff2") format("woff2"); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /* Post layout (in list pages) */ | ||||
| .list-page-content { | ||||
|   display: flex; | ||||
| @@ -123,8 +141,8 @@ | ||||
|   gap: 40px; | ||||
| } | ||||
|  | ||||
| .page-list ul, | ||||
| .series-taxonomy ul { | ||||
| .page-list, | ||||
| .series-taxonomy-list { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   list-style: none; | ||||
| @@ -132,12 +150,13 @@ | ||||
|   gap: 40px; | ||||
| } | ||||
|  | ||||
| .series-taxonomy ul { | ||||
| .series-taxonomy-list { | ||||
|   gap: 80px; | ||||
| } | ||||
|  | ||||
| .page-list li, | ||||
| .series-taxonomy li { | ||||
| .page-list .post, | ||||
| .series-taxonomy-list .series-taxonomy, | ||||
| .series-taxonomy .post { | ||||
|   padding-top: 8px; | ||||
|   padding-left: 24px; | ||||
|   padding-right: 24px; | ||||
| @@ -158,6 +177,11 @@ | ||||
|   margin-bottom: 10px; | ||||
| } | ||||
|  | ||||
| .post-title h1, | ||||
| .author-name h1 { | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
| .post-title a, | ||||
| .author-name a { | ||||
|   color: inherit; | ||||
| @@ -172,7 +196,7 @@ | ||||
|  | ||||
| .post-metadata, | ||||
| .author-metadata { | ||||
|   margin-bottom: 15px; | ||||
|   margin-bottom: 24px; | ||||
| } | ||||
|  | ||||
| .categories, | ||||
| @@ -206,7 +230,7 @@ | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
| .taxonomy-list ul { | ||||
| .taxonomy-list { | ||||
|   list-style: none; | ||||
|   padding: 0; | ||||
|   display: flex; | ||||
| @@ -214,7 +238,7 @@ | ||||
|   gap: 10px; | ||||
| } | ||||
|  | ||||
| .taxonomy-list li { | ||||
| .taxonomy-list .taxonomy-term { | ||||
|   background-color: var(--background-1); | ||||
|   color: var(--text-1); | ||||
|   padding: 8px 12px; | ||||
| @@ -230,7 +254,7 @@ | ||||
| } | ||||
|  | ||||
| @media (max-width: 480px) { | ||||
|   .taxonomy-list li { | ||||
|   .taxonomy-list .taxonomy-term { | ||||
|     flex-direction: column; | ||||
|     gap: 4px; | ||||
|   } | ||||
| @@ -244,7 +268,7 @@ | ||||
|  | ||||
|  | ||||
| /* Series list format */ | ||||
| .series-pages ul { | ||||
| .series-page-list { | ||||
|   display: flex; | ||||
|   gap: 10px; | ||||
|   flex-flow: row wrap; | ||||
| @@ -255,7 +279,7 @@ | ||||
|   border-radius: 16px; | ||||
| } | ||||
|  | ||||
| .series-pages li { | ||||
| .series-page-list .post { | ||||
|   flex: 1; | ||||
|   min-width: 49%; | ||||
| } | ||||
| @@ -266,7 +290,7 @@ | ||||
| .sections { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   gap: 40px; | ||||
|   gap: 10px; | ||||
| } | ||||
|  | ||||
| .section { | ||||
| @@ -304,13 +328,15 @@ | ||||
|  | ||||
|  | ||||
| /* Header formatting (website title and article section headers) */ | ||||
| h1.header { | ||||
|   font-size: 1.5em; | ||||
| .header { | ||||
|   margin: 16px 0; | ||||
| } | ||||
|  | ||||
| .header a, | ||||
| .section-header a { | ||||
|   color: inherit; | ||||
|   font-size: 1.5em; | ||||
|   font-weight: bold; | ||||
| } | ||||
|  | ||||
| .section-header-link svg { | ||||
| @@ -347,6 +373,7 @@ h1.header { | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /* Related posts */ | ||||
| .full-width-page-list { | ||||
|   /* make left/right 0 margin so it takes up full width */ | ||||
| @@ -359,16 +386,16 @@ h1.header { | ||||
|   margin-right: 20px; | ||||
| } | ||||
|  | ||||
| .full-width-page-list li { | ||||
| .full-width-page-list .post { | ||||
|   min-width: 300px; | ||||
|   max-width: 300px; | ||||
|  | ||||
| } | ||||
|  | ||||
| .full-width-page-list li:first-child { | ||||
| .full-width-page-list .post:first-child { | ||||
|   margin-left: 20px; | ||||
| } | ||||
| .full-width-page-list li:last-child { | ||||
| .full-width-page-list .post:last-child { | ||||
|   margin-right: 20px; | ||||
| } | ||||
|  | ||||
| @@ -393,7 +420,7 @@ h1.header { | ||||
|   } | ||||
| } | ||||
|  | ||||
| .full-width-page-list .page-list ul { | ||||
| .full-width-page-list .page-list { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   gap: 20px; | ||||
| @@ -401,6 +428,7 @@ h1.header { | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /* Social media share buttons */ | ||||
| .share-buttons { | ||||
|   background: var(--background-1); | ||||
| @@ -413,16 +441,15 @@ h1.header { | ||||
|   justify-content: center; | ||||
| } | ||||
|  | ||||
| .share-buttons button, | ||||
| .share-buttons a { | ||||
|   background-color: var(--background-2); | ||||
|   color: var(--text-2); | ||||
|   padding: 4px; | ||||
|   border-radius: 8px; | ||||
| } | ||||
|  | ||||
| .share-buttons button { | ||||
|   border: none; | ||||
| .share-buttons a:hover { | ||||
|   background-color: var(--background-3); | ||||
|   color: var(--text-3); | ||||
| } | ||||
|  | ||||
| .share-buttons svg { | ||||
| @@ -439,6 +466,7 @@ h1.header { | ||||
| */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /* See also formating */ | ||||
| .see-also { | ||||
|   background-color: var(--background-1); | ||||
| @@ -453,6 +481,7 @@ h1.header { | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /* Back to top */ | ||||
| #back-to-top { | ||||
|   position: fixed; | ||||
| @@ -558,7 +587,9 @@ html { | ||||
| body { | ||||
|   background-color: var(--background-0); | ||||
|   color: var(--text-0); | ||||
|   font-family: "Open Sans", "Noto Sans", sans-serif; | ||||
|   /*font-family: "Jost", "Open Sans", "Noto Sans", sans-serif;*/ | ||||
|   font-family: sans-serif; | ||||
|   font-size: 16px; | ||||
|   margin: 20px; | ||||
|   max-width: 720px; | ||||
|   overflow-wrap: break-word; | ||||
| @@ -571,6 +602,7 @@ body { | ||||
| } | ||||
|  | ||||
| footer { | ||||
|   margin-top: 20px; | ||||
|   text-align: center; | ||||
| } | ||||
|  | ||||
| @@ -618,12 +650,21 @@ a:hover { | ||||
| blockquote { | ||||
|   border-left: 5px solid var(--background-2); | ||||
|   padding-left: 15px; | ||||
|   margin-left: 0; | ||||
| } | ||||
|  | ||||
| hr { | ||||
|   border: 1px solid var(--background-3); | ||||
| } | ||||
|  | ||||
| @media (min-width: 720px) { | ||||
|   .full-width-hr { | ||||
|     /* see also: the related-posts section too */ | ||||
|     margin-left: calc(-100vw / 2 + 760px / 2); | ||||
|     margin-right: calc(-100vw / 2 + 760px / 2); | ||||
|   } | ||||
| } | ||||
|  | ||||
| table.markdown { | ||||
|   border-collapse: collapse; | ||||
|   border: 2px solid var(--text-1); | ||||
| @@ -648,6 +689,13 @@ table.markdown { | ||||
|   color: var(--text-1); | ||||
| } | ||||
|  | ||||
| :target { | ||||
|   animation: target-fade 10s ease-out; | ||||
| } | ||||
| @keyframes target-fade { | ||||
|     0% { background-color: var(--background-yellow-2); } | ||||
| } | ||||
|  | ||||
| * { | ||||
|   box-sizing: border-box; | ||||
| } | ||||
| @@ -655,14 +703,53 @@ table.markdown { | ||||
|  | ||||
|  | ||||
| /* Code blocks */ | ||||
| .highlight { | ||||
| .code-block { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   margin: 16px 0; | ||||
|   background-color: var(--background-1); | ||||
|   border-radius: 8px; | ||||
| } | ||||
| .code-block > .code-header { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   justify-content: space-between; | ||||
|   background-color: var(--background-2); | ||||
|   padding: 4px 8px; | ||||
|   border-top-left-radius: 8px; | ||||
|   border-top-right-radius: 8px; | ||||
| } | ||||
| .code-block > .code-header > .code-type { | ||||
|   border-top-left-radius: 8px; | ||||
|   margin: auto 0; | ||||
| } | ||||
| /* TODO: make the code copy button prettier */ | ||||
| .code-block > .code-header > .code-copy-button { | ||||
|   color: var(--link-1); | ||||
| } | ||||
| .code-block > .code-header > .code-copy-button:hover { | ||||
|   cursor: pointer; | ||||
| } | ||||
| .code-block > .highlight { | ||||
|   margin: 8px 4px; | ||||
| } | ||||
|  | ||||
| .highlight > pre { | ||||
|   padding: 12px 8px; | ||||
| .highlight > .chroma { | ||||
|   overflow: auto; | ||||
| } | ||||
| .chroma { | ||||
|   /* the syntax highlight CSS adds a border */ | ||||
|   background-color: transparent !important; | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
| .chroma .gp { | ||||
|   /* Generic Prompt symbol */ | ||||
|   user-select: none; | ||||
|   -webkit-user-select: none; | ||||
|   -moz-user-select: none; | ||||
|   -ms-user-select: none; | ||||
| } | ||||
|  | ||||
| :not(pre) > code { | ||||
|   background-color: var(--background-2); | ||||
| @@ -674,6 +761,12 @@ table.markdown { | ||||
|   overflow-wrap: break-word; | ||||
| } | ||||
|  | ||||
| .code-block > .code-header > .code-type, | ||||
| pre, | ||||
| code { | ||||
|   /*font-family: JetBrainsMono;*/ | ||||
|   font-size: 12px; | ||||
| } | ||||
| code { | ||||
|   border-radius: 5px; | ||||
| } | ||||
| @@ -790,7 +883,7 @@ li.disabled > .page-link:hover { | ||||
|  | ||||
|  | ||||
| /* Breadcrumb navigation */ | ||||
| .breadcrumb { | ||||
| .breadcrumb ul { | ||||
|   margin: 30px 0 20px; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,14 +1,21 @@ | ||||
| /* tango style */ | ||||
|  | ||||
| @media print, (prefers-color-scheme: light) { | ||||
|   .chroma { | ||||
|     color: black; | ||||
|   } | ||||
|  | ||||
| /* Background */ .bg { background-color: #f8f8f8 } | ||||
| /* PreWrapper */ .chroma { background-color: #f8f8f8; } | ||||
| /* Other */ .chroma .x { color: #000000 } | ||||
| /* Error */ .chroma .err { color: #a40000 } | ||||
| /* CodeLine */ .chroma .cl {  } | ||||
| /* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; } | ||||
| /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; width: auto; overflow: auto; display: block; } | ||||
| /* LineHighlight */ .chroma .hl { display: block; width: 100%;background-color: #ffffcc } | ||||
| /* LineNumbersTable */ .chroma .lnt { margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f } | ||||
| /* LineNumbers */ .chroma .ln { margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f } | ||||
| /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; } | ||||
| /* LineHighlight */ .chroma .hl { background-color: #ffffcc } | ||||
| /* LineNumbersTable */ .chroma .lnt { white-space: pre; user-select: none; margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f } | ||||
| /* LineNumbers */ .chroma .ln { white-space: pre; user-select: none; margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f } | ||||
| /* Line */ .chroma .line { display: flex; } | ||||
| /* Keyword */ .chroma .k { color: #204a87; font-weight: bold } | ||||
| /* KeywordConstant */ .chroma .kc { color: #204a87; font-weight: bold } | ||||
| /* KeywordDeclaration */ .chroma .kd { color: #204a87; font-weight: bold } | ||||
| @@ -83,6 +90,7 @@ | ||||
| /* GenericTraceback */ .chroma .gt { color: #a40000; font-weight: bold } | ||||
| /* GenericUnderline */ .chroma .gl { color: #000000; text-decoration: underline } | ||||
| /* TextWhitespace */ .chroma .w { color: #f8f8f8; text-decoration: underline } | ||||
|  | ||||
| } | ||||
|  | ||||
| @media (prefers-color-scheme: light) { | ||||
|   | ||||
| @@ -1,11 +1,16 @@ | ||||
| /* Background */ .chroma { color: #d0d0d0; background-color: #202020 } | ||||
| /* native style */ | ||||
|  | ||||
| /* Background */ .bg { color: #d0d0d0; background-color: #202020 } | ||||
| /* PreWrapper */ .chroma { color: #d0d0d0; background-color: #202020; } | ||||
| /* Other */ .chroma .x {  } | ||||
| /* Error */ .chroma .err { color: #a61717; background-color: #e3d2d2 } | ||||
| /* CodeLine */ .chroma .cl {  } | ||||
| /* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; } | ||||
| /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; width: auto; overflow: auto; display: block; } | ||||
| /* LineHighlight */ .chroma .hl { display: block; width: 100%;background-color: #363636 } | ||||
| /* LineNumbersTable */ .chroma .lnt { margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #686868 } | ||||
| /* LineNumbers */ .chroma .ln { margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #686868 } | ||||
| /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; } | ||||
| /* LineHighlight */ .chroma .hl { background-color: #ffffcc } | ||||
| /* LineNumbersTable */ .chroma .lnt { white-space: pre; user-select: none; margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #686868 } | ||||
| /* LineNumbers */ .chroma .ln { white-space: pre; user-select: none; margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #686868 } | ||||
| /* Line */ .chroma .line { display: flex; } | ||||
| /* Keyword */ .chroma .k { color: #6ab825; font-weight: bold } | ||||
| /* KeywordConstant */ .chroma .kc { color: #6ab825; font-weight: bold } | ||||
| /* KeywordDeclaration */ .chroma .kd { color: #6ab825; font-weight: bold } | ||||
|   | ||||
| @@ -1,8 +0,0 @@ | ||||
| const backToTop = document.getElementById("back-to-top"); | ||||
| window.onscroll = function() { | ||||
|     if (document.body.scrollTop > 100 || document.documentElement.scrollTop > 100) { | ||||
|         backToTop.style.display = "block"; | ||||
|     } else { | ||||
|         backToTop.style.display = "none"; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										35
									
								
								assets/js/bobatheme.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								assets/js/bobatheme.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| // back to top | ||||
| const backToTop = document.getElementById("back-to-top"); | ||||
| window.onscroll = function() { | ||||
|     if (document.body.scrollTop > 100 || document.documentElement.scrollTop > 100) { | ||||
|         backToTop.style.display = "block"; | ||||
|     } else { | ||||
|         backToTop.style.display = "none"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| // code block copy to clipboard | ||||
| window.onload = () => { | ||||
|     document.querySelectorAll(".code-block").forEach(codeBlock => { | ||||
|         const button = codeBlock.querySelector(".code-header > .code-copy-button"); | ||||
|  | ||||
|         // lang will not be unset because we default it to text | ||||
|         // clone it so it doesn't change the actual DOM element | ||||
|         const codeElem = codeBlock.querySelector("code[data-lang]").cloneNode(true); | ||||
|         // bashsession: remove command output lines | ||||
|         codeElem.querySelectorAll(".go").forEach(e => e.parentNode.removeChild(e)); | ||||
|         // bashsession: remove prompt symbol | ||||
|         codeElem.querySelectorAll(".gp").forEach(e => e.parentNode.removeChild(e)); | ||||
|         const rawCode = codeElem.innerText; | ||||
|  | ||||
|         const originalCopyText = button.innerHTML; | ||||
|         button.onclick = event => { | ||||
|             navigator.clipboard.writeText(rawCode); | ||||
|             // TODO: maybe we could add a fancier indicator, like a flash or something | ||||
|             event.target.innerHTML = "Copied!"; | ||||
|             setTimeout(() => { | ||||
|                 event.target.innerHTML = originalCopyText; | ||||
|             }, 3000); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| @@ -14,6 +14,9 @@ latest_posts: | ||||
| see_also: | ||||
|   other: "SEE ALSO:" | ||||
|  | ||||
| copy_to_clipboard: | ||||
|   other: "Copy" | ||||
|  | ||||
|  | ||||
| # Meta items | ||||
| long_date: | ||||
|   | ||||
| @@ -14,6 +14,9 @@ latest_posts: | ||||
| see_also: | ||||
|   other: "Véase también:" | ||||
|  | ||||
| copy_to_clipboard: | ||||
|   other: "Copiar" | ||||
|  | ||||
|  | ||||
| # Meta items | ||||
| long_date: | ||||
|   | ||||
							
								
								
									
										15
									
								
								layouts/_default/_markup/render-codeblock.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								layouts/_default/_markup/render-codeblock.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| {{ $type := "text" }} | ||||
| {{ with .Type }} | ||||
|     {{ $type = . }} | ||||
| {{ end }} | ||||
| <div class="code-block"> | ||||
|     <div class="code-header"> | ||||
|         <span class="code-type">{{ $type }}</span> | ||||
|         <a href="javascript:void(0)" class="code-copy-button"> | ||||
|             {{ i18n "copy_to_clipboard" }} | ||||
|         </a> | ||||
|     </div> | ||||
|  | ||||
|     {{/* a div.highlight is already created by highlight function */}} | ||||
|     {{ highlight .Inner $type }} | ||||
| </div> | ||||
| @@ -21,7 +21,6 @@ | ||||
|         </main> | ||||
|  | ||||
|         {{ if or .Site.Copyright .Site.Params.footer }} | ||||
|             <hr> | ||||
|             <footer> | ||||
|                 <small> | ||||
|                     {{ with .Site.Copyright }} | ||||
|   | ||||
| @@ -5,6 +5,10 @@ | ||||
|         {{ partial "rss-link.html" . }} | ||||
|     </h1> | ||||
|  | ||||
|     {{ with .Content }} | ||||
|         {{ . }} | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="list-page-content"> | ||||
|         {{ with .Sections }} | ||||
|             <div class="sections"> | ||||
|   | ||||
| @@ -28,9 +28,9 @@ | ||||
|         </div> | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="post-content"> | ||||
|     <article class="post-content"> | ||||
|         {{ .Content }} | ||||
|     </div> | ||||
|     </article> | ||||
|  | ||||
|     {{ partial "series-box.html" . }} | ||||
|  | ||||
|   | ||||
| @@ -1,23 +1,21 @@ | ||||
| <div class="post"> | ||||
|     <h2 class="post-title"> | ||||
|         {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||
|         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||
|         {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||
|     </h2> | ||||
| <h2 class="post-title"> | ||||
|     {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||
|     <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||
|     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||
| </h2> | ||||
|  | ||||
|     {{ partial "post-metadata/short.html" . }} | ||||
| {{ partial "post-metadata/short.html" . }} | ||||
|  | ||||
|     {{ with .Resources.GetMatch "feature" }} | ||||
|         <div class="post-media"> | ||||
|             {{ partial "figure.html" (dict "src" .) }} | ||||
|         </div> | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="post-description"> | ||||
|         {{ partial "description-or-summary.html" . }} | ||||
| {{ with .Resources.GetMatch "feature" }} | ||||
|     <div class="post-media"> | ||||
|         {{ partial "figure.html" (dict "src" .) }} | ||||
|     </div> | ||||
| {{ end }} | ||||
|  | ||||
|     <div class="readmore"> | ||||
|         <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> | ||||
|     </div> | ||||
| <div class="post-description"> | ||||
|     {{ partial "description-or-summary.html" . }} | ||||
| </div> | ||||
|  | ||||
| <div class="readmore"> | ||||
|     <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> | ||||
| </div> | ||||
|   | ||||
| @@ -1,26 +1,24 @@ | ||||
| <div class="post"> | ||||
|     <h2 class="post-title"> | ||||
|         {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||
|         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||
|         {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||
|     </h2> | ||||
| <h2 class="post-title"> | ||||
|     {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||
|     <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||
|     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||
| </h2> | ||||
|  | ||||
|     {{ partial "post-metadata/series.html" . }} | ||||
| {{ partial "post-metadata/series.html" . }} | ||||
|  | ||||
|     <div class="post-description"> | ||||
|         {{ partial "description-or-summary.html" . }} | ||||
|     </div> | ||||
|  | ||||
|     <div class="series-pages"> | ||||
|         <ul> | ||||
|             {{ $i := 0 }} | ||||
|             {{ $total := len .Data.Pages }} | ||||
|             {{ range .Data.Pages.Reverse }} | ||||
|                 {{ $i = add 1 $i }} | ||||
|                 {{ .Scratch.Set "series_position" $i }} | ||||
|                 {{ .Scratch.Set "series_total" $total }} | ||||
|                 <li>{{ .Render "summary/series_post" }}</li> | ||||
|             {{ end }} | ||||
|         </ul> | ||||
|     </div> | ||||
| <div class="post-description"> | ||||
|     {{ partial "description-or-summary.html" . }} | ||||
| </div> | ||||
|  | ||||
| <div class="series-page-list"> | ||||
|     {{ $i := 0 }} | ||||
|     {{ $total := len .Data.Pages }} | ||||
|     {{ range .Data.Pages.Reverse }} | ||||
|         {{ $i = add 1 $i }} | ||||
|         {{ .Scratch.Set "series_position" $i }} | ||||
|         {{ .Scratch.Set "series_total" $total }} | ||||
|         <article class="post"> | ||||
|             {{ .Render "summary/series_post" }} | ||||
|         </article> | ||||
|     {{ end }} | ||||
| </div> | ||||
|   | ||||
| @@ -1,29 +1,27 @@ | ||||
| <div class="post"> | ||||
|     <div class="post-series-position"> | ||||
|         {{ if .Scratch.Get "series_position" }} | ||||
|             ({{ .Scratch.Get "series_position" }}/{{ .Scratch.Get "series_total" }}) | ||||
|         {{ end }} | ||||
|     </div> | ||||
|  | ||||
|     <h2 class="post-title"> | ||||
|         {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||
|         <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||
|         {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||
|     </h2> | ||||
|  | ||||
|     {{ partial "post-metadata/short.html" . }} | ||||
|  | ||||
|     {{ with .Resources.GetMatch "feature" }} | ||||
|         <div class="post-media"> | ||||
|             {{ partial "figure.html" (dict "src" .) }} | ||||
|         </div> | ||||
| <div class="post-series-position"> | ||||
|     {{ if .Scratch.Get "series_position" }} | ||||
|         ({{ .Scratch.Get "series_position" }}/{{ .Scratch.Get "series_total" }}) | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="post-description"> | ||||
|         {{ partial "description-or-summary.html" . }} | ||||
|     </div> | ||||
|  | ||||
|     <div class="readmore"> | ||||
|         <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> | ||||
|     </div> | ||||
| </div> | ||||
|  | ||||
| <h2 class="post-title"> | ||||
|     {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} | ||||
|     <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> | ||||
|     {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} | ||||
| </h2> | ||||
|  | ||||
| {{ partial "post-metadata/short.html" . }} | ||||
|  | ||||
| {{ with .Resources.GetMatch "feature" }} | ||||
|     <div class="post-media"> | ||||
|         {{ partial "figure.html" (dict "src" .) }} | ||||
|     </div> | ||||
| {{ end }} | ||||
|  | ||||
| <div class="post-description"> | ||||
|     {{ partial "description-or-summary.html" . }} | ||||
| </div> | ||||
|  | ||||
| <div class="readmore"> | ||||
|     <a href="{{ .Permalink }}">{{ i18n "read_more" }} →</a> | ||||
| </div> | ||||
|   | ||||
| @@ -4,13 +4,17 @@ | ||||
|         {{ .Title | markdownify }} | ||||
|     </h1> | ||||
|  | ||||
|     {{ with .Content }} | ||||
|         {{ . }} | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="page-list"> | ||||
|         {{ with .Paginator.Pages }} | ||||
|             <ul> | ||||
|                 {{ range . }} | ||||
|                     <li>{{ .Render "summary/author" }}</li> | ||||
|                 {{ end }} | ||||
|             </ul> | ||||
|             {{ range . }} | ||||
|                 <article class="post"> | ||||
|                     {{ .Render "summary/author" }} | ||||
|                 </article> | ||||
|             {{ end }} | ||||
|         {{ else }} | ||||
|             <div> | ||||
|                 {{ i18n "no_posts" }} | ||||
|   | ||||
| @@ -1,9 +1,11 @@ | ||||
| {{ define "main" }} | ||||
|     <h1> | ||||
|         {{ partial "icon.html" "user-circle" }} | ||||
|         {{ .Title | markdownify }} | ||||
|         {{ partial "rss-link.html" . }} | ||||
|     </h1> | ||||
|     <div class="author-name"> | ||||
|         <h1> | ||||
|             {{ partial "icon.html" "user-circle" }} | ||||
|             {{ .Title | markdownify }} | ||||
|             {{ partial "rss-link.html" . }} | ||||
|         </h1> | ||||
|     </div> | ||||
|  | ||||
|     {{ partial "post-metadata/author.html" . }} | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| {{ define "main" }} | ||||
|     {{ with .Content }} | ||||
|         <div class="homepage-content"> | ||||
|         <article class="homepage-content"> | ||||
|             {{ . }} | ||||
|         </div> | ||||
|         </article> | ||||
|         <hr> | ||||
|     {{ end }} | ||||
| 
 | ||||
| @@ -13,7 +13,7 @@ | ||||
|         <link rel="stylesheet" type="text/css" href="{{ .Permalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> | ||||
|     {{ end }} | ||||
|  | ||||
|     {{ with resources.Get "js/back-to-top.js" | fingerprint "sha512" }} | ||||
|     {{ with resources.Get "js/bobatheme.js" | fingerprint "sha512" }} | ||||
|         <script defer src="{{ .Permalink }}" type="text/javascript" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"></script> | ||||
|     {{ end }} | ||||
|     {{ with resources.Get "js/share-event.js" | fingerprint "sha512" }} | ||||
| @@ -40,7 +40,7 @@ | ||||
|     {{ partial "seo-tags/author.html" . }} | ||||
|  | ||||
|     <meta name="language" content="{{ .Language.Lang }}"> | ||||
|     <meta name="description" content="{{ (partial "seo-tags/description.html" .) | plainify }}"> | ||||
|     <meta name="description" content="{{ (partial "seo-description.html" .) | plainify }}"> | ||||
|  | ||||
|     {{ partial "additional-head.html" . }} | ||||
| </head> | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| <div class="page-list"> | ||||
|     {{ with . }} | ||||
|         <ul> | ||||
|             {{ range . }} | ||||
|                 <li>{{ .Render "summary/post" }}</li> | ||||
|             {{ end }} | ||||
|         </ul> | ||||
|         {{ range . }} | ||||
|             <article class="post"> | ||||
|                 {{ .Render "summary/post" }} | ||||
|             </article> | ||||
|         {{ end }} | ||||
|     {{ else }} | ||||
|         <div> | ||||
|             {{ i18n "no_posts" }} | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| {{ if gt .Paginator.TotalPages 1 }} | ||||
|     <div class="pagination"> | ||||
|     <nav class="pagination"> | ||||
|         {{ template "_internal/pagination.html" . }} | ||||
|     </div> | ||||
|     </nav> | ||||
| {{ end }} | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <meta property="og:title" content="{{ .Title | plainify }}"> | ||||
| <meta property="og:description" content="{{ (partial "seo-tags/description.html" .) | plainify }}"> | ||||
| <meta property="og:description" content="{{ (partial "seo-description.html" .) | plainify }}"> | ||||
| <meta property="og:type" content="{{ if .IsPage }}article{{ else }}website{{ end }}"> | ||||
| <meta property="og:url" content="{{ .Permalink }}"> | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <meta itemprop="name" content="{{ .Title | plainify }}"> | ||||
| <meta itemprop="description" content="{{ (partial "seo-tags/description.html" .) | plainify }}"> | ||||
| <meta itemprop="description" content="{{ (partial "seo-description.html" .) | plainify }}"> | ||||
|  | ||||
| {{ $format := "2006-01-02T15:04:05-07:00" }} | ||||
| {{ with .Date }} | ||||
| @@ -21,6 +21,10 @@ | ||||
|     <meta itemprop="image" content="{{ $featured.Permalink }}"> | ||||
| {{ end }} | ||||
|  | ||||
| {{ with .Params.tags }} | ||||
|     <meta itemprop="keywords" content="{{ delimit . ", " }}"> | ||||
| {{ with (.GetTerms "tags") }} | ||||
|     {{ $tags := slice }} | ||||
|     {{ range . }} | ||||
|         {{ $tags = $tags | append .LinkTitle }} | ||||
|     {{ end }} | ||||
|     <meta itemprop="keywords" content="{{ delimit $tags ", " }}"> | ||||
| {{ end }} | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
| {{ end }} | ||||
|  | ||||
| <meta name="twitter:title" content="{{ .Title | plainify }}"> | ||||
| <meta name="twitter:description" content="{{ (partial "seo-tags/description.html" .) | plainify }}"> | ||||
| <meta name="twitter:description" content="{{ (partial "seo-description.html" .) | plainify }}"> | ||||
|  | ||||
| {{ with .Site.Social.twitter }} | ||||
|     <meta name="twitter:site" content="@{{ . }}"> | ||||
|   | ||||
| @@ -54,9 +54,10 @@ | ||||
|     */}} | ||||
|  | ||||
|     {{ if .Site.Params.shareButtons.print }} | ||||
|         <button class="print-share" | ||||
|         <a class="print-share" | ||||
|            href="javascript:void(0)" | ||||
|            onclick="window.print(); share_event('Print');"> | ||||
|             {{- partial "icon.html" "printer" -}} | ||||
|         </button> | ||||
|         </a> | ||||
|     {{ end }} | ||||
| </div> | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| <h1 class="header"> | ||||
|     <a href="{{ .Site.Home.Permalink | absLangURL }}">{{ .Site.Title | markdownify }}</a> | ||||
| </h1> | ||||
| <header class="header"> | ||||
|     <a href="{{ .Site.Home.Permalink | absLangURL }}"> | ||||
|         {{ .Site.Title | markdownify }} | ||||
|     </a> | ||||
| </header> | ||||
|  | ||||
| <div class="topbar"> | ||||
|     <nav class="navbar" aria-label="{{ i18n "aria_navbar" }}"> | ||||
|   | ||||
| @@ -4,13 +4,17 @@ | ||||
|         {{ .Title | markdownify }} | ||||
|     </h1> | ||||
|  | ||||
|     <div class="series-taxonomy"> | ||||
|     {{ with .Content }} | ||||
|         {{ . }} | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="series-taxonomy-list"> | ||||
|         {{ with .Pages }} | ||||
|             <ul> | ||||
|                 {{ range . }} | ||||
|                     <li>{{ .Render "summary/series" }}</li> | ||||
|                 {{ end }} | ||||
|             </ul> | ||||
|             {{ range . }} | ||||
|                 <article class="series-taxonomy"> | ||||
|                     {{ .Render "summary/series" }} | ||||
|                 </article> | ||||
|             {{ end }} | ||||
|         {{ else }} | ||||
|             <div> | ||||
|                 {{ i18n "no_posts" }} | ||||
|   | ||||
| @@ -1,9 +1,4 @@ | ||||
| {{ $resource := "" }} | ||||
| {{ if .IsNamedParams }} | ||||
|     {{ $resource = $.Page.Resources.GetMatch (.Get "src") }} | ||||
| {{ else }} | ||||
|     {{ $resource = $.Page.Resources.GetMatch (.Get 0) }} | ||||
| {{ end }} | ||||
| {{ $resource := .Page.Resources.GetMatch (.Get "src") }} | ||||
|  | ||||
| {{ $noborder := false }} | ||||
| {{ if .Get "noborder" }} | ||||
|   | ||||
							
								
								
									
										1
									
								
								layouts/shortcodes/full-width-hr.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								layouts/shortcodes/full-width-hr.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| <hr class="full-width-hr"> | ||||
| @@ -9,5 +9,5 @@ | ||||
| {{ end }} | ||||
| 
 | ||||
| <p> | ||||
|     {{ partial "remote_figure.html" (dict "src" (.Get "src") "border" $border "hidecaption" $hidecaption "type" "image" "alt" (.Get "alt")) }} | ||||
|     {{ partial "remote_figure.html" (dict "src" (.Get "src") "border" $border "hidecaption" $hidecaption "type" (.Get "type") "alt" (.Get "alt")) }} | ||||
| </p> | ||||
| @@ -1,13 +0,0 @@ | ||||
| {{ $border := false }} | ||||
| {{ if .Get "border" }} | ||||
|     {{ $border = true }} | ||||
| {{ end }} | ||||
|  | ||||
| {{ $hidecaption := false }} | ||||
| {{ if .Get "hidecaption" }} | ||||
|     {{ $hidecaption = true }} | ||||
| {{ end }} | ||||
|  | ||||
| <p> | ||||
|     {{ partial "remote_figure.html" (dict "src" (.Get "src") "border" $border "hidecaption" $hidecaption "type" "video" "alt" (.Get "alt")) }} | ||||
| </p> | ||||
| @@ -1,33 +1,37 @@ | ||||
| {{ define "main" }} | ||||
|     <h1> | ||||
|         {{ if eq .Data.Singular "tag" }} | ||||
|             {{ partial "icon.html" "tag" }} | ||||
|         {{ else if eq .Data.Singular "category" }} | ||||
|             {{ partial "icon.html" "folder" }} | ||||
|         {{ else }} | ||||
|             {{ partial "icon.html" "filter" }} | ||||
|         {{ end }} | ||||
|     <div class="post-title"> | ||||
|         <h1> | ||||
|             {{ if eq .Data.Singular "tag" }} | ||||
|                 {{ partial "icon.html" "tag" }} | ||||
|             {{ else if eq .Data.Singular "category" }} | ||||
|                 {{ partial "icon.html" "folder" }} | ||||
|             {{ else }} | ||||
|                 {{ partial "icon.html" "filter" }} | ||||
|             {{ end }} | ||||
|  | ||||
|         {{ .Title | markdownify }} | ||||
|     </h1> | ||||
|             {{ .Title | markdownify }} | ||||
|         </h1> | ||||
|     </div> | ||||
|  | ||||
|     {{ with .Content }} | ||||
|         {{ . }} | ||||
|     {{ end }} | ||||
|  | ||||
|     <div class="taxonomy-list"> | ||||
|         {{ with .Data.Terms.Alphabetical }} | ||||
|             <ul> | ||||
|                 {{ range . }} | ||||
|                     {{ with .Page }} | ||||
|                         <li> | ||||
|                             <div class="taxonomy-list-left"> | ||||
|                                 <a href="{{ .Permalink }}"> | ||||
|                                     <p>{{ .Title | markdownify }}</p> | ||||
|                                 </a> | ||||
|                                 {{ partial "post-metadata/taxonomy.html" . }} | ||||
|                             </div> | ||||
|                             {{ partial "description-or-summary.html" . }} | ||||
|                         </li> | ||||
|                     {{ end }} | ||||
|             {{ range . }} | ||||
|                 {{ with .Page }} | ||||
|                     <article class="taxonomy-term"> | ||||
|                         <div class="taxonomy-list-left"> | ||||
|                             <a href="{{ .Permalink }}"> | ||||
|                                 <p>{{ .Title | markdownify }}</p> | ||||
|                             </a> | ||||
|                             {{ partial "post-metadata/taxonomy.html" . }} | ||||
|                         </div> | ||||
|                         {{ partial "description-or-summary.html" . }} | ||||
|                     </article> | ||||
|                 {{ end }} | ||||
|             </ul> | ||||
|             {{ end }} | ||||
|         {{ else }} | ||||
|             <div> | ||||
|                 {{ i18n "no_posts" }} | ||||
|   | ||||
| @@ -1,16 +1,18 @@ | ||||
| {{ define "main" }} | ||||
|     <h1> | ||||
|         {{ if eq .Data.Singular "tag" }} | ||||
|             {{ partial "icon.html" "tag" }} | ||||
|         {{ else if eq .Data.Singular "category" }} | ||||
|             {{ partial "icon.html" "folder" }} | ||||
|         {{ else }} | ||||
|             {{ partial "icon.html" "filter" }} | ||||
|         {{ end }} | ||||
|     <div class="post-title"> | ||||
|         <h1> | ||||
|             {{ if eq .Data.Singular "tag" }} | ||||
|                 {{ partial "icon.html" "tag" }} | ||||
|             {{ else if eq .Data.Singular "category" }} | ||||
|                 {{ partial "icon.html" "folder" }} | ||||
|             {{ else }} | ||||
|                 {{ partial "icon.html" "filter" }} | ||||
|             {{ end }} | ||||
|  | ||||
|         {{ .Title | markdownify }} | ||||
|         {{ partial "rss-link.html" . }} | ||||
|     </h1> | ||||
|             {{ .Title | markdownify }} | ||||
|             {{ partial "rss-link.html" . }} | ||||
|         </h1> | ||||
|     </div> | ||||
|  | ||||
|     {{ partial "post-metadata/taxonomy.html" . }} | ||||
|  | ||||
|   | ||||
							
								
								
									
										10
									
								
								static/font/jetbrainsmono/AUTHORS.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								static/font/jetbrainsmono/AUTHORS.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| # This is the official list of project authors for copyright purposes. | ||||
| # This file is distinct from the CONTRIBUTORS.txt file. | ||||
| # See the latter for an explanation. | ||||
| #  | ||||
| # Names should be added to this file as: | ||||
| # Name or Organization <email address> | ||||
|  | ||||
| JetBrains <> | ||||
| Philipp Nurullin <philipp.nurullin@jetbrains.com> | ||||
| Konstantin Bulenkov <kb@jetbrains.com> | ||||
							
								
								
									
										
											BIN
										
									
								
								static/font/jetbrainsmono/JetBrainsMono-Italic_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/font/jetbrainsmono/JetBrainsMono-Italic_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								static/font/jetbrainsmono/JetBrainsMono_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/font/jetbrainsmono/JetBrainsMono_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										93
									
								
								static/font/jetbrainsmono/OFL.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								static/font/jetbrainsmono/OFL.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| Copyright 2020 The JetBrains Mono Project Authors (https://github.com/JetBrains/JetBrainsMono) | ||||
|  | ||||
| This Font Software is licensed under the SIL Open Font License, Version 1.1. | ||||
| This license is copied below, and is also available with a FAQ at: | ||||
| https://scripts.sil.org/OFL | ||||
|  | ||||
|  | ||||
| ----------------------------------------------------------- | ||||
| SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007 | ||||
| ----------------------------------------------------------- | ||||
|  | ||||
| PREAMBLE | ||||
| The goals of the Open Font License (OFL) are to stimulate worldwide | ||||
| development of collaborative font projects, to support the font creation | ||||
| efforts of academic and linguistic communities, and to provide a free and | ||||
| open framework in which fonts may be shared and improved in partnership | ||||
| with others. | ||||
|  | ||||
| The OFL allows the licensed fonts to be used, studied, modified and | ||||
| redistributed freely as long as they are not sold by themselves. The | ||||
| fonts, including any derivative works, can be bundled, embedded,  | ||||
| redistributed and/or sold with any software provided that any reserved | ||||
| names are not used by derivative works. The fonts and derivatives, | ||||
| however, cannot be released under any other type of license. The | ||||
| requirement for fonts to remain under this license does not apply | ||||
| to any document created using the fonts or their derivatives. | ||||
|  | ||||
| DEFINITIONS | ||||
| "Font Software" refers to the set of files released by the Copyright | ||||
| Holder(s) under this license and clearly marked as such. This may | ||||
| include source files, build scripts and documentation. | ||||
|  | ||||
| "Reserved Font Name" refers to any names specified as such after the | ||||
| copyright statement(s). | ||||
|  | ||||
| "Original Version" refers to the collection of Font Software components as | ||||
| distributed by the Copyright Holder(s). | ||||
|  | ||||
| "Modified Version" refers to any derivative made by adding to, deleting, | ||||
| or substituting -- in part or in whole -- any of the components of the | ||||
| Original Version, by changing formats or by porting the Font Software to a | ||||
| new environment. | ||||
|  | ||||
| "Author" refers to any designer, engineer, programmer, technical | ||||
| writer or other person who contributed to the Font Software. | ||||
|  | ||||
| PERMISSION & CONDITIONS | ||||
| Permission is hereby granted, free of charge, to any person obtaining | ||||
| a copy of the Font Software, to use, study, copy, merge, embed, modify, | ||||
| redistribute, and sell modified and unmodified copies of the Font | ||||
| Software, subject to the following conditions: | ||||
|  | ||||
| 1) Neither the Font Software nor any of its individual components, | ||||
| in Original or Modified Versions, may be sold by itself. | ||||
|  | ||||
| 2) Original or Modified Versions of the Font Software may be bundled, | ||||
| redistributed and/or sold with any software, provided that each copy | ||||
| contains the above copyright notice and this license. These can be | ||||
| included either as stand-alone text files, human-readable headers or | ||||
| in the appropriate machine-readable metadata fields within text or | ||||
| binary files as long as those fields can be easily viewed by the user. | ||||
|  | ||||
| 3) No Modified Version of the Font Software may use the Reserved Font | ||||
| Name(s) unless explicit written permission is granted by the corresponding | ||||
| Copyright Holder. This restriction only applies to the primary font name as | ||||
| presented to the users. | ||||
|  | ||||
| 4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font | ||||
| Software shall not be used to promote, endorse or advertise any | ||||
| Modified Version, except to acknowledge the contribution(s) of the | ||||
| Copyright Holder(s) and the Author(s) or with their explicit written | ||||
| permission. | ||||
|  | ||||
| 5) The Font Software, modified or unmodified, in part or in whole, | ||||
| must be distributed entirely under this license, and must not be | ||||
| distributed under any other license. The requirement for fonts to | ||||
| remain under this license does not apply to any document created | ||||
| using the Font Software. | ||||
|  | ||||
| TERMINATION | ||||
| This license becomes null and void if any of the above conditions are | ||||
| not met. | ||||
|  | ||||
| DISCLAIMER | ||||
| THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
| EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF | ||||
| MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT | ||||
| OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE | ||||
| COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | ||||
| INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL | ||||
| DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM | ||||
| OTHER DEALINGS IN THE FONT SOFTWARE. | ||||
							
								
								
									
										
											BIN
										
									
								
								static/font/jost/Jost-Italic-VariableFont_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/font/jost/Jost-Italic-VariableFont_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								static/font/jost/Jost-VariableFont_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								static/font/jost/Jost-VariableFont_wght.woff2
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										93
									
								
								static/font/jost/OFL.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								static/font/jost/OFL.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| Copyright 2020 The Jost Project Authors (https://github.com/indestructible-type) | ||||
|  | ||||
| This Font Software is licensed under the SIL Open Font License, Version 1.1. | ||||
| This license is copied below, and is also available with a FAQ at: | ||||
| http://scripts.sil.org/OFL | ||||
|  | ||||
|  | ||||
| ----------------------------------------------------------- | ||||
| SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007 | ||||
| ----------------------------------------------------------- | ||||
|  | ||||
| PREAMBLE | ||||
| The goals of the Open Font License (OFL) are to stimulate worldwide | ||||
| development of collaborative font projects, to support the font creation | ||||
| efforts of academic and linguistic communities, and to provide a free and | ||||
| open framework in which fonts may be shared and improved in partnership | ||||
| with others. | ||||
|  | ||||
| The OFL allows the licensed fonts to be used, studied, modified and | ||||
| redistributed freely as long as they are not sold by themselves. The | ||||
| fonts, including any derivative works, can be bundled, embedded,  | ||||
| redistributed and/or sold with any software provided that any reserved | ||||
| names are not used by derivative works. The fonts and derivatives, | ||||
| however, cannot be released under any other type of license. The | ||||
| requirement for fonts to remain under this license does not apply | ||||
| to any document created using the fonts or their derivatives. | ||||
|  | ||||
| DEFINITIONS | ||||
| "Font Software" refers to the set of files released by the Copyright | ||||
| Holder(s) under this license and clearly marked as such. This may | ||||
| include source files, build scripts and documentation. | ||||
|  | ||||
| "Reserved Font Name" refers to any names specified as such after the | ||||
| copyright statement(s). | ||||
|  | ||||
| "Original Version" refers to the collection of Font Software components as | ||||
| distributed by the Copyright Holder(s). | ||||
|  | ||||
| "Modified Version" refers to any derivative made by adding to, deleting, | ||||
| or substituting -- in part or in whole -- any of the components of the | ||||
| Original Version, by changing formats or by porting the Font Software to a | ||||
| new environment. | ||||
|  | ||||
| "Author" refers to any designer, engineer, programmer, technical | ||||
| writer or other person who contributed to the Font Software. | ||||
|  | ||||
| PERMISSION & CONDITIONS | ||||
| Permission is hereby granted, free of charge, to any person obtaining | ||||
| a copy of the Font Software, to use, study, copy, merge, embed, modify, | ||||
| redistribute, and sell modified and unmodified copies of the Font | ||||
| Software, subject to the following conditions: | ||||
|  | ||||
| 1) Neither the Font Software nor any of its individual components, | ||||
| in Original or Modified Versions, may be sold by itself. | ||||
|  | ||||
| 2) Original or Modified Versions of the Font Software may be bundled, | ||||
| redistributed and/or sold with any software, provided that each copy | ||||
| contains the above copyright notice and this license. These can be | ||||
| included either as stand-alone text files, human-readable headers or | ||||
| in the appropriate machine-readable metadata fields within text or | ||||
| binary files as long as those fields can be easily viewed by the user. | ||||
|  | ||||
| 3) No Modified Version of the Font Software may use the Reserved Font | ||||
| Name(s) unless explicit written permission is granted by the corresponding | ||||
| Copyright Holder. This restriction only applies to the primary font name as | ||||
| presented to the users. | ||||
|  | ||||
| 4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font | ||||
| Software shall not be used to promote, endorse or advertise any | ||||
| Modified Version, except to acknowledge the contribution(s) of the | ||||
| Copyright Holder(s) and the Author(s) or with their explicit written | ||||
| permission. | ||||
|  | ||||
| 5) The Font Software, modified or unmodified, in part or in whole, | ||||
| must be distributed entirely under this license, and must not be | ||||
| distributed under any other license. The requirement for fonts to | ||||
| remain under this license does not apply to any document created | ||||
| using the Font Software. | ||||
|  | ||||
| TERMINATION | ||||
| This license becomes null and void if any of the above conditions are | ||||
| not met. | ||||
|  | ||||
| DISCLAIMER | ||||
| THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
| EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF | ||||
| MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT | ||||
| OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE | ||||
| COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | ||||
| INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL | ||||
| DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM | ||||
| OTHER DEALINGS IN THE FONT SOFTWARE. | ||||
							
								
								
									
										81
									
								
								static/font/jost/README.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								static/font/jost/README.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | ||||
| Jost Variable Font | ||||
| ================== | ||||
|  | ||||
| This download contains Jost as both variable fonts and static fonts. | ||||
|  | ||||
| Jost is a variable font with this axis: | ||||
|   wght | ||||
|  | ||||
| This means all the styles are contained in these files: | ||||
|   Jost-VariableFont_wght.ttf | ||||
|   Jost-Italic-VariableFont_wght.ttf | ||||
|  | ||||
| If your app fully supports variable fonts, you can now pick intermediate styles | ||||
| that aren’t available as static fonts. Not all apps support variable fonts, and | ||||
| in those cases you can use the static font files for Jost: | ||||
|   static/Jost-Thin.ttf | ||||
|   static/Jost-ExtraLight.ttf | ||||
|   static/Jost-Light.ttf | ||||
|   static/Jost-Regular.ttf | ||||
|   static/Jost-Medium.ttf | ||||
|   static/Jost-SemiBold.ttf | ||||
|   static/Jost-Bold.ttf | ||||
|   static/Jost-ExtraBold.ttf | ||||
|   static/Jost-Black.ttf | ||||
|   static/Jost-ThinItalic.ttf | ||||
|   static/Jost-ExtraLightItalic.ttf | ||||
|   static/Jost-LightItalic.ttf | ||||
|   static/Jost-Italic.ttf | ||||
|   static/Jost-MediumItalic.ttf | ||||
|   static/Jost-SemiBoldItalic.ttf | ||||
|   static/Jost-BoldItalic.ttf | ||||
|   static/Jost-ExtraBoldItalic.ttf | ||||
|   static/Jost-BlackItalic.ttf | ||||
|  | ||||
| Get started | ||||
| ----------- | ||||
|  | ||||
| 1. Install the font files you want to use | ||||
|  | ||||
| 2. Use your app's font picker to view the font family and all the | ||||
| available styles | ||||
|  | ||||
| Learn more about variable fonts | ||||
| ------------------------------- | ||||
|  | ||||
|   https://developers.google.com/web/fundamentals/design-and-ux/typography/variable-fonts | ||||
|   https://variablefonts.typenetwork.com | ||||
|   https://medium.com/variable-fonts | ||||
|  | ||||
| In desktop apps | ||||
|  | ||||
|   https://theblog.adobe.com/can-variable-fonts-illustrator-cc | ||||
|   https://helpx.adobe.com/nz/photoshop/using/fonts.html#variable_fonts | ||||
|  | ||||
| Online | ||||
|  | ||||
|   https://developers.google.com/fonts/docs/getting_started | ||||
|   https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Fonts/Variable_Fonts_Guide | ||||
|   https://developer.microsoft.com/en-us/microsoft-edge/testdrive/demos/variable-fonts | ||||
|  | ||||
| Installing fonts | ||||
|  | ||||
|   MacOS: https://support.apple.com/en-us/HT201749 | ||||
|   Linux: https://www.google.com/search?q=how+to+install+a+font+on+gnu%2Blinux | ||||
|   Windows: https://support.microsoft.com/en-us/help/314960/how-to-install-or-remove-a-font-in-windows | ||||
|  | ||||
| Android Apps | ||||
|  | ||||
|   https://developers.google.com/fonts/docs/android | ||||
|   https://developer.android.com/guide/topics/ui/look-and-feel/downloadable-fonts | ||||
|  | ||||
| License | ||||
| ------- | ||||
| Please read the full license text (OFL.txt) to understand the permissions, | ||||
| restrictions and requirements for usage, redistribution, and modification. | ||||
|  | ||||
| You can use them in your products & projects – print or digital, | ||||
| commercial or otherwise. | ||||
|  | ||||
| This isn't legal advice, please consider consulting a lawyer and see the full | ||||
| license for all details. | ||||
| @@ -8,7 +8,7 @@ description = "Simple Hugo theme for boba.best and bbaovanc.com" | ||||
| homepage = "https://bbaovanc.com" | ||||
| tags = [] | ||||
| features = [] | ||||
| min_version = "0.80.0" | ||||
| min_version = "0.93.0" | ||||
|  | ||||
| [author] | ||||
|   name = "bbaovanc" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user