aboutsummaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorMichael Gall <michael@wakeless.net>2011-05-31 11:38:28 +1000
committerPhilip Arndt <parndt@gmail.com>2011-05-31 13:53:56 +1200
commit60fc7839f8b6227951eed454442b69836840df01 (patch)
treeb34f4b00c7d8616635480befeb5200b68dfacca7 /app
parent7bb8b056f5b181cfdc88afa60799f3a669d9913f (diff)
downloadrefinerycms-blog-60fc7839f8b6227951eed454442b69836840df01.tar.gz
refinerycms-blog-60fc7839f8b6227951eed454442b69836840df01.tar.bz2
refinerycms-blog-60fc7839f8b6227951eed454442b69836840df01.zip
Add page-like tab functionality
Diffstat (limited to 'app')
-rw-r--r--app/models/blog_post.rb2
-rw-r--r--app/views/admin/blog/posts/_form.html.erb29
-rw-r--r--app/views/admin/blog/posts/_form.js.erb1
-rw-r--r--app/views/admin/blog/posts/_form_part.html.erb3
4 files changed, 33 insertions, 2 deletions
diff --git a/app/models/blog_post.rb b/app/models/blog_post.rb
index 63c66ba..e298bcf 100644
--- a/app/models/blog_post.rb
+++ b/app/models/blog_post.rb
@@ -22,6 +22,8 @@ class BlogPost < ActiveRecord::Base
validates :body, :presence => true
has_friendly_id :title, :use_slug => true
+
+ attr_accessible :title, :body, :tag_list, :draft, :published_at, :browser_title, :meta_keywords, :meta_description, :user_id
scope :by_archive, lambda { |archive_date|
where(['published_at between ? and ?', archive_date.beginning_of_month, archive_date.end_of_month])
diff --git a/app/views/admin/blog/posts/_form.html.erb b/app/views/admin/blog/posts/_form.html.erb
index 7bcca84..7d95052 100644
--- a/app/views/admin/blog/posts/_form.html.erb
+++ b/app/views/admin/blog/posts/_form.html.erb
@@ -11,8 +11,33 @@
</div>
<div class='field'>
- <%= f.label :body -%>
- <%= f.text_area :body, :rows => 20, :class => 'wymeditor widest' -%>
+ <div id='page-tabs' class='clearfix ui-tabs ui-widget ui-widget-content ui-corner-all'>
+ <ul id='page_parts'>
+ <li class='ui-state-default'>
+ <%= link_to "Body", "#page_part_body" %>
+ </li>
+ <% Refinery::Blog.tabs.each_with_index do |tab, tab_index| %>
+ <li class='ui-state-default' id="custom_<%= tab.name %>_tab">
+ <%= link_to tab.name.titleize, "#custom_tab_#{tab_index}" %>
+ </li>
+ <% end %>
+ </ul>
+
+ <div id='page_part_editors'>
+
+ <% part_index = -1 %>
+ <%= render :partial => 'form_part',
+ :locals => {
+ :f => f,
+ :part_index => (part_index += 1),
+ } -%>
+ <% Refinery::Blog.tabs.each_with_index do |tab, tab_index| %>
+ <div class='page_part' id='<%= "custom_tab_#{tab_index}" %>'>
+ <%= render :partial => tab.partial, :locals => {:f => f} %>
+ </div>
+ <% end %>
+ </div>
+ </div>
</div>
<div class='field'>
diff --git a/app/views/admin/blog/posts/_form.js.erb b/app/views/admin/blog/posts/_form.js.erb
index 1d65448..98a61d0 100644
--- a/app/views/admin/blog/posts/_form.js.erb
+++ b/app/views/admin/blog/posts/_form.js.erb
@@ -10,4 +10,5 @@
}, 250);
});
});
+ var tabs = $('#page-tabs').tabs();
</script>
diff --git a/app/views/admin/blog/posts/_form_part.html.erb b/app/views/admin/blog/posts/_form_part.html.erb
new file mode 100644
index 0000000..114e493
--- /dev/null
+++ b/app/views/admin/blog/posts/_form_part.html.erb
@@ -0,0 +1,3 @@
+<div class='page_part' id='page_part_body'>
+ <%= f.text_area :body, :rows => 20, :class => 'wymeditor widest' -%>
+</div>