Package Data | |
---|---|
Maintainer Username: | graham-campbell |
Maintainer Contact: | shawn@mccool.email (Shawn McCool) |
Package Create Date: | 2013-08-11 |
Package Last Update: | 2024-05-21 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-21 03:12:37 |
Package Statistics | |
---|---|
Total Downloads: | 1,036,227 |
Monthly Downloads: | 1,685 |
Daily Downloads: | 86 |
Total Stars: | 752 |
Total Watchers: | 20 |
Total Forks: | 74 |
Total Open Issues: | 5 |
This package automatically decorates objects bound to views during the view render process.
In Laravel Auto Presenter 7, note that:
Going from Laravel Auto Presenter 5, to 6, note that:
Decoratable
interface to determine if relations can be decorated. While this is not a BC break, since HasPresenter
extends it, it is definitely worth noting.If you're upgrading from Laravel Auto Presenter 4, to 5, note that:
BasePresenter
no longer has a constructor, so you cannot call parent::__construct($resource)
.setWrappedObject
method, inherited from the BasePresenter
.Laravel Auto Presenter 6 requires PHP 7.1 or 7.2. This particular version supports Laravel 5.5 or 5.6 only. If you need support for older PHP versions, please choose an older version of Laravel Auto Presenter.
To get the latest version, simply require the project using Composer:
$ composer require mccool/laravel-auto-presenter
Once installed, if you are not using automatic package discovery, then you need to register the McCool\LaravelAutoPresenter\AutoPresenterServiceProvider
service provider in your config/app.php
.
You can also optionally alias our facade:
'AutoPresenter' => McCool\LaravelAutoPresenter\Facades\AutoPresenter::class,
To show how it's used, we'll pretend that we have an Eloquent Post model. It doesn't have to be Eloquent, it could be any kind of class. But, this is a normal situation. The Post model represents a blog post.
I'm using really basic code examples here, so just focus on how the auto-presenter is used and ignore the rest.
use Example\Accounts\User;
use Illuminate\Database\Eloquent\Model;
class Post extends Model
{
protected $table = 'posts';
protected $fillable = ['author_id', 'title', 'content', 'published_at'];
public function author()
{
return $this->belongsTo(User::class, 'author_id');
}
}
Also, we'll need a controller..
use Example\Accounts\Post;
use Illuminate\Routing\Controller;
use Illuminate\Support\Facades\View;
class PostsController extends Controller
{
public function getIndex()
{
$posts = Post::all();
return View::make('posts.index', compact('posts'));
}
}
and a view...
@foreach($posts as $post)
<li>{{ $post->title }} - {{ $post->published_at }}</li>
@endforeach
In this example the published_at attribute is likely to be in the format: "Y-m-d H:i:s" or "2013-08-10 10:20:13". In the real world this is not what we want in our view. So, let's make a presenter that lets us change how the data from the Post class is rendered within the view.
use Carbon\Carbon;
use Example\Accounts\Post;
use McCool\LaravelAutoPresenter\BasePresenter;
class PostPresenter extends BasePresenter
{
public function published_at()
{
$published = $this->wrappedObject->published_at;
return Carbon::createFromFormat('Y-m-d H:i:s', $published)
->toFormattedDateString();
}
}
Note that the model is injected by calling the setWrappedObject
method, inherited from BasePresenter
.
We need the post class to implement the interface.
use Example\Accounts\User;
use Example\Blog\PostPresenter;
use McCool\LaravelAutoPresenter\HasPresenter;
use Illuminate\Database\Eloquent\Model;
class Post extends Model implements HasPresenter
{
protected $table = 'posts';
protected $fillable = ['author_id', 'title', 'content', 'published_at'];
public function author()
{
return $this->belongsTo(User::class, 'author_id');
}
public function getPresenterClass()
{
return PostPresenter::class;
}
}
Now, with no additional changes our view will show the date in the desired format.
The Decoratable
interface is used to allow the model's relations to be decorated, and the HasPresenter
interface (which extends that one) is used to have the model itself decorated.
If an object isn't being decorated correctly in the view then there's a good chance that it's simply not in existence when the view begins to render. For example, lazily-loaded relationships won't be decorated. You can fix this by eager-loading them instead. Auth::user() will never be decorated. I prefer to bind $currentUser to my views, anyway.
If an object is a relation of another object and it isn't being decorated in the view, you might not have added the Decoratable
interface to the other object. To fix this, add the Decoratable
interface to the other object.
If you discover a security vulnerability within this package, please send an e-mail to Graham Campbell at graham@alt-three.com. All security vulnerabilities will be promptly addressed.
Laravel Auto Presenter is licensed under The MIT License (MIT).