make layouts simpler to think about
This commit is contained in:
		| @@ -5,22 +5,25 @@ import BodyConstructor from "../../components/Body" | ||||
| import { pageResources, renderPage } from "../../components/renderPage" | ||||
| import { FullPageLayout } from "../../cfg" | ||||
| import { FilePath, canonicalizeServer } from "../../path" | ||||
| import { defaultContentPageLayout, sharedPageComponents } from "../../../quartz.layout" | ||||
| import { Content } from "../../components" | ||||
|  | ||||
| export const ContentPage: QuartzEmitterPlugin<FullPageLayout> = (opts) => { | ||||
|   if (!opts) { | ||||
|     throw new Error( | ||||
|       "ContentPage must be initialized with options specifiying the components to use", | ||||
|     ) | ||||
| export const ContentPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) => { | ||||
|   const opts: FullPageLayout = { | ||||
|     ...sharedPageComponents, | ||||
|     ...defaultContentPageLayout, | ||||
|     pageBody: Content(), | ||||
|     ...userOpts, | ||||
|   } | ||||
|  | ||||
|   const { head: Head, header, beforeBody, pageBody: Content, left, right, footer: Footer } = opts | ||||
|   const { head: Head, header, beforeBody, pageBody, left, right, footer: Footer } = opts | ||||
|   const Header = HeaderConstructor() | ||||
|   const Body = BodyConstructor() | ||||
|  | ||||
|   return { | ||||
|     name: "ContentPage", | ||||
|     getQuartzComponents() { | ||||
|       return [Head, Header, Body, ...header, ...beforeBody, Content, ...left, ...right, Footer] | ||||
|       return [Head, Header, Body, ...header, ...beforeBody, pageBody, ...left, ...right, Footer] | ||||
|     }, | ||||
|     async emit(ctx, content, resources, emit): Promise<FilePath[]> { | ||||
|       const cfg = ctx.cfg.configuration | ||||
|   | ||||
| @@ -7,20 +7,25 @@ import { ProcessedContent, defaultProcessedContent } from "../vfile" | ||||
| import { FullPageLayout } from "../../cfg" | ||||
| import path from "path" | ||||
| import { CanonicalSlug, FilePath, ServerSlug, canonicalizeServer, joinSegments } from "../../path" | ||||
| import { defaultListPageLayout, sharedPageComponents } from "../../../quartz.layout" | ||||
| import { FolderContent } from "../../components" | ||||
|  | ||||
| export const FolderPage: QuartzEmitterPlugin<FullPageLayout> = (opts) => { | ||||
|   if (!opts) { | ||||
|     throw new Error("ErrorPage must be initialized with options specifiying the components to use") | ||||
| export const FolderPage: QuartzEmitterPlugin<FullPageLayout> = (userOpts) => { | ||||
|   const opts: FullPageLayout = { | ||||
|     ...sharedPageComponents, | ||||
|     ...defaultListPageLayout, | ||||
|     pageBody: FolderContent(), | ||||
|     ...userOpts, | ||||
|   } | ||||
|  | ||||
|   const { head: Head, header, beforeBody, pageBody: Content, left, right, footer: Footer } = opts | ||||
|   const { head: Head, header, beforeBody, pageBody, left, right, footer: Footer } = opts | ||||
|   const Header = HeaderConstructor() | ||||
|   const Body = BodyConstructor() | ||||
|  | ||||
|   return { | ||||
|     name: "FolderPage", | ||||
|     getQuartzComponents() { | ||||
|       return [Head, Header, Body, ...header, ...beforeBody, Content, ...left, ...right, Footer] | ||||
|       return [Head, Header, Body, ...header, ...beforeBody, pageBody, ...left, ...right, Footer] | ||||
|     }, | ||||
|     async emit(ctx, content, resources, emit): Promise<FilePath[]> { | ||||
|       const fps: FilePath[] = [] | ||||
|   | ||||
| @@ -12,20 +12,25 @@ import { | ||||
|   getAllSegmentPrefixes, | ||||
|   joinSegments, | ||||
| } from "../../path" | ||||
| import { defaultListPageLayout, sharedPageComponents } from "../../../quartz.layout" | ||||
| import { TagContent } from "../../components" | ||||
|  | ||||
| export const TagPage: QuartzEmitterPlugin<FullPageLayout> = (opts) => { | ||||
|   if (!opts) { | ||||
|     throw new Error("TagPage must be initialized with options specifiying the components to use") | ||||
| export const TagPage: QuartzEmitterPlugin<FullPageLayout> = (userOpts) => { | ||||
|   const opts: FullPageLayout = { | ||||
|     ...sharedPageComponents, | ||||
|     ...defaultListPageLayout, | ||||
|     pageBody: TagContent(), | ||||
|     ...userOpts, | ||||
|   } | ||||
|  | ||||
|   const { head: Head, header, beforeBody, pageBody: Content, left, right, footer: Footer } = opts | ||||
|   const { head: Head, header, beforeBody, pageBody, left, right, footer: Footer } = opts | ||||
|   const Header = HeaderConstructor() | ||||
|   const Body = BodyConstructor() | ||||
|  | ||||
|   return { | ||||
|     name: "TagPage", | ||||
|     getQuartzComponents() { | ||||
|       return [Head, Header, Body, ...header, ...beforeBody, Content, ...left, ...right, Footer] | ||||
|       return [Head, Header, Body, ...header, ...beforeBody, pageBody, ...left, ...right, Footer] | ||||
|     }, | ||||
|     async emit(ctx, content, resources, emit): Promise<FilePath[]> { | ||||
|       const fps: FilePath[] = [] | ||||
|   | ||||
		Reference in New Issue
	
	Block a user