mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig-portal.git
synced 2025-12-11 06:46:47 +00:00
filters changed
This commit is contained in:
15
app/Http/Livewire/BookCase/CityTable.php
Normal file
15
app/Http/Livewire/BookCase/CityTable.php
Normal file
@@ -0,0 +1,15 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Livewire\BookCase;
|
||||
|
||||
use App\Models\Country;
|
||||
use Livewire\Component;
|
||||
|
||||
class CityTable extends Component
|
||||
{
|
||||
public Country $country;
|
||||
public function render()
|
||||
{
|
||||
return view('livewire.book-case.city-table');
|
||||
}
|
||||
}
|
||||
@@ -3,6 +3,7 @@
|
||||
namespace App\Http\Livewire\Tables;
|
||||
|
||||
use App\Models\BitcoinEvent;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
||||
use Rappasoft\LaravelLivewireTables\Views\Column;
|
||||
|
||||
@@ -56,4 +57,10 @@ class BitcoinEventTable extends DataTableComponent
|
||||
->sortable(),
|
||||
];
|
||||
}
|
||||
|
||||
public function builder(): Builder
|
||||
{
|
||||
return BitcoinEvent::query()
|
||||
->whereHas('venue.city.country', fn($query) => $query->where('code', $this->country));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -49,6 +49,7 @@ class BookCaseTable extends DataTableComponent
|
||||
{
|
||||
return [
|
||||
TextFilter::make('By IDs', 'byids')
|
||||
->hiddenFromMenus()
|
||||
->filter(function (Builder $builder, string $value) {
|
||||
$builder->whereIn('id', str($value)->explode(','));
|
||||
}),
|
||||
|
||||
@@ -14,6 +14,7 @@ class CityTable extends DataTableComponent
|
||||
use Actions;
|
||||
|
||||
public string $country;
|
||||
public string $type;
|
||||
|
||||
protected $model = City::class;
|
||||
|
||||
@@ -39,25 +40,36 @@ class CityTable extends DataTableComponent
|
||||
|
||||
public function columns(): array
|
||||
{
|
||||
return [
|
||||
Column::make("Stadt Name", "name")
|
||||
->sortable()
|
||||
->searchable(),
|
||||
Column::make('Veranstaltungs-Orte')
|
||||
->label(
|
||||
fn($row, Column $column) => $row->venues_count
|
||||
)
|
||||
->collapseOnMobile(),
|
||||
Column::make('Termine')
|
||||
->label(
|
||||
fn($row, Column $column) => $row->events_count
|
||||
)
|
||||
->collapseOnMobile(),
|
||||
Column::make('')
|
||||
->label(
|
||||
fn($row, Column $column) => view('columns.cities.action')->withRow($row)
|
||||
),
|
||||
];
|
||||
$columns = collect([]);
|
||||
if($this->type === 'school') {
|
||||
$columns = $columns->merge([
|
||||
Column::make('Veranstaltungs-Orte')
|
||||
->label(
|
||||
fn($row, Column $column) => $row->venues_count
|
||||
)
|
||||
->collapseOnMobile(),
|
||||
Column::make('Termine')
|
||||
->label(
|
||||
fn($row, Column $column) => $row->events_count
|
||||
)
|
||||
->collapseOnMobile(),
|
||||
]);
|
||||
}
|
||||
if ($this->type === 'bookCase') {
|
||||
$columns = $columns->merge([
|
||||
Column::make("Stadt Name", "name")
|
||||
->sortable()
|
||||
->searchable(),
|
||||
Column::make('')
|
||||
->label(
|
||||
fn($row, Column $column) => view('columns.cities.action')
|
||||
->withRow($row)
|
||||
->withType($this->type)
|
||||
),
|
||||
]);
|
||||
}
|
||||
|
||||
return $columns->toArray();
|
||||
}
|
||||
|
||||
public function builder(): Builder
|
||||
@@ -94,13 +106,18 @@ class CityTable extends DataTableComponent
|
||||
$city = City::query()
|
||||
->find($id);
|
||||
$query = BookCase::radius($city->latitude, $city->longitude, 5);
|
||||
$ids = $query->pluck('id');
|
||||
if ($ids->isEmpty()) {
|
||||
$this->notification()
|
||||
->error(__('No bookcases found in the radius of 5km'));
|
||||
return;
|
||||
}
|
||||
|
||||
return to_route('bookCases.table.bookcases', [
|
||||
'#table',
|
||||
'country' => $this->country,
|
||||
'table' => [
|
||||
'table' => [
|
||||
'filters' => [
|
||||
'byids' => $query->pluck('id')
|
||||
->implode(',')
|
||||
'byids' => $ids->implode(',')
|
||||
],
|
||||
]
|
||||
]);
|
||||
|
||||
@@ -71,6 +71,7 @@ class MeetupEventTable extends DataTableComponent
|
||||
public function builder(): Builder
|
||||
{
|
||||
return MeetupEvent::query()
|
||||
->whereHas('meetup.city.country', fn($query) => $query->where('code', $this->country))
|
||||
->with([
|
||||
'meetup',
|
||||
]);
|
||||
|
||||
@@ -55,6 +55,7 @@ class MeetupTable extends DataTableComponent
|
||||
public function builder(): Builder
|
||||
{
|
||||
return Meetup::query()
|
||||
->whereHas('city.country', fn($query) => $query->where('code', $this->country))
|
||||
->withCount([
|
||||
'meetupEvents',
|
||||
]);
|
||||
@@ -64,7 +65,7 @@ class MeetupTable extends DataTableComponent
|
||||
{
|
||||
return to_route('meetup.table.meetupEvent', [
|
||||
'country' => $this->country,
|
||||
'table' => [
|
||||
'table' => [
|
||||
'filters' => ['id' => $id],
|
||||
]
|
||||
]);
|
||||
|
||||
Reference in New Issue
Block a user