From c7d3474ba8cb49ab0f1978216d80b08ec2c8e5d7 Mon Sep 17 00:00:00 2001
From: Ben Schlegel <ben5.schlegel@gmail.com>
Date: Sat, 16 Sep 2023 10:40:19 +0000
Subject: [PATCH] feat(explorer): add config to support custom sort fn
---
quartz/components/RecentNotes.tsx | 19 ++++++++++---------
1 files changed, 10 insertions(+), 9 deletions(-)
diff --git a/quartz/components/RecentNotes.tsx b/quartz/components/RecentNotes.tsx
index 5e992b4..cb14b33 100644
--- a/quartz/components/RecentNotes.tsx
+++ b/quartz/components/RecentNotes.tsx
@@ -3,7 +3,8 @@
import { QuartzPluginData } from "../plugins/vfile"
import { byDateAndAlphabetical } from "./PageList"
import style from "./styles/recentNotes.scss"
-import { Date } from "./Date"
+import { Date, getDate } from "./Date"
+import { GlobalConfiguration } from "../cfg"
interface Options {
title: string
@@ -13,25 +14,25 @@
sort: (f1: QuartzPluginData, f2: QuartzPluginData) => number
}
-const defaultOptions: Options = {
+const defaultOptions = (cfg: GlobalConfiguration): Options => ({
title: "Recent Notes",
limit: 3,
linkToMore: false,
filter: () => true,
- sort: byDateAndAlphabetical,
-}
+ sort: byDateAndAlphabetical(cfg),
+})
export default ((userOpts?: Partial<Options>) => {
- const opts = { ...defaultOptions, ...userOpts }
function RecentNotes(props: QuartzComponentProps) {
- const { allFiles, fileData, displayClass } = props
- const pages = allFiles.filter(opts.filter).sort(opts.sort).slice(0, opts.limit)
+ const { allFiles, fileData, displayClass, cfg } = props
+ const opts = { ...defaultOptions(cfg), ...userOpts }
+ const pages = allFiles.filter(opts.filter).sort(opts.sort)
const remaining = Math.max(0, pages.length - opts.limit)
return (
<div class={`recent-notes ${displayClass}`}>
<h3>{opts.title}</h3>
<ul class="recent-ul">
- {pages.map((page) => {
+ {pages.slice(0, opts.limit).map((page) => {
const title = page.frontmatter?.title
const tags = page.frontmatter?.tags ?? []
@@ -47,7 +48,7 @@
</div>
{page.dates && (
<p class="meta">
- <Date date={page.dates.modified} />
+ <Date date={getDate(cfg, page)!} />
</p>
)}
<ul class="tags">
--
Gitblit v1.10.0