Files
einundzwanzig-portal/app/Http/Livewire/Tables/CityTable.php
2022-12-01 22:29:53 +01:00

63 lines
1.8 KiB
PHP

<?php
namespace App\Http\Livewire\Tables;
use App\Models\City;
use Illuminate\Database\Eloquent\Builder;
use Rappasoft\LaravelLivewireTables\DataTableComponent;
use Rappasoft\LaravelLivewireTables\Views\Column;
use WireUi\Traits\Actions;
class CityTable extends DataTableComponent
{
use Actions;
public string $country;
protected $model = City::class;
public function configure(): void
{
$this->setPrimaryKey('id')
->setAdditionalSelects(['id']);
}
public function columns(): array
{
return [
Column::make("Stadt Name", "name")
->sortable()
->searchable(),
Column::make('Veranstaltungs-Orte')
->label(
fn($row, Column $column) => random_int(0, 100)
),
Column::make('Kurse')
->label(
fn($row, Column $column) => random_int(0, 100)
),
Column::make('')
->label(
fn($row, Column $column) => view('columns.cities.action')->withRow($row)
),
];
}
public function builder(): Builder
{
return City::query()
->whereHas('country', fn($query) => $query->where('code', $this->country));
}
public function proximitySearch($id)
{
$city = City::query()
->find($id);
$query = City::radius($city->latitude, $city->longitude, 100)
->where('id', '!=', $id);
$this->notification()
->success('Proximity Search', 'Found '.$query->count().' cities. '.$query->pluck('name')
->implode(', '));
}
}