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,7 +8,22 @@ import { Root } from "hast" | ||||
| import { pluralize } from "../../util/lang" | ||||
| import { htmlToJsx } from "../../util/jsx" | ||||
|  | ||||
| function FolderContent(props: QuartzComponentProps) { | ||||
| 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) { | ||||
|     const { tree, fileData, allFiles } = props | ||||
|     const folderSlug = _stripSlashes(simplifySlug(fileData.slug!)) | ||||
|     const allPagesInFolder = allFiles.filter((file) => { | ||||
| @@ -35,13 +50,14 @@ function FolderContent(props: QuartzComponentProps) { | ||||
|         <article> | ||||
|           <p>{content}</p> | ||||
|         </article> | ||||
|       <p>{pluralize(allPagesInFolder.length, "item")} under this folder.</p> | ||||
|         {options.showFolderCount && <p>{pluralize(allPagesInFolder.length, "item")} under this folder.</p>} | ||||
|         <div> | ||||
|           <PageList {...listProps} /> | ||||
|         </div> | ||||
|       </div> | ||||
|     ) | ||||
| } | ||||
|   } | ||||
|  | ||||
| FolderContent.css = style + PageList.css | ||||
| export default (() => FolderContent) satisfies QuartzComponentConstructor | ||||
|   FolderContent.css = style + PageList.css | ||||
|   return FolderContent | ||||
| }) satisfies QuartzComponentConstructor | ||||
|   | ||||
		Reference in New Issue
	
	Block a user