forked from deriv-com/ui
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.tsx
80 lines (76 loc) · 1.91 KB
/
index.tsx
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import React, { ComponentProps, ReactNode } from "react";
import clsx from "clsx";
import HelperMessage from "./HelperMessage";
import "./Input.scss";
export type InputVariants = "general" | "success" | "error";
interface InputProps
extends Omit<ComponentProps<"input">, "style" | "placeholder"> {
label?: string;
leftPlaceholder?: ReactNode;
rightPlaceholder?: ReactNode;
error?: boolean;
variant?: InputVariants;
message?: ReactNode;
}
const InputVariant: Record<InputVariants, string> = {
general: "deriv-input--field__general",
success: "deriv-input--field__success",
error: "deriv-input--field__error",
};
const LabelVariant: Record<InputVariants, string> = {
general: "deriv-input--label__general",
success: "deriv-input--label__success",
error: "deriv-input--label__error",
};
export const Input = ({
label,
id,
error,
message,
leftPlaceholder,
rightPlaceholder,
variant = "general",
className,
disabled,
...rest
}: InputProps) => {
return (
<div className="deriv-input">
{leftPlaceholder && (
<div className="deriv-input--left-content">{leftPlaceholder}</div>
)}
<input
placeholder={label}
className={clsx(
"deriv-input--field",
className,
InputVariant[error ? "error" : variant]
)}
id={id}
{...rest}
/>
<label
className={clsx(
"deriv-input--label",
LabelVariant[error ? "error" : variant]
)}
htmlFor={id}
>
{label}
</label>
{rightPlaceholder && (
<div className="deriv-input--right-content">{rightPlaceholder}</div>
)}
<div className="deriv-input--helper-message">
{message && (
<HelperMessage
message={message}
variant={variant}
error={error}
disabled={disabled}
/>
)}
</div>
</div>
);
};