PHPackages                             erikgall/presenter - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Templating &amp; Views](/categories/templating)
4. /
5. erikgall/presenter

ActiveLibrary[Templating &amp; Views](/categories/templating)

erikgall/presenter
==================

Simple view presenters

v1.0.0(10y ago)141MITPHPPHP &gt;=5.4

Since Jun 30Pushed 10y ago1 watchersCompare

[ Source](https://github.com/erikgall/presenter)[ Packagist](https://packagist.org/packages/erikgall/presenter)[ RSS](/packages/erikgall-presenter/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (1)Dependencies (3)Versions (2)Used By (0)

Laravel Model/View Presenter (Laracasts)
========================================

[](#laravel-modelview-presenter-laracasts)

So you have those scenarios where a bit of logic needs to be performed before some data (likely from your entity) is displayed from the view.

- Should that logic be hard-coded into the view? **No**.
- Should we instead store the logic in the model? **No again!**

Instead, leverage view presenters. That's what they're for! This package provides one such implementation.

Install
-------

[](#install)

Pull this package in through Composer.

```
{
    "require": {
        "erikgall/presenter": "1.*"
    }
}
```

Usage
-----

[](#usage)

The first step is to store your presenters somewhere - anywhere. These will be simple objects that do nothing more than format data, as required.

Here's an example of a presenter.

```
use EGALL\Presenter\Presenter;

class UserPresenter extends Presenter {

    public function fullName()
    {
        return $this->first . ' ' . $this->last;
    }

    public function accountAge()
    {
        return $this->created_at->diffForHumans();
    }

}
```

Next, on your entity, pull in the `Laracasts\Presenter\PresentableTrait` trait, which will automatically instantiate your presenter class.

Here's an example - maybe a Laravel `User` model.

```
