added new conductors

This commit is contained in:
2023-03-12 13:51:23 +10:00
parent 3d13fc6864
commit 615abcc8e3
5 changed files with 335 additions and 39 deletions

View File

@@ -1,37 +1,92 @@
<?php
namespace App\Conductors;
use Carbon\Carbon;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Http\Request;
use Illuminate\Support\Str;
class EventConductor extends Conductor {
class EventConductor extends Conductor
{
/**
* The Model Class
* @var string
*/
protected $class = '\App\Models\Event';
// protected $includes = ['yaw'];
public function scope(Builder $builder) {
/**
* The default sorting field
* @var string
*/
protected $sort = 'start_at';
}
public function fields(Model $model) {
return ['id', 'title', 'location', 'address'];
}
public function transform(Model $model) {
if($model->location == 'online') {
unset($model['address']);
/**
* Run a scope query on the collection before anything else.
*
* @param Builder $builder The builder in use.
* @return void
*/
public function scope(Builder $builder)
{
$user = auth()->user();
if ($user === null || $user->has_permission('admin/events') === false) {
$builder
->where('status', '!=', 'draft')
->where('publish_at', '<=', now());
}
return $model->toArray();
}
public static function viewable(Model $model) {
/**
* Return if the current model is visible.
*
* @param Model $model The model.
* @return boolean Allow model to be visible.
*/
public static function viewable(Model $model)
{
if (strtolower($model->status) === 'draft' || Carbon::parse($model->publish_at)->isFuture() === true) {
$user = auth()->user();
if ($user === null || $user->has_permission('admin/events') === false) {
return false;
}
}
return true;
}
public function includeYaw(Model $model) {
$model->yaw = 'YAW!!';
/**
* Return if the current model is creatable.
*
* @return boolean Allow creating model.
*/
public static function creatable()
{
$user = auth()->user();
return ($user !== null && $user->has_permission('admin/events') === true);
}
}
/**
* Return if the current model is updatable.
*
* @param Model $model The model.
* @return boolean Allow updating model.
*/
public static function updatable(Model $model)
{
$user = auth()->user();
return ($user !== null && $user->has_permission('admin/events') === true);
}
/**
* Return if the current model is deletable.
*
* @param Model $model The model.
* @return boolean Allow deleting model.
*/
public static function deletable(Model $model)
{
$user = auth()->user();
return ($user !== null && $user->has_permission('admin/events') === true);
}
}