Commit 57484551b6a5e1fb6e6d80c26decaca0142e8a3a
Committed by
Daniela Feitosa
1 parent
b87e8539
Exists in
master
and in
29 other branches
Displaying blocks types that are acceptable for each box position
Showing
3 changed files
with
44 additions
and
18 deletions
Show diff stats
app/controllers/box_organizer_controller.rb
@@ -68,7 +68,8 @@ class BoxOrganizerController < ApplicationController | @@ -68,7 +68,8 @@ class BoxOrganizerController < ApplicationController | ||
68 | raise ArgumentError.new("Type %s is not allowed. Go away." % type) | 68 | raise ArgumentError.new("Type %s is not allowed. Go away." % type) |
69 | end | 69 | end |
70 | else | 70 | else |
71 | - @block_types = available_blocks | 71 | + @center_block_types = Box.acceptable_center_blocks & available_blocks |
72 | + @side_block_types = Box.acceptable_side_blocks & available_blocks | ||
72 | @boxes = boxes_holder.boxes | 73 | @boxes = boxes_holder.boxes |
73 | render :action => 'add_block', :layout => false | 74 | render :action => 'add_block', :layout => false |
74 | end | 75 | end |
@@ -0,0 +1,12 @@ | @@ -0,0 +1,12 @@ | ||
1 | +<% block_types.in_groups_of(2) do |block1, block2| %> | ||
2 | + <div style='float: left; width: 48%; padding-top: 2px;'> | ||
3 | + <%= radio_button_tag('type', block1.name) %> | ||
4 | + <%= label_tag "type_#{block1.name.downcase}", block1.description %> | ||
5 | + </div> | ||
6 | + <% if block2 %> | ||
7 | + <div style='float: left; width: 48%; padding-top: 2px;'> | ||
8 | + <%= radio_button_tag('type', block2.name) %> | ||
9 | + <%= label_tag "type_#{block2.name.downcase}", block2.description %> | ||
10 | + </div> | ||
11 | + <% end %> | ||
12 | +<% end %> |
app/views/box_organizer/add_block.rhtml
@@ -2,25 +2,38 @@ | @@ -2,25 +2,38 @@ | ||
2 | 2 | ||
3 | <p><%= _('In what area do you want to put your new block?') %></p> | 3 | <p><%= _('In what area do you want to put your new block?') %></p> |
4 | 4 | ||
5 | - <%# FIXME hardcoded stuff %> | ||
6 | - <%= select_tag('box_id', options_for_select(@boxes.select { |item| item.position != 1 }.map {|item| [ _("Area %d") % item.position, item.id]})) %> | ||
7 | - | ||
8 | - <p><%= _('Select the type of block you want to add to your page.') %></p> | ||
9 | - | ||
10 | - <% @block_types.in_groups_of(2) do |block1, block2| %> | ||
11 | - <div style='float: left; width: 48%; padding-top: 2px;'> | ||
12 | - <%= radio_button_tag('type', block1.name) %> | ||
13 | - <%= label_tag "type_#{block1.name.downcase}", block1.description %> | ||
14 | - </div> | ||
15 | - <% if block2 %> | ||
16 | - <div style='float: left; width: 48%; padding-top: 2px;'> | ||
17 | - <%= radio_button_tag('type', block2.name) %> | ||
18 | - <%= label_tag "type_#{block2.name.downcase}", block2.description %> | ||
19 | - </div> | ||
20 | - <% end %> | 5 | + <% @boxes.each do |box| %> |
6 | + <%= radio_button_tag 'box-position', box.id, box.central?, { :class => 'box-position', 'data-position' => box.position } %> | ||
7 | + <%= label_tag _("Area %d") % box.position %> | ||
21 | <% end %> | 8 | <% end %> |
9 | + | ||
10 | + <script type="text/javascript"> | ||
11 | + (function ($) { | ||
12 | + $(document).ready(function () { | ||
13 | + $(".box-position").live('change', function () { | ||
14 | + if ($(this).attr('data-position') == '1') { | ||
15 | + $('#center-block-types').show(); | ||
16 | + $('#side-block-types').hide(); | ||
17 | + } else { | ||
18 | + $('#center-block-types').hide(); | ||
19 | + $('#side-block-types').show(); | ||
20 | + }; | ||
21 | + }); | ||
22 | + })})(jQuery); | ||
23 | + </script> | ||
24 | + | ||
25 | + <p><%= _('Select the type of block you want to add to your page.') %></p> | ||
26 | + | ||
27 | + <div id='center-block-types'> | ||
28 | + <%= render :partial => 'block_types', :locals => { :block_types => @center_block_types } %> | ||
29 | + </div> | ||
30 | + | ||
31 | + <div id='side-block-types' style='display:none'> | ||
32 | + <%= render :partial => 'block_types', :locals => { :block_types => @side_block_types } %> | ||
33 | + </div> | ||
34 | + | ||
22 | <br style='clear: both'/> | 35 | <br style='clear: both'/> |
23 | - | 36 | + |
24 | <% button_bar do %> | 37 | <% button_bar do %> |
25 | <%= submit_button(:add, _("Add")) %> | 38 | <%= submit_button(:add, _("Add")) %> |
26 | <%= lightbox_close_button(_('Close')) %> | 39 | <%= lightbox_close_button(_('Close')) %> |