|
| 1 | +<?php |
| 2 | + |
| 3 | +namespace JustBetter\AkeneoProductsNova\Nova\Lenses; |
| 4 | + |
| 5 | +use Illuminate\Database\Eloquent\Builder as EloquentBuilder; |
| 6 | +use Illuminate\Database\Eloquent\Model; |
| 7 | +use Illuminate\Database\Query\Builder; |
| 8 | +use Illuminate\Database\Query\JoinClause; |
| 9 | +use Illuminate\Support\Facades\DB; |
| 10 | +use JustBetter\AkeneoProducts\Models\ProductModel; |
| 11 | +use JustBetter\AkeneoProductsNova\Nova\Filters\RetrieveFilter; |
| 12 | +use JustBetter\AkeneoProductsNova\Nova\Filters\SynchronizeFilter; |
| 13 | +use JustBetter\AkeneoProductsNova\Nova\Filters\UpdateFilter; |
| 14 | +use Laravel\Nova\Fields\DateTime; |
| 15 | +use Laravel\Nova\Fields\Text; |
| 16 | +use Laravel\Nova\Http\Requests\LensRequest; |
| 17 | +use Laravel\Nova\Http\Requests\NovaRequest; |
| 18 | +use Laravel\Nova\Lenses\Lens; |
| 19 | + |
| 20 | +class ProductModelLastErrorsLens extends Lens |
| 21 | +{ |
| 22 | + public function name(): string |
| 23 | + { |
| 24 | + return __('Last Errors'); |
| 25 | + } |
| 26 | + |
| 27 | + public static function query(LensRequest $request, $query): EloquentBuilder |
| 28 | + { |
| 29 | + return $request->withOrdering($request->withFilters( |
| 30 | + $query->select(self::columns()) |
| 31 | + ->join('activity_log', function (JoinClause $join) { |
| 32 | + $join |
| 33 | + ->on('activity_log.subject_id', '=', 'akeneo_product_models.id') |
| 34 | + ->where('log_name', '=', 'error') |
| 35 | + ->where('subject_type', '=', ProductModel::class) |
| 36 | + ->where('activity_log.id', '=', function (Builder $builder) { |
| 37 | + $builder |
| 38 | + ->selectRaw('MAX(id)') |
| 39 | + ->from('activity_log') |
| 40 | + ->where('subject_type', '=', ProductModel::class) |
| 41 | + ->where('subject_id', '=', DB::raw('akeneo_product_models.id')) |
| 42 | + ->groupBy('subject_id'); |
| 43 | + }); |
| 44 | + }) |
| 45 | + ->orderByDesc('activity_log.created_at') |
| 46 | + )); |
| 47 | + } |
| 48 | + |
| 49 | + protected static function columns(): array |
| 50 | + { |
| 51 | + return [ |
| 52 | + 'akeneo_product_models.*', |
| 53 | + 'activity_log.description', |
| 54 | + 'activity_log.created_at', |
| 55 | + ]; |
| 56 | + } |
| 57 | + |
| 58 | + public function fields(NovaRequest $request): array |
| 59 | + { |
| 60 | + return [ |
| 61 | + Text::make(__('Code'), 'code'), |
| 62 | + |
| 63 | + Text::make( |
| 64 | + __('Last Activity'), |
| 65 | + fn (Model $resource) => $resource->description ?? '' |
| 66 | + ), |
| 67 | + DateTime::make( |
| 68 | + __('Last Activity Date'), |
| 69 | + fn (Model $resource) => $resource->created_at |
| 70 | + ), |
| 71 | + ]; |
| 72 | + } |
| 73 | + |
| 74 | + public function filters(NovaRequest $request): array |
| 75 | + { |
| 76 | + return [ |
| 77 | + RetrieveFilter::make(), |
| 78 | + UpdateFilter::make(), |
| 79 | + SynchronizeFilter::make(), |
| 80 | + ]; |
| 81 | + } |
| 82 | + |
| 83 | + public function uriKey(): string |
| 84 | + { |
| 85 | + return 'akeneo-product-models-last-errors'; |
| 86 | + } |
| 87 | +} |
0 commit comments