src/lib/utils.ts (view raw)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
import { getEntry } from 'astro:content' import { type ClassValue, clsx } from 'clsx' import { twMerge } from 'tailwind-merge' export function cn(...inputs: ClassValue[]) { return twMerge(clsx(inputs)) } export function formatDate(date: Date) { return Intl.DateTimeFormat('en-US', { year: 'numeric', month: 'long', day: 'numeric', }).format(date) } export function readingTime(html: string) { const textOnly = html.replace(/<[^>]+>/g, '') const wordCount = textOnly.split(/\s+/).length const readingTimeMinutes = (wordCount / 200 + 1).toFixed() return `${readingTimeMinutes} min read` } export async function parseAuthors(authors: string[]) { if (!authors || authors.length === 0) return [] const parseAuthor = async (slug: string) => { try { const author = await getEntry('authors', slug) return { name: author?.data?.name || slug, avatar: author?.data?.avatar || '/static/logo.png', isRegistered: !!author, } } catch (error) { console.error(`Error fetching author with slug ${slug}:`, error) return { name: slug, avatar: '/static/logo.png', isRegistered: false, } } } return await Promise.all(authors.map(parseAuthor)) } |