33 lines
1.3 KiB
PHP
33 lines
1.3 KiB
PHP
@props(['folder', 'currentFolder', 'expandedFolders', 'level' => 0])
|
|
|
|
<li class="pl-{{ $level * 4 }}">
|
|
<div class="flex items-center justify-between p-2 hover:bg-gray-50
|
|
{{ $folder->id === optional($currentFolder)->id ? 'bg-blue-50' : '' }}">
|
|
<div class="flex items-center flex-1" wire:click="selectFolder({{ $folder->id }})">
|
|
<button wire:click.prevent="toggleFolder({{ $folder->id }})"
|
|
class="mr-2">
|
|
@if(in_array($folder->id, $expandedFolders))
|
|
<x-icons.chevron-down class="w-4 h-4" />
|
|
@else
|
|
<x-icons.chevron-right class="w-4 h-4" />
|
|
@endif
|
|
</button>
|
|
<x-icons.folder class="w-5 h-5 mr-2 text-yellow-500" />
|
|
<span>{{ $folder->name }}</span>
|
|
</div>
|
|
</div>
|
|
|
|
@if(in_array($folder->id, $expandedFolders))
|
|
<ul class="ml-4">
|
|
@foreach($folder->children as $child)
|
|
<x-folder-item
|
|
:folder="$child"
|
|
:currentFolder="$currentFolder"
|
|
:expandedFolders="$expandedFolders"
|
|
:level="$level + 1"
|
|
wire:key="folder-{{ $child->id }}"
|
|
/>
|
|
@endforeach
|
|
</ul>
|
|
@endif
|
|
</li> |