101 lines
2.5 KiB
TypeScript
Raw Permalink Normal View History

2024-05-26 12:18:09 -07:00
import { type ClassValue, clsx } from "clsx"
2024-04-30 01:56:43 -04:00
// import { toast } from "sonner"
2024-05-26 12:18:09 -07:00
import { twMerge } from "tailwind-merge"
import { Sandbox, TFile, TFolder } from "./types"
import fileExtToLang from "./file-extension-to-language.json"
2024-04-06 19:03:04 -04:00
export function cn(...inputs: ClassValue[]) {
2024-05-26 12:18:09 -07:00
return twMerge(clsx(inputs))
2024-04-06 19:03:04 -04:00
}
2024-04-27 00:28:00 -04:00
export function processFileType(file: string) {
const extension = file.split(".").pop()
const fileExtToLangMap = fileExtToLang as Record<string, string>
if (extension && fileExtToLangMap[extension]) {
return fileExtToLangMap[extension]
}
2024-04-27 00:28:00 -04:00
2024-05-26 12:18:09 -07:00
return "plaintext"
2024-04-27 00:28:00 -04:00
}
2024-04-28 20:06:47 -04:00
2024-04-29 00:50:25 -04:00
export function validateName(
newName: string,
oldName: string,
type: "file" | "folder"
) {
2024-05-05 12:55:34 -07:00
if (newName === oldName || newName.length === 0) {
2024-05-26 12:18:09 -07:00
return { status: false, message: "" }
2024-05-05 12:55:34 -07:00
}
2024-04-29 00:50:25 -04:00
if (
newName.includes("/") ||
newName.includes("\\") ||
newName.includes(" ") ||
(type === "file" && !newName.includes(".")) ||
(type === "folder" && newName.includes("."))
) {
2024-05-26 12:18:09 -07:00
return { status: false, message: "Invalid file name." }
2024-04-29 00:50:25 -04:00
}
2024-05-26 12:18:09 -07:00
return { status: true, message: "" }
2024-04-29 00:50:25 -04:00
}
2024-05-11 18:03:42 -07:00
2024-05-13 22:04:00 -07:00
export function addNew(
name: string,
type: "file" | "folder",
setFiles: React.Dispatch<React.SetStateAction<(TFolder | TFile)[]>>,
sandboxData: Sandbox
) {
2024-05-11 18:03:42 -07:00
if (type === "file") {
setFiles((prev) => [
...prev,
{ id: `projects/${sandboxData.id}/${name}`, name, type: "file" },
2024-05-26 12:18:09 -07:00
])
2024-05-11 18:03:42 -07:00
} else {
2024-05-26 12:18:09 -07:00
console.log("adding folder")
2024-05-13 22:04:00 -07:00
setFiles((prev) => [
...prev,
{
id: `projects/${sandboxData.id}/${name}`,
name,
type: "folder",
children: [],
},
2024-05-26 12:18:09 -07:00
])
2024-05-11 18:03:42 -07:00
}
}
export function debounce<T extends (...args: any[]) => void>(
func: T,
wait: number
): T {
let timeout: NodeJS.Timeout | null = null
return function (...args: Parameters<T>) {
if (timeout) {
clearTimeout(timeout)
}
timeout = setTimeout(() => func(...args), wait)
} as T
}
// Deep merge utility function
export const deepMerge = (target: any, source: any) => {
const output = { ...target }
if (isObject(target) && isObject(source)) {
Object.keys(source).forEach((key) => {
if (isObject(source[key])) {
if (!(key in target)) {
Object.assign(output, { [key]: source[key] })
} else {
output[key] = deepMerge(target[key], source[key])
}
} else {
Object.assign(output, { [key]: source[key] })
}
})
}
return output
}
const isObject = (item: any) => {
return item && typeof item === "object" && !Array.isArray(item)
}