Module: Cms::ApplicationHelper

Defined in:
app/helpers/cms/application_helper.rb

Instance Method Summary collapse

Instance Method Details

#able_to?(*perms, &block) ⇒ Boolean

Returns:

  • (Boolean)


95
96
97
# File 'app/helpers/cms/application_helper.rb', line 95

def able_to?(*perms, &block)
  yield if current_user.able_to?(*perms)
end

#action_icon(name, options = {}) ⇒ Object



56
57
58
# File 'app/helpers/cms/application_helper.rb', line 56

def action_icon(name, options={})
  image_tag action_icon_src(name), {:alt => name.to_s.titleize}.merge(options)
end

#action_icon_src(name) ⇒ Object



52
53
54
# File 'app/helpers/cms/application_helper.rb', line 52

def action_icon_src(name)
  "cms/icons/actions/#{name}.png"
end

#categories_for(category_type_name, order = "name") ⇒ Object



125
126
127
128
# File 'app/helpers/cms/application_helper.rb', line 125

def categories_for(category_type_name, order="name")
  cat_type = CategoryType.named(category_type_name).first
  cat_type ? cat_type.category_list(order) : []
end

#determine_order(current_order, order) ⇒ Object



156
157
158
159
160
161
162
163
164
165
166
# File 'app/helpers/cms/application_helper.rb', line 156

def determine_order(current_order, order)
  if current_order == order
    if order =~ / desc$/i
      order.sub(/ desc$/i, '')
    else
      order << ' desc'
    end
  else
    order
  end 
end

#dk_button_wrapper(content) ⇒ Object



114
115
116
# File 'app/helpers/cms/application_helper.rb', line 114

def dk_button_wrapper(content)
  lt_button_wrapper(content).gsub("lt_button_","dk_button_")
end

#format_date(time) ⇒ Object



83
84
85
# File 'app/helpers/cms/application_helper.rb', line 83

def format_date(time)
  time && "#{time.strftime("%b %e, %Y")}"
end

#group_filterObject



121
122
123
# File 'app/helpers/cms/application_helper.rb', line 121

def group_filter
  select_tag("group_id", options_from_collection_for_select(Group.all.insert(0, Group.new(:id => nil, :name => "Show All Groups")), "id", "name", params[:group_id].to_i))
end

#group_idsObject



117
118
119
# File 'app/helpers/cms/application_helper.rb', line 117

def group_ids
  (params[:group_ids] || @user.group_ids).collect { |g| g.to_i }
end


87
88
89
# File 'app/helpers/cms/application_helper.rb', line 87

def link_to_check_all(selector, name="Check All")
  link_to_function name, "$('#{selector}').attr('checked', true)"
end


91
92
93
# File 'app/helpers/cms/application_helper.rb', line 91

def link_to_uncheck_all(selector, name="Uncheck All")
  link_to_function name, "$('#{selector}').attr('checked', false)"
end


68
69
70
71
72
73
74
75
76
77
# File 'app/helpers/cms/application_helper.rb', line 68

def link_to_usages(block)
  count = block.connected_pages.count
  if count > 0
    # Would love a cleaner solution to this problem, see http://stackoverflow.com/questions/702728
    path = Portlet === block ? usages_cms_portlet_path(block) : [:usages, :cms, block]
    link_to count, path, :id => block.id, :block_type => block.content_block_type
  else
    count
  end
end

#lt_button_wrapper(content) ⇒ Object



102
103
104
105
106
107
108
109
110
111
112
# File 'app/helpers/cms/application_helper.rb', line 102

def lt_button_wrapper(content)
<<LBW
  <div class="lt_button">
<img src="/images/cms/lt_button_l.gif" alt="" />
<div class="lt_button_content">
  <span>#{ content }</span>
</div>
<img src="/images/cms/lt_button_r.gif" alt="" style="margin-right: 10px;" />
  </div>
LBW
end

#page_versions(page) ⇒ Object



17
18
19
20
21
22
23
24
25
# File 'app/helpers/cms/application_helper.rb', line 17

def page_versions(page)
  text = select_tag(:version, 
                    options_for_select(page.versions.all(:order => "version desc").map { |r| 
                                         ["v#{r.version}: #{r.version_comment} by #{r.updated_by.} at #{time_on_date(r.updated_at)}", r.version] 
                                       }, page.version), 
                    :onchange => 'this.form.submit(); return false')
  text << javascript_tag("$('version').selectedIndex = 0") if page.live?
  text
end

#render_cms_toolbar(tab = :dashboard) ⇒ Object



64
65
66
# File 'app/helpers/cms/application_helper.rb', line 64

def render_cms_toolbar(tab=:dashboard)
  render :partial => 'layouts/cms_toolbar', :locals => {:tab => tab}    
end

#render_connectable(content_block) ⇒ Object



36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'app/helpers/cms/application_helper.rb', line 36

def render_connectable(content_block)
  if content_block
    if content_block.class.renderable?
      logger.info "..... Rendering connectable #{content_block.class} ##{content_block.id} #{"v#{content_block.version}" if content_block.respond_to?(:version)}"
      content_block.perform_render(@controller)
    else
      logger.warn "Connectable #{content_block.class} ##{content_block.id} is not renderable"
    end
  else
    logger.warn "Connectable is null"
  end    
rescue Exception => e
  logger.error "Error occurred while rendering #{content_block.class}##{content_block.id}: #{e.message}\n#{e.backtrace.join("\n")}"
  "ERROR: #{e.message}"
end

#render_connector_and_connectable(connector, connectable) ⇒ Object



27
28
29
30
31
32
33
34
# File 'app/helpers/cms/application_helper.rb', line 27

def render_connector_and_connectable(connector, connectable)
  if logged_in? && @mode == "edit" && current_user.able_to_edit?(connector.page)
    render :partial => 'cms/pages/edit_connector', 
      :locals => { :connector => connector, :connectable => connectable}
  else
    render_connectable(connectable)
  end
end

#render_pagination(collection, collection_name, options = {}) ⇒ Object



130
131
132
133
134
135
136
137
138
139
140
141
142
143
# File 'app/helpers/cms/application_helper.rb', line 130

def render_pagination(collection, collection_name, options={})
  if collection.blank?
    (:div, "No Content", :class => "pagination")
  else
    render :partial => "cms/shared/pagination", :locals => {
      :collection => collection,
      :first_page_path => send("cms_#{collection_name}_path", {:page => 1}.merge(options)),
      :previous_page_path => send("cms_#{collection_name}_path", {:page => collection.previous_page ? collection.previous_page : 1}.merge(options)),
      :current_page_path => send("cms_#{collection_name}_path", options),
      :next_page_path => send("cms_#{collection_name}_path", {:page => collection.next_page ? collection.next_page : collection.current_page}.merge(options)),
      :last_page_path => send("cms_#{collection_name}_path", {:page => collection.total_pages}.merge(options))
    }
  end
end

#searchable_sections(selected = nil) ⇒ Object



5
6
7
8
9
10
# File 'app/helpers/cms/application_helper.rb', line 5

def searchable_sections(selected = nil)
  root = Section.root.first
  options = [['All sections', 'all'], [root.name, root.id]]
  root.all_children_with_name.each { |s|  options << [s.full_path, s.id] }
  options_for_select(options, selected.to_i)
end

#select_per_pageObject



12
13
14
15
# File 'app/helpers/cms/application_helper.rb', line 12

def select_per_page
  options = [10, 20, 50, 100].collect { |c| ["#{c} per page", c] }
  select_tag("per_page", options_for_select(options, params[:per_page].to_i))
end

#span_tag(content) ⇒ Object



99
100
101
# File 'app/helpers/cms/application_helper.rb', line 99

def span_tag(content)
   :span, content
end

#status_icon(status, options = {}) ⇒ Object



60
61
62
# File 'app/helpers/cms/application_helper.rb', line 60

def status_icon(status, options={})
  image_tag "cms/icons/status/#{status.to_s.underscore}.gif", {:alt => status.to_s.titleize}.merge(options)
end

#time_on_date(time) ⇒ Object



79
80
81
# File 'app/helpers/cms/application_helper.rb', line 79

def time_on_date(time)
  time && "#{time.strftime("%l:%M %p")} on #{time.strftime("%b %e, %Y")}"
end

#url_with_mode(url, mode) ⇒ Object



145
146
147
148
149
150
151
152
153
154
# File 'app/helpers/cms/application_helper.rb', line 145

def url_with_mode(url, mode)
  uri = URI.parse(url)
  if uri.query =~ /mode=[^&]*/
    "#{uri.path}?#{uri.query.gsub(/((^|&)mode=)[^&]*/) {|s| "#{$1}#{mode}" }}"
  elsif uri.query
    "#{uri.path}?#{uri.query}&mode=#{mode}"
  else
    "#{uri.path}?mode=#{mode}"
  end
end