docs + chore: cleanup custom sort ordering for folder + tag listings, add docs
| | |
| | | |
| | | ## Customization |
| | | |
| | | The folder listings are a functionality of the [[FolderPage]] plugin, the tag listings of the [[TagPage]] plugin. See the plugin pages for customization options. |
| | | Quartz allows you to define a custom sort ordering for content on both page types. The folder listings are a functionality of the [[FolderPage]] plugin, the tag listings of the [[TagPage]] plugin. See the plugin pages for customization options. |
| | |
| | | > [!note] |
| | | > For information on how to add, remove or configure plugins, see the [[configuration#Plugins|Configuration]] page. |
| | | |
| | | This plugin has no configuration options. |
| | | |
| | | The pages are displayed using the `defaultListPageLayout` in `quartz.layouts.ts`. For the content, the `FolderContent` component is used. If you want to modify the layout, you must edit it directly (`quartz/components/pages/FolderContent.tsx`). |
| | | |
| | | This plugin accepts the following configuration options: |
| | | |
| | | - `sort`: A function of type `(f1: QuartzPluginData, f2: QuartzPluginData) => number{:ts}` used to sort entries. Defaults to sorting by date and tie-breaking on lexographical order. |
| | | |
| | | ## API |
| | | |
| | | - Category: Emitter |
| | |
| | | > [!note] |
| | | > For information on how to add, remove or configure plugins, see the [[configuration#Plugins|Configuration]] page. |
| | | |
| | | This plugin has no configuration options. |
| | | |
| | | The pages are displayed using the `defaultListPageLayout` in `quartz.layouts.ts`. For the content, the `TagContent` component is used. If you want to modify the layout, you must edit it directly (`quartz/components/pages/TagContent.tsx`). |
| | | |
| | | This plugin accepts the following configuration options: |
| | | |
| | | - `sort`: A function of type `(f1: QuartzPluginData, f2: QuartzPluginData) => number{:ts}` used to sort entries. Defaults to sorting by date and tie-breaking on lexographical order. |
| | | |
| | | ## API |
| | | |
| | | - Category: Emitter |
| | |
| | | import { QuartzComponent, QuartzComponentProps } from "./types" |
| | | import { GlobalConfiguration } from "../cfg" |
| | | |
| | | export function byDateAndAlphabetical( |
| | | cfg: GlobalConfiguration, |
| | | ): (f1: QuartzPluginData, f2: QuartzPluginData) => number { |
| | | export type SortFn = (f1: QuartzPluginData, f2: QuartzPluginData) => number |
| | | |
| | | export function byDateAndAlphabetical(cfg: GlobalConfiguration): SortFn { |
| | | return (f1, f2) => { |
| | | if (f1.dates && f2.dates) { |
| | | // sort descending |
| | |
| | | |
| | | type Props = { |
| | | limit?: number |
| | | sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number |
| | | sort?: SortFn |
| | | } & QuartzComponentProps |
| | | |
| | | export const PageList: QuartzComponent = ({ cfg, fileData, allFiles, limit, sort }: Props) => { |
| | |
| | | import path from "path" |
| | | |
| | | import style from "../styles/listPage.scss" |
| | | import { PageList } from "../PageList" |
| | | import { PageList, SortFn } from "../PageList" |
| | | import { stripSlashes, simplifySlug } from "../../util/path" |
| | | import { Root } from "hast" |
| | | import { htmlToJsx } from "../../util/jsx" |
| | | import { i18n } from "../../i18n" |
| | | import { QuartzPluginData } from "../../plugins/vfile" |
| | | |
| | | interface FolderContentOptions { |
| | | /** |
| | | * Whether to display number of folders |
| | | */ |
| | | showFolderCount: boolean |
| | | sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number |
| | | sort?: SortFn |
| | | } |
| | | |
| | | const defaultOptions: FolderContentOptions = { |
| | |
| | | import { QuartzComponent, QuartzComponentConstructor, QuartzComponentProps } from "../types" |
| | | import style from "../styles/listPage.scss" |
| | | import { PageList } from "../PageList" |
| | | import { PageList, SortFn } from "../PageList" |
| | | import { FullSlug, getAllSegmentPrefixes, simplifySlug } from "../../util/path" |
| | | import { QuartzPluginData } from "../../plugins/vfile" |
| | | import { Root } from "hast" |
| | | import { htmlToJsx } from "../../util/jsx" |
| | | import { i18n } from "../../i18n" |
| | | |
| | | export default ((opts?: { sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number }) => { |
| | | const numPages = 10 |
| | | interface TagContentOptions { |
| | | sort?: SortFn |
| | | numPages: number |
| | | } |
| | | |
| | | const defaultOptions: TagContentOptions = { |
| | | numPages: 10, |
| | | } |
| | | |
| | | export default ((opts?: Partial<TagContentOptions>) => { |
| | | const options: TagContentOptions = { ...defaultOptions, ...opts } |
| | | |
| | | const TagContent: QuartzComponent = (props: QuartzComponentProps) => { |
| | | const { tree, fileData, allFiles, cfg } = props |
| | | const slug = fileData.slug |
| | |
| | | <div class="page-listing"> |
| | | <p> |
| | | {i18n(cfg.locale).pages.tagContent.itemsUnderTag({ count: pages.length })} |
| | | {pages.length > numPages && ( |
| | | {pages.length > options.numPages && ( |
| | | <> |
| | | {" "} |
| | | <span> |
| | | {i18n(cfg.locale).pages.tagContent.showingFirst({ count: numPages })} |
| | | {i18n(cfg.locale).pages.tagContent.showingFirst({ |
| | | count: options.numPages, |
| | | })} |
| | | </span> |
| | | </> |
| | | )} |
| | | </p> |
| | | <PageList limit={numPages} {...listProps} sort={opts?.sort} /> |
| | | <PageList limit={options.numPages} {...listProps} sort={opts?.sort} /> |
| | | </div> |
| | | </div> |
| | | ) |
| | |
| | | import { i18n } from "../../i18n" |
| | | import DepGraph from "../../depgraph" |
| | | |
| | | export const FolderPage: QuartzEmitterPlugin< |
| | | Partial<FullPageLayout> & { sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number } |
| | | > = (userOpts) => { |
| | | interface FolderPageOptions extends FullPageLayout { |
| | | sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number |
| | | } |
| | | |
| | | export const FolderPage: QuartzEmitterPlugin<Partial<FolderPageOptions>> = (userOpts) => { |
| | | const opts: FullPageLayout = { |
| | | ...sharedPageComponents, |
| | | ...defaultListPageLayout, |
| | |
| | | import { i18n } from "../../i18n" |
| | | import DepGraph from "../../depgraph" |
| | | |
| | | export const TagPage: QuartzEmitterPlugin< |
| | | Partial<FullPageLayout> & { sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number } |
| | | > = (userOpts) => { |
| | | interface TagPageOptions extends FullPageLayout { |
| | | sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number |
| | | } |
| | | |
| | | export const TagPage: QuartzEmitterPlugin<Partial<TagPageOptions>> = (userOpts) => { |
| | | const opts: FullPageLayout = { |
| | | ...sharedPageComponents, |
| | | ...defaultListPageLayout, |