32 lines
782 B
TypeScript
32 lines
782 B
TypeScript
import {inc, throttle} from "@welshman/lib"
|
|
import {custom} from "@welshman/store"
|
|
import {repository} from "./core.js"
|
|
|
|
export type Topic = {
|
|
name: string
|
|
count: number
|
|
}
|
|
|
|
export const topics = custom<Topic[]>(setter => {
|
|
const getTopics = () => {
|
|
const topics = new Map<string, number>()
|
|
for (const tagString of repository.eventsByTag.keys()) {
|
|
if (tagString.startsWith("t:")) {
|
|
const topic = tagString.slice(2).toLowerCase()
|
|
|
|
topics.set(topic, inc(topics.get(topic)))
|
|
}
|
|
}
|
|
|
|
return Array.from(topics.entries()).map(([name, count]) => ({name, count}))
|
|
}
|
|
|
|
setter(getTopics())
|
|
|
|
const onUpdate = throttle(3000, () => setter(getTopics()))
|
|
|
|
repository.on("update", onUpdate)
|
|
|
|
return () => repository.off("update", onUpdate)
|
|
})
|