Module: Admin::NavigationHelper
- Defined in:
- app/helpers/admin/navigation_helper.rb
Instance Method Summary collapse
- #button(text, icon_name = nil, button_type = 'submit', options = {}) ⇒ Object
- #button_link_to(text, url, html_options = {}) ⇒ Object
- #button_link_to_function(text, function, html_options = {}) ⇒ Object
- #configurations_menu_item(link_text, url, description = '') ⇒ Object
- #html_options_for_button_link(html_options) ⇒ Object
- #icon(icon_name) ⇒ Object
- #link_to_clone(resource, options = {}) ⇒ Object
- #link_to_delete(resource, options = {}, html_options = {}) ⇒ Object
- #link_to_edit(resource, options = {}) ⇒ Object
- #link_to_edit_url(url, options = {}) ⇒ Object
- #link_to_function_delete(options, html_options) ⇒ Object
- #link_to_function_delete_ajax(options) ⇒ Object
-
#link_to_function_delete_native(options, html_options) ⇒ Object
this function does not use jConfirm.
- #link_to_new(resource) ⇒ Object
- #link_to_with_icon(icon_name, text, url, options = {}) ⇒ Object
-
#tab(*args) ⇒ Object
Make an admin tab that coveres one or more resources supplied by symbols Option hash may follow.
-
#text_for_button_link(text, html_options) ⇒ Object
RAILS 3 TODO - no longer needed def button_link_to_remote(text, url, html_options = {}) html_options.reverse_merge! :remote => true link_to(text_for_button_link(text, html_options), url, html_options_for_button_link(html_options)) end.
Instance Method Details
#button(text, icon_name = nil, button_type = 'submit', options = {}) ⇒ Object
104 105 106 |
# File 'app/helpers/admin/navigation_helper.rb', line 104 def (text, icon_name = nil, = 'submit', ={}) content_tag('button', content_tag('span', icon(icon_name) + ' ' + text), .merge(:type => )) end |
#button_link_to(text, url, html_options = {}) ⇒ Object
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 |
# File 'app/helpers/admin/navigation_helper.rb', line 108 def (text, url, = {}) if ([:method] && [:method].to_s.downcase != 'get' && ![:remote]) form_tag(url, :method => [:method]) do (text, [:icon]) end else if ['data-update'].nil? && [:remote] object_name, action = url.split('/')[-2..-1] ['data-update'] = [action, object_name.singularize].join('_') end .delete('data-update') unless ['data-update'] link_to((text, ), url, ()) end end |
#button_link_to_function(text, function, html_options = {}) ⇒ Object
125 126 127 |
# File 'app/helpers/admin/navigation_helper.rb', line 125 def (text, function, = {}) link_to_function((text, ), function, ()) end |
#configurations_menu_item(link_text, url, description = '') ⇒ Object
154 155 156 157 158 159 160 |
# File 'app/helpers/admin/navigation_helper.rb', line 154 def (link_text, url, description = '') %(<tr> <td>#{link_to(link_text, url)}</td> <td>#{description}</td> </tr> ).html_safe end |
#html_options_for_button_link(html_options) ⇒ Object
150 151 152 |
# File 'app/helpers/admin/navigation_helper.rb', line 150 def () = {:class => 'button'}.update() end |
#icon(icon_name) ⇒ Object
100 101 102 |
# File 'app/helpers/admin/navigation_helper.rb', line 100 def icon(icon_name) icon_name ? image_tag("/images/admin/icons/#{icon_name}.png") : '' end |
#link_to_clone(resource, options = {}) ⇒ Object
50 51 52 |
# File 'app/helpers/admin/navigation_helper.rb', line 50 def link_to_clone(resource, ={}) link_to_with_icon('exclamation', t("clone"), clone_admin_product_url(resource), ) end |
#link_to_delete(resource, options = {}, html_options = {}) ⇒ Object
54 55 56 57 58 59 60 61 62 63 64 65 66 |
# File 'app/helpers/admin/navigation_helper.rb', line 54 def link_to_delete(resource, = {}, ={}) .assert_valid_keys(:url, :caption, :title, :dataType, :success, :name) .reverse_merge! :url => object_url(resource) unless .key? :url .reverse_merge! :caption => t('are_you_sure') .reverse_merge! :title => t('confirm_delete') .reverse_merge! :dataType => 'script' .reverse_merge! :success => "function(r){ jQuery('##{dom_id resource}').fadeOut('hide'); }" .reverse_merge! :name => icon("delete") + ' ' + t("delete") link_to_function_delete(, ) #link_to_function_delete_native(options, html_options) end |
#link_to_edit(resource, options = {}) ⇒ Object
42 43 44 |
# File 'app/helpers/admin/navigation_helper.rb', line 42 def link_to_edit(resource, ={}) link_to_with_icon('edit', t("edit"), edit_object_url(resource), ) end |
#link_to_edit_url(url, options = {}) ⇒ Object
46 47 48 |
# File 'app/helpers/admin/navigation_helper.rb', line 46 def link_to_edit_url(url, ={}) link_to_with_icon('edit', t("edit"), url, ) end |
#link_to_function_delete(options, html_options) ⇒ Object
77 78 79 80 81 |
# File 'app/helpers/admin/navigation_helper.rb', line 77 def link_to_function_delete(, ) link_to_function [:name], "jConfirm('#{[:caption]}', '#{[:title]}', function(r) { if(r){ #{link_to_function_delete_ajax()} } });", end |
#link_to_function_delete_ajax(options) ⇒ Object
83 84 85 86 87 88 89 90 91 92 93 |
# File 'app/helpers/admin/navigation_helper.rb', line 83 def link_to_function_delete_ajax() %Q{ jQuery.ajax({ type: 'POST', url: '#{[:url]}', data: ({_method: 'delete', authenticity_token: AUTH_TOKEN}), dataType:'#{[:dataType]}', success: #{[:success]} }); } end |
#link_to_function_delete_native(options, html_options) ⇒ Object
this function does not use jConfirm
69 70 71 72 73 74 75 |
# File 'app/helpers/admin/navigation_helper.rb', line 69 def link_to_function_delete_native(, ) fn = %Q{ var answer = confirm("are you sure?"); if (!!answer) { #{link_to_function_delete_ajax()} }; } link_to_function [:name], fn, end |
#link_to_new(resource) ⇒ Object
38 39 40 |
# File 'app/helpers/admin/navigation_helper.rb', line 38 def link_to_new(resource) link_to_with_icon('add', t("new"), edit_object_url(resource)) end |
#link_to_with_icon(icon_name, text, url, options = {}) ⇒ Object
95 96 97 98 |
# File 'app/helpers/admin/navigation_helper.rb', line 95 def link_to_with_icon(icon_name, text, url, = {}) [:class] = ([:class].to_s + " icon_link").strip link_to(icon(icon_name) + ' ' + text, url, ) end |
#tab(*args) ⇒ Object
Make an admin tab that coveres one or more resources supplied by symbols Option hash may follow. Valid options are
* :label to override link text, otherwise based on the first resource name (translated)
* :route to override automatically determining the default route
* :match_path as an alternative way to control when the tab is active, /products would match /admin/products, /admin/products/5/variants etc.
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'app/helpers/admin/navigation_helper.rb', line 8 def tab(*args) = {:label => args.first.to_s} if args.last.is_a?(Hash) = .merge(args.pop) end [:route] ||= "admin_#{args.first}" destination_url = send("#{[:route]}_path") ## if more than one form, it'll capitalize all words label_with_first_letters_capitalized = t([:label]).gsub(/\b\w/){$&.upcase} link = link_to(label_with_first_letters_capitalized, destination_url) css_classes = [] selected = if [:match_path] request.fullpath.starts_with?("/admin#{[:match_path]}") else args.include?(controller.controller_name.to_sym) end css_classes << 'selected' if selected if [:css_class] css_classes << [:css_class] end content_tag('li', link, :class => css_classes.join(' ')) end |
#text_for_button_link(text, html_options) ⇒ Object
RAILS 3 TODO - no longer needed def button_link_to_remote(text, url, html_options = {})
.reverse_merge! :remote => true
link_to((text, ), url, ())
end
def link_to_remote(name, options = {}, html_options = {})
[:before] ||= "jQuery(this).parent().hide(); jQuery('#busy_indicator').show();"
[:complete] ||= "jQuery('#busy_indicator').hide()"
link_to_function(name, remote_function(), || .delete(:html))
end
141 142 143 144 145 146 147 148 |
# File 'app/helpers/admin/navigation_helper.rb', line 141 def (text, ) s = '' if [:icon] s << icon(.delete(:icon)) + ' ' end s << text content_tag('span', raw(s)) end |