mirror of
https://gitlab.com/MisterBiggs/brain-quartz.git
synced 2025-07-21 22:01:34 +00:00
.github
content
docs
quartz
cli
components
i18n
plugins
emitters
404.tsx
aliases.ts
assets.ts
cname.ts
componentResources.ts
contentIndex.ts
contentPage.tsx
folderPage.tsx
helpers.ts
index.ts
static.ts
tagPage.tsx
filters
transformers
index.ts
types.ts
vfile.ts
processors
static
styles
util
bootstrap-cli.mjs
bootstrap-worker.mjs
build.ts
cfg.ts
depgraph.test.ts
depgraph.ts
worker.ts
.gitattributes
.gitignore
.npmrc
.prettierignore
.prettierrc
CODE_OF_CONDUCT.md
Dockerfile
LICENSE.txt
README.md
globals.d.ts
index.d.ts
package-lock.json
package.json
quartz.config.ts
quartz.layout.ts
tsconfig.json
111 lines
3.4 KiB
TypeScript
111 lines
3.4 KiB
TypeScript
import { QuartzEmitterPlugin } from "../types"
|
|
import { QuartzComponentProps } from "../../components/types"
|
|
import HeaderConstructor from "../../components/Header"
|
|
import BodyConstructor from "../../components/Body"
|
|
import { pageResources, renderPage } from "../../components/renderPage"
|
|
import { ProcessedContent, defaultProcessedContent } from "../vfile"
|
|
import { FullPageLayout } from "../../cfg"
|
|
import path from "path"
|
|
import {
|
|
FilePath,
|
|
FullSlug,
|
|
SimpleSlug,
|
|
stripSlashes,
|
|
joinSegments,
|
|
pathToRoot,
|
|
simplifySlug,
|
|
} from "../../util/path"
|
|
import { defaultListPageLayout, sharedPageComponents } from "../../../quartz.layout"
|
|
import { FolderContent } from "../../components"
|
|
import { write } from "./helpers"
|
|
import { i18n } from "../../i18n"
|
|
import DepGraph from "../../depgraph"
|
|
|
|
export const FolderPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) => {
|
|
const opts: FullPageLayout = {
|
|
...sharedPageComponents,
|
|
...defaultListPageLayout,
|
|
pageBody: FolderContent(),
|
|
...userOpts,
|
|
}
|
|
|
|
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, pageBody, ...left, ...right, Footer]
|
|
},
|
|
async getDependencyGraph(_ctx, _content, _resources) {
|
|
// Example graph:
|
|
// nested/file.md --> nested/file.html
|
|
// \-------> nested/index.html
|
|
// TODO implement
|
|
return new DepGraph<FilePath>()
|
|
},
|
|
async emit(ctx, content, resources): Promise<FilePath[]> {
|
|
const fps: FilePath[] = []
|
|
const allFiles = content.map((c) => c[1].data)
|
|
const cfg = ctx.cfg.configuration
|
|
|
|
const folders: Set<SimpleSlug> = new Set(
|
|
allFiles.flatMap((data) => {
|
|
const slug = data.slug
|
|
const folderName = path.dirname(slug ?? "") as SimpleSlug
|
|
if (slug && folderName !== "." && folderName !== "tags") {
|
|
return [folderName]
|
|
}
|
|
return []
|
|
}),
|
|
)
|
|
|
|
const folderDescriptions: Record<string, ProcessedContent> = Object.fromEntries(
|
|
[...folders].map((folder) => [
|
|
folder,
|
|
defaultProcessedContent({
|
|
slug: joinSegments(folder, "index") as FullSlug,
|
|
frontmatter: {
|
|
title: `${i18n(cfg.locale).pages.folderContent.folder}: ${folder}`,
|
|
tags: [],
|
|
},
|
|
}),
|
|
]),
|
|
)
|
|
|
|
for (const [tree, file] of content) {
|
|
const slug = stripSlashes(simplifySlug(file.data.slug!)) as SimpleSlug
|
|
if (folders.has(slug)) {
|
|
folderDescriptions[slug] = [tree, file]
|
|
}
|
|
}
|
|
|
|
for (const folder of folders) {
|
|
const slug = joinSegments(folder, "index") as FullSlug
|
|
const externalResources = pageResources(pathToRoot(slug), resources)
|
|
const [tree, file] = folderDescriptions[folder]
|
|
const componentData: QuartzComponentProps = {
|
|
fileData: file.data,
|
|
externalResources,
|
|
cfg,
|
|
children: [],
|
|
tree,
|
|
allFiles,
|
|
}
|
|
|
|
const content = renderPage(cfg, slug, componentData, opts, externalResources)
|
|
const fp = await write({
|
|
ctx,
|
|
content,
|
|
slug,
|
|
ext: ".html",
|
|
})
|
|
|
|
fps.push(fp)
|
|
}
|
|
return fps
|
|
},
|
|
}
|
|
}
|