Helpers are testable! Views should have no complex logic on them. On 27 October 2014 11:40, Pier-Olivier Thibault <poth...@gmail.com> wrote:
> I am aware of the existence of helpers. But they are in no way a silver > bullet to building HTML tags. First of all, the number of helper_class() > methods proportionally increment with the number of attributes/class you > use. Soon enough, you get very complicated helper method name due to very > close but yet different methods. This is one of the reason why some people > uses Presenters/Decorators in their project. > > On Monday, October 27, 2014 5:12:43 AM UTC-4, Abdelkader Boudih wrote: >> >> :-1: You should be using helpers. >> >> >> <% for @posts.each do |post|%> >> <%= content_tag :li, post.title, class: post_classes(post) %> >> <% end %> >> >> # in PostHelper >> def post_classes(post) >> # your code here >> end >> >> On 27 October 2014 09:02, Anuj Dutta <dutta...@googlemail.com> wrote: >> >>> Hello, >>> >>> How about moving the conditional to a helper in your first example? Just >>> curious to know if you would prefer that approach. >>> >>> Thanks. >>> >>> Anuj >>> >>> On 26 Oct 2014 17:34, "Pier-Olivier Thibault" <pot...@gmail.com> wrote: >>> > >>> > Hello everyone, >>> > >>> > I have a feature request here that comes from an internal struggle >>> here between view helpers, decorator patterns and ERB in general. A problem >>> that occurs from time to time is how to build HTML tags with different >>> settings depending on the some states. Here's an example of what I mean. >>> > >>> > <% for @posts.each do |post|%> >>> > <%= content_tag :li, post.title, class: "post #{post.id == 3 ? >>> 'selected' : ''}" %> >>> > <% end %> >>> > >>> > With builtin' methods, there's many way to build this kind of HTML >>> tag. And I'm sure people here knows a few of them. However, none seem to >>> really make it easy to build them. So I decided to take a stab at it this >>> weekend and came up with this solution. >>> > >>> > <% for @posts.each do |post|%> >>> > <%= content_tag :li, class: %w(post) do |li| %> >>> > <% if post.id == 3 %> >>> > <% li.css << 'selected' %> >>> > <% end %> >>> > post.title >>> > <% end %> >>> > <% end %> >>> > >>> > All attributes can be either set inline (as previously possible) or >>> through a tag object that is available inside the block. Now, since this >>> might not be really easy to figure out how useful this could be, I created >>> a helper that overrides content_tag() and saved it as a gist for you to >>> test out locally. It's very possible that there's a few bugs as it's the >>> very first version. >>> > >>> > Gist: https://gist.github.com/pothibo/69d60505fa6e44863e52 >>> > >>> > Would this be something RoR:Core would be interested in merging into >>> Rails? >>> > >>> > -- >>> > You received this message because you are subscribed to the Google >>> Groups "Ruby on Rails: Core" group. >>> > To unsubscribe from this group and stop receiving emails from it, send >>> an email to rubyonrails-co...@googlegroups.com. >>> > To post to this group, send email to rubyonra...@googlegroups.com. >>> > Visit this group at http://groups.google.com/group/rubyonrails-core. >>> > For more options, visit https://groups.google.com/d/optout. >>> >>> -- >>> You received this message because you are subscribed to the Google >>> Groups "Ruby on Rails: Core" group. >>> To unsubscribe from this group and stop receiving emails from it, send >>> an email to rubyonrails-co...@googlegroups.com. >>> To post to this group, send email to rubyonra...@googlegroups.com. >>> Visit this group at http://groups.google.com/group/rubyonrails-core. >>> For more options, visit https://groups.google.com/d/optout. >>> >> >> -- > You received this message because you are subscribed to the Google Groups > "Ruby on Rails: Core" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to rubyonrails-core+unsubscr...@googlegroups.com. > To post to this group, send email to rubyonrails-core@googlegroups.com. > Visit this group at http://groups.google.com/group/rubyonrails-core. > For more options, visit https://groups.google.com/d/optout. > -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-core+unsubscr...@googlegroups.com. To post to this group, send email to rubyonrails-core@googlegroups.com. Visit this group at http://groups.google.com/group/rubyonrails-core. For more options, visit https://groups.google.com/d/optout.