Files
Nexora/resources/views/components/folder-item.blade.php
2025-10-25 11:29:20 +02:00

37 lines
1.7 KiB
PHP

@props(['folder', 'currentFolder', 'expandedFolders', 'level' => 0, 'itemsCount' => 0])
<li class="pl-{{ $level * 4 }}">
<div class="flex items-center justify-between p-1 hover:bg-gray-50
{{ $folder->id === optional($currentFolder)->id ? 'bg-blue-50' : '' }}">
<div class="flex items-center relative 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 icon="chevron-down" class="w-4 h-4" />
@else
<x-icons icon="chevron-right" class="w-4 h-4" />
@endif
</button>
@if(in_array($folder->id, $expandedFolders))
<flux:icon.folder-open class="size-5 mr-2"/>
@else
<flux:icon.folder class="size-5 mr-2"/>
@endif
<span class="flex-1 whitespace-nowrap">{{ $folder->name }}</span>
@if($itemsCount > 0)
<flux:badge class="text-xs font-medium rounded-sm px-1 py-0.5 text-gray-700 dark:text-gray-200 bg-gray-400/15 dark:bg-white/10" size="sm" inset="top bottom">{{ $itemsCount }}</flux:badge>
@endif
</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>