Sha256: a077ae2aef1c8c88b1db50f9d913c8e088440ae92c40adca1e925515b69198c3

Contents?: true

Size: 1.25 KB

Versions: 5

Compression:

Stored size: 1.25 KB

Contents

require 'volt/page/bindings/template_binding'

# Component bindings are the same as template bindings, but handle components
# and do not pass their context through
class ComponentBinding < TemplateBinding
  # The context for a component binding can be either the controller, or the 
  # component arguments (@model), with the $page as the context.  This gives
  # components access to the page collections.
  def render_template(full_path, controller_name)
    # TODO: at the moment a :body section and a :title will both initialize different
    # controllers.  Maybe we should have a way to tie them together?
    controller_class = get_controller(controller_name)
    model_with_parent = {parent: @context}.merge(@model || {})
    
    if controller_class
      # The user provided a controller, pass in the model as an argument (in a 
      # sub-context)
      args = []
      args << SubContext.new(model_with_parent) if @model
      
      current_context = controller_class.new(*args)
      @controller = current_context
    else
      # There is not a controller
      current_context = SubContext.new(model_with_parent, $page)
    end

    @current_template = TemplateRenderer.new(@page, @target, current_context, @binding_name, full_path)
    
    call_ready
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
volt-0.6.4 lib/volt/page/bindings/component_binding.rb
volt-0.6.3 lib/volt/page/bindings/component_binding.rb
volt-0.6.2 lib/volt/page/bindings/component_binding.rb
volt-0.6.1 lib/volt/page/bindings/component_binding.rb
volt-0.6.0 lib/volt/page/bindings/component_binding.rb