Fixed issue with tablerow tag

This commit is contained in:
Alex Sanford 2011-08-19 09:55:15 -03:00
parent 0e3d601ea9
commit 88fd17a5aa
3 changed files with 78 additions and 0 deletions

View File

@ -0,0 +1,42 @@
Feature: TableRow liquid tags
As a designer
I want to be able to use the tablerow liquid tag with locomotive contents
Background:
Given I have the site: "test site" set up
And I have a custom model named "Projects" with
| label | kind | required |
| Name | string | true |
And I have entries for "Projects" with
| name |
| Project 1 |
| Project 2 |
| Project 3 |
Scenario: Use the tablerow tag
Given a page named "project-table" with the template:
"""
<h1>Projects</h1>
<table>
{% tablerow project in contents.projects cols: 2 %}
{{ project.name }}
{% endtablerow %}
</table>
"""
When I view the rendered page at "/project-table"
Then the rendered output should look like:
"""
<h1>Projects</h1>
<table>
<tr class="row1">
<td class="col1">
Project 1
</td><td class="col2">
Project 2
</td></tr>
<tr class="row2"><td class="col1">
Project 3
</td></tr>
</table>
"""

View File

@ -29,10 +29,16 @@ module Locomotive
self.collection.each(&block) self.collection.each(&block)
end end
def each_with_index(&block)
self.collection.each_with_index(&block)
end
def size def size
self.collection.size self.collection.size
end end
alias :length :size
def empty? def empty?
self.collection.empty? self.collection.empty?
end end

View File

@ -3,6 +3,9 @@ require 'spec_helper'
describe Locomotive::Liquid::Drops::Contents do describe Locomotive::Liquid::Drops::Contents do
before(:each) do before(:each) do
# Reload the file (needed for spork)
load File.join(Rails.root, 'lib', 'locomotive', 'liquid', 'drops', 'contents.rb')
@site = Factory.build(:site) @site = Factory.build(:site)
@content_type = Factory.build(:content_type, :site => @site, :slug => 'projects') @content_type = Factory.build(:content_type, :site => @site, :slug => 'projects')
end end
@ -22,6 +25,26 @@ describe Locomotive::Liquid::Drops::Contents do
end end
describe Locomotive::Liquid::Drops::ProxyCollection do
before(:each) do
populate_content_type
@proxy_collection = Locomotive::Liquid::Drops::ProxyCollection.new(@content_type)
@proxy_collection.context = {}
end
it 'provides its size like an Array' do
@proxy_collection.size.should == @proxy_collection.length
end
it 'can be enumerated using each_with_index' do
@proxy_collection.each_with_index do |item, index|
item._slug.should == "item#{index + 1}"
end
end
end
def render_template(template = '', assigns = {}) def render_template(template = '', assigns = {})
assigns = { assigns = {
'contents' => Locomotive::Liquid::Drops::Contents.new 'contents' => Locomotive::Liquid::Drops::Contents.new
@ -30,4 +53,11 @@ describe Locomotive::Liquid::Drops::Contents do
Liquid::Template.parse(template).render(::Liquid::Context.new({}, assigns, { :site => @site })) Liquid::Template.parse(template).render(::Liquid::Context.new({}, assigns, { :site => @site }))
end end
def populate_content_type
@content_type.order_by = :_slug
@content_type.contents.build(:_slug => 'item1')
@content_type.contents.build(:_slug => 'item2')
@content_type.contents.build(:_slug => 'item3')
end
end end