mirror of
https://github.com/dyzulk/trustlab.git
synced 2026-01-26 21:41:52 +07:00
71 lines
1.9 KiB
TypeScript
71 lines
1.9 KiB
TypeScript
"use client";
|
|
import React, { useState } from "react";
|
|
import ComponentCard from "../../common/ComponentCard";
|
|
import Input from "../input/InputField";
|
|
import Label from "../Label";
|
|
|
|
export default function InputStates() {
|
|
const [email, setEmail] = useState("");
|
|
const [error, setError] = useState(false);
|
|
|
|
// Simulate a validation check
|
|
const validateEmail = (value: string) => {
|
|
const isValidEmail =
|
|
/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(value);
|
|
setError(!isValidEmail);
|
|
return isValidEmail;
|
|
};
|
|
|
|
const handleEmailChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
const value = e.target.value;
|
|
setEmail(value);
|
|
validateEmail(value);
|
|
};
|
|
return (
|
|
<ComponentCard
|
|
title="Input States"
|
|
desc="Validation styles for error, success and disabled states on form controls."
|
|
>
|
|
<div className="space-y-5 sm:space-y-6">
|
|
{/* Error Input */}
|
|
<div>
|
|
<Label>Email</Label>
|
|
<Input
|
|
type="email"
|
|
defaultValue={email}
|
|
error={error}
|
|
onChange={handleEmailChange}
|
|
placeholder="Enter your email"
|
|
hint={error ? "This is an invalid email address." : ""}
|
|
/>
|
|
</div>
|
|
|
|
{/* Success Input */}
|
|
<div>
|
|
<Label>Email</Label>
|
|
<Input
|
|
type="email"
|
|
defaultValue={email}
|
|
success={!error}
|
|
onChange={handleEmailChange}
|
|
placeholder="Enter your email"
|
|
hint={!error ? "Valid email!" : ""}
|
|
/>
|
|
</div>
|
|
|
|
{/* Disabled Input */}
|
|
<div>
|
|
<Label>Email</Label>
|
|
<Input
|
|
type="text"
|
|
defaultValue="disabled@example.com"
|
|
disabled={true}
|
|
placeholder="Disabled email"
|
|
hint="This field is disabled."
|
|
/>
|
|
</div>
|
|
</div>
|
|
</ComponentCard>
|
|
);
|
|
}
|