Fix saving of page_part after layout change
This commit is contained in:
parent
2757044c32
commit
5c7f1aa164
|
@ -28,20 +28,10 @@ class Page < Item
|
||||||
|
|
||||||
def generate_parts
|
def generate_parts
|
||||||
page_design = self.design
|
page_design = self.design
|
||||||
parent = self.parent
|
|
||||||
menu_part = parent.page_parts.detect{|page_part| page_part.kind.eql?('public_r_tag') && page_part.public_r_tag.eql?('sub_menu') && page_part.public_r_tag_object_id.eql?(parent.id.to_s)} if parent
|
|
||||||
page_design.layout.layout_parts.each do |layout_part|
|
page_design.layout.layout_parts.each do |layout_part|
|
||||||
current_part = self.page_parts.detect{|page_part| page_part.name.eql?(layout_part.name)}
|
current_part = self.page_parts.detect{|page_part| page_part.name.eql?(layout_part.name)}
|
||||||
current_part = self.page_parts.build(:name => layout_part.name) unless current_part
|
current_part = self.page_parts.build(:name => layout_part.name) unless current_part
|
||||||
if menu_part && current_part.name.eql?(menu_part.name)
|
current_part.save if current_part.new_record?
|
||||||
if current_part.new_record?
|
|
||||||
current_part.kind = menu_part.kind
|
|
||||||
current_part.public_r_tag = menu_part.public_r_tag
|
|
||||||
current_part.public_r_tag_object_id = menu_part.public_r_tag_object_id
|
|
||||||
current_part.save
|
|
||||||
else
|
|
||||||
current_part.update_attributes(:kind => menu_part.kind, :public_r_tag => menu_part.public_r_tag, :public_r_tag_object_id => menu_part.public_r_tag_object_id)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -50,7 +40,22 @@ class Page < Item
|
||||||
|
|
||||||
def create_parts
|
def create_parts
|
||||||
if self.new_record? || self.design_id_changed?
|
if self.new_record? || self.design_id_changed?
|
||||||
generate_parts
|
page_design = self.design
|
||||||
|
parent = self.parent
|
||||||
|
menu_part = parent.page_parts.detect{|page_part| page_part.kind.eql?('public_r_tag') && page_part.public_r_tag.eql?('sub_menu') && page_part.public_r_tag_object_id.eql?(parent.id.to_s)} if parent
|
||||||
|
page_design.layout.layout_parts.each do |layout_part|
|
||||||
|
current_part = self.page_parts.detect{|page_part| page_part.name.eql?(layout_part.name)}
|
||||||
|
current_part = self.page_parts.build(:name => layout_part.name) unless current_part
|
||||||
|
if menu_part && current_part.name.eql?(menu_part.name)
|
||||||
|
if current_part.new_record?
|
||||||
|
current_part.kind = menu_part.kind
|
||||||
|
current_part.public_r_tag = menu_part.public_r_tag
|
||||||
|
current_part.public_r_tag_object_id = menu_part.public_r_tag_object_id
|
||||||
|
else
|
||||||
|
current_part.update_attributes(:kind => menu_part.kind, :public_r_tag => menu_part.public_r_tag, :public_r_tag_object_id => menu_part.public_r_tag_object_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Reference in New Issue