the extends tag was not looking for the right fullpath (when localization is enabled) + sample in order to modify the tinyMCE settings in the back-office

This commit is contained in:
Didier Lafforgue 2012-04-22 23:25:18 +02:00
parent 57b7cc1ef2
commit ce5576da09
5 changed files with 23 additions and 11 deletions

View File

@ -1,7 +1,2 @@
#= require ./utils/aloha_settings #= require ./utils/aloha_settings
#= require aloha #= require aloha
# r equire_tree ./../aloha/plugins
# . /.. / aloha / plugins

View File

@ -27,8 +27,10 @@ module Locomotive
@context[:parent_page] = @context[:page].parent @context[:parent_page] = @context[:page].parent
end end
else else
locale = ::Mongoid::Fields::I18n.locale
@context[:parent_page] = @context[:cached_pages].try(:[], @template_name) || @context[:parent_page] = @context[:cached_pages].try(:[], @template_name) ||
@context[:site].pages.where(:fullpath => @template_name).first @context[:site].pages.where("fullpath.#{locale}" => @template_name).first
end end
raise PageNotFound.new("Page with fullpath '#{@template_name}' was not found") if @context[:parent_page].nil? raise PageNotFound.new("Page with fullpath '#{@template_name}' was not found") if @context[:parent_page].nil?

View File

@ -0,0 +1,2 @@
# FIXME: just to demonstrate how easy it is to change the tinymce settings for the LocomotiveCMS back-office
# window.Locomotive.tinyMCE.defaultSettings.theme_advanced_buttons2 = 'formatselect,fontselect,fontsizeselect'

View File

@ -0,0 +1 @@
= javascript_include_tag 'locomotive_misc'

View File

@ -12,17 +12,29 @@ describe Locomotive::Liquid::Tags::Extends do
end end
it 'works' do it 'works' do
lambda {
page = FactoryGirl.build(:page, :slug => 'sub_page_1', :parent => @home) page = FactoryGirl.build(:page, :slug => 'sub_page_1', :parent => @home)
parse('parent', page) parse('parent', page).render.should == 'Hello world'
}.should_not raise_error end
it 'looks for the index with the right locale' do
::Mongoid::Fields::I18n.with_locale 'fr' do
@home.raw_template = 'Bonjour le monde'
@home.send :serialize_template
end
@site.pages.expects(:where).with('fullpath.fr' => 'index').returns([@home])
::Mongoid::Fields::I18n.with_locale 'fr' do
page = FactoryGirl.build(:page, :slug => 'sub_page_1', :parent => @home)
parse('index', page).render.should == 'Bonjour le monde'
end
end end
context '#errors' do context '#errors' do
it 'raises an error if the source page does not exist' do it 'raises an error if the source page does not exist' do
lambda { lambda {
@site.pages.expects(:where).with(:fullpath => 'foo').returns([]) @site.pages.expects(:where).with('fullpath.en' => 'foo').returns([])
parse('foo') parse('foo')
}.should raise_error(Locomotive::Liquid::PageNotFound, "Page with fullpath 'foo' was not found") }.should raise_error(Locomotive::Liquid::PageNotFound, "Page with fullpath 'foo' was not found")
end end