Radio Button and Checkbox Created

This commit is contained in:
2025-07-30 23:10:17 -04:00
parent cb8c2c23be
commit f6f77c9d42
29 changed files with 892 additions and 18 deletions

View File

@@ -1,20 +1,84 @@
import { useRef } from "react";
import type { FileInputProps } from "$/types/Input";
import { humanReadableBytes } from "$/util/FileUtil";
import clsx from "clsx";
import { useEffect, useRef, useState } from "react";
export default function DragAndDropFileInput(){
export default function DragAndDropFileInput({
id,
className,
name,
minSize,
maxSize,
showFileName,
showSize,
onChange,
disabled,
children
}: FileInputProps){
const [ file, setFile ] = useState<File>();
const inputRef = useRef<HTMLInputElement>(null);
useEffect(() => {
onChange?.(file);
}, [ file ]);
return (
<div
className="relative border-2 rounded-lg w-full h-full cursor-pointer"
<label
className={clsx(
"flex flex-col items-center justify-center border-2 rounded-lg w-full h-full cursor-pointer",
className
)}
onDragOver={(e) => e.preventDefault()}
onDrop={(e) => {
e.preventDefault();
setFile(e.dataTransfer.files[0]);
if(inputRef.current){ inputRef.current.files = e.dataTransfer.files; }
}}
>
<input
ref={inputRef}
type="file"
id={id}
className="sr-only"
name={name}
onChange={(e) => setFile(e.target.files?.[0])}
disabled={disabled}
/>
Drag And Drop File Input
</div>
<div
className="flex flex-col items-center justify-between w-full h-full px-2"
>
{children}
<div
className="flex flex-row items-center justify-between gap-x-8 w-full"
>
{
showFileName &&
<div
className="text-center"
>
{file?.name}
</div>
}
{
showSize &&
<div
className={clsx(
{
"text-red-600": minSize && file?.size && file?.size < minSize,
"text-red-600 ": maxSize && file?.size && file?.size > maxSize,
"text-green-600": minSize && !maxSize && file?.size && file?.size > minSize,
"text-green-600 ": !minSize && maxSize && file?.size && file?.size < maxSize,
" text-green-600": minSize && maxSize && file?.size && file?.size > minSize && file?.size < maxSize
}
)}
>
{humanReadableBytes(file?.size ?? 0)}
</div>
}
</div>
</div>
</label>
);
}

View File

@@ -23,16 +23,16 @@ export default function FileInput({
return (
<div
className="flex flex-row items-center justify-between w-full border-2 rounded-lg"
className={clsx(
"flex flex-row items-center justify-between w-full border-2 rounded-lg",
className
)}
>
<input
ref={inputRef}
id={id}
type="file"
className={clsx(
"sr-only",
className
)}
className="sr-only"
name={name}
onChange={(e) => { setFile(e.target.files?.[0]); onChange?.(e.target.files?.[0]); }}
disabled={disabled}
@@ -76,6 +76,7 @@ export default function FileInput({
className="text-nowrap rounded-r-lg"
rounding="none"
onClick={() => { inputRef.current?.click(); }}
disabled={disabled}
>
Click Me
</SecondaryButton>