Ruby Rails
Rails Presenter
Presenter Classes
data:image/s3,"s3://crabby-images/bfb1d/bfb1d9f0d02ab7c55905c6c55b80dc656ca11e17" alt="Hero title.min"
data:image/s3,"s3://crabby-images/64fa1/64fa12e600973397637f34b857d5cda1f92005e5" alt="Hero title lg.min"
data:image/s3,"s3://crabby-images/af370/af370e22e129d57391d87e5ae7ca0b3cd8b17536" alt="Hero linework.min"
It's time to beautify your Rails views
data:image/s3,"s3://crabby-images/af370/af370e22e129d57391d87e5ae7ca0b3cd8b17536" alt="Hero linework.min"
MetaPresenter is a 100% free Ruby gem for view presenter classes.
MetaPresenter is a 100% free Ruby gem for view presenter classes. Pull yourself out of the vortex of scattered logic.
To install just add to your Gemfile and bundle:
gem 'meta_presenter'
$ bundle install
data:image/s3,"s3://crabby-images/fc6d7/fc6d7b4cad2a6bef8601593eff7e2409c9f7c561" alt="Fold slash white.min"
Learn More
data:image/s3,"s3://crabby-images/2c0f9/2c0f9c8112ec6c6a1538a71e35cdc28ae2677c6f" alt="Hero line base.min"
data:image/s3,"s3://crabby-images/2e89a/2e89a45a9c7986de986209d2de7176cbed903658" alt="Line base hero lg bottom.min"
MetaPresenter
data:image/s3,"s3://crabby-images/a8790/a8790209acb2761fa8c3845218325d4316582518" alt="Linework.min"
How does it work?
data:image/s3,"s3://crabby-images/a8790/a8790209acb2761fa8c3845218325d4316582518" alt="Linework.min"
Each action gets its own Presenter class that the view calls with presenter.method_name . Presenters can also delegate to objects or controller methods.
data:image/s3,"s3://crabby-images/319f8/319f871cf32c34b1a5856f72f6bc419a7ba185ef" alt="Diagonal slice rectangle.min"
data:image/s3,"s3://crabby-images/e3f2a/e3f2ad13268c6abe9f6e52ca3f922722846e1880" alt="Red three dots.min"
Decompose your view logic into tight, easily-testable classes
In 4 simple steps
data:image/s3,"s3://crabby-images/0aff7/0aff73fe2d53c6af5e77b3542f6ea26ba095c519" alt="Overlay shape large.min"
data:image/s3,"s3://crabby-images/aeb66/aeb665c79e9893002ca5da75c9f7150ef237de8e" alt="Overlay shape.min"
data:image/s3,"s3://crabby-images/7685b/7685b4fe5022b81e9288b9691a7eeda8b4b5f890" alt="Line.min"
Include in your controller
Including MetaPresenter::Helpers
gives you access to the presenter
method within your views.
# app/presenters/application_presenter.rb
class ApplicationController < ActionController::Base
include MetaPresenter::Helpers
end
# Works with mailers, too!
class ApplicationMailer < ActionMailer::Base
include MetaPresenter::Helpers
end
data:image/s3,"s3://crabby-images/7685b/7685b4fe5022b81e9288b9691a7eeda8b4b5f890" alt="Line.min"
Create a presenter class
Your presenter class is scoped to an individual view. No more chaos of global helper methods!
# app/presenters/pages/home_presenter.rb
class Pages::HomePresenter < PagesPresenter
# presenter.email, presenter.last_login_at or any
# other method not already defined will delegate
# to the current_user
delegate_all_to :current_user
# presenter.greeting in views
def greeting
"Hello, #{current_user.name}"
end
end
data:image/s3,"s3://crabby-images/7685b/7685b4fe5022b81e9288b9691a7eeda8b4b5f890" alt="Line.min"
Write clean views with the presenter object
Now you can use presenter.whatever
in your views and it will delegate to the presenter.
<h1>Home</h1>
<p><%= presenter.greeting %></p>
<p>Last login <%= presenter.last_login_at %></p>
data:image/s3,"s3://crabby-images/7685b/7685b4fe5022b81e9288b9691a7eeda8b4b5f890" alt="Line.min"
Test your presenter class
You can test presenters just like any other class. Don't be afraid to test every permutation because unlike system specs they run blazing fast!
describe Pages::HomePresenter do
let(:user) { User.new(name: "Mario") }
let(:controller) do
OpenStruct.new(current_user: user)
end
let(:presenter) do
described_class.new(controller)
end
describe '#hello' do
subject { presenter.hello }
it { is_expected.to eql("Hello, Mario") }
end
end
data:image/s3,"s3://crabby-images/44b1d/44b1d1b4bc8515fdf98baea41b0deab96b134f2f" alt="Overlay shape bottom.min"
data:image/s3,"s3://crabby-images/6e9fb/6e9fb80885fc99cb905327020d7a3332217ca7d2" alt="Side lines mobile.min"
data:image/s3,"s3://crabby-images/0e2c8/0e2c8dd35442ddc326f6dbc1effb5b5987c0f2dc" alt="Side lines.min"
data:image/s3,"s3://crabby-images/e3f2a/e3f2ad13268c6abe9f6e52ca3f922722846e1880" alt="Red three dots.min"
Are you ready to
Give it a try?
data:image/s3,"s3://crabby-images/96421/964217d7eb88b706a78897357deaa3ea6c468ebc" alt="Line bottom.min"
data:image/s3,"s3://crabby-images/96421/964217d7eb88b706a78897357deaa3ea6c468ebc" alt="Line bottom.min"
If you're ready to start beautifying your views, visit the GitHub page for setup instructions.