2023-08-06 17:09:29 -07:00
|
|
|
import { PageLayout, SharedLayout } from "./quartz/cfg"
|
2023-07-25 23:37:24 -07:00
|
|
|
import * as Component from "./quartz/components"
|
|
|
|
|
|
|
|
// components shared across all pages
|
2023-08-06 17:09:29 -07:00
|
|
|
export const sharedPageComponents: SharedLayout = {
|
2023-07-25 23:37:24 -07:00
|
|
|
head: Component.Head(),
|
|
|
|
header: [],
|
2024-07-09 19:09:31 -07:00
|
|
|
afterBody: [],
|
2023-07-25 23:37:24 -07:00
|
|
|
footer: Component.Footer({
|
|
|
|
links: {
|
2023-08-21 12:27:12 +09:00
|
|
|
"Top": "https://matsuuratomoya.com",
|
|
|
|
"Mastodon": "https://social.matsuuratomoya.com/@tomoya",
|
|
|
|
"Twitter": "https://twitter.com/tomoya_nonymous",
|
|
|
|
"GitHub": "https://github.com/tomoyanonymous",
|
2023-07-25 23:37:24 -07:00
|
|
|
},
|
|
|
|
}),
|
|
|
|
}
|
|
|
|
|
|
|
|
// components for pages that display a single page (e.g. a single note)
|
2023-08-24 22:38:07 +09:00
|
|
|
const graph_cfg = {
|
|
|
|
localGraph: {
|
|
|
|
drag: true, // whether to allow panning the view around
|
|
|
|
zoom: true, // whether to allow zooming in and out
|
|
|
|
depth: 2, // how many hops of notes to display
|
|
|
|
scale: 1.1, // default view scale
|
|
|
|
repelForce: 0.5, // how much nodes should repel each other
|
|
|
|
centerForce: 0.3, // how much force to use when trying to center the nodes
|
|
|
|
linkDistance: 30, // how long should the links be by default?
|
|
|
|
fontSize: 0.6, // what size should the node labels be?
|
|
|
|
opacityScale: 1, // how quickly do we fade out the labels when zooming out?
|
|
|
|
},
|
|
|
|
globalGraph: {
|
|
|
|
drag: true,
|
|
|
|
zoom: true,
|
|
|
|
depth: -1,
|
|
|
|
scale: 0.9,
|
|
|
|
repelForce: 0.5,
|
|
|
|
centerForce: 0.3,
|
|
|
|
linkDistance: 30,
|
|
|
|
fontSize: 0.6,
|
|
|
|
opacityScale: 1,
|
|
|
|
},
|
|
|
|
};
|
2023-07-25 23:37:24 -07:00
|
|
|
export const defaultContentPageLayout: PageLayout = {
|
2023-11-27 18:01:51 +09:00
|
|
|
beforeBody: [Component.Breadcrumbs(),
|
|
|
|
Component.ArticleTitle(), Component.ContentMeta(), /*Component.TagList()*/],
|
2023-07-25 23:37:24 -07:00
|
|
|
left: [
|
|
|
|
Component.PageTitle(),
|
|
|
|
Component.MobileOnly(Component.Spacer()),
|
|
|
|
Component.Search(),
|
|
|
|
Component.Darkmode(),
|
|
|
|
Component.DesktopOnly(Component.TableOfContents()),
|
|
|
|
],
|
2024-01-29 13:59:31 +09:00
|
|
|
right: [Component.Graph(graph_cfg), Component.Backlinks(), Component.RecentNotes({ title: "Recent writing" })],
|
2023-07-25 23:37:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// components for pages that display lists of pages (e.g. tags or folders)
|
|
|
|
export const defaultListPageLayout: PageLayout = {
|
2024-02-05 19:45:36 +09:00
|
|
|
beforeBody: [Component.Breadcrumbs(), Component.ArticleTitle(), Component.ContentMeta()],
|
2023-07-25 23:37:24 -07:00
|
|
|
left: [
|
|
|
|
Component.PageTitle(),
|
|
|
|
Component.MobileOnly(Component.Spacer()),
|
|
|
|
Component.Search(),
|
|
|
|
Component.Darkmode(),
|
2024-02-05 19:45:36 +09:00
|
|
|
Component.DesktopOnly(Component.Explorer()),
|
2023-07-25 23:37:24 -07:00
|
|
|
],
|
2024-08-21 17:07:03 +09:00
|
|
|
right: [
|
|
|
|
Component.Graph(),
|
|
|
|
Component.DesktopOnly(Component.TableOfContents()),
|
|
|
|
Component.Backlinks(),
|
|
|
|
],
|
2023-11-27 18:01:51 +09:00
|
|
|
}
|