Module: ActionController::Helpers::ClassMethods

Defined in:
actionpack/lib/action_controller/metal/helpers.rb

Instance Method Summary collapse

Instance Method Details

#all_helpers_from_path(path) ⇒ Object



96
97
98
99
100
101
102
103
104
# File 'actionpack/lib/action_controller/metal/helpers.rb', line 96

def all_helpers_from_path(path)
  helpers = Array(path).flat_map do |_path|
    extract = /^#{Regexp.quote(_path.to_s)}\/?(.*)_helper.rb$/
    names = Dir["#{_path}/**/*_helper.rb"].map { |file| file.sub(extract, '\1') }
    names.sort!
  end
  helpers.uniq!
  helpers
end

#helper_attr(*attrs) ⇒ Object

Declares helper accessors for controller attributes. For example, the following adds new name and name= instance methods to a controller and makes them available to the view:

attr_accessor :name
helper_attr :name

Parameters

  • attrs - Names of attributes to be converted into helpers.



70
71
72
# File 'actionpack/lib/action_controller/metal/helpers.rb', line 70

def helper_attr(*attrs)
  attrs.flatten.each { |attr| helper_method(attr, "#{attr}=") }
end

#helpersObject

Provides a proxy to access helpers methods from outside the view.



75
76
77
78
79
80
81
# File 'actionpack/lib/action_controller/metal/helpers.rb', line 75

def helpers
  @helper_proxy ||= begin 
    proxy = ActionView::Base.new
    proxy.config = config.inheritable_copy
    proxy.extend(_helpers)
  end
end

#modules_for_helpers(args) ⇒ Object

Overwrite modules_for_helpers to accept :all as argument, which loads all helpers in helpers_path.

Parameters

  • args - A list of helpers

Returns

  • array - A normalized list of modules for the list of helpers provided.



91
92
93
94
# File 'actionpack/lib/action_controller/metal/helpers.rb', line 91

def modules_for_helpers(args)
  args += all_application_helpers if args.delete(:all)
  super(args)
end