feat(map): filtros por columna en cabecera (elementos e inspecciones)
Usa la cabecera secundaria de Rappasoft (setSecondaryHeaderEnabled + secondaryHeaderFilter): - Elementos: Elemento (texto), Capa (select), Fase (select). - Inspecciones: Fecha (date), Elemento (texto), Resultado (select), Usuario (select); Plantilla sin filtro. Tests: MapTablesTest amplía con filtro de capa funcional. Suite 75 passing. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -3,12 +3,15 @@
|
||||
namespace App\Livewire\Projects;
|
||||
|
||||
use App\Models\Feature;
|
||||
use App\Models\Layer;
|
||||
use App\Models\Phase;
|
||||
use App\Models\Project;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
||||
use Rappasoft\LaravelLivewireTables\Views\Column;
|
||||
use Rappasoft\LaravelLivewireTables\Views\Filters\SelectFilter;
|
||||
use Rappasoft\LaravelLivewireTables\Views\Filters\TextFilter;
|
||||
|
||||
class FeatureTable extends DataTableComponent
|
||||
{
|
||||
@@ -21,6 +24,7 @@ class FeatureTable extends DataTableComponent
|
||||
$this->setPrimaryKey('id')
|
||||
->setDefaultSort('name', 'asc')
|
||||
->setSortingPillsEnabled(false)
|
||||
->setSecondaryHeaderEnabled()
|
||||
->setAdditionalSelects(['features.id as id', 'features.layer_id as layer_id']);
|
||||
}
|
||||
|
||||
@@ -44,13 +48,16 @@ class FeatureTable extends DataTableComponent
|
||||
Column::make('Elemento', 'name')
|
||||
->sortable()
|
||||
->searchable()
|
||||
->secondaryHeaderFilter('name')
|
||||
->format(fn ($value) => '<span class="font-medium">' . e($value) . '</span>')
|
||||
->html(),
|
||||
|
||||
Column::make('Capa')
|
||||
->secondaryHeaderFilter('layer')
|
||||
->label(fn ($row) => e($row->layer?->name ?? '—')),
|
||||
|
||||
Column::make('Fase')
|
||||
->secondaryHeaderFilter('phase')
|
||||
->label(fn ($row) => e($row->layer?->phase?->name ?? '—')),
|
||||
|
||||
Column::make('Progreso', 'progress')
|
||||
@@ -76,17 +83,23 @@ class FeatureTable extends DataTableComponent
|
||||
|
||||
public function filters(): array
|
||||
{
|
||||
$layers = Layer::whereHas('phase', fn ($q) => $q->where('project_id', $this->projectId))
|
||||
->orderBy('name')->pluck('name', 'id')->toArray();
|
||||
$phases = Phase::where('project_id', $this->projectId)
|
||||
->orderBy('order')->pluck('name', 'id')->toArray();
|
||||
|
||||
return [
|
||||
SelectFilter::make('Progreso', 'progress')
|
||||
->options(['' => 'Progreso: todos', 'pending' => 'Sin iniciar', 'in_progress' => 'En curso', 'done' => 'Completado'])
|
||||
->filter(function (Builder $query, string $value) {
|
||||
match ($value) {
|
||||
'pending' => $query->where('features.progress', '=', 0),
|
||||
'in_progress' => $query->where('features.progress', '>', 0)->where('features.progress', '<', 100),
|
||||
'done' => $query->where('features.progress', '>=', 100),
|
||||
default => null,
|
||||
};
|
||||
}),
|
||||
TextFilter::make('Elemento', 'name')
|
||||
->config(['placeholder' => 'Buscar elemento…'])
|
||||
->filter(fn (Builder $query, string $value) => $query->where('features.name', 'like', '%' . $value . '%')),
|
||||
|
||||
SelectFilter::make('Capa', 'layer')
|
||||
->options(['' => 'Todas'] + $layers)
|
||||
->filter(fn (Builder $query, string $value) => $query->where('features.layer_id', $value)),
|
||||
|
||||
SelectFilter::make('Fase', 'phase')
|
||||
->options(['' => 'Todas'] + $phases)
|
||||
->filter(fn (Builder $query, string $value) => $query->whereHas('layer', fn ($l) => $l->where('phase_id', $value))),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user