mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig-portal.git
synced 2025-12-13 06:56:48 +00:00
meetups added
This commit is contained in:
15
app/Http/Livewire/Meetup/MeetupEventTable.php
Normal file
15
app/Http/Livewire/Meetup/MeetupEventTable.php
Normal file
@@ -0,0 +1,15 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Livewire\Meetup;
|
||||
|
||||
use App\Models\Country;
|
||||
use Livewire\Component;
|
||||
|
||||
class MeetupEventTable extends Component
|
||||
{
|
||||
public Country $country;
|
||||
public function render()
|
||||
{
|
||||
return view('livewire.meetup.meetup-event-table');
|
||||
}
|
||||
}
|
||||
15
app/Http/Livewire/Meetup/MeetupTable.php
Normal file
15
app/Http/Livewire/Meetup/MeetupTable.php
Normal file
@@ -0,0 +1,15 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Livewire\Meetup;
|
||||
|
||||
use App\Models\Country;
|
||||
use Livewire\Component;
|
||||
|
||||
class MeetupTable extends Component
|
||||
{
|
||||
public Country $country;
|
||||
public function render()
|
||||
{
|
||||
return view('livewire.meetup.meetup-table');
|
||||
}
|
||||
}
|
||||
@@ -3,7 +3,7 @@
|
||||
namespace App\Http\Livewire\Tables;
|
||||
|
||||
use App\Models\Category;
|
||||
use App\Models\Event;
|
||||
use App\Models\CourseEvent;
|
||||
use App\Models\Lecturer;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
||||
@@ -17,7 +17,7 @@ class EventTable extends DataTableComponent
|
||||
public string $country;
|
||||
public bool $viewingModal = false;
|
||||
public $currentModal;
|
||||
protected $model = Event::class;
|
||||
protected $model = CourseEvent::class;
|
||||
|
||||
public function configure(): void
|
||||
{
|
||||
@@ -157,18 +157,18 @@ class EventTable extends DataTableComponent
|
||||
|
||||
public function builder(): Builder
|
||||
{
|
||||
return Event::query()
|
||||
->withCount([
|
||||
return CourseEvent::query()
|
||||
->withCount([
|
||||
'registrations',
|
||||
])
|
||||
->whereHas('venue.city.country',
|
||||
->whereHas('venue.city.country',
|
||||
fn($query) => $query->where('countries.code', $this->country));
|
||||
}
|
||||
|
||||
public function viewHistoryModal($modelId): void
|
||||
{
|
||||
$this->viewingModal = true;
|
||||
$this->currentModal = Event::findOrFail($modelId);
|
||||
$this->currentModal = CourseEvent::findOrFail($modelId);
|
||||
}
|
||||
|
||||
public function resetModal(): void
|
||||
|
||||
35
app/Http/Livewire/Tables/MeetupEventTable.php
Normal file
35
app/Http/Livewire/Tables/MeetupEventTable.php
Normal file
@@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Livewire\Tables;
|
||||
|
||||
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
||||
use Rappasoft\LaravelLivewireTables\Views\Column;
|
||||
use App\Models\MeetupEvent;
|
||||
|
||||
class MeetupEventTable extends DataTableComponent
|
||||
{
|
||||
public string $country;
|
||||
|
||||
protected $model = MeetupEvent::class;
|
||||
|
||||
public function configure(): void
|
||||
{
|
||||
$this->setPrimaryKey('id');
|
||||
}
|
||||
|
||||
public function columns(): array
|
||||
{
|
||||
return [
|
||||
Column::make(__('Location'), 'location')
|
||||
->sortable(),
|
||||
Column::make(__('Start'), 'start')
|
||||
->sortable(),
|
||||
Column::make(__('Link'), 'link')
|
||||
->sortable(),
|
||||
Column::make("Created at", "created_at")
|
||||
->sortable(),
|
||||
Column::make("Updated at", "updated_at")
|
||||
->sortable(),
|
||||
];
|
||||
}
|
||||
}
|
||||
29
app/Http/Livewire/Tables/MeetupTable.php
Normal file
29
app/Http/Livewire/Tables/MeetupTable.php
Normal file
@@ -0,0 +1,29 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Livewire\Tables;
|
||||
|
||||
use App\Models\Meetup;
|
||||
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
||||
use Rappasoft\LaravelLivewireTables\Views\Column;
|
||||
|
||||
class MeetupTable extends DataTableComponent
|
||||
{
|
||||
public string $country;
|
||||
|
||||
protected $model = Meetup::class;
|
||||
|
||||
public function configure(): void
|
||||
{
|
||||
$this->setPrimaryKey('id');
|
||||
}
|
||||
|
||||
public function columns(): array
|
||||
{
|
||||
return [
|
||||
Column::make(__('Name'), 'name')
|
||||
->sortable(),
|
||||
Column::make(__('Link'), 'link')
|
||||
->sortable(),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -52,6 +52,6 @@ class City extends Model
|
||||
|
||||
function events()
|
||||
{
|
||||
return $this->hasManyThrough(Event::class, Venue::class);
|
||||
return $this->hasManyThrough(CourseEvent::class, Venue::class);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -66,6 +66,6 @@ class Course extends Model implements HasMedia
|
||||
|
||||
public function events(): \Illuminate\Database\Eloquent\Relations\HasMany
|
||||
{
|
||||
return $this->hasMany(Event::class);
|
||||
return $this->hasMany(CourseEvent::class);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,7 +5,7 @@ namespace App\Models;
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class Event extends Model
|
||||
class CourseEvent extends Model
|
||||
{
|
||||
use HasFactory;
|
||||
|
||||
33
app/Models/Meetup.php
Normal file
33
app/Models/Meetup.php
Normal file
@@ -0,0 +1,33 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class Meetup extends Model
|
||||
{
|
||||
use HasFactory;
|
||||
|
||||
/**
|
||||
* The attributes that aren't mass assignable.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $guarded = [];
|
||||
|
||||
/**
|
||||
* The attributes that should be cast to native types.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $casts = [
|
||||
'id' => 'integer',
|
||||
'city_id' => 'integer',
|
||||
];
|
||||
|
||||
public function city(): \Illuminate\Database\Eloquent\Relations\BelongsTo
|
||||
{
|
||||
return $this->belongsTo(City::class);
|
||||
}
|
||||
}
|
||||
34
app/Models/MeetupEvent.php
Normal file
34
app/Models/MeetupEvent.php
Normal file
@@ -0,0 +1,34 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class MeetupEvent extends Model
|
||||
{
|
||||
use HasFactory;
|
||||
|
||||
/**
|
||||
* The attributes that aren't mass assignable.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $guarded = [];
|
||||
|
||||
/**
|
||||
* The attributes that should be cast to native types.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $casts = [
|
||||
'id' => 'integer',
|
||||
'meetup_id' => 'integer',
|
||||
'start' => 'datetime',
|
||||
];
|
||||
|
||||
public function meetup(): \Illuminate\Database\Eloquent\Relations\BelongsTo
|
||||
{
|
||||
return $this->belongsTo(Meetup::class);
|
||||
}
|
||||
}
|
||||
@@ -30,7 +30,7 @@ class Registration extends Model
|
||||
|
||||
public function event(): \Illuminate\Database\Eloquent\Relations\BelongsTo
|
||||
{
|
||||
return $this->belongsTo(Event::class);
|
||||
return $this->belongsTo(CourseEvent::class);
|
||||
}
|
||||
|
||||
public function participant(): \Illuminate\Database\Eloquent\Relations\BelongsTo
|
||||
|
||||
@@ -75,11 +75,11 @@ class Venue extends Model implements HasMedia
|
||||
|
||||
public function courses()
|
||||
{
|
||||
return $this->hasManyDeepFromRelations($this->events(), (new Event())->course());
|
||||
return $this->hasManyDeepFromRelations($this->events(), (new CourseEvent())->course());
|
||||
}
|
||||
|
||||
public function events(): \Illuminate\Database\Eloquent\Relations\HasMany
|
||||
{
|
||||
return $this->hasMany(Event::class);
|
||||
return $this->hasMany(CourseEvent::class);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -11,13 +11,13 @@ use Laravel\Nova\Fields\ID;
|
||||
use Laravel\Nova\Fields\URL;
|
||||
use Laravel\Nova\Http\Requests\NovaRequest;
|
||||
|
||||
class Event extends Resource
|
||||
class CourseEvent extends Resource
|
||||
{
|
||||
/**
|
||||
* The model the resource corresponds to.
|
||||
* @var string
|
||||
*/
|
||||
public static $model = \App\Models\Event::class;
|
||||
public static $model = \App\Models\CourseEvent::class;
|
||||
/**
|
||||
* The columns that should be searched.
|
||||
* @var array
|
||||
101
app/Nova/Meetup.php
Normal file
101
app/Nova/Meetup.php
Normal file
@@ -0,0 +1,101 @@
|
||||
<?php
|
||||
|
||||
namespace App\Nova;
|
||||
|
||||
use Laravel\Nova\Fields\ID;
|
||||
use Illuminate\Http\Request;
|
||||
use Laravel\Nova\Fields\Text;
|
||||
use Laravel\Nova\Fields\BelongsTo;
|
||||
|
||||
class Meetup extends Resource
|
||||
{
|
||||
/**
|
||||
* The model the resource corresponds to.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
public static $model = \App\Models\Meetup::class;
|
||||
|
||||
/**
|
||||
* The single value that should be used to represent the resource when being displayed.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
public static $title = 'name';
|
||||
|
||||
/**
|
||||
* The columns that should be searched.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
public static $search = [
|
||||
'id',
|
||||
'name',
|
||||
];
|
||||
|
||||
/**
|
||||
* Get the fields displayed by the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function fields(Request $request)
|
||||
{
|
||||
return [
|
||||
ID::make()->sortable(),
|
||||
|
||||
Text::make('Name')
|
||||
->rules('required', 'string', 'unique:meetups,name'),
|
||||
|
||||
Text::make('Link')
|
||||
->rules('required', 'string'),
|
||||
|
||||
BelongsTo::make('City')->searchable(),
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the cards available for the request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function cards(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the filters available for the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function filters(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the lenses available for the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function lenses(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the actions available for the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function actions(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
}
|
||||
111
app/Nova/MeetupEvent.php
Normal file
111
app/Nova/MeetupEvent.php
Normal file
@@ -0,0 +1,111 @@
|
||||
<?php
|
||||
|
||||
namespace App\Nova;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use Laravel\Nova\Fields\BelongsTo;
|
||||
use Laravel\Nova\Fields\DateTime;
|
||||
use Laravel\Nova\Fields\ID;
|
||||
use Laravel\Nova\Fields\Text;
|
||||
|
||||
class MeetupEvent extends Resource
|
||||
{
|
||||
/**
|
||||
* The model the resource corresponds to.
|
||||
* @var string
|
||||
*/
|
||||
public static $model = \App\Models\MeetupEvent::class;
|
||||
|
||||
/**
|
||||
* The single value that should be used to represent the resource when being displayed.
|
||||
* @var string
|
||||
*/
|
||||
public static $title = 'id';
|
||||
|
||||
/**
|
||||
* The columns that should be searched.
|
||||
* @var array
|
||||
*/
|
||||
public static $search = [
|
||||
'id',
|
||||
];
|
||||
|
||||
/**
|
||||
* Get the fields displayed by the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function fields(Request $request)
|
||||
{
|
||||
return [
|
||||
ID::make()
|
||||
->sortable(),
|
||||
|
||||
DateTime::make(__('Start'), 'start'),
|
||||
|
||||
Text::make('Location')
|
||||
->rules('required', 'string'),
|
||||
|
||||
Text::make('Description')
|
||||
->rules('required', 'string')
|
||||
->hideFromIndex(),
|
||||
|
||||
Text::make('Link')
|
||||
->rules('required', 'string'),
|
||||
|
||||
BelongsTo::make('Meetup')
|
||||
->searchable(),
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the cards available for the request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function cards(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the filters available for the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function filters(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the lenses available for the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function lenses(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the actions available for the resource.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function actions(Request $request)
|
||||
{
|
||||
return [];
|
||||
}
|
||||
}
|
||||
@@ -46,10 +46,9 @@ class Registration extends Resource
|
||||
Boolean::make('Active')
|
||||
->rules('required'),
|
||||
|
||||
BelongsTo::make('Event'),
|
||||
BelongsTo::make('Course Event'),
|
||||
BelongsTo::make('Participant'),
|
||||
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
@@ -2,18 +2,18 @@
|
||||
|
||||
namespace App\Observers;
|
||||
|
||||
use App\Models\Event;
|
||||
use App\Models\CourseEvent;
|
||||
|
||||
class EventObserver
|
||||
{
|
||||
/**
|
||||
* Handle the Event "created" event.
|
||||
*
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $event
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function created(Event $event)
|
||||
public function created(CourseEvent $event)
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -21,11 +21,11 @@ class EventObserver
|
||||
/**
|
||||
* Handle the Event "updated" event.
|
||||
*
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $event
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function updated(Event $event)
|
||||
public function updated(CourseEvent $event)
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -33,11 +33,11 @@ class EventObserver
|
||||
/**
|
||||
* Handle the Event "deleted" event.
|
||||
*
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $event
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function deleted(Event $event)
|
||||
public function deleted(CourseEvent $event)
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -45,11 +45,11 @@ class EventObserver
|
||||
/**
|
||||
* Handle the Event "restored" event.
|
||||
*
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $event
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function restored(Event $event)
|
||||
public function restored(CourseEvent $event)
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -57,11 +57,11 @@ class EventObserver
|
||||
/**
|
||||
* Handle the Event "force deleted" event.
|
||||
*
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $event
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function forceDeleted(Event $event)
|
||||
public function forceDeleted(CourseEvent $event)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
@@ -2,11 +2,11 @@
|
||||
|
||||
namespace App\Policies;
|
||||
|
||||
use App\Models\Event;
|
||||
use App\Models\CourseEvent;
|
||||
use App\Models\User;
|
||||
use Illuminate\Auth\Access\HandlesAuthorization;
|
||||
|
||||
class EventPolicy extends BasePolicy
|
||||
class CourseEventPolicy extends BasePolicy
|
||||
{
|
||||
use HandlesAuthorization;
|
||||
|
||||
@@ -25,10 +25,11 @@ class EventPolicy extends BasePolicy
|
||||
* Determine whether the user can view the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $courseEvent
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function view(User $user, Event $event)
|
||||
public function view(User $user, CourseEvent $courseEvent)
|
||||
{
|
||||
return $user->is_lecturer;
|
||||
}
|
||||
@@ -48,22 +49,24 @@ class EventPolicy extends BasePolicy
|
||||
* Determine whether the user can update the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $courseEvent
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function update(User $user, Event $event)
|
||||
public function update(User $user, CourseEvent $courseEvent)
|
||||
{
|
||||
return $user->belongsToTeam($event->course->lecturer->team);
|
||||
return $user->belongsToTeam($courseEvent->course->lecturer->team);
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can delete the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $courseEvent
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function delete(User $user, Event $event)
|
||||
public function delete(User $user, CourseEvent $courseEvent)
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -72,10 +75,11 @@ class EventPolicy extends BasePolicy
|
||||
* Determine whether the user can restore the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $courseEvent
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function restore(User $user, Event $event)
|
||||
public function restore(User $user, CourseEvent $courseEvent)
|
||||
{
|
||||
//
|
||||
}
|
||||
@@ -84,10 +88,11 @@ class EventPolicy extends BasePolicy
|
||||
* Determine whether the user can permanently delete the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Event $event
|
||||
* @param \App\Models\CourseEvent $courseEvent
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function forceDelete(User $user, Event $event)
|
||||
public function forceDelete(User $user, CourseEvent $courseEvent)
|
||||
{
|
||||
//
|
||||
}
|
||||
94
app/Policies/MeetupEventPolicy.php
Normal file
94
app/Policies/MeetupEventPolicy.php
Normal file
@@ -0,0 +1,94 @@
|
||||
<?php
|
||||
|
||||
namespace App\Policies;
|
||||
|
||||
use App\Models\MeetupEvent;
|
||||
use App\Models\User;
|
||||
use Illuminate\Auth\Access\HandlesAuthorization;
|
||||
|
||||
class MeetupEventPolicy extends BasePolicy
|
||||
{
|
||||
use HandlesAuthorization;
|
||||
|
||||
/**
|
||||
* Determine whether the user can view any models.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function viewAny(User $user)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can view the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\MeetupEvent $meetupEvent
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function view(User $user, MeetupEvent $meetupEvent)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can create models.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function create(User $user)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can update the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\MeetupEvent $meetupEvent
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function update(User $user, MeetupEvent $meetupEvent)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can delete the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\MeetupEvent $meetupEvent
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function delete(User $user, MeetupEvent $meetupEvent)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can restore the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\MeetupEvent $meetupEvent
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function restore(User $user, MeetupEvent $meetupEvent)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can permanently delete the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\MeetupEvent $meetupEvent
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function forceDelete(User $user, MeetupEvent $meetupEvent)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
101
app/Policies/MeetupPolicy.php
Normal file
101
app/Policies/MeetupPolicy.php
Normal file
@@ -0,0 +1,101 @@
|
||||
<?php
|
||||
|
||||
namespace App\Policies;
|
||||
|
||||
use App\Models\Meetup;
|
||||
use App\Models\User;
|
||||
use Illuminate\Auth\Access\HandlesAuthorization;
|
||||
|
||||
class MeetupPolicy extends BasePolicy
|
||||
{
|
||||
use HandlesAuthorization;
|
||||
|
||||
/**
|
||||
* Determine whether the user can view any models.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function viewAny(User $user)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can view the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Meetup $meetup
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function view(User $user, Meetup $meetup)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can create models.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function create(User $user)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can update the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Meetup $meetup
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function update(User $user, Meetup $meetup)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can delete the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Meetup $meetup
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function delete(User $user, Meetup $meetup)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can restore the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Meetup $meetup
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function restore(User $user, Meetup $meetup)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine whether the user can permanently delete the model.
|
||||
*
|
||||
* @param \App\Models\User $user
|
||||
* @param \App\Models\Meetup $meetup
|
||||
*
|
||||
* @return \Illuminate\Auth\Access\Response|bool
|
||||
*/
|
||||
public function forceDelete(User $user, Meetup $meetup)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -10,10 +10,12 @@ use App\Nova\Country;
|
||||
use App\Nova\Course;
|
||||
use App\Nova\Dashboards\Main;
|
||||
use App\Nova\Episode;
|
||||
use App\Nova\Event;
|
||||
use App\Nova\CourseEvent;
|
||||
use App\Nova\Lecturer;
|
||||
use App\Nova\Library;
|
||||
use App\Nova\LibraryItem;
|
||||
use App\Nova\Meetup;
|
||||
use App\Nova\MeetupEvent;
|
||||
use App\Nova\OrangePill;
|
||||
use App\Nova\Participant;
|
||||
use App\Nova\Podcast;
|
||||
@@ -45,12 +47,19 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
MenuSection::dashboard(Main::class)
|
||||
->icon('lightning-bolt'),
|
||||
|
||||
MenuSection::make('Meetups', [
|
||||
MenuItem::resource(Meetup::class),
|
||||
MenuItem::resource(MeetupEvent::class),
|
||||
])
|
||||
->icon('calendar')
|
||||
->collapsable(),
|
||||
|
||||
MenuSection::make('Schule', [
|
||||
MenuItem::resource(City::class),
|
||||
MenuItem::resource(Venue::class),
|
||||
MenuItem::resource(Lecturer::class),
|
||||
MenuItem::resource(Course::class),
|
||||
MenuItem::resource(Event::class),
|
||||
MenuItem::resource(CourseEvent::class),
|
||||
MenuItem::resource(Participant::class),
|
||||
MenuItem::resource(Registration::class),
|
||||
])
|
||||
@@ -71,7 +80,7 @@ class NovaServiceProvider extends NovaApplicationServiceProvider
|
||||
->icon('microphone')
|
||||
->collapsable(),
|
||||
|
||||
MenuSection::make('Books', [
|
||||
MenuSection::make('Book-Cases', [
|
||||
MenuItem::resource(BookCase::class),
|
||||
MenuItem::resource(OrangePill::class),
|
||||
])
|
||||
|
||||
Reference in New Issue
Block a user