merge
This commit is contained in:
commit
4cccff065a
@ -1,11 +1,25 @@
|
|||||||
module Locomotive
|
module Locomotive
|
||||||
module Liquid
|
module Liquid
|
||||||
module Tags
|
module Tags
|
||||||
|
|
||||||
|
# Filter a collection
|
||||||
|
#
|
||||||
|
# Usage:
|
||||||
|
#
|
||||||
|
# {% with_scope main_developer: 'John Doe', active: true %}
|
||||||
|
# {% for project in contents.projects %}
|
||||||
|
# {{ project.name }}
|
||||||
|
# {% endfor %}
|
||||||
|
# {% endwith_scope %}
|
||||||
|
#
|
||||||
|
|
||||||
class WithScope < ::Liquid::Block
|
class WithScope < ::Liquid::Block
|
||||||
|
|
||||||
|
TagAttributes = /(\w+|\w+\.\w+)\s*\:\s*(#{::Liquid::QuotedFragment})/
|
||||||
|
|
||||||
def initialize(tag_name, markup, tokens, context)
|
def initialize(tag_name, markup, tokens, context)
|
||||||
@attributes = {}
|
@attributes = HashWithIndifferentAccess.new
|
||||||
markup.scan(::Liquid::TagAttributes) do |key, value|
|
markup.scan(TagAttributes) do |key, value|
|
||||||
@attributes[key] = value
|
@attributes[key] = value
|
||||||
end
|
end
|
||||||
super
|
super
|
||||||
@ -22,13 +36,7 @@ module Locomotive
|
|||||||
|
|
||||||
def decode(attributes, context)
|
def decode(attributes, context)
|
||||||
attributes.each_pair do |key, value|
|
attributes.each_pair do |key, value|
|
||||||
attributes[key] = (case value
|
attributes[key] = context[value]
|
||||||
when /^true|false$/i then value == 'true'
|
|
||||||
when /^[0-9]+$/ then value.to_i
|
|
||||||
when /^["|'](.+)["|']$/ then $1.gsub(/^["|']/, '').gsub(/["|']$/, '')
|
|
||||||
else
|
|
||||||
context[value]
|
|
||||||
end)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -2,25 +2,33 @@ require 'spec_helper'
|
|||||||
|
|
||||||
describe Locomotive::Liquid::Tags::WithScope do
|
describe Locomotive::Liquid::Tags::WithScope do
|
||||||
|
|
||||||
it 'should decode basic options (boolean, interger, ...)' do
|
it 'decodes basic options (boolean, integer, ...)' do
|
||||||
scope = Locomotive::Liquid::Tags::WithScope.new('with_scope', 'active:true price:42 title:\'foo\' hidden:false', ["{% endwith_scope %}"], {})
|
scope = Locomotive::Liquid::Tags::WithScope.new('with_scope', 'active:true price:42 title:\'foo\' hidden:false', ["{% endwith_scope %}"], {})
|
||||||
attributes = scope.send(:decode, scope.instance_variable_get(:@attributes), {})
|
attributes = scope.send(:decode, scope.instance_variable_get(:@attributes), ::Liquid::Context.new)
|
||||||
attributes['active'].should == true
|
attributes['active'].should == true
|
||||||
attributes['price'].should == 42
|
attributes['price'].should == 42
|
||||||
attributes['title'].should == 'foo'
|
attributes['title'].should == 'foo'
|
||||||
attributes['hidden'].should == false
|
attributes['hidden'].should == false
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should decode context variable' do
|
it 'decodes more complex options' do
|
||||||
|
scope = Locomotive::Liquid::Tags::WithScope.new('with_scope', 'price.gt:42.0 price.lt:50', ["{% endwith_scope %}"], {})
|
||||||
|
attributes = scope.send(:decode, scope.instance_variable_get(:@attributes), ::Liquid::Context.new)
|
||||||
|
attributes['price.gt'].should == 42.0
|
||||||
|
attributes['price.lt'].should == 50
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'decodes context variable' do
|
||||||
scope = Locomotive::Liquid::Tags::WithScope.new('with_scope', 'category: params.type', ["{% endwith_scope %}"], {})
|
scope = Locomotive::Liquid::Tags::WithScope.new('with_scope', 'category: params.type', ["{% endwith_scope %}"], {})
|
||||||
attributes = scope.send(:decode, scope.instance_variable_get(:@attributes), { 'params.type' => 'posts' })
|
attributes = scope.send(:decode, scope.instance_variable_get(:@attributes), ::Liquid::Context.new({ 'params' => { 'type' => 'posts' } }))
|
||||||
attributes['category'].should == 'posts'
|
attributes['category'].should == 'posts'
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should store attributes in the context' do
|
it 'stores attributes in the context' do
|
||||||
template = ::Liquid::Template.parse("{% with_scope active:true title:'foo' %}{{ with_scope.active }}-{{ with_scope.title }}{% endwith_scope %}")
|
template = ::Liquid::Template.parse("{% with_scope active:true title:'foo' %}{{ with_scope.active }}-{{ with_scope.title }}{% endwith_scope %}")
|
||||||
text = template.render
|
text = template.render
|
||||||
text.should == "true-foo"
|
text.should == "true-foo"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user