Show more of the background images
This commit is contained in:
		
							parent
							
								
									2f9e9a4912
								
							
						
					
					
						commit
						4639935eb8
					
				| @ -2,7 +2,7 @@ | |||||||
| import Html from "./components/Html.astro"; | import Html from "./components/Html.astro"; | ||||||
| import Topbar from "./components/Topbar/Topbar.astro"; | import Topbar from "./components/Topbar/Topbar.astro"; | ||||||
| import Footer from "./components/Footer.astro"; | import Footer from "./components/Footer.astro"; | ||||||
| import type { ParentPage } from "src/shared/payload/payload-sdk"; | import type { ParentPage, PayloadImage } from "src/shared/payload/payload-sdk"; | ||||||
| import AppLayoutBackgroundImg from "./components/AppLayoutBackgroundImg.astro"; | import AppLayoutBackgroundImg from "./components/AppLayoutBackgroundImg.astro"; | ||||||
| import type { ComponentProps } from "astro/types"; | import type { ComponentProps } from "astro/types"; | ||||||
| 
 | 
 | ||||||
| @ -10,17 +10,17 @@ interface Props { | |||||||
|   openGraph?: ComponentProps<typeof Html>["openGraph"]; |   openGraph?: ComponentProps<typeof Html>["openGraph"]; | ||||||
|   parentPages?: ParentPage[]; |   parentPages?: ParentPage[]; | ||||||
|   hideFooterLinks?: boolean; |   hideFooterLinks?: boolean; | ||||||
|   backgroundIllustration?: string | undefined; |   backgroundImage?: PayloadImage | undefined; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const { openGraph, hideFooterLinks = false, parentPages, backgroundIllustration } = Astro.props; | const { openGraph, hideFooterLinks = false, parentPages, backgroundImage } = Astro.props; | ||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| {/* ------------------------------------------- HTML ------------------------------------------- */} | {/* ------------------------------------------- HTML ------------------------------------------- */} | ||||||
| 
 | 
 | ||||||
| <Html openGraph={openGraph}> | <Html openGraph={openGraph}> | ||||||
|   <header> |   <header> | ||||||
|     {backgroundIllustration && <AppLayoutBackgroundImg src={backgroundIllustration} />} |     {backgroundImage && <AppLayoutBackgroundImg img={backgroundImage} />} | ||||||
|     <Topbar parentPages={parentPages} /> |     <Topbar parentPages={parentPages} /> | ||||||
|   </header> |   </header> | ||||||
|   <main><slot /></main> |   <main><slot /></main> | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ import Topbar from "./components/Topbar/Topbar.astro"; | |||||||
| import Footer from "./components/Footer.astro"; | import Footer from "./components/Footer.astro"; | ||||||
| import AppLayoutTitle from "./components/AppLayoutTitle.astro"; | import AppLayoutTitle from "./components/AppLayoutTitle.astro"; | ||||||
| import type { ComponentProps } from "astro/types"; | import type { ComponentProps } from "astro/types"; | ||||||
|  | import type { PayloadImage } from "src/shared/payload/payload-sdk"; | ||||||
| 
 | 
 | ||||||
| interface Props { | interface Props { | ||||||
|   openGraph?: ComponentProps<typeof Html>["openGraph"]; |   openGraph?: ComponentProps<typeof Html>["openGraph"]; | ||||||
| @ -16,7 +17,7 @@ interface Props { | |||||||
|   illustration?: string; |   illustration?: string; | ||||||
|   illustrationSize?: string; |   illustrationSize?: string; | ||||||
|   illustrationPosition?: string; |   illustrationPosition?: string; | ||||||
|   backgroundIllustration?: string | undefined; |   backgroundImage?: PayloadImage | undefined; | ||||||
|   hideFooterLinks?: boolean; |   hideFooterLinks?: boolean; | ||||||
|   hideHomeButton?: boolean; |   hideHomeButton?: boolean; | ||||||
| } | } | ||||||
| @ -28,7 +29,7 @@ const { | |||||||
|   pretitle, |   pretitle, | ||||||
|   description, |   description, | ||||||
|   illustration, |   illustration, | ||||||
|   backgroundIllustration, |   backgroundImage, | ||||||
|   parentPages, |   parentPages, | ||||||
|   illustrationSize = "contain", |   illustrationSize = "contain", | ||||||
|   illustrationPosition = "center", |   illustrationPosition = "center", | ||||||
| @ -41,7 +42,7 @@ const { | |||||||
| 
 | 
 | ||||||
| <Html openGraph={openGraph}> | <Html openGraph={openGraph}> | ||||||
|   <header> |   <header> | ||||||
|     {backgroundIllustration && <AppLayoutBackgroundImg src={backgroundIllustration} />} |     {backgroundImage && <AppLayoutBackgroundImg img={backgroundImage} />} | ||||||
| 
 | 
 | ||||||
|     <Topbar parentPages={parentPages} hideHomeButton={hideHomeButton} /> |     <Topbar parentPages={parentPages} hideHomeButton={hideHomeButton} /> | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -1,24 +1,34 @@ | |||||||
| --- | --- | ||||||
|  | import type { PayloadImage } from "src/shared/payload/payload-sdk"; | ||||||
| import { getRandomId } from "src/utils/random"; | import { getRandomId } from "src/utils/random"; | ||||||
| 
 | 
 | ||||||
| interface Props { | interface Props { | ||||||
|   src: string; |   img: PayloadImage; | ||||||
|   alt?: string; |  | ||||||
|   id?: string; |  | ||||||
|   class?: string; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const { src, alt } = Astro.props; | const { | ||||||
|  |   img: { url, width, height }, | ||||||
|  | } = Astro.props; | ||||||
| const uniqueId = getRandomId(); | const uniqueId = getRandomId(); | ||||||
|  | 
 | ||||||
|  | const style = ` | ||||||
|  | @media (max-aspect-ratio: ${width}/${height}) { | ||||||
|  |   #${uniqueId} { | ||||||
|  |       mask-image: linear-gradient( to bottom, rgba(0 0 0 / 30%) 0%, transparent 100% ); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | `; | ||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| {/* ------------------------------------------- HTML ------------------------------------------- */} | {/* ------------------------------------------- HTML ------------------------------------------- */} | ||||||
| 
 | 
 | ||||||
| <img id={uniqueId} src={src} alt={alt} class="when-no-print when-js" /> | <img id={uniqueId} src={url} class="when-no-print when-js" /> | ||||||
| <img src={src} alt={alt} class="when-no-print when-no-js" /> | <img src={url} class="when-no-print when-no-js" /> | ||||||
| 
 | 
 | ||||||
| {/* ------------------------------------------- CSS -------------------------------------------- */} | {/* ------------------------------------------- CSS -------------------------------------------- */} | ||||||
| 
 | 
 | ||||||
|  | <style set:html={style} is:inline></style> | ||||||
|  | 
 | ||||||
| <style> | <style> | ||||||
|   img { |   img { | ||||||
|     position: absolute; |     position: absolute; | ||||||
| @ -28,25 +38,21 @@ const uniqueId = getRandomId(); | |||||||
|     bottom: 0; |     bottom: 0; | ||||||
| 
 | 
 | ||||||
|     width: 100%; |     width: 100%; | ||||||
|     height: 100vh; |     height: auto; | ||||||
|  |     max-height: 100%; | ||||||
| 
 | 
 | ||||||
|     object-fit: cover; |     object-fit: cover; | ||||||
|     object-position: 50% 0; |     object-position: 50% 0; | ||||||
| 
 | 
 | ||||||
|     z-index: -1; |     z-index: -1; | ||||||
| 
 | 
 | ||||||
|     mask-image: linear-gradient(to bottom, rgba(0 0 0 / 30%) 0%, transparent 100%); |     mask-image: linear-gradient( | ||||||
| 
 |       to bottom, | ||||||
|     @media (min-width: 110vh) { |       rgba(0 0 0 / 30%) 0%, | ||||||
|       mask-image: linear-gradient( |       rgba(0 0 0 / 5%) 100vh, | ||||||
|         to bottom, |       rgba(0 0 0 / 5%) 80%, | ||||||
|         rgba(0 0 0 / 30%) 0%, |       transparent 100% | ||||||
|         rgba(0 0 0 / 5%) 100vh, |     ); | ||||||
|         transparent 100% |  | ||||||
|       ); |  | ||||||
|       height: 100%; |  | ||||||
|       max-height: 100vw; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     user-select: none; |     user-select: none; | ||||||
| 
 | 
 | ||||||
| @ -59,7 +65,7 @@ const uniqueId = getRandomId(); | |||||||
| 
 | 
 | ||||||
| {/* ------------------------------------------- JS --------------------------------------------- */} | {/* ------------------------------------------- JS --------------------------------------------- */} | ||||||
| 
 | 
 | ||||||
| <script define:vars={{ uniqueId }}> | <script define:vars={{ uniqueId }} is:inline> | ||||||
|   const element = document.getElementById(uniqueId); |   const element = document.getElementById(uniqueId); | ||||||
| 
 | 
 | ||||||
|   element.addEventListener("load", () => { |   element.addEventListener("load", () => { | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ const scansFirstImage = scans[0]; | |||||||
|     description: translation.description && formatRichTextToString(translation.description), |     description: translation.description && formatRichTextToString(translation.description), | ||||||
|   }} |   }} | ||||||
|   parentPages={parentPages} |   parentPages={parentPages} | ||||||
|   backgroundIllustration={backgroundImage?.url ?? thumbnail?.url}> |   backgroundImage={backgroundImage ?? thumbnail}> | ||||||
|   <div id="layout"> |   <div id="layout"> | ||||||
|     <div id="left"> |     <div id="left"> | ||||||
|       <AppLayoutTitle |       <AppLayoutTitle | ||||||
|  | |||||||
| @ -14,7 +14,13 @@ const { t, getLocalizedUrl } = await getI18n(Astro.locals.currentLocale); | |||||||
| 
 | 
 | ||||||
| <AppLayout | <AppLayout | ||||||
|   openGraph={{ title: t("home.title") }} |   openGraph={{ title: t("home.title") }} | ||||||
|   backgroundIllustration="/img/background-image.webp" |   backgroundImage={{ | ||||||
|  |     url: "/img/background-image.webp", | ||||||
|  |     filename: "background-image", | ||||||
|  |     height: 2279, | ||||||
|  |     width: 1920, | ||||||
|  |     mimeType: "image/webp", | ||||||
|  |   }} | ||||||
|   hideFooterLinks |   hideFooterLinks | ||||||
|   hideHomeButton> |   hideHomeButton> | ||||||
|   <div id="title" slot="header-title"> |   <div id="title" slot="header-title"> | ||||||
| @ -102,37 +108,40 @@ const { t, getLocalizedUrl } = await getI18n(Astro.locals.currentLocale); | |||||||
|       </a> |       </a> | ||||||
|     </section> |     </section> | ||||||
| 
 | 
 | ||||||
|     <section class="DEV_TODO"> |     <section> | ||||||
|       <h2>{t("home.moreSection.title")}</h2> |       <h2>{t("home.moreSection.title")}</h2> | ||||||
|       <p set:html={t("home.moreSection.description")} /> |       <p set:html={t("home.moreSection.description")} /> | ||||||
|       <div class="grid"> |       <div class="grid"> | ||||||
|         <LinkCard |         <div class="DEV_TODO"> | ||||||
|           icon="material-symbols:calendar-month-outline" |           <LinkCard | ||||||
|           title={t("footer.links.timeline.title")} |             icon="material-symbols:calendar-month-outline" | ||||||
|           subtitle={t("footer.links.timeline.subtitle", { |             title={t("footer.links.timeline.title")} | ||||||
|             eraCount: 8, |             subtitle={t("footer.links.timeline.subtitle", { | ||||||
|             eventCount: 358, |               eraCount: 8, | ||||||
|           })} |               eventCount: 358, | ||||||
|           href={getLocalizedUrl("/timeline")} |             })} | ||||||
|         /> |             href={getLocalizedUrl("/timeline")} | ||||||
|  |           /> | ||||||
|  |           <LinkCard | ||||||
|  |             icon="material-symbols:movie-outline" | ||||||
|  |             title={t("footer.links.videos.title")} | ||||||
|  |             subtitle={t("footer.links.videos.subtitle", { count: 2115 })} | ||||||
|  |             href={getLocalizedUrl("/videos")} | ||||||
|  |           /> | ||||||
|  |           <LinkCard | ||||||
|  |             icon="material-symbols:folder-zip-outline" | ||||||
|  |             title={t("footer.links.webArchives.title")} | ||||||
|  |             subtitle={t("footer.links.webArchives.subtitle", { count: 20 })} | ||||||
|  |             href={getLocalizedUrl("/archives")} | ||||||
|  |           /> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|         <LinkCard |         <LinkCard | ||||||
|           icon="material-symbols:perm-media-outline" |           icon="material-symbols:perm-media-outline" | ||||||
|           title={t("footer.links.gallery.title")} |           title={t("footer.links.gallery.title")} | ||||||
|           subtitle={t("footer.links.gallery.subtitle", { count: 5750 })} |           subtitle={t("footer.links.gallery.subtitle", { count: 5750 })} | ||||||
|           href="https://gallery.accords-library.com/posts" |           href="https://gallery.accords-library.com/posts" | ||||||
|         /> |         /> | ||||||
|         <LinkCard |  | ||||||
|           icon="material-symbols:movie-outline" |  | ||||||
|           title={t("footer.links.videos.title")} |  | ||||||
|           subtitle={t("footer.links.videos.subtitle", { count: 2115 })} |  | ||||||
|           href={getLocalizedUrl("/videos")} |  | ||||||
|         /> |  | ||||||
|         <LinkCard |  | ||||||
|           icon="material-symbols:folder-zip-outline" |  | ||||||
|           title={t("footer.links.webArchives.title")} |  | ||||||
|           subtitle={t("footer.links.webArchives.subtitle", { count: 20 })} |  | ||||||
|           href={getLocalizedUrl("/archives")} |  | ||||||
|         /> |  | ||||||
|       </div> |       </div> | ||||||
|     </section> |     </section> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -26,6 +26,6 @@ const meta = getLocalizedMatch(page.translations); | |||||||
|     thumbnail: page.thumbnail?.url, |     thumbnail: page.thumbnail?.url, | ||||||
|   }} |   }} | ||||||
|   parentPages={page.parentPages} |   parentPages={page.parentPages} | ||||||
|   backgroundIllustration={page.backgroundImage?.url ?? page.thumbnail?.url}> |   backgroundImage={page.backgroundImage ?? page.thumbnail}> | ||||||
|   <Page slug={page.slug} lang={Astro.locals.currentLocale} page={page} /> |   <Page slug={page.slug} lang={Astro.locals.currentLocale} page={page} /> | ||||||
| </AppEmptyLayout> | </AppEmptyLayout> | ||||||
|  | |||||||
| @ -1022,6 +1022,7 @@ export enum Collections { | |||||||
|   Wordings = "wordings", |   Wordings = "wordings", | ||||||
|   Collectibles = "collectibles", |   Collectibles = "collectibles", | ||||||
|   GenericContents = "generic-contents", |   GenericContents = "generic-contents", | ||||||
|  |   BackgroundImages = "background-images", | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export enum CollectionGroups { | export enum CollectionGroups { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 DrMint
						DrMint