summaryrefslogtreecommitdiff
path: root/app/helpers/link_helper.rb
blob: 55e392b13f3c4c7fb2c52467efdc19a65e1fc513 (plain)
1
2
3
4
5
6
7
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
module LinkHelper

  #
  # markup for bootstrap button
  #
  # takes same arguments as link_to and adds a 'btn' class.
  # In addition:
  # * the name will be translated if it is a symbol
  # * html_options[:type] will be converted into a btn-type class
  #
  # example:
  # btn :home, home_path, type: [:large, :primary]
  #
  def btn(*args, &block)
    html_options = extract_html_options!(args, &block)
    type = Array(html_options.delete(:type))
    type.map! {|t| "btn-#{t}"}
    html_options[:class] = concat_classes(html_options[:class], 'btn', type)
    args[0] = t(args[0]) if args[0].is_a?(Symbol)
    link_to *args, html_options, &block
  end

  def destroy_btn(*args, &block)
    html_options = extract_html_options!(args, &block)
    confirmation = t "#{controller_symbol}.confirm.destroy.are_you_sure",
      cascade: true
    html_options.merge! method: :delete, confirm: confirmation
    btn *args, html_options, &block
  end

  #
  # concat_classes will combine classes in a fairly flexible way.
  # it can handle nil, arrays, space separated strings
  # it returns a space separated string of classes.
  def concat_classes(*classes)
    classes.compact!
    classes.map {|c| c.respond_to?(:split) ? c.split(' ') : c }
    classes.flatten!
    classes.join ' '
  end

  def extract_html_options!(args)
    if args.count > 2 or args.count > 1 && block_given?
      args.extract_options!
    else
      {}
    end
  end
end