Module: AbAdmin::Views::AdminHelpers

Defined in:
lib/ab_admin/views/admin_helpers.rb

Instance Method Summary collapse

Instance Method Details

#admin_commentsObject



114
115
116
# File 'lib/ab_admin/views/admin_helpers.rb', line 114

def admin_comments
  render 'admin/admin_comments/comments'
end

#admin_editable(item, attr, opts = nil) ⇒ Object



30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# File 'lib/ab_admin/views/admin_helpers.rb', line 30

def admin_editable(item, attr, opts=nil)
  opts = {} unless opts.is_a?(Hash)
  if opts[:title]
    title = opts[:title]
  else
    assoc_name = attr.to_s.remove('_id')
    title = item.class.reflect_on_association(assoc_name) ? AbAdmin.display_name(item.send(assoc_name)) : item[attr]
  end
  html_title = admin_pretty_data(title).to_s.html_safe
  return html_title unless can?(:update, item)

  if opts[:collection]
    if opts[:collection].is_a?(Hash)
      opts[:source] = opts[:collection]
    elsif opts[:collection].is_a?(Array)
      opts[:source] = opts[:collection].first.respond_to?(:id) ? opts[:collection].map {|r| [r.id, AbAdmin.display_name(r)]}.to_h : opts[:collection].map {|v| [v, v]}.to_h
    end
  end

  unless opts[:type]
    if opts[:source]
      opts[:type] = 'select'
    else
      case attr.to_s
        when /_at$/
          opts[:type] ||= 'date'
          opts[:title] ||= html_title
        when /^is_/
          opts[:type] ||= 'select'
          opts[:source] ||= {1 => 'yes', 0 => 'no'}
          opts[:value] ||= item[attr] ? 1 : 0
          opts[:title] ||= item[attr] ? 'yes' : 'no'
        when /description|body|content/
          opts[:type] ||= 'textarea'
        else
          opts[:type] ||= 'text'
      end
    end
  end

  data = {
      type: opts[:type],
      source: opts[:source].try(:to_json),
      model: opts[:model] || item.class.model_name.singular,
      accept: opts[:accept],
      url: opts[:url] || "/admin/#{item.class.model_name.plural}/#{item.id}",
      name: attr,
      value: opts[:value] || item[attr],
      title: opts[:title] || item[attr]
  }
  link_to html_title, '#', class: "editable #{opts[:class]}", data: data.update(opts[:data] || {})
end

#admin_form_for(object, *args, &block) ⇒ Object



4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# File 'lib/ab_admin/views/admin_helpers.rb', line 4

def admin_form_for(object, *args, &block)
  record = Array(object).last
  record.fallbacks_for_empty_translations = false if record.respond_to?(:fallbacks_for_empty_translations)
  options = args.extract_options!
  options[:remote] = true if request.xhr?
  options[:html] ||= {}
  options[:html][:class] ||= 'form-horizontal'
  options[:builder] ||= ::AbAdmin::Views::FormBuilder
  options[:html]['data-id'] = record.id
  if controller_name == 'manager' && resource_class == Array(object).last.class
    options[:url] ||= object.new_record? ? collection_path : resource_path
  end
  if options.delete(:nested)
    simple_nested_form_for([:admin, object].flatten, *(args << options), &block)
  else
    simple_form_for([:admin, object].flatten, *(args << options), &block)
  end
end

#admin_layout_cssObject



96
97
98
99
100
101
102
# File 'lib/ab_admin/views/admin_helpers.rb', line 96

def admin_layout_css
  css = []
  css << 'content_with_sidebar' if settings[:sidebar] || content_for?(:sidebar)
  css << 'well' if !@settings[:well].is_a?(FalseClass) && (collection_action? || %w(show history).include?(action_name)) && @settings[:current_index_view] != :tree
  css << "#{settings[:current_index_view]}_view"
  css
end

#admin_pretty_data(object) ⇒ Object



133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
# File 'lib/ab_admin/views/admin_helpers.rb', line 133

def admin_pretty_data(object)
  case object
    when String, Integer, BigDecimal, Float
      object
    when TrueClass, FalseClass
      color_bool(object)
    when Date, DateTime, Time, ActiveSupport::TimeWithZone
      I18n.l(object, format: :long)
    when NilClass
      ''
    when ActiveRecord::Base
      admin_show_link(object)
    else
      AbAdmin.safe_display_name(object) || object
  end
end

#admin_site_nameObject



185
186
187
# File 'lib/ab_admin/views/admin_helpers.rb', line 185

def admin_site_name
  AbAdmin.site_name.is_a?(String) ? AbAdmin.site_name : AbAdmin.site_name.call
end

#admin_titleObject



104
105
106
107
108
# File 'lib/ab_admin/views/admin_helpers.rb', line 104

def admin_title
  base = @breadcrumbs ? @breadcrumbs.map{|b| b[:name] }.reverse : []
  base << @page_title || 'Ab Admin'
  base.join(' - ')
end

#admin_tree(items) ⇒ Object



91
92
93
94
# File 'lib/ab_admin/views/admin_helpers.rb', line 91

def admin_tree(items)
  return if items.blank?
  items.map { |item| admin_tree_item(item) }.join.html_safe
end

#admin_tree_item(item) ⇒ Object



87
88
89
# File 'lib/ab_admin/views/admin_helpers.rb', line 87

def admin_tree_item(item)
  render 'tree_item', item: item, child_tree: admin_tree(item.cached_children)
end

#call_method_or_proc_on(obj, symbol_or_proc, options = {}) ⇒ Object



189
190
191
192
193
194
195
196
197
198
199
# File 'lib/ab_admin/views/admin_helpers.rb', line 189

def call_method_or_proc_on(obj, symbol_or_proc, options = {})
  exec = options[:exec].nil? ? true : options[:exec]
  case symbol_or_proc
    when String
      symbol_or_proc
    when Symbol
      obj.send(symbol_or_proc.to_sym)
    when Proc
      exec ? instance_exec(obj, &symbol_or_proc) : symbol_or_proc.call(obj)
  end
end

#color_bool(val, options = {}) ⇒ Object



118
119
120
121
122
123
# File 'lib/ab_admin/views/admin_helpers.rb', line 118

def color_bool(val, options={})
  options.reverse_merge!(true_css: 'badge-success', false_css: nil, nil_css: nil)
  css = options["#{val.inspect}_css".to_sym]
  text = val.nil? ? '?' : (val ? '+' : '-')
  %(<span class="badge #{css}">#{text}</span>).html_safe
end

#editable_bool(item, attr, label: nil, wrapper_class: nil) ⇒ Object



23
24
25
26
27
28
# File 'lib/ab_admin/views/admin_helpers.rb', line 23

def editable_bool(item, attr, label: nil, wrapper_class: nil)
  url = "/admin/#{item.class.model_name.plural}/#{item.id}.json"
  html = check_box_tag("#{item.class.model_name.singular}[#{attr}]", '1', item.send(attr), class: 'js-auto-submit-checkbox', data: {url: url})
  html = (:label, "#{label}&nbsp;#{html}".html_safe) if label
   :div, html, class: ['auto-submit-checkbox-wrap', 'white-space-nowrap', ('tool' unless label), wrapper_class], title: attr
end

#ha(attr) ⇒ Object



181
182
183
# File 'lib/ab_admin/views/admin_helpers.rb', line 181

def ha(attr)
  resource_class.han(attr)
end

#icon(name, white = false) ⇒ Object



125
126
127
# File 'lib/ab_admin/views/admin_helpers.rb', line 125

def icon(name, white=false)
  "<i class='icon-#{name} #{'icon-white' if white}'></i> ".html_safe
end

#include_fvObject



110
111
112
# File 'lib/ab_admin/views/admin_helpers.rb', line 110

def include_fv
  "<script type='text/javascript'>window.fv = #{fv.to_h.to_json}</script>".html_safe
end

#input_set(title, options = {}, &block) ⇒ Object

input_set ‘title’, legend_class: ‘do_sort’, label_class: ‘label-info’ do



174
175
176
177
178
179
# File 'lib/ab_admin/views/admin_helpers.rb', line 174

def input_set(title, options={}, &block)
  options.reverse_merge!(class: "inputs well well-small clearfix #{options.delete(:legend_class) || 'do_sort'}", id: options.delete(:legend_id))
  html = title ? (:label, title, class: "input_set label #{options.delete(:label_class)}") : ''.html_safe
  html.concat(capture(&block)) if block_given?
  (:div, html, options)
end

#item_image(item, assoc = :photo, size = :thumb) ⇒ Object



169
170
171
# File 'lib/ab_admin/views/admin_helpers.rb', line 169

def item_image(item, assoc=:photo, size=:thumb)
  image_tag_if(item.send(assoc).try(:url, size))
end


154
155
156
157
158
159
160
161
162
163
164
165
166
167
# File 'lib/ab_admin/views/admin_helpers.rb', line 154

def item_image_link(item, options={})
  options.reverse_merge!(assoc: :picture)
  options[:url] ||= resource_path(item)
  image = item.send(options[:assoc])
  return nil unless image
  version = options[:version] || image.class.thumb_size
  image_url_method = options[:image_url_method] || :url
  popover_content = "<img class='image_link_popover popover_#{options[:assoc]}' src='#{image.send(image_url_method, options[:full_version])}'></img>"
  popover_data = {content: popover_content, title: AbAdmin.display_name(item)}

  html_options = options.delete(:html_options) || {}
  html_options.reverse_merge!(rel: 'popover', remote: options[:remote], data: popover_data)
  link_to image_tag(image.send(image_url_method, version)), options[:url], html_options
end

#locale_flag(code) ⇒ Object



129
130
131
# File 'lib/ab_admin/views/admin_helpers.rb', line 129

def locale_flag(code)
  (AbAdmin.locale_to_country_code[code] || code).to_s[0..1].upcase.tr('A-Z', '🇦-🇿')
end

#options_for_ckeditor(options = {}) ⇒ Object



83
84
85
# File 'lib/ab_admin/views/admin_helpers.rb', line 83

def options_for_ckeditor(options = {})
  {width: 930, height: 200, namespace: ''}.update(options)
end

#pretty_data(object) ⇒ Object



150
151
152
# File 'lib/ab_admin/views/admin_helpers.rb', line 150

def pretty_data(object)
  AbAdmin.pretty_data(object)
end