rendering, link resolution, asset copying
This commit is contained in:
		| @@ -1,18 +1,22 @@ | ||||
| import { resolveToRoot } from "../path" | ||||
| import { StaticResources } from "../resources" | ||||
|  | ||||
| interface Props { | ||||
|   title: string, | ||||
|   description: string, | ||||
|   externalResources: StaticResources, | ||||
|   baseDir: string | ||||
| export interface HeadProps { | ||||
|   title: string | ||||
|   description: string | ||||
|   slug: string | ||||
|   externalResources: StaticResources | ||||
| } | ||||
|  | ||||
| export default function({ title, description, externalResources, baseDir }: Props) { | ||||
| export default function({ title, description, slug, externalResources }: HeadProps) { | ||||
|   const { css, js } = externalResources | ||||
|   const baseDir = resolveToRoot(slug) | ||||
|   const iconPath = baseDir + "/static/icon.png" | ||||
|   const ogImagePath = baseDir + "/static/og-image.png" | ||||
|   return <head> | ||||
|     <title>{title}</title> | ||||
|     <meta charSet="utf-8" /> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1" /> | ||||
|     <meta property="og:title" content={title} /> | ||||
|     <meta property="og:description" content={title} /> | ||||
|     <meta property="og:image" content={ogImagePath} /> | ||||
| @@ -21,8 +25,16 @@ export default function({ title, description, externalResources, baseDir }: Prop | ||||
|     <link rel="icon" href={iconPath} /> | ||||
|     <meta name="description" content={description} /> | ||||
|     <meta name="generator" content="Quartz" /> | ||||
|     <meta charSet="UTF-8" /> | ||||
|     <base href={slug} /> | ||||
|     {css.map(href => <link key={href} href={href} rel="stylesheet" type="text/css" />)} | ||||
|     {js.filter(resource => resource.loadTime === "beforeDOMReady").map(resource => <script key={resource.src} src={resource.src} />)} | ||||
|   </head> | ||||
| } | ||||
|  | ||||
| export function beforeDOMLoaded() { | ||||
|  | ||||
| } | ||||
|  | ||||
| export function onDOMLoaded() { | ||||
|  | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user