hadder/laravel-presenter

Presenters baseado no laracasts/presenter

1.0.8 2025-03-26 18:58 UTC

This package is auto-updated.

Last update: 2025-03-26 18:59:34 UTC


README

Fork com modificações do pacote laracasts/presenter (Jeffrey https://laracasts.com)

Em alguns casos é necessário executar alguma lógica antes de apresentar algum dado ou simplismente alguma formatação se faz necessária.

  • Esta lógica deve ser feita na view? Não.
  • Deve ser feita no model? NÃO!

Para isto usamos "presenters". Este pacote tem esta finalidade.

Instalação

Composer

composer require hadder/laravel-presenter

Uso

O primeiro passo é armazenar seus apresentadores em algum lugar - em qualquer lugar. Esses serão objetos simples que não fazem nada além de formatar dados, conforme necessário.

use Hadder\LaravelPresenter\Presenter;

class UserPresenter extends Presenter {

    public function nomeCompleto()
    {
        return $this->nome . ' ' . $this->sobrenome;
    }

    public function data_nascimento()
    {
        return $this->data_nascimento->format('d/m/Y');
    }
  
}

Ou utilize o comando php artisan presenter:make UserPresenter

Em seguida no seu model utilize o trait Hadder\LaravelPresenter\PresentableTrait.

Exemplo:

<?php

use Hadder\LaravelPresenter\PresentableTrait;

class User extends \Eloquent {

    use PresentableTrait;

    protected $presenter = \App\Presenters\UserPresenter::class;

    protected $date = ['data_nascimento'];
}

Feitooooooooooo! Agora você pode fazer:

    <h1>Olá, {{ $user->present()->nomeCompleto }}</h1>

Observações

Por padrão alguns presenters de formatação de data já estãos etados como created_at e updated_at no formato d/m/Y H:i:s, ou seja todo model recuperado já tem $model->present()->created_at.