Module: Spree::Admin::NavigationHelper

Defined in:
app/helpers/spree/admin/navigation_helper.rb

Instance Method Summary collapse

Instance Method Details

#button(text, icon_name = nil, button_type = 'submit', options = {}) ⇒ Object



168
169
170
171
172
173
174
# File 'app/helpers/spree/admin/navigation_helper.rb', line 168

def button(text, icon_name = nil, button_type = 'submit', options={})
  if icon_name
    icon = (:span, '', class: "icon icon-#{icon_name}")
    text.insert(0, icon + ' ')
  end
  button_tag(text.html_safe, options.merge(type: button_type, class: "btn btn-primary #{options[:class]}"))
end


176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
# File 'app/helpers/spree/admin/navigation_helper.rb', line 176

def button_link_to(text, url, html_options = {})
  if (html_options[:method] &&
      html_options[:method].to_s.downcase != 'get' &&
      !html_options[:remote])
    form_tag(url, method: html_options.delete(:method)) do
      button(text, html_options.delete(:icon), nil, html_options)
    end
  else
    if html_options['data-update'].nil? && html_options[:remote]
      object_name, action = url.split('/')[-2..-1]
      html_options['data-update'] = [action, object_name.singularize].join('_')
    end

    html_options.delete('data-update') unless html_options['data-update']

    html_options[:class]  = html_options[:class] ? "btn #{html_options[:class]}" : "btn btn-default"

    if html_options[:icon]
      icon = (:span, '', class: "icon icon-#{html_options[:icon]}")
      text.insert(0, icon + ' ')
    end

    link_to(text.html_safe, url, html_options)
  end
end

sidebar are used on order edit, product edit, user overview etc. this link is shown so a user can collapse the sidebar



65
66
67
68
69
70
71
72
# File 'app/helpers/spree/admin/navigation_helper.rb', line 65

def collapse_sidebar_link
   :div, class: "collapse-sidebar" do
    link_to "javascript:;", class: "js-collapse-sidebar" do
      (:span, nil, class: "icon icon-chevron-right") +
      (:span, "Collapse sidebar", class: "text")
    end
  end
end

#configurations_menu_item(link_text, url, description = '') ⇒ Object



202
203
204
205
206
207
208
# File 'app/helpers/spree/admin/navigation_helper.rb', line 202

def configurations_menu_item(link_text, url, description = '')
  %(<tr>
    <td>#{link_to(link_text, url)}</td>
    <td>#{description}</td>
  </tr>
  ).html_safe
end

#configurations_sidebar_menu_item(link_text, url, options = {}) ⇒ Object



210
211
212
213
214
215
216
217
218
# File 'app/helpers/spree/admin/navigation_helper.rb', line 210

def configurations_sidebar_menu_item(link_text, url, options = {})
  is_active = url.ends_with?(controller.controller_name) ||
              url.ends_with?("#{controller.controller_name}/edit") ||
              url.ends_with?("#{controller.controller_name.singularize}/edit")
  options.merge!(class: is_active ? 'active' : nil)
  (:li, options) do
    link_to(link_text, url)
  end
end

#icon(icon_name) ⇒ Object



164
165
166
# File 'app/helpers/spree/admin/navigation_helper.rb', line 164

def icon(icon_name)
  icon_name ? (:i, '', class: icon_name) : ''
end

#klass_for(name) ⇒ Object

finds class for a given symbol / string

Example : :products returns Spree::Product :my_products returns MyProduct if MyProduct is defined :my_products returns My::Product if My::Product is defined if cannot constantize it returns nil This will allow us to use cancan abilities on tab



110
111
112
113
114
115
116
# File 'app/helpers/spree/admin/navigation_helper.rb', line 110

def klass_for(name)
  model_name = name.to_s

  ["Spree::#{model_name.classify}", model_name.classify, model_name.gsub('_', '/').classify].find do |t|
    t.safe_constantize
  end.try(:safe_constantize)
end


118
119
120
121
122
# File 'app/helpers/spree/admin/navigation_helper.rb', line 118

def link_to_clone(resource, options={})
  options[:data] = { action: 'clone' }
  options[:class] = "btn btn-primary btn-sm"
  link_to_with_icon('clone', Spree.t(:clone), clone_object_url(resource), options)
end


143
144
145
146
147
148
149
# File 'app/helpers/spree/admin/navigation_helper.rb', line 143

def link_to_delete(resource, options={})
  url = options[:url] || object_url(resource)
  name = options[:name] || Spree.t(:delete)
  options[:class] = "btn btn-danger btn-sm delete-resource"
  options[:data] = { confirm: Spree.t(:are_you_sure), action: 'remove' }
  link_to_with_icon 'delete', name, url, options
end


130
131
132
133
134
135
# File 'app/helpers/spree/admin/navigation_helper.rb', line 130

def link_to_edit(resource, options={})
  url = options[:url] || edit_object_url(resource)
  options[:data] = { action: 'edit' }
  options[:class] = "btn btn-primary btn-sm"
  link_to_with_icon('edit', Spree.t(:edit), url, options)
end


137
138
139
140
141
# File 'app/helpers/spree/admin/navigation_helper.rb', line 137

def link_to_edit_url(url, options={})
  options[:data] = { action: 'edit' }
  options[:class] = "btn btn-primary btn-sm"
  link_to_with_icon('edit', Spree.t(:edit), url, options)
end


124
125
126
127
128
# File 'app/helpers/spree/admin/navigation_helper.rb', line 124

def link_to_new(resource)
  options[:data] = { action: 'new' }
  options[:class] = "btn btn-success btn-sm"
  link_to_with_icon('plus', Spree.t(:new), edit_object_url(resource))
end


151
152
153
154
155
156
157
158
159
160
161
162
# File 'app/helpers/spree/admin/navigation_helper.rb', line 151

def link_to_with_icon(icon_name, text, url, options = {})
  options[:class] = (options[:class].to_s + " icon-link with-tip action-#{icon_name}").strip
  options[:class] += ' no-text' if options[:no_text]
  options[:title] = text if options[:no_text]
  text = options[:no_text] ? '' : raw("<span class='text'>#{text}</span>")
  options.delete(:no_text)
  if icon_name
    icon = (:span, '', class: "icon icon-#{icon_name}")
    text.insert(0, icon + ' ')
  end
  link_to(text.html_safe, url, options)
end

Single main menu item



47
48
49
50
51
52
53
# File 'app/helpers/spree/admin/navigation_helper.rb', line 47

def main_menu_item text, url: nil, icon: nil
  link_to url, :'data-toggle' => "collapse", :'data-parent' => '#sidebar' do
    (:span, nil, class: "icon icon-#{icon}") +
    (:span, " #{text}", class: 'text') +
    (:span, nil, class: "icon icon-chevron-left pull-right")
  end
end

Main menu tree menu



56
57
58
59
60
61
# File 'app/helpers/spree/admin/navigation_helper.rb', line 56

def main_menu_tree text, icon: nil, sub_menu: nil, url: '#'
   :li, class: 'sidebar-menu-item' do
    main_menu_item(text, url: url, icon: icon) +
    render(partial: "spree/admin/shared/sub_menu/#{sub_menu}")
  end
end

#main_part_classesObject



220
221
222
223
224
225
226
# File 'app/helpers/spree/admin/navigation_helper.rb', line 220

def main_part_classes
  if cookies['sidebar-minimized'] == 'true'
    return 'col-sm-12 col-md-12 sidebar-collapsed'
  else
    return 'col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2'
  end
end

#per_page_dropdownObject

the per_page_dropdown is used on index pages like orders, products, promotions etc. this method generates the select_tag



76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
# File 'app/helpers/spree/admin/navigation_helper.rb', line 76

def per_page_dropdown
  # there is a config setting for admin_products_per_page, only for the orders page
  if @products && per_page_default = Spree::Config.admin_products_per_page
    per_page_options = []
    5.times do |amount|
      per_page_options << (amount + 1) * Spree::Config.admin_products_per_page
    end
  else
    per_page_default = 15
    per_page_options = %w{5 15 30 45 60}
  end

  select_tag(:per_page,
    options_for_select(per_page_options, params['per_page'] || per_page_default),
    { class: "form-control pull-right js-per-page-select" })
end

#per_page_dropdown_paramsObject

helper method to create proper url to apply per page filtering fixes github.com/spree/spree/issues/6888



95
96
97
98
99
100
# File 'app/helpers/spree/admin/navigation_helper.rb', line 95

def per_page_dropdown_params
  args = params.clone
  args.delete(:page)
  args.delete(:per_page)
  args
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.


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
36
37
38
39
40
41
42
43
44
# File 'app/helpers/spree/admin/navigation_helper.rb', line 9

def tab(*args)
  options = { label: args.first.to_s }

  # Return if resource is found and user is not allowed to :admin
  return '' if klass = klass_for(options[:label]) and cannot?(:admin, klass)

  if args.last.is_a?(Hash)
    options = options.merge(args.pop)
  end
  options[:route] ||=  "admin_#{args.first}"

  destination_url = options[:url] || spree.send("#{options[:route]}_path")
  titleized_label = Spree.t(options[:label], default: options[:label], scope: [:admin, :tab]).titleize

  css_classes = ['sidebar-menu-item']

  if options[:icon]
    link = link_to_with_icon(options[:icon], titleized_label, destination_url)
  else
    link = link_to(titleized_label, destination_url)
  end

  selected = if options[:match_path].is_a? Regexp
    request.fullpath =~ options[:match_path]
  elsif options[:match_path]
    request.fullpath.starts_with?("#{spree.admin_path}#{options[:match_path]}")
  else
    args.include?(controller.controller_name.to_sym)
  end
  css_classes << 'selected' if selected

  if options[:css_class]
    css_classes << options[:css_class]
  end
  ('li', link, class: css_classes.join(' '))
end

#wrapper_classesObject



228
229
230
231
232
# File 'app/helpers/spree/admin/navigation_helper.rb', line 228

def wrapper_classes
  if cookies['sidebar-minimized'] == 'true'
    return 'sidebar-minimized'
  end
end