feat: Allow custom sorting of FolderPage and TagPage (#1250)
| | |
| | | |
| | | type Props = { |
| | | limit?: number |
| | | sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number |
| | | } & QuartzComponentProps |
| | | |
| | | export const PageList: QuartzComponent = ({ cfg, fileData, allFiles, limit }: Props) => { |
| | | let list = allFiles.sort(byDateAndAlphabetical(cfg)) |
| | | export const PageList: QuartzComponent = ({ cfg, fileData, allFiles, limit, sort }: Props) => { |
| | | const sorter = sort ?? byDateAndAlphabetical(cfg) |
| | | let list = allFiles.sort(sorter) |
| | | if (limit) { |
| | | list = list.slice(0, limit) |
| | | } |
| | |
| | | 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 |
| | | } |
| | | |
| | | const defaultOptions: FolderContentOptions = { |
| | |
| | | const classes = ["popover-hint", ...cssClasses].join(" ") |
| | | const listProps = { |
| | | ...props, |
| | | sort: options.sort, |
| | | allFiles: allPagesInFolder, |
| | | } |
| | | |
| | |
| | | import { htmlToJsx } from "../../util/jsx" |
| | | import { i18n } from "../../i18n" |
| | | |
| | | export default ((opts?: { sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number }) => { |
| | | const numPages = 10 |
| | | const TagContent: QuartzComponent = (props: QuartzComponentProps) => { |
| | | const { tree, fileData, allFiles, cfg } = props |
| | |
| | | </> |
| | | )} |
| | | </p> |
| | | <PageList limit={numPages} {...listProps} /> |
| | | <PageList limit={numPages} {...listProps} sort={opts?.sort} /> |
| | | </div> |
| | | </div> |
| | | ) |
| | |
| | | } |
| | | |
| | | TagContent.css = style + PageList.css |
| | | export default (() => TagContent) satisfies QuartzComponentConstructor |
| | | return TagContent |
| | | }) satisfies QuartzComponentConstructor |
| | |
| | | import HeaderConstructor from "../../components/Header" |
| | | import BodyConstructor from "../../components/Body" |
| | | import { pageResources, renderPage } from "../../components/renderPage" |
| | | import { ProcessedContent, defaultProcessedContent } from "../vfile" |
| | | import { ProcessedContent, QuartzPluginData, defaultProcessedContent } from "../vfile" |
| | | import { FullPageLayout } from "../../cfg" |
| | | import path from "path" |
| | | import { |
| | |
| | | import { i18n } from "../../i18n" |
| | | import DepGraph from "../../depgraph" |
| | | |
| | | export const FolderPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) => { |
| | | export const FolderPage: QuartzEmitterPlugin< |
| | | Partial<FullPageLayout> & { sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number } |
| | | > = (userOpts) => { |
| | | const opts: FullPageLayout = { |
| | | ...sharedPageComponents, |
| | | ...defaultListPageLayout, |
| | | pageBody: FolderContent(), |
| | | pageBody: FolderContent({ sort: userOpts?.sort }), |
| | | ...userOpts, |
| | | } |
| | | |
| | |
| | | import HeaderConstructor from "../../components/Header" |
| | | import BodyConstructor from "../../components/Body" |
| | | import { pageResources, renderPage } from "../../components/renderPage" |
| | | import { ProcessedContent, defaultProcessedContent } from "../vfile" |
| | | import { ProcessedContent, QuartzPluginData, defaultProcessedContent } from "../vfile" |
| | | import { FullPageLayout } from "../../cfg" |
| | | import { |
| | | FilePath, |
| | |
| | | import { i18n } from "../../i18n" |
| | | import DepGraph from "../../depgraph" |
| | | |
| | | export const TagPage: QuartzEmitterPlugin<Partial<FullPageLayout>> = (userOpts) => { |
| | | export const TagPage: QuartzEmitterPlugin< |
| | | Partial<FullPageLayout> & { sort?: (f1: QuartzPluginData, f2: QuartzPluginData) => number } |
| | | > = (userOpts) => { |
| | | const opts: FullPageLayout = { |
| | | ...sharedPageComponents, |
| | | ...defaultListPageLayout, |
| | | pageBody: TagContent(), |
| | | pageBody: TagContent({ sort: userOpts?.sort }), |
| | | ...userOpts, |
| | | } |
| | | |