default images added

This commit is contained in:
Benjamin Takats
2022-12-02 11:49:17 +01:00
parent 48d529d4e3
commit 1c2bf70773
10 changed files with 170 additions and 13 deletions

View File

@@ -6,6 +6,7 @@ use App\Models\Venue;
use Illuminate\Database\Eloquent\Builder;
use Rappasoft\LaravelLivewireTables\DataTableComponent;
use Rappasoft\LaravelLivewireTables\Views\Column;
use Rappasoft\LaravelLivewireTables\Views\Columns\ImageColumn;
class VenueTable extends DataTableComponent
{
@@ -21,6 +22,14 @@ class VenueTable extends DataTableComponent
public function columns(): array
{
return [
ImageColumn::make('')
->location(
fn($row) => $row->getFirstMediaUrl('images', 'thumb')
)
->attributes(fn($row) => [
'class' => 'rounded h-16 w-16',
'alt' => $row->name.' Avatar',
]),
Column::make("Name", "name")
->sortable(),
Column::make("Street", "street")

View File

@@ -47,7 +47,8 @@ class Lecturer extends Model implements HasMedia
public function registerMediaCollections(): void
{
$this->addMediaCollection('avatar')
->singleFile();
->singleFile()
->useFallbackUrl(asset('img/einundzwanzig-cover-lesestunde.png'));
}
/**

View File

@@ -4,13 +4,20 @@ namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Spatie\Image\Manipulations;
use Spatie\MediaLibrary\HasMedia;
use Spatie\MediaLibrary\InteractsWithMedia;
use Spatie\MediaLibrary\MediaCollections\Models\Media;
use Spatie\Sluggable\HasSlug;
use Spatie\Sluggable\SlugOptions;
use Staudenmeir\EloquentHasManyDeep\HasRelationships;
class Venue extends Model
class Venue extends Model implements HasMedia
{
use HasFactory;
use HasSlug;
use HasRelationships;
use InteractsWithMedia;
/**
* The attributes that aren't mass assignable.
@@ -27,6 +34,24 @@ class Venue extends Model
'city_id' => 'integer',
];
public function registerMediaConversions(Media $media = null): void
{
$this
->addMediaConversion('preview')
->fit(Manipulations::FIT_CROP, 300, 300)
->nonQueued();
$this->addMediaConversion('thumb')
->fit(Manipulations::FIT_CROP, 130, 130)
->width(130)
->height(130);
}
public function registerMediaCollections(): void
{
$this->addMediaCollection('images')
->useFallbackUrl(asset('img/einundzwanzig-cover-lesestunde.png'));
}
/**
* Get the options for generating the slug.
*/
@@ -43,6 +68,16 @@ class Venue extends Model
return $this->belongsTo(City::class);
}
public function lecturers()
{
return $this->hasManyDeepFromRelations($this->courses(), (new Course())->lecturer());
}
public function courses()
{
return $this->hasManyDeepFromRelations($this->events(), (new Event())->course());
}
public function events(): \Illuminate\Database\Eloquent\Relations\HasMany
{
return $this->hasMany(Event::class);

View File

@@ -7,6 +7,7 @@ use Illuminate\Http\Request;
use Laravel\Nova\Fields\BelongsTo;
use Laravel\Nova\Fields\Boolean;
use Laravel\Nova\Fields\Field;
use Laravel\Nova\Fields\ID;
use Laravel\Nova\Fields\Text;
use Laravel\Nova\Http\Requests\NovaRequest;
@@ -52,9 +53,11 @@ class Lecturer extends Resource
public function fields(Request $request)
{
return [
ID::make()
->sortable(),
Images::make('Avatar', 'avatar') // second parameter is the media collection name
->conversionOnIndexView('thumb') // conversion used to display the image
->rules('required'), // validation rules
->conversionOnIndexView('thumb'), // conversion used to display the image
Text::make('Name')
->rules('required', 'string'),

View File

@@ -2,6 +2,7 @@
namespace App\Nova;
use Ebess\AdvancedNovaMediaLibrary\Fields\Images;
use Illuminate\Http\Request;
use Laravel\Nova\Fields\BelongsTo;
use Laravel\Nova\Fields\ID;
@@ -43,6 +44,9 @@ class Venue extends Resource
ID::make()
->sortable(),
Images::make('Bilder', 'images') // second parameter is the media collection name
->conversionOnIndexView('thumb'), // conversion used to display the image
Text::make('Name')
->rules('required', 'string'),

View File

@@ -18,7 +18,7 @@ class PermissionPolicy
*/
public function viewAny(User $user)
{
return true;
return $user->hasRole('super-admin');
}
/**
@@ -30,7 +30,7 @@ class PermissionPolicy
*/
public function view(User $user, Permission $permission)
{
//
return $user->hasRole('super-admin');
}
/**
@@ -41,7 +41,7 @@ class PermissionPolicy
*/
public function create(User $user)
{
//
return $user->hasRole('super-admin');
}
/**
@@ -53,7 +53,7 @@ class PermissionPolicy
*/
public function update(User $user, Permission $permission)
{
//
return $user->hasRole('super-admin');
}
/**
@@ -65,7 +65,7 @@ class PermissionPolicy
*/
public function delete(User $user, Permission $permission)
{
//
return $user->hasRole('super-admin');
}
/**
@@ -77,7 +77,7 @@ class PermissionPolicy
*/
public function restore(User $user, Permission $permission)
{
//
return $user->hasRole('super-admin');
}
/**
@@ -89,6 +89,6 @@ class PermissionPolicy
*/
public function forceDelete(User $user, Permission $permission)
{
//
return $user->hasRole('super-admin');
}
}

View File

@@ -14,6 +14,7 @@ class VenuePolicy
* Determine whether the user can view any models.
*
* @param \App\Models\User $user
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function viewAny(User $user)
@@ -26,6 +27,7 @@ class VenuePolicy
*
* @param \App\Models\User $user
* @param \App\Models\Venue $venue
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function view(User $user, Venue $venue)
@@ -37,6 +39,7 @@ class VenuePolicy
* Determine whether the user can create models.
*
* @param \App\Models\User $user
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function create(User $user)
@@ -49,11 +52,13 @@ class VenuePolicy
*
* @param \App\Models\User $user
* @param \App\Models\Venue $venue
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function update(User $user, Venue $venue)
{
//
return $venue->lecturers->where('team_id', $user->current_team_id)
->isNotEmpty();
}
/**
@@ -61,6 +66,7 @@ class VenuePolicy
*
* @param \App\Models\User $user
* @param \App\Models\Venue $venue
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function delete(User $user, Venue $venue)
@@ -73,6 +79,7 @@ class VenuePolicy
*
* @param \App\Models\User $user
* @param \App\Models\Venue $venue
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function restore(User $user, Venue $venue)
@@ -85,6 +92,7 @@ class VenuePolicy
*
* @param \App\Models\User $user
* @param \App\Models\Venue $venue
*
* @return \Illuminate\Auth\Access\Response|bool
*/
public function forceDelete(User $user, Venue $venue)