mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig-portal.git
synced 2025-12-11 06:46:47 +00:00
recurring meetup events
This commit is contained in:
128
app/Http/Livewire/Meetup/Form/MeetupEventForm.php
Normal file
128
app/Http/Livewire/Meetup/Form/MeetupEventForm.php
Normal file
@@ -0,0 +1,128 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Livewire\Meetup\Form;
|
||||
|
||||
use App\Models\MeetupEvent;
|
||||
use App\Support\Carbon;
|
||||
use Livewire\Component;
|
||||
use WireUi\Traits\Actions;
|
||||
|
||||
class MeetupEventForm extends Component
|
||||
{
|
||||
use Actions;
|
||||
|
||||
public string $country;
|
||||
public ?MeetupEvent $meetupEvent = null;
|
||||
|
||||
public bool $recurring = false;
|
||||
public int $repetitions = 52;
|
||||
public array $series = [];
|
||||
|
||||
public function rules()
|
||||
{
|
||||
return [
|
||||
'meetupEvent.meetup_id' => 'required',
|
||||
'meetupEvent.start' => 'required',
|
||||
'meetupEvent.location' => 'string|nullable',
|
||||
'meetupEvent.description' => 'string|nullable',
|
||||
'meetupEvent.link' => 'string|url|nullable',
|
||||
|
||||
'series.*.start' => 'required',
|
||||
|
||||
'recurring' => 'bool',
|
||||
'repetitions' => 'numeric|min:1',
|
||||
];
|
||||
}
|
||||
|
||||
public function mount()
|
||||
{
|
||||
if (!$this->meetupEvent) {
|
||||
$this->meetupEvent = new MeetupEvent(
|
||||
[
|
||||
'start' => now()
|
||||
->startOfDay()
|
||||
->addHours(17),
|
||||
]
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
public function updatedMeetupEventStart($value)
|
||||
{
|
||||
if ($this->recurring) {
|
||||
$this->updatedRecurring(true);
|
||||
}
|
||||
}
|
||||
|
||||
public function updatedRecurring($value)
|
||||
{
|
||||
if ($value && $this->meetupEvent->start) {
|
||||
$this->series = [];
|
||||
for ($i = 0; $i < $this->repetitions; $i++) {
|
||||
$this->series[] = [
|
||||
'start' => $this->meetupEvent->start->addWeeks($i + 1)
|
||||
->toDateTimeString(),
|
||||
];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function updatedRepetitions($value)
|
||||
{
|
||||
if ($this->recurring) {
|
||||
$this->updatedRecurring(true);
|
||||
}
|
||||
}
|
||||
|
||||
public function submit()
|
||||
{
|
||||
$this->validate();
|
||||
if (!$this->meetupEvent->id) {
|
||||
$hasAppointmentsOnThisDate = MeetupEvent::query()
|
||||
->where('meetup_id', $this->meetupEvent->meetup_id)
|
||||
->where('start', '>', Carbon::parse($this->meetupEvent->start)
|
||||
->startOfDay())
|
||||
->where('start', '<', Carbon::parse($this->meetupEvent->start)
|
||||
->endOfDay())
|
||||
->exists();
|
||||
if ($hasAppointmentsOnThisDate) {
|
||||
$this->notification()
|
||||
->warning(__('There is already an event on this date. Please choose another date or delete the existing events.'));
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
$this->meetupEvent->save();
|
||||
|
||||
if (!$this->meetupEvent->id && $this->recurring) {
|
||||
foreach ($this->series as $event) {
|
||||
$hasAppointmentsOnThisDate = MeetupEvent::query()
|
||||
->where('meetup_id', $this->meetupEvent->meetup_id)
|
||||
->where('start', '>', Carbon::parse($event['start'])
|
||||
->startOfDay())
|
||||
->where('start', '<', Carbon::parse($event['start'])
|
||||
->endOfDay())
|
||||
->exists();
|
||||
|
||||
if ($hasAppointmentsOnThisDate) {
|
||||
continue;
|
||||
}
|
||||
|
||||
$this->meetupEvent->replicate()
|
||||
->fill($event)
|
||||
->saveQuietly();
|
||||
}
|
||||
}
|
||||
|
||||
$this->notification()
|
||||
->success(__('Event saved successfully.'));
|
||||
|
||||
return to_route('meetup.table.meetupEvent', ['country' => $this->country]);
|
||||
}
|
||||
|
||||
public function render()
|
||||
{
|
||||
return view('livewire.meetup.form.meetup-event-form');
|
||||
}
|
||||
}
|
||||
@@ -32,7 +32,14 @@ class MeetupEventTable extends DataTableComponent
|
||||
];
|
||||
})
|
||||
->setColumnSelectStatus(false)
|
||||
->setPerPage(10);
|
||||
->setPerPage(10)
|
||||
->setConfigurableAreas([
|
||||
'toolbar-left-end' => [
|
||||
'columns.meetup_events.areas.toolbar-left-end', [
|
||||
'country' => $this->country,
|
||||
],
|
||||
],
|
||||
]);
|
||||
}
|
||||
|
||||
public function filters(): array
|
||||
@@ -53,7 +60,7 @@ class MeetupEventTable extends DataTableComponent
|
||||
|
||||
public function columns(): array
|
||||
{
|
||||
return [
|
||||
$columns = [
|
||||
Column::make(__('Meetup'), 'meetup.name')
|
||||
->format(
|
||||
fn($value, $row, Column $column) => view('columns.meetup_events.name')
|
||||
@@ -72,12 +79,22 @@ class MeetupEventTable extends DataTableComponent
|
||||
)
|
||||
->sortable()
|
||||
->collapseOnMobile(),
|
||||
Column::make(__('Link'), 'link')
|
||||
Column::make(__('Link'))
|
||||
->label(
|
||||
fn($row, Column $column) => view('columns.meetup_events.link')
|
||||
->withRow($row)
|
||||
),
|
||||
];
|
||||
|
||||
$adminColumns = auth()->check() ? [
|
||||
Column::make(__('Actions'))
|
||||
->label(
|
||||
fn($row, Column $column) => view('columns.meetup_events.manage')
|
||||
->withRow($row)
|
||||
),
|
||||
] : [];
|
||||
|
||||
return array_merge($columns, $adminColumns);
|
||||
}
|
||||
|
||||
public function builder(): Builder
|
||||
|
||||
Reference in New Issue
Block a user