| | |
| | | import { Root } from "hast" |
| | | import { pluralize } from "../../util/lang" |
| | | import { htmlToJsx } from "../../util/jsx" |
| | | import { i18n } from "../../i18n/i18next" |
| | | |
| | | const numPages = 10 |
| | | function TagContent(props: QuartzComponentProps) { |
| | | const { tree, fileData, allFiles } = props |
| | | const { tree, fileData, allFiles, cfg } = props |
| | | const slug = fileData.slug |
| | | |
| | | if (!(slug?.startsWith("tags/") || slug === "tags")) { |
| | |
| | | (tree as Root).children.length === 0 |
| | | ? fileData.description |
| | | : htmlToJsx(fileData.filePath!, tree) |
| | | |
| | | const cssClasses: string[] = fileData.frontmatter?.cssclasses ?? [] |
| | | const classes = ["popover-hint", ...cssClasses].join(" ") |
| | | if (tag === "/") { |
| | | const tags = [ |
| | | ...new Set( |
| | |
| | | for (const tag of tags) { |
| | | tagItemMap.set(tag, allPagesWithTag(tag)) |
| | | } |
| | | |
| | | return ( |
| | | <div class="popover-hint"> |
| | | <div class={classes}> |
| | | <article> |
| | | <p>{content}</p> |
| | | </article> |
| | | <p>Found {tags.length} total tags.</p> |
| | | <p> |
| | | {i18n(cfg.locale, "tagContent.found")} {tags.length}{" "} |
| | | {i18n(cfg.locale, "tagContent.totalTags")}. |
| | | </p> |
| | | <div> |
| | | {tags.map((tag) => { |
| | | const pages = tagItemMap.get(tag)! |
| | |
| | | </a> |
| | | </h2> |
| | | {content && <p>{content}</p>} |
| | | <p> |
| | | {pluralize(pages.length, "item")} with this tag.{" "} |
| | | {pages.length > numPages && `Showing first ${numPages}.`} |
| | | </p> |
| | | <PageList limit={numPages} {...listProps} /> |
| | | <div class="page-listing"> |
| | | <p> |
| | | {pluralize(pages.length, i18n(cfg.locale, "common.item"))}{" "} |
| | | {i18n(cfg.locale, "tagContent.withThisTag")}.{" "} |
| | | {pages.length > numPages && |
| | | `${i18n(cfg.locale, "tagContent.showingFirst")} ${numPages}.`} |
| | | </p> |
| | | <PageList limit={numPages} {...listProps} /> |
| | | </div> |
| | | </div> |
| | | ) |
| | | })} |
| | |
| | | } |
| | | |
| | | return ( |
| | | <div class="popover-hint"> |
| | | <div class={classes}> |
| | | <article>{content}</article> |
| | | <p>{pluralize(pages.length, "item")} with this tag.</p> |
| | | <div> |
| | | <PageList {...listProps} /> |
| | | <div class="page-listing"> |
| | | <p> |
| | | {pluralize(pages.length, i18n(cfg.locale, "common.item"))}{" "} |
| | | {i18n(cfg.locale, "tagContent.withThisTag")}. |
| | | </p> |
| | | <div> |
| | | <PageList {...listProps} /> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | ) |