24 lines
685 B
TypeScript
24 lines
685 B
TypeScript
|
import { pathToRoot } from "../util/path"
|
||
|
import { QuartzComponent, QuartzComponentConstructor, QuartzComponentProps } from "./types"
|
||
|
import { classNames } from "../util/lang"
|
||
|
import { i18n } from "../i18n"
|
||
|
|
||
|
const PageTitle: QuartzComponent = ({ fileData, cfg, displayClass }: QuartzComponentProps) => {
|
||
|
const title = cfg?.pageTitle ?? i18n(cfg.locale).propertyDefaults.title
|
||
|
const baseDir = pathToRoot(fileData.slug!)
|
||
|
return (
|
||
|
<h2 class={classNames(displayClass, "page-title")}>
|
||
|
<a href={baseDir}>{title}</a>
|
||
|
</h2>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
PageTitle.css = `
|
||
|
.page-title {
|
||
|
font-size: 1.75rem;
|
||
|
margin: 0;
|
||
|
}
|
||
|
`
|
||
|
|
||
|
export default (() => PageTitle) satisfies QuartzComponentConstructor
|