import { escapeHtml, getGitHubUrl, getLastUpdatedHtml, } from "../utils"; export interface RenderableSkillFile { name: string; path: string; } export interface RenderableSkill { id: string; title: string; description?: string; path: string; skillFile: string; category: string; hasAssets: boolean; assetCount: number; files: RenderableSkillFile[]; lastUpdated?: string | null; } export type SkillSortOption = "title" | "lastUpdated"; export function sortSkills( items: T[], sort: SkillSortOption ): T[] { return [...items].sort((a, b) => { if (sort === "lastUpdated") { const dateA = a.lastUpdated ? new Date(a.lastUpdated).getTime() : 0; const dateB = b.lastUpdated ? new Date(b.lastUpdated).getTime() : 0; return dateB - dateA; } return a.title.localeCompare(b.title); }); } export function renderSkillsHtml( items: RenderableSkill[], options: { query?: string; highlightTitle?: (title: string, query: string) => string; } = {} ): string { const { query = "", highlightTitle } = options; if (items.length === 0) { return `

No skills found

Try a different search term or adjust filters

`; } return items .map((item) => { const titleHtml = query && highlightTitle ? highlightTitle(item.title, query) : escapeHtml(item.title); return `
GitHub
`; }) .join(""); }