feat: conditional render component
This commit is contained in:
		@@ -60,3 +60,25 @@ The `DesktopOnly` component is the counterpart to `MobileOnly`. It makes its chi
 | 
			
		||||
```typescript
 | 
			
		||||
Component.DesktopOnly(Component.TableOfContents())
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## `ConditionalRender` Component
 | 
			
		||||
 | 
			
		||||
The `ConditionalRender` component is a wrapper that conditionally renders its child component based on a provided condition function. This is useful for creating dynamic layouts where components should only appear under certain conditions.
 | 
			
		||||
 | 
			
		||||
```typescript
 | 
			
		||||
type ConditionalRenderConfig = {
 | 
			
		||||
  component: QuartzComponent
 | 
			
		||||
  condition: (props: QuartzComponentProps) => boolean
 | 
			
		||||
}
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### Example Usage
 | 
			
		||||
 | 
			
		||||
```typescript
 | 
			
		||||
Component.ConditionalRender({
 | 
			
		||||
  component: Component.Search(),
 | 
			
		||||
  condition: (props) => props.displayClass !== "fullpage",
 | 
			
		||||
})
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
This example would only render the Search component when the page is not in fullpage mode.
 | 
			
		||||
 
 | 
			
		||||
@@ -17,7 +17,10 @@ export const sharedPageComponents: SharedLayout = {
 | 
			
		||||
// components for pages that display a single page (e.g. a single note)
 | 
			
		||||
export const defaultContentPageLayout: PageLayout = {
 | 
			
		||||
  beforeBody: [
 | 
			
		||||
    Component.Breadcrumbs(),
 | 
			
		||||
    Component.ConditionalRender({
 | 
			
		||||
      component: Component.Breadcrumbs(),
 | 
			
		||||
      condition: (page) => page.fileData.slug !== "index",
 | 
			
		||||
    }),
 | 
			
		||||
    Component.ArticleTitle(),
 | 
			
		||||
    Component.ContentMeta(),
 | 
			
		||||
    Component.TagList(),
 | 
			
		||||
 
 | 
			
		||||
@@ -21,7 +21,6 @@ import { getStaticResourcesFromPlugins } from "./plugins"
 | 
			
		||||
import { randomIdNonSecure } from "./util/random"
 | 
			
		||||
import { ChangeEvent } from "./plugins/types"
 | 
			
		||||
import { minimatch } from "minimatch"
 | 
			
		||||
import { FileTrieNode } from "./util/fileTrie"
 | 
			
		||||
 | 
			
		||||
type ContentMap = Map<
 | 
			
		||||
  FilePath,
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										22
									
								
								quartz/components/ConditionalRender.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								quartz/components/ConditionalRender.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
			
		||||
import { QuartzComponent, QuartzComponentConstructor, QuartzComponentProps } from "./types"
 | 
			
		||||
 | 
			
		||||
type ConditionalRenderConfig = {
 | 
			
		||||
  component: QuartzComponent
 | 
			
		||||
  condition: (props: QuartzComponentProps) => boolean
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export default ((config: ConditionalRenderConfig) => {
 | 
			
		||||
  const ConditionalRender: QuartzComponent = (props: QuartzComponentProps) => {
 | 
			
		||||
    if (config.condition(props)) {
 | 
			
		||||
      return <config.component {...props} />
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return null
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  ConditionalRender.afterDOMLoaded = config.component.afterDOMLoaded
 | 
			
		||||
  ConditionalRender.beforeDOMLoaded = config.component.beforeDOMLoaded
 | 
			
		||||
  ConditionalRender.css = config.component.css
 | 
			
		||||
 | 
			
		||||
  return ConditionalRender
 | 
			
		||||
}) satisfies QuartzComponentConstructor<ConditionalRenderConfig>
 | 
			
		||||
@@ -21,6 +21,7 @@ import RecentNotes from "./RecentNotes"
 | 
			
		||||
import Breadcrumbs from "./Breadcrumbs"
 | 
			
		||||
import Comments from "./Comments"
 | 
			
		||||
import Flex from "./Flex"
 | 
			
		||||
import ConditionalRender from "./ConditionalRender"
 | 
			
		||||
 | 
			
		||||
export {
 | 
			
		||||
  ArticleTitle,
 | 
			
		||||
@@ -46,4 +47,5 @@ export {
 | 
			
		||||
  Breadcrumbs,
 | 
			
		||||
  Comments,
 | 
			
		||||
  Flex,
 | 
			
		||||
  ConditionalRender,
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user