Jacky Zhao
2024-01-31 22de92f6c46fd8aae3e803faaea734f28277cfae
quartz/components/pages/TagContent.tsx
@@ -26,16 +26,20 @@
    (tree as Root).children.length === 0
      ? fileData.description
      : htmlToJsx(fileData.filePath!, tree)
  if (tag === "") {
    const tags = [...new Set(allFiles.flatMap((data) => data.frontmatter?.tags ?? []))]
  const cssClasses: string[] = fileData.frontmatter?.cssclasses ?? []
  const classes = ["popover-hint", ...cssClasses].join(" ")
  if (tag === "/") {
    const tags = [
      ...new Set(
        allFiles.flatMap((data) => data.frontmatter?.tags ?? []).flatMap(getAllSegmentPrefixes),
      ),
    ].sort((a, b) => a.localeCompare(b))
    const tagItemMap: Map<string, QuartzPluginData[]> = new Map()
    for (const tag of tags) {
      tagItemMap.set(tag, allPagesWithTag(tag))
    }
    return (
      <div class="popover-hint">
      <div class={classes}>
        <article>
          <p>{content}</p>
        </article>
@@ -53,16 +57,18 @@
            return (
              <div>
                <h2>
                  <a class="internal tag-link" href={`./${tag}`}>
                  <a class="internal tag-link" href={`../tags/${tag}`}>
                    #{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, "item")} with this tag.{" "}
                    {pages.length > numPages && `Showing first ${numPages}.`}
                  </p>
                  <PageList limit={numPages} {...listProps} />
                </div>
              </div>
            )
          })}
@@ -77,11 +83,13 @@
    }
    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, "item")} with this tag.</p>
          <div>
            <PageList {...listProps} />
          </div>
        </div>
      </div>
    )