128 lines
8.9 KiB
PHP
128 lines
8.9 KiB
PHP
<div>
|
|
<div class="mb-6">
|
|
<a href="{{ route('territori.index') }}" class="inline-flex items-center gap-1 text-sm text-gray-500 hover:text-indigo-600 transition-colors mb-1">
|
|
<svg class="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 19l-7-7 7-7"/></svg>
|
|
Torna ai territori
|
|
</a>
|
|
<h1 class="text-2xl font-bold text-gray-900">Assegnazioni</h1>
|
|
<p class="text-sm text-gray-500 mt-1">Questa funzione consente un'assegnazione arbitraria, indipendente dalle tre schede della Home.</p>
|
|
</div>
|
|
|
|
<div class="bg-white rounded-xl shadow-sm border border-gray-200 p-4 sm:p-6 max-w-3xl">
|
|
<form wire:submit="save" class="space-y-4">
|
|
<div>
|
|
@if(!$preselectedTerritorioId)
|
|
<label for="territorio_search" class="block text-sm font-medium text-gray-700">Filtra territori</label>
|
|
<input wire:model.live.debounce.300ms="territorioSearch"
|
|
type="text"
|
|
id="territorio_search"
|
|
placeholder="Cerca per numero, zona o tipologia"
|
|
class="mt-1 mb-2 block w-full rounded-lg border-gray-300 shadow-sm focus:ring-indigo-500 focus:border-indigo-500 text-sm">
|
|
@endif
|
|
|
|
<label for="territorio_id" class="block text-sm font-medium text-gray-700">Territorio *</label>
|
|
<select wire:model.live="territorio_id" id="territorio_id" class="mt-1 block w-full rounded-lg border-gray-300 shadow-sm focus:ring-indigo-500 focus:border-indigo-500 text-sm" @if($preselectedTerritorioId) disabled @endif>
|
|
<option value="">Seleziona un territorio</option>
|
|
@foreach($territoriDisponibili as $t)
|
|
<option value="{{ $t->id }}">N° {{ $t->numero }} — {{ $t->zona?->nome }} ({{ $t->tipologia?->nome }})</option>
|
|
@endforeach
|
|
</select>
|
|
@if($preselectedTerritorioId)
|
|
<input type="hidden" wire:model="territorio_id" value="{{ $preselectedTerritorioId }}">
|
|
@endif
|
|
@error('territorio_id') <p class="text-red-500 text-xs mt-1">{{ $message }}</p> @enderror
|
|
|
|
@if($territorio_id)
|
|
<div class="mt-3">
|
|
<p class="text-xs text-gray-500 mb-2">Anteprima territorio</p>
|
|
@if($this->selectedThumbnailUrl)
|
|
<div class="overflow-hidden rounded-xl border border-gray-200 bg-gray-50 shadow-sm">
|
|
<img src="{{ $this->selectedThumbnailUrl }}"
|
|
alt="Thumbnail territorio selezionato"
|
|
class="block w-full h-auto max-h-[70vh] object-contain bg-white">
|
|
</div>
|
|
<p class="mt-2 text-xs text-gray-500">Miniatura del territorio ottimizzata per consultazione rapida anche da mobile.</p>
|
|
@else
|
|
<div class="rounded-lg border border-dashed border-gray-300 bg-gray-50 px-4 py-6 text-sm text-gray-500">
|
|
Nessuna thumbnail disponibile per questo territorio.
|
|
</div>
|
|
@endif
|
|
</div>
|
|
@endif
|
|
</div>
|
|
|
|
<div>
|
|
<label for="proclamatore_id" class="block text-sm font-medium text-gray-700">Proclamatore *</label>
|
|
<select wire:model="proclamatore_id" id="proclamatore_id" class="mt-1 block w-full rounded-lg border-gray-300 shadow-sm focus:ring-indigo-500 focus:border-indigo-500 text-sm">
|
|
<option value="">Seleziona un proclamatore</option>
|
|
@foreach($proclamatoriAttivi as $p)
|
|
<option value="{{ $p->id }}">{{ $p->cognome }} {{ $p->nome }}</option>
|
|
@endforeach
|
|
</select>
|
|
@error('proclamatore_id') <p class="text-red-500 text-xs mt-1">{{ $message }}</p> @enderror
|
|
</div>
|
|
|
|
<div>
|
|
<label for="assigned_at" class="block text-sm font-medium text-gray-700">Data Assegnazione *</label>
|
|
<input wire:model="assigned_at" type="date" id="assigned_at" max="{{ now()->format('Y-m-d') }}" class="mt-1 block w-full rounded-lg border-gray-300 shadow-sm focus:ring-indigo-500 focus:border-indigo-500 text-sm">
|
|
@error('assigned_at') <p class="text-red-500 text-xs mt-1">{{ $message }}</p> @enderror
|
|
</div>
|
|
|
|
<div class="flex flex-col-reverse gap-3 pt-4 sm:flex-row sm:items-center">
|
|
<button type="submit" class="px-4 py-2 text-sm font-medium text-white bg-indigo-600 rounded-lg hover:bg-indigo-700 transition">Assegna</button>
|
|
<a href="{{ route('territori.index') }}" class="px-4 py-2 text-sm font-medium text-gray-700 bg-gray-100 rounded-lg hover:bg-gray-200 transition">Annulla</a>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
|
|
{{-- Elenco territori attualmente assegnati con link --}}
|
|
@if($assegnazioniAperte->count())
|
|
<div class="bg-white rounded-xl shadow-sm border border-gray-200 overflow-hidden mt-10">
|
|
<div class="px-5 py-4 border-b flex items-center gap-3" style="background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-color:#c7d2fe">
|
|
<div class="h-8 w-8 rounded-lg flex items-center justify-center" style="background:#6366f1">
|
|
<svg class="h-4 w-4 text-white" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13.828 10.172a4 4 0 00-5.656 0l-4 4a4 4 0 105.656 5.656l1.102-1.101m-.758-4.899a4 4 0 005.656 0l4-4a4 4 0 00-5.656-5.656l-1.1 1.1"/></svg>
|
|
</div>
|
|
<div>
|
|
<h3 class="text-sm font-semibold" style="color:#3730a3">Territori Assegnati ({{ $assegnazioniAperte->count() }})</h3>
|
|
<p class="text-xs" style="color:#4f46e5">Per ogni territorio è visibile il link da condividere</p>
|
|
</div>
|
|
</div>
|
|
<div class="divide-y divide-gray-100">
|
|
@foreach($assegnazioniAperte as $a)
|
|
@php($pdfUrl = $a->shortPdfUrl())
|
|
<div class="px-5 py-4 hover:bg-indigo-50/30 transition-colors">
|
|
<div class="flex items-center justify-between gap-4">
|
|
<div class="flex items-center gap-4">
|
|
<a href="{{ route('territori.show', $a->territorio_id) }}" class="text-indigo-600 hover:underline font-semibold text-sm">N° {{ $a->territorio?->numero }}</a>
|
|
<span class="text-xs text-gray-400">{{ $a->territorio?->zona?->nome }}</span>
|
|
</div>
|
|
<div class="flex items-center gap-5 text-sm">
|
|
<span class="text-gray-700">{{ $a->proclamatore?->nome_completo ?? 'N/A' }}</span>
|
|
<span class="text-gray-400">{{ $a->assigned_at->format('d/m/Y') }}</span>
|
|
<span class="text-xs font-medium {{ $a->giorni > 120 ? 'text-red-600' : ($a->giorni > 90 ? 'text-amber-600' : 'text-gray-500') }}">{{ $a->giorni }}g</span>
|
|
</div>
|
|
</div>
|
|
@if($pdfUrl)
|
|
<div x-data="{ copied: false }" class="mt-2 flex items-center gap-2">
|
|
<code class="flex-1 min-w-0 text-xs bg-gray-50 border border-gray-200 rounded-md px-3 py-2 text-gray-600 break-all select-all cursor-text" x-on:click="window.getSelection().selectAllChildren($el)">{{ $pdfUrl }}</code>
|
|
<button type="button"
|
|
x-on:click="
|
|
const text = $el.closest('div').querySelector('code').textContent;
|
|
navigator.clipboard.writeText(text).then(() => { copied = true; setTimeout(() => copied = false, 2000) });
|
|
"
|
|
class="flex-none btn-action btn-action-indigo" title="Copia link" style="padding:6px 10px">
|
|
<svg x-show="!copied" class="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 5H6a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2v-1M8 5a2 2 0 002 2h2a2 2 0 002-2M8 5a2 2 0 012-2h2a2 2 0 012 2m0 0h2a2 2 0 012 2v3m2 4H10m0 0l3-3m-3 3l3 3"/></svg>
|
|
<svg x-show="copied" x-cloak class="h-4 w-4 text-green-600" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"/></svg>
|
|
</button>
|
|
<span x-show="copied" x-cloak class="flex-none text-xs text-green-600 font-medium">Copiato!</span>
|
|
</div>
|
|
@else
|
|
<p class="mt-2 text-xs text-gray-300">Nessun PDF disponibile</p>
|
|
@endif
|
|
</div>
|
|
@endforeach
|
|
</div>
|
|
</div>
|
|
@endif
|
|
</div>
|