Add photoswipe
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
		
							
								
								
									
										31
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,19 +1,14 @@ | ||||
| .PHONY: all css js font update-inter reset-submodules | ||||
| .PHONY: default update update-inter update-photoswipe format | ||||
|  | ||||
| all: css js font reset-submodules | ||||
| default: | ||||
|  | ||||
| css: | ||||
|  | ||||
| js: | ||||
|  | ||||
| font: | ||||
| update: update-inter update-photoswipe format | ||||
|  | ||||
| update-inter: | ||||
| 	@tmp_zip=$$(mktemp) && \ | ||||
| 	tmp_dir=$$(mktemp -d) && \ | ||||
| 	curl -s https://api.github.com/repos/rsms/inter/releases/latest \ | ||||
| 	| grep "browser_download_url.*zip" \ | ||||
| 	| cut -d '"' -f 4 \ | ||||
| 	| jq -r '.assets[] | select(.name | test("\\.zip$$")) | .browser_download_url' \ | ||||
| 	| xargs curl -Ls -o $$tmp_zip && \ | ||||
| 	unzip -q -o $$tmp_zip "web/*" -d $$tmp_dir && \ | ||||
| 	rm -rf static/font/inter && \ | ||||
| @@ -21,5 +16,19 @@ update-inter: | ||||
| 	cp -r $$tmp_dir/web/{InterVariable*.woff2,Inter-*.woff2} static/font/inter && \ | ||||
| 	rm -rf $$tmp_zip $$tmp_dir | ||||
|  | ||||
| reset-submodules: | ||||
| 	git submodule foreach --recursive 'git reset --hard' | ||||
| update-photoswipe: | ||||
| 	@tmp_zip=$$(mktemp) && \ | ||||
| 	tmp_dir=$$(mktemp -d) && \ | ||||
| 	curl -s https://api.github.com/repos/dimsemenov/photoswipe/releases/latest \ | ||||
| 	| jq -r '.zipball_url' \ | ||||
| 	| xargs curl -Ls -o $$tmp_zip && \ | ||||
| 	unzip -q -o $$tmp_zip -d $$tmp_dir && \ | ||||
| 	rm -rf assets/js/photoswipe assets/css/photoswipe && \ | ||||
| 	mkdir -p assets/js/photoswipe assets/css/photoswipe && \ | ||||
| 	cp $$tmp_dir/*PhotoSwipe*/dist/photoswipe-lightbox.esm.js assets/js/photoswipe && \ | ||||
| 	cp $$tmp_dir/*PhotoSwipe*/dist/photoswipe.esm.js assets/js/photoswipe && \ | ||||
| 	cp $$tmp_dir/*PhotoSwipe*/dist/photoswipe.css assets/css/photoswipe && \ | ||||
| 	rm -rf $$tmp_zip $$tmp_dir | ||||
|  | ||||
| format: | ||||
| 	nix fmt | ||||
|   | ||||
							
								
								
									
										417
									
								
								assets/css/photoswipe/photoswipe.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										417
									
								
								assets/css/photoswipe/photoswipe.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,417 @@ | ||||
| /*! PhotoSwipe main CSS by Dmytro Semenov | photoswipe.com */ | ||||
|  | ||||
| .pswp { | ||||
|   --pswp-bg: #000; | ||||
|   --pswp-placeholder-bg: #222; | ||||
|  | ||||
|   --pswp-root-z-index: 100000; | ||||
|  | ||||
|   --pswp-preloader-color: rgba(79, 79, 79, 0.4); | ||||
|   --pswp-preloader-color-secondary: rgba(255, 255, 255, 0.9); | ||||
|  | ||||
|   /* defined via js: | ||||
|   --pswp-transition-duration: 333ms; */ | ||||
|  | ||||
|   --pswp-icon-color: #fff; | ||||
|   --pswp-icon-color-secondary: #4f4f4f; | ||||
|   --pswp-icon-stroke-color: #4f4f4f; | ||||
|   --pswp-icon-stroke-width: 2px; | ||||
|  | ||||
|   --pswp-error-text-color: var(--pswp-icon-color); | ||||
| } | ||||
|  | ||||
| /* | ||||
| 	Styles for basic PhotoSwipe (pswp) functionality (sliding area, open/close transitions) | ||||
| */ | ||||
|  | ||||
| .pswp { | ||||
|   position: fixed; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   z-index: var(--pswp-root-z-index); | ||||
|   display: none; | ||||
|   touch-action: none; | ||||
|   outline: 0; | ||||
|   opacity: 0.003; | ||||
|   contain: layout style size; | ||||
|   -webkit-tap-highlight-color: rgba(0, 0, 0, 0); | ||||
| } | ||||
|  | ||||
| /* Prevents focus outline on the root element, | ||||
|   (it may be focused initially) */ | ||||
| .pswp:focus { | ||||
|   outline: 0; | ||||
| } | ||||
|  | ||||
| .pswp * { | ||||
|   box-sizing: border-box; | ||||
| } | ||||
|  | ||||
| .pswp img { | ||||
|   max-width: none; | ||||
| } | ||||
|  | ||||
| .pswp--open { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| .pswp, | ||||
| .pswp__bg { | ||||
|   transform: translateZ(0); | ||||
|   will-change: opacity; | ||||
| } | ||||
|  | ||||
| .pswp__bg { | ||||
|   opacity: 0.005; | ||||
|   background: var(--pswp-bg); | ||||
| } | ||||
|  | ||||
| .pswp, | ||||
| .pswp__scroll-wrap { | ||||
|   overflow: hidden; | ||||
| } | ||||
|  | ||||
| .pswp__scroll-wrap, | ||||
| .pswp__bg, | ||||
| .pswp__container, | ||||
| .pswp__item, | ||||
| .pswp__content, | ||||
| .pswp__img, | ||||
| .pswp__zoom-wrap { | ||||
|   position: absolute; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
| } | ||||
|  | ||||
| .pswp__img, | ||||
| .pswp__zoom-wrap { | ||||
|   width: auto; | ||||
|   height: auto; | ||||
| } | ||||
|  | ||||
| .pswp--click-to-zoom.pswp--zoom-allowed .pswp__img { | ||||
|   cursor: -webkit-zoom-in; | ||||
|   cursor: -moz-zoom-in; | ||||
|   cursor: zoom-in; | ||||
| } | ||||
|  | ||||
| .pswp--click-to-zoom.pswp--zoomed-in .pswp__img { | ||||
|   cursor: move; | ||||
|   cursor: -webkit-grab; | ||||
|   cursor: -moz-grab; | ||||
|   cursor: grab; | ||||
| } | ||||
|  | ||||
| .pswp--click-to-zoom.pswp--zoomed-in .pswp__img:active { | ||||
|   cursor: -webkit-grabbing; | ||||
|   cursor: -moz-grabbing; | ||||
|   cursor: grabbing; | ||||
| } | ||||
|  | ||||
| /* :active to override grabbing cursor */ | ||||
| .pswp--no-mouse-drag.pswp--zoomed-in .pswp__img, | ||||
| .pswp--no-mouse-drag.pswp--zoomed-in .pswp__img:active, | ||||
| .pswp__img { | ||||
|   cursor: -webkit-zoom-out; | ||||
|   cursor: -moz-zoom-out; | ||||
|   cursor: zoom-out; | ||||
| } | ||||
|  | ||||
| /* Prevent selection and tap highlights */ | ||||
| .pswp__container, | ||||
| .pswp__img, | ||||
| .pswp__button, | ||||
| .pswp__counter { | ||||
|   -webkit-user-select: none; | ||||
|   -moz-user-select: none; | ||||
|   -ms-user-select: none; | ||||
|   user-select: none; | ||||
| } | ||||
|  | ||||
| .pswp__item { | ||||
|   /* z-index for fade transition */ | ||||
|   z-index: 1; | ||||
|   overflow: hidden; | ||||
| } | ||||
|  | ||||
| .pswp__hidden { | ||||
|   display: none !important; | ||||
| } | ||||
|  | ||||
| /* Allow to click through pswp__content element, but not its children */ | ||||
| .pswp__content { | ||||
|   pointer-events: none; | ||||
| } | ||||
| .pswp__content > * { | ||||
|   pointer-events: auto; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
|   PhotoSwipe UI | ||||
|  | ||||
| */ | ||||
|  | ||||
| /* | ||||
| 	Error message appears when image is not loaded | ||||
| 	(JS option errorMsg controls markup) | ||||
| */ | ||||
| .pswp__error-msg-container { | ||||
|   display: grid; | ||||
| } | ||||
| .pswp__error-msg { | ||||
|   margin: auto; | ||||
|   font-size: 1em; | ||||
|   line-height: 1; | ||||
|   color: var(--pswp-error-text-color); | ||||
| } | ||||
|  | ||||
| /* | ||||
| class pswp__hide-on-close is applied to elements that | ||||
| should hide (for example fade out) when PhotoSwipe is closed | ||||
| and show (for example fade in) when PhotoSwipe is opened | ||||
|  */ | ||||
| .pswp .pswp__hide-on-close { | ||||
|   opacity: 0.005; | ||||
|   will-change: opacity; | ||||
|   transition: opacity var(--pswp-transition-duration) | ||||
|     cubic-bezier(0.4, 0, 0.22, 1); | ||||
|   z-index: 10; /* always overlap slide content */ | ||||
|   pointer-events: none; /* hidden elements should not be clickable */ | ||||
| } | ||||
|  | ||||
| /* class pswp--ui-visible is added when opening or closing transition starts */ | ||||
| .pswp--ui-visible .pswp__hide-on-close { | ||||
|   opacity: 1; | ||||
|   pointer-events: auto; | ||||
| } | ||||
|  | ||||
| /* <button> styles, including css reset */ | ||||
| .pswp__button { | ||||
|   position: relative; | ||||
|   display: block; | ||||
|   width: 50px; | ||||
|   height: 60px; | ||||
|   padding: 0; | ||||
|   margin: 0; | ||||
|   overflow: hidden; | ||||
|   cursor: pointer; | ||||
|   background: none; | ||||
|   border: 0; | ||||
|   box-shadow: none; | ||||
|   opacity: 0.85; | ||||
|   -webkit-appearance: none; | ||||
|   -webkit-touch-callout: none; | ||||
| } | ||||
|  | ||||
| .pswp__button:hover, | ||||
| .pswp__button:active, | ||||
| .pswp__button:focus { | ||||
|   transition: none; | ||||
|   padding: 0; | ||||
|   background: none; | ||||
|   border: 0; | ||||
|   box-shadow: none; | ||||
|   opacity: 1; | ||||
| } | ||||
|  | ||||
| .pswp__button:disabled { | ||||
|   opacity: 0.3; | ||||
|   cursor: auto; | ||||
| } | ||||
|  | ||||
| .pswp__icn { | ||||
|   fill: var(--pswp-icon-color); | ||||
|   color: var(--pswp-icon-color-secondary); | ||||
| } | ||||
|  | ||||
| .pswp__icn { | ||||
|   position: absolute; | ||||
|   top: 14px; | ||||
|   left: 9px; | ||||
|   width: 32px; | ||||
|   height: 32px; | ||||
|   overflow: hidden; | ||||
|   pointer-events: none; | ||||
| } | ||||
|  | ||||
| .pswp__icn-shadow { | ||||
|   stroke: var(--pswp-icon-stroke-color); | ||||
|   stroke-width: var(--pswp-icon-stroke-width); | ||||
|   fill: none; | ||||
| } | ||||
|  | ||||
| .pswp__icn:focus { | ||||
|   outline: 0; | ||||
| } | ||||
|  | ||||
| /* | ||||
| 	div element that matches size of large image, | ||||
| 	large image loads on top of it, | ||||
| 	used when msrc is not provided | ||||
| */ | ||||
| div.pswp__img--placeholder, | ||||
| .pswp__img--with-bg { | ||||
|   background: var(--pswp-placeholder-bg); | ||||
| } | ||||
|  | ||||
| .pswp__top-bar { | ||||
|   position: absolute; | ||||
|   left: 0; | ||||
|   top: 0; | ||||
|   width: 100%; | ||||
|   height: 60px; | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   justify-content: flex-end; | ||||
|   z-index: 10; | ||||
|  | ||||
|   /* allow events to pass through top bar itself */ | ||||
|   pointer-events: none !important; | ||||
| } | ||||
| .pswp__top-bar > * { | ||||
|   pointer-events: auto; | ||||
|   /* this makes transition significantly more smooth, | ||||
|      even though inner elements are not animated */ | ||||
|   will-change: opacity; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
|   Close button | ||||
|  | ||||
| */ | ||||
| .pswp__button--close { | ||||
|   margin-right: 6px; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
|   Arrow buttons | ||||
|  | ||||
| */ | ||||
| .pswp__button--arrow { | ||||
|   position: absolute; | ||||
|   top: 0; | ||||
|   width: 75px; | ||||
|   height: 100px; | ||||
|   top: 50%; | ||||
|   margin-top: -50px; | ||||
| } | ||||
|  | ||||
| .pswp__button--arrow:disabled { | ||||
|   display: none; | ||||
|   cursor: default; | ||||
| } | ||||
|  | ||||
| .pswp__button--arrow .pswp__icn { | ||||
|   top: 50%; | ||||
|   margin-top: -30px; | ||||
|   width: 60px; | ||||
|   height: 60px; | ||||
|   background: none; | ||||
|   border-radius: 0; | ||||
| } | ||||
|  | ||||
| .pswp--one-slide .pswp__button--arrow { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /* hide arrows on touch screens */ | ||||
| .pswp--touch .pswp__button--arrow { | ||||
|   visibility: hidden; | ||||
| } | ||||
|  | ||||
| /* show arrows only after mouse was used */ | ||||
| .pswp--has_mouse .pswp__button--arrow { | ||||
|   visibility: visible; | ||||
| } | ||||
|  | ||||
| .pswp__button--arrow--prev { | ||||
|   right: auto; | ||||
|   left: 0px; | ||||
| } | ||||
|  | ||||
| .pswp__button--arrow--next { | ||||
|   right: 0px; | ||||
| } | ||||
| .pswp__button--arrow--next .pswp__icn { | ||||
|   left: auto; | ||||
|   right: 14px; | ||||
|   /* flip horizontally */ | ||||
|   transform: scale(-1, 1); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
|   Zoom button | ||||
|  | ||||
| */ | ||||
| .pswp__button--zoom { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| .pswp--zoom-allowed .pswp__button--zoom { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /* "+" => "-" */ | ||||
| .pswp--zoomed-in .pswp__zoom-icn-bar-v { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
|   Loading indicator | ||||
|  | ||||
| */ | ||||
| .pswp__preloader { | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
|   width: 50px; | ||||
|   height: 60px; | ||||
|   margin-right: auto; | ||||
| } | ||||
|  | ||||
| .pswp__preloader .pswp__icn { | ||||
|   opacity: 0; | ||||
|   transition: opacity 0.2s linear; | ||||
|   animation: pswp-clockwise 600ms linear infinite; | ||||
| } | ||||
|  | ||||
| .pswp__preloader--active .pswp__icn { | ||||
|   opacity: 0.85; | ||||
| } | ||||
|  | ||||
| @keyframes pswp-clockwise { | ||||
|   0% { | ||||
|     transform: rotate(0deg); | ||||
|   } | ||||
|   100% { | ||||
|     transform: rotate(360deg); | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
|   "1 of 10" counter | ||||
|  | ||||
| */ | ||||
| .pswp__counter { | ||||
|   height: 30px; | ||||
|   margin-top: 15px; | ||||
|   margin-inline-start: 20px; | ||||
|   font-size: 14px; | ||||
|   line-height: 30px; | ||||
|   color: var(--pswp-icon-color); | ||||
|   text-shadow: 1px 1px 3px var(--pswp-icon-color-secondary); | ||||
|   opacity: 0.85; | ||||
| } | ||||
|  | ||||
| .pswp--one-slide .pswp__counter { | ||||
|   display: none; | ||||
| } | ||||
							
								
								
									
										10
									
								
								assets/js/photoswipe.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								assets/js/photoswipe.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| import PhotoSwipeLightbox from "js/photoswipe/photoswipe-lightbox.esm.js"; | ||||
|  | ||||
| new PhotoSwipeLightbox({ | ||||
|   gallery: ".gallery", | ||||
|   children: "a", | ||||
|   showAnimationDuration: 300, | ||||
|   hideAnimationDuration: 300, | ||||
|   initialZoomLevel: "fit", | ||||
|   pswpModule: () => import("js/photoswipe/photoswipe.esm.js"), | ||||
| }).init(); | ||||
							
								
								
									
										2075
									
								
								assets/js/photoswipe/photoswipe-lightbox.esm.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2075
									
								
								assets/js/photoswipe/photoswipe-lightbox.esm.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										7335
									
								
								assets/js/photoswipe/photoswipe.esm.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7335
									
								
								assets/js/photoswipe/photoswipe.esm.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -4,6 +4,7 @@ | ||||
|  | ||||
|   img { | ||||
|     width: 100%; | ||||
|     height: auto; | ||||
|     display: block; | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -15,3 +15,5 @@ $width-wide: 75rem; | ||||
| @import "content"; | ||||
| @import "hero"; | ||||
| @import "footer"; | ||||
|  | ||||
| @import "photoswipe"; | ||||
|   | ||||
							
								
								
									
										5
									
								
								assets/sass/photoswipe.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								assets/sass/photoswipe.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| .pswp { | ||||
|   --pswp-bg: var(--background); | ||||
|   --pswp-icon-color: var(--text); | ||||
|   --pswp-icon-color-secondary: var(--text); | ||||
| } | ||||
| @@ -27,6 +27,7 @@ | ||||
|         devShells.${system}.default = pkgs.mkShell { | ||||
|           packages = with pkgs; [ | ||||
|             hugo | ||||
|             jq | ||||
|             unzip | ||||
|           ]; | ||||
|         }; | ||||
|   | ||||
| @@ -19,27 +19,13 @@ | ||||
|  | ||||
|  | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1" /> | ||||
|     <meta name="robots" content="all,follow" /> | ||||
|     <meta name="googlebot" content="index,follow,snippet,archive" /> | ||||
|  | ||||
|     {{ with resources.Get "sass/main.scss" }} | ||||
|       {{ with . | toCSS (dict "targetPath" "css/main.css") | fingerprint }} | ||||
|         <link | ||||
|           rel="stylesheet" | ||||
|           href="{{- .RelPermalink -}}" | ||||
|           integrity="{{- .Data.Integrity -}}" | ||||
|         /> | ||||
|       {{ end }} | ||||
|     {{ end }} | ||||
|  | ||||
|     {{ with .OutputFormats.Get "RSS" }} | ||||
|       {{ printf ` | ||||
|         <link href="%s" rel="%s" type="%s" title="%s" />` .Permalink .Rel .MediaType.Type $.Site.Title | safeHTML | ||||
|       }} | ||||
|     {{ end }} | ||||
|  | ||||
|     {{ partial "opengraph.html" . }} | ||||
|     {{ partial "twitter.html" . }} | ||||
|     {{ partial "head/bots.html" }} | ||||
|     {{ partial "head/rss.html" }} | ||||
|     {{ partial "head/opengraph.html" . }} | ||||
|     {{ partial "head/twitter.html" . }} | ||||
|     {{ partial "head/photoswipe.html" }} | ||||
|     {{ partial "head/styles.html" }} | ||||
|   </head> | ||||
|  | ||||
|   <body> | ||||
|   | ||||
							
								
								
									
										2
									
								
								layouts/partials/head/bots.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								layouts/partials/head/bots.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| <meta name="robots" content="all,follow" /> | ||||
| <meta name="googlebot" content="index,follow,snippet,archive" /> | ||||
							
								
								
									
										17
									
								
								layouts/partials/head/photoswipe.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								layouts/partials/head/photoswipe.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| {{ with resources.Get "css/photoswipe/photoswipe.css" | minify | fingerprint }} | ||||
|   <link | ||||
|     rel="stylesheet" | ||||
|     href="{{- .RelPermalink -}}" | ||||
|     integrity="{{- .Data.Integrity -}}" | ||||
|   /> | ||||
| {{ end }} | ||||
|  | ||||
| {{ $opts := dict "minify" true }} | ||||
| {{ with resources.Get "js/photoswipe.js" | js.Build $opts | minify | fingerprint }} | ||||
|   <script | ||||
|     src="{{ .RelPermalink }}" | ||||
|     integrity="{{ .Data.Integrity }}" | ||||
|     crossorigin="anonymous" | ||||
|     async | ||||
|   ></script> | ||||
| {{ end }} | ||||
							
								
								
									
										5
									
								
								layouts/partials/head/rss.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								layouts/partials/head/rss.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| {{ with .OutputFormats.Get "RSS" }} | ||||
|   {{ printf ` | ||||
|     <link href="%s" rel="%s" type="%s" title="%s" />` .Permalink .Rel .MediaType.Type $.Site.Title | safeHTML | ||||
|   }} | ||||
| {{ end }} | ||||
							
								
								
									
										8
									
								
								layouts/partials/head/styles.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								layouts/partials/head/styles.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| {{ $opts := dict "targetPath" "css/main.css" }} | ||||
| {{ with resources.Get "sass/main.scss" | css.Sass $opts | minify | fingerprint }} | ||||
|   <link | ||||
|     rel="stylesheet" | ||||
|     href="{{- .RelPermalink -}}" | ||||
|     integrity="{{- .Data.Integrity -}}" | ||||
|   /> | ||||
| {{ end }} | ||||
| @@ -1,13 +1,3 @@ | ||||
| {{ with .Params.image }} | ||||
|   {{ $image := $.Resources.GetMatch . }} | ||||
|   {{ with $image }} | ||||
|     {{ $thumb := .Resize "400x" }} | ||||
|     <meta name="twitter:card" content="summary_large_image" /> | ||||
|     <meta name="twitter:image" content="{{- $thumb.Permalink -}}" /> | ||||
|   {{ end }} | ||||
| {{ end }} | ||||
| 
 | ||||
| 
 | ||||
| <meta name="twitter:title" content="{{- .Title -}}" /> | ||||
| <meta | ||||
|   name="twitter:description" | ||||
| @@ -21,3 +11,12 @@ | ||||
|     {{- end -}} | ||||
|   {{- end -}}" | ||||
| /> | ||||
| 
 | ||||
| {{ with .Params.image }} | ||||
|   {{ $image := $.Resources.GetMatch . }} | ||||
|   {{ with $image }} | ||||
|     {{ $thumb := .Resize "400x" }} | ||||
|     <meta name="twitter:card" content="summary_large_image" /> | ||||
|     <meta name="twitter:image" content="{{- $thumb.Permalink -}}" /> | ||||
|   {{ end }} | ||||
| {{ end }} | ||||
| @@ -2,15 +2,28 @@ | ||||
| {{- $caption := .caption -}} | ||||
| {{- $alt := default .caption .alt -}} | ||||
|  | ||||
| {{ if $path }} | ||||
|   <figure class="image"> | ||||
|     <img | ||||
|       src="{{- $path | absURL -}}" | ||||
|       {{ with $caption }}title="{{- . -}}"{{ end }} | ||||
|       {{ with $alt }}alt="{{- . -}}"{{ end }} | ||||
|     /> | ||||
|     {{ with $caption }} | ||||
|       <figcaption>{{ . }}</figcaption> | ||||
|     {{ end }} | ||||
|   </figure> | ||||
| {{ end }} | ||||
| {{- if $path -}} | ||||
|   {{- $isRemote := strings.HasPrefix $path "http" -}} | ||||
|   {{- $image := cond $isRemote (resources.GetRemote $path) (resources.Get $path) -}} | ||||
|  | ||||
|   {{- if $image -}} | ||||
|     <figure class="image gallery"> | ||||
|       <a | ||||
|         href="{{- $image.RelPermalink -}}" | ||||
|         data-pswp-width="{{- $image.Width -}}" | ||||
|         data-pswp-height="{{- $image.Height -}}" | ||||
|       > | ||||
|         <img | ||||
|           src="{{- $image.RelPermalink -}}" | ||||
|           width="{{- $image.Width -}}" | ||||
|           height="{{- $image.Height -}}" | ||||
|           {{ with $caption }}title="{{- . -}}"{{ end }} | ||||
|           {{ with $alt }}alt="{{- . -}}"{{ end }} | ||||
|         /> | ||||
|       </a> | ||||
|       {{ with $caption }} | ||||
|         <figcaption>{{ . }}</figcaption> | ||||
|       {{ end }} | ||||
|     </figure> | ||||
|   {{- end -}} | ||||
| {{- end -}} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user