feat: Option to mask folder count (#734)
* Option to mask folder count * Update quartz/components/pages/FolderContent.tsx --------- Co-authored-by: Jacky Zhao <j.zhao2k19@gmail.com>
This commit is contained in:
		| @@ -8,6 +8,21 @@ import { Root } from "hast" | |||||||
| import { pluralize } from "../../util/lang" | import { pluralize } from "../../util/lang" | ||||||
| import { htmlToJsx } from "../../util/jsx" | import { htmlToJsx } from "../../util/jsx" | ||||||
|  |  | ||||||
|  | interface FolderContentOptions { | ||||||
|  |   /** | ||||||
|  |    * Whether to display number of folders | ||||||
|  |    */ | ||||||
|  |   showFolderCount: boolean | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const defaultOptions: FolderContentOptions = { | ||||||
|  |   showFolderCount: true, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export default ((opts?: Partial<FolderContentOptions>) => { | ||||||
|  |   // Merge options with defaults | ||||||
|  |   const options: FolderContentOptions = { ...defaultOptions, ...opts } | ||||||
|  |  | ||||||
|   function FolderContent(props: QuartzComponentProps) { |   function FolderContent(props: QuartzComponentProps) { | ||||||
|     const { tree, fileData, allFiles } = props |     const { tree, fileData, allFiles } = props | ||||||
|     const folderSlug = _stripSlashes(simplifySlug(fileData.slug!)) |     const folderSlug = _stripSlashes(simplifySlug(fileData.slug!)) | ||||||
| @@ -35,7 +50,7 @@ function FolderContent(props: QuartzComponentProps) { | |||||||
|         <article> |         <article> | ||||||
|           <p>{content}</p> |           <p>{content}</p> | ||||||
|         </article> |         </article> | ||||||
|       <p>{pluralize(allPagesInFolder.length, "item")} under this folder.</p> |         {options.showFolderCount && <p>{pluralize(allPagesInFolder.length, "item")} under this folder.</p>} | ||||||
|         <div> |         <div> | ||||||
|           <PageList {...listProps} /> |           <PageList {...listProps} /> | ||||||
|         </div> |         </div> | ||||||
| @@ -44,4 +59,5 @@ function FolderContent(props: QuartzComponentProps) { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   FolderContent.css = style + PageList.css |   FolderContent.css = style + PageList.css | ||||||
| export default (() => FolderContent) satisfies QuartzComponentConstructor |   return FolderContent | ||||||
|  | }) satisfies QuartzComponentConstructor | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user