mirror of
https://github.com/jackyzha0/quartz.git
synced 2026-02-03 22:15:42 -06:00
fix: deduplication and slugiication of tags
based on copilot's review
This commit is contained in:
parent
b91651f9a7
commit
84ff4012d1
@ -9,6 +9,7 @@ import {
|
||||
getAllSegmentPrefixes,
|
||||
joinSegments,
|
||||
simplifySlug,
|
||||
slugTag,
|
||||
} from "../../util/path"
|
||||
import { QuartzEmitterPlugin } from "../types"
|
||||
import { toHtml } from "hast-util-to-html"
|
||||
@ -153,6 +154,9 @@ export const ContentIndex: QuartzEmitterPlugin<Partial<Options>> = (opts) => {
|
||||
let sortedTags: string[] = []
|
||||
|
||||
if (opts.rssTags && opts.rssTags.length > 0) {
|
||||
// Deduplicate and slugify user-provided tags
|
||||
const userTags = new Set(opts.rssTags.map((tag) => slugTag(tag)))
|
||||
|
||||
// Only include user-specified tags that actually exist in the content
|
||||
const availableTags = new Set<string>()
|
||||
for (const [_, content] of linkIndex) {
|
||||
@ -161,7 +165,7 @@ export const ContentIndex: QuartzEmitterPlugin<Partial<Options>> = (opts) => {
|
||||
availableTags.add(tag)
|
||||
}
|
||||
}
|
||||
sortedTags = opts.rssTags.filter((tag) => availableTags.has(tag))
|
||||
sortedTags = Array.from(userTags).filter((tag) => availableTags.has(tag))
|
||||
} else if ((opts.rssTagsLimit ?? 0) > 0) {
|
||||
const tagCounts: Map<string, number> = new Map()
|
||||
|
||||
|
||||
Loading…
Reference in New Issue
Block a user