File size: 1,022 Bytes
c3e8f3d
 
 
3ba9c0c
 
c3e8f3d
3ba9c0c
 
 
c3e8f3d
 
 
3ba9c0c
 
c3e8f3d
 
3ba9c0c
c3e8f3d
 
3ba9c0c
c3e8f3d
 
 
 
 
 
 
 
 
 
 
 
3ba9c0c
c3e8f3d
3ba9c0c
 
 
c3e8f3d
 
 
 
 
 
3ba9c0c
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
import { clsx, type ClassValue } from 'clsx';
import { customAlphabet } from 'nanoid';
import { twMerge } from 'tailwind-merge';

export function cn(...inputs: ClassValue[]) {
	return twMerge(clsx(inputs));
}

export const nanoid = customAlphabet(
	'0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',
	7,
); // 7-character random string

export async function fetcher<JSON = any>(
	input: RequestInfo,
	init?: RequestInit,
): Promise<JSON> {
	const res = await fetch(input, init);
	console.log('[Ming] ~ res:', res);

	if (!res.ok) {
		const json = await res.json();
		if (json.error) {
			const error = new Error(json.error) as Error & {
				status: number;
			};
			error.status = res.status;
			throw error;
		} else {
			throw new Error('An unexpected error occurred');
		}
	}

	return res.json();
}

export function formatDate(input: string | number | Date): string {
	const date = new Date(input);
	return date.toLocaleDateString('en-US', {
		month: 'long',
		day: 'numeric',
		year: 'numeric',
	});
}