mirror of
https://github.com/ChatGPTNextWeb/ChatGPT-Next-Web.git
synced 2025-10-01 15:46:39 +08:00
60 lines
2.5 KiB
TypeScript
60 lines
2.5 KiB
TypeScript
// import { clsx, type ClassValue } from "clsx";
|
|
import { twMerge } from "tailwind-merge";
|
|
|
|
// export function cn(...inputs: ClassValue[]) {
|
|
// return twMerge(clsx(inputs));
|
|
// }
|
|
export async function fetcher<JSON = any>(
|
|
input: RequestInfo,
|
|
init?: RequestInit,
|
|
): Promise<JSON> {
|
|
const response = await fetch(input, { ...init, cache: "no-store" });
|
|
|
|
return response.json();
|
|
}
|
|
|
|
export const capitalize = (s: string) => {
|
|
if (typeof s !== "string") return "";
|
|
return s.charAt(0).toUpperCase() + s.slice(1);
|
|
};
|
|
|
|
export const truncate = (str: string, num: number) => {
|
|
if (!str) return "";
|
|
if (str.length <= num) {
|
|
return str;
|
|
}
|
|
return str.slice(0, num) + "...";
|
|
};
|
|
|
|
export const getBlurDataURL = async (url: string | null) => {
|
|
if (!url) {
|
|
return "";
|
|
}
|
|
try {
|
|
const response = await fetch(
|
|
`https://wsrv.nl/?url=${url}&w=50&h=50&blur=5`,
|
|
);
|
|
const buffer = await response.arrayBuffer();
|
|
const base64 = Buffer.from(buffer).toString("base64");
|
|
|
|
return `data:image/png;base64,${base64}`;
|
|
} catch (error) {
|
|
return "";
|
|
}
|
|
};
|
|
|
|
export const placeholderBlurhash =
|
|
"";
|
|
|
|
export const toDateString = (date: Date) => {
|
|
return new Date(date).toLocaleDateString("en-US", {
|
|
month: "short",
|
|
day: "numeric",
|
|
year: "numeric",
|
|
});
|
|
};
|
|
|
|
export const random = (min: number, max: number) => {
|
|
return Math.floor(Math.random() * (max - min + 1) + min);
|
|
};
|