46 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| @props([
 | |
|     'id',
 | |
|     'label' => null,
 | |
|     'helper' => null,
 | |
|     'disabled' => false,
 | |
|     'instantSave' => false,
 | |
|     'value' => null,
 | |
|     'domValue' => null,
 | |
|     'checked' => false,
 | |
|     'fullWidth' => false,
 | |
| ])
 | |
| 
 | |
| <div @class([
 | |
|     'flex flex-row items-center gap-4 pr-2 py-1 form-control min-w-fit dark:hover:bg-coolgray-100',
 | |
|     'w-full' => $fullWidth,
 | |
| ])>
 | |
|     <label @class([
 | |
|         'flex gap-4 items-center px-0 min-w-fit label w-full cursor-pointer',
 | |
|     ])>
 | |
|         <span class="flex flex-grow gap-2">
 | |
|             @if ($label)
 | |
|                 {!! $label !!}
 | |
|             @else
 | |
|                 {{ $id }}
 | |
|             @endif
 | |
|             @if ($helper)
 | |
|                 <x-helper :helper="$helper" />
 | |
|             @endif
 | |
|         </span>
 | |
|         @if ($instantSave)
 | |
|             <input type="checkbox" @disabled($disabled) {{ $attributes->merge(['class' => $defaultClass]) }}
 | |
|                 wire:loading.attr="disabled"
 | |
|                 wire:click='{{ $instantSave === 'instantSave' || $instantSave == '1' ? 'instantSave' : $instantSave }}'
 | |
|                 wire:model={{ $id }} @if ($checked) checked @endif />
 | |
|         @else
 | |
|             @if ($domValue)
 | |
|                 <input type="checkbox" @disabled($disabled) {{ $attributes->merge(['class' => $defaultClass]) }}
 | |
|                     value={{ $domValue }} @if ($checked) checked @endif />
 | |
|             @else
 | |
|                 <input type="checkbox" @disabled($disabled) {{ $attributes->merge(['class' => $defaultClass]) }}
 | |
|                     wire:model={{ $value ?? $id }} @if ($checked) checked @endif />
 | |
|             @endif
 | |
|         @endif
 | |
|     </label>
 | |
| </div>
 | 
