improve the solution for the issue #127 and write tests (pull request #139)

This commit is contained in:
did 2011-07-28 00:39:59 +02:00
parent 2c2c565aad
commit 8da0db2454
5 changed files with 43 additions and 29 deletions

View File

@ -52,7 +52,7 @@ GEM
bson (1.3.1) bson (1.3.1)
bson_ext (1.3.1) bson_ext (1.3.1)
builder (2.1.2) builder (2.1.2)
bushido (0.0.31) bushido (0.0.34)
highline (>= 1.6.1) highline (>= 1.6.1)
json (>= 1.4.6) json (>= 1.4.6)
orm_adapter (~> 0.0.3) orm_adapter (~> 0.0.3)
@ -289,7 +289,7 @@ DEPENDENCIES
actionmailer-with-request actionmailer-with-request
autotest autotest
bson_ext (~> 1.3.0) bson_ext (~> 1.3.0)
bushido (= 0.0.31) bushido (= 0.0.34)
bushido_stub (= 0.0.3) bushido_stub (= 0.0.3)
cancan cancan
capybara capybara

View File

@ -67,11 +67,14 @@ module Extensions
if existing_el.nil? # new one from parents if existing_el.nil? # new one from parents
new_attributes = el.attributes.merge(:from_parent => true) new_attributes = el.attributes.merge(:from_parent => true)
if new_attributes['default_attribute'].present? if new_attributes['default_attribute'].present?
new_attributes['default_content'] = self.send(new_attributes['default_attribute']) || el.content new_attributes['default_content'] = self.send(new_attributes['default_attribute']) || el.content
else else
if el.respond_to?(:content) # only for text
new_attributes['default_content'] = el.content new_attributes['default_content'] = el.content
end end
end
self.editable_elements.build(new_attributes, el.class) self.editable_elements.build(new_attributes, el.class)
elsif existing_el.default_attribute.nil? elsif existing_el.default_attribute.nil?

View File

@ -84,28 +84,7 @@ module Locomotive
page.save! page.save!
unless editable_elements_attributes.nil? unless editable_elements_attributes.nil?
page.editable_elements.each do |editable_element| self.assign_editable_elements(page, editable_elements_attributes)
editable_elements_attributes.each do |attributes|
if editable_element.block == attributes['block'] && editable_element.slug == attributes['slug']
if editable_element.respond_to?(:source)
# editable_file, update file
unless attributes['content'].blank?
full_path = File.join(File.join(theme_path,'public',attributes['content']))
if File.exists?(full_path)
file = File.open(full_path)
editable_element.source = file
editable_element.save!
file.close
end
end
else
# update content value
editable_element.update_attribute(:content, attributes['content'])
end
break
end
end
end
end end
self.log "adding #{page.fullpath} (#{template.blank? ? 'without' : 'with'} template) / #{page.position}" self.log "adding #{page.fullpath} (#{template.blank? ? 'without' : 'with'} template) / #{page.position}"
@ -117,6 +96,28 @@ module Locomotive
page page
end end
def assign_editable_elements(page, elements)
page.reload # editable elements are not synchronized otherwise
elements.each do |attributes|
element = page.find_editable_element(attributes['block'], attributes['slug'])
next if element.nil?
if element.respond_to?(:source)
asset_path = File.join(theme_path, 'public', attributes['content'])
if File.exists?(asset_path)
element.source = File.open(asset_path)
end
else
element.content = attributes['content']
end
end
page.save!
end
def build_parent_template(template) def build_parent_template(template)
# just check if the template contains the extends keyword # just check if the template contains the extends keyword
fullpath = template.scan(/\{% extends \'?([\w|\/]+)\'? %\}/).flatten.first fullpath = template.scan(/\{% extends \'?([\w|\/]+)\'? %\}/).flatten.first
@ -148,7 +149,7 @@ module Locomotive
return if template.blank? return if template.blank?
template.gsub!(/\/samples\/(.*\.[a-zA-Z0-9]{3})/) do |match| template.gsub!(/\/samples\/(.*\.[a-zA-Z0-9]{3})/) do |match|
name = $1 name = File.basename($1)
if asset = site.assets.where(:source_filename => name).first if asset = site.assets.where(:source_filename => name).first
asset.source.url asset.source.url

Binary file not shown.

View File

@ -55,6 +55,16 @@ describe Locomotive::Import::Job do
@site.pages.not_found.first.should_not be_nil @site.pages.not_found.first.should_not be_nil
end end
it 'sets the editable text for a page from the site config file' do
page = @site.pages.where(:title => 'Contact').first
page.find_editable_element('content', 'address').content.should == '<p>Our office address: 215 Vine Street, Scranton, PA 18503</p>'
end
it 'sets the editable file for a page from the site config file' do
page = @site.pages.where(:title => 'Contact').first
page.find_editable_element('content', 'office').source_filename.should == 'office.jpg'
end
it 'inserts templatized page' do it 'inserts templatized page' do
page = @site.pages.where(:templatized => true).first page = @site.pages.where(:templatized => true).first
page.should_not be_nil page.should_not be_nil