mirror of
https://github.com/documenso/documenso.git
synced 2025-11-10 12:32:34 +10:00
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
import * as React from 'react';
|
|
|
|
import { Eye, EyeOff } from 'lucide-react';
|
|
|
|
import { cn } from '../lib/utils';
|
|
import { Button } from './button';
|
|
import type { InputProps } from './input';
|
|
import { Input } from './input';
|
|
|
|
const PasswordInput = React.forwardRef<HTMLInputElement, Omit<InputProps, 'type'>>(
|
|
({ className, ...props }, ref) => {
|
|
const [showPassword, setShowPassword] = React.useState(false);
|
|
|
|
return (
|
|
<div className="relative">
|
|
<Input
|
|
type={showPassword ? 'text' : 'password'}
|
|
className={cn('pr-10', className)}
|
|
ref={ref}
|
|
{...props}
|
|
/>
|
|
|
|
<Button
|
|
variant="link"
|
|
type="button"
|
|
className="absolute right-0 top-0 flex h-full items-center justify-center pr-3"
|
|
aria-label={showPassword ? 'Mask password' : 'Reveal password'}
|
|
onClick={() => setShowPassword((show) => !show)}
|
|
>
|
|
{showPassword ? (
|
|
<EyeOff aria-hidden className="text-muted-foreground h-5 w-5" />
|
|
) : (
|
|
<Eye aria-hidden className="text-muted-foreground h-5 w-5" />
|
|
)}
|
|
</Button>
|
|
</div>
|
|
);
|
|
},
|
|
);
|
|
|
|
PasswordInput.displayName = 'PasswordInput';
|
|
|
|
export { PasswordInput };
|