Files
site/app/Nova/FeedAds.php
2025-04-21 16:03:20 +02:00

127 lines
3.0 KiB
PHP

<?php
namespace App\Nova;
use App\Domain\Feeds\Enums\StatusEnum;
use Laravel\Nova\Fields\ID;
use Illuminate\Http\Request;
use Laravel\Nova\Fields\Text;
use Laravel\Nova\Fields\Select;
use Laravel\Nova\Fields\HasMany;
use Laravel\Nova\Fields\DateTime;
use Laravel\Nova\Fields\Textarea;
use Laravel\Nova\Fields\BelongsTo;
use Laravel\Nova\Fields\MorphMany;
use Laravel\Nova\Http\Requests\NovaRequest;
use App\Domain\Feeds\Models\Feed as ModelsFeed;
use Ebess\AdvancedNovaMediaLibrary\Fields\Files;
class FeedAds extends Resource
{
/**
* The model the resource corresponds to.
*
* @var string
*/
public static $model = ModelsFeed::class;
public static $group = 'Content';
// /**
// * The single value that should be used to represent the resource when being displayed.
// *
// * @var string
// */
// public static $title = 'title';
/**
* Get the value that should be displayed to represent the resource.
*
* @return string
*/
public function title()
{
return $this->id;
}
/**
* The columns that should be searched.
*
* @var array
*/
public static $search = [
'id', 'title', 'body'
];
public static function indexQuery(NovaRequest $request, $query)
{
return $query->where('is_ads', true);
}
/**
* Get the fields displayed by the resource.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function fields(Request $request)
{
return [
ID::make(__('ID'), 'id')->sortable(),
Files::make('Media Preview', 'preview'),
Files::make('Media', 'common'),
Text::make('Title')->rules('required'),
Select::make('Type')->options([
'images' => 'Изображение',
// 'musics' => 'Аудио',
'videos' => 'Видео',
])->displayUsingLabels()->rules('required'),
Textarea::make('Body')->rules('required')->alwaysShow()->hideFromIndex(),
DateTime::make('Created At')->format('DD MMM YYYY')->onlyOnIndex(),
];
}
/**
* 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 [];
}
}