-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathindex.tsx
98 lines (94 loc) · 2.25 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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
import React, { ComponentProps, ReactNode } from "react";
import clsx from "clsx";
import HelperMessage from "./HelperMessage";
import "./Input.scss";
export type InputVariants =
| "general"
| "success"
| "error"
| "warning"
| "disabled";
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--general",
success: "deriv-input--success",
warning: "deriv-input--general",
error: "deriv-input--error",
disabled: "deriv-input--disabled",
};
const LabelVariant: Record<InputVariants, string> = {
general: "deriv-input__label--general",
success: "deriv-input__label--success",
warning: "deriv-input__label--general",
error: "deriv-input__label--error",
disabled: "deriv-input__label--disabled",
};
export const Input = ({
label,
id,
error,
message,
leftPlaceholder,
rightPlaceholder,
variant = "general",
className,
disabled,
...rest
}: InputProps) => {
return (
<div
className={clsx(
"deriv-input",
className,
InputVariant[error ? "error" : variant],
{
"deriv-input--disabled": disabled,
}
)}
>
{leftPlaceholder && (
<div className="deriv-input__left-content">{leftPlaceholder}</div>
)}
<input
placeholder={label}
className="deriv-input__field"
id={id}
disabled={disabled}
{...rest}
/>
<label
className={clsx(
"deriv-input__label",
LabelVariant[error ? "error" : variant],
{
"deriv-input--label--disabled": disabled,
}
)}
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>
);
};