Previews

No matching results.

x
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
<div class="form-field-wrapper">
<label for="user[password]" class="block font-medium text-gray-700 mb-1 text-sm">
Password
</label>
<div class="relative flex items-center" data-controller="better-ui--forms--password-input">
<input name="user[password]" placeholder="Enter your password" class="block w-full rounded-md border shadow-sm transition-colors duration-200 text-base py-2 px-4 border-gray-300 bg-white text-gray-900 placeholder-gray-400 focus:border-primary-500 focus:ring-2 focus:ring-primary-500 focus:ring-opacity-20 focus:outline-none pr-10" type="password" data-better-ui--forms--password-input-target="input" />
<div class="absolute inset-y-0 right-0 flex items-center px-4">
<button
type="button"
tabindex="-1"
class="text-gray-400 hover:text-gray-600 focus:outline-none focus:text-gray-600 transition-colors duration-150"
data-action="mousedown->better-ui--forms--password-input#toggle"
aria-label="Toggle password visibility"
>
<!-- Eye icon (shown when password is hidden) -->
<svg
class="w-5 h-5"
fill="none"
stroke="currentColor"
viewBox="0 0 24 24"
xmlns="http://www.w3.org/2000/svg"
data-better-ui--forms--password-input-target="eyeIcon"
>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z" />
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z" />
</svg>
<!-- Eye-slash icon (shown when password is visible) -->
<svg
class="w-5 h-5 hidden"
fill="none"
stroke="currentColor"
viewBox="0 0 24 24"
xmlns="http://www.w3.org/2000/svg"
data-better-ui--forms--password-input-target="eyeSlashIcon"
>
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.88 9.88l-3.29-3.29m7.532 7.532l3.29 3.29M3 3l3.59 3.59m0 0A9.953 9.953 0 0112 5c4.478 0 8.268 2.943 9.543 7a10.025 10.025 0 01-4.132 5.411m0 0L21 21" />
</svg>
</button>
</div>
</div>
</div>
1
2
3
4
5
render BetterUi::Forms::PasswordInputComponent.new(
name: "user[password]",
label: "Password",
placeholder: "Enter your password"
)