Files
investbrain/resources/views/components/ib-textarea.blade.php
T

61 lines
1.8 KiB
PHP
Raw Normal View History

2024-10-21 23:02:18 -05:00
@props([
'uuid' => md5(rand()),
'label' => '',
'hint' => '',
'errorField' => '',
'rows' => 4
])
<div class="mt-1">
<!-- STANDARD LABEL -->
@if($label)
<label for="{{ $uuid }}" class="pt-0 label label-text font-semibold">
<span>
{{ $label }}
@if($attributes->get('required'))
<span class="text-error">*</span>
@endif
</span>
</label>
@endif
<textarea {{ $attributes
->merge([
'id' => $uuid
])
->class([
'textarea textarea-primary w-full peer',
'border border-dashed' => $attributes->has('readonly') && $attributes->get('readonly') == true,
'textarea-error' => $errors->has($errorField)
])
}}
x-data="{
resize (rows) {
$el.style.height = '0px';
2024-10-28 13:07:45 -05:00
$el.style.height = ($el.scrollHeight >= rows * 32 ? $el.scrollHeight : rows * 32) + 'px';
2024-10-21 23:02:18 -05:00
}
}"
x-init="resize({{$rows}})"
2024-10-28 13:07:45 -05:00
@input="resize({{$rows}})"
2024-10-21 23:02:18 -05:00
type="text"
placeholder = "{{ $attributes->whereStartsWith('placeholder')->first() }}"
>{{ $slot }}</textarea>
@if($errors->has($errorField))
@foreach($errors->get($errorField) as $message)
@foreach(Arr::wrap($message) as $line)
<div class="{{ $errorClass }}" x-classes="text-red-500 label-text-alt p-1">{{ $line }}</div>
@break($firstErrorOnly)
@endforeach
@break($firstErrorOnly)
@endforeach
@endif
<!-- HINT -->
@if($hint)
<div x-classes="label-text-alt text-gray-400 py-1 pb-0">{{ $hint }}</div>
@endif
</div>