Sha256: 77b6122df17f9d1488ddf712bceee57b4866cd44d45d6ec5c5b7f613715269af
Contents?: true
Size: 1.24 KB
Versions: 1
Compression:
Stored size: 1.24 KB
Contents
module Apotomo # Shortcut methods for creating widget trees. module WidgetShortcuts # Creates an instance of <tt>class_name</tt> with the id <tt>id</tt> and start state <tt>state</tt>. # Default start state is <tt>:display</tt>. # Yields self if a block is passed. # Example: # widget(:form, 'uploads', :build_form) do |form| # form << widget(:upload_field) # # You can also use namespaces. # # widget('jquery/tabs', 'panel') def widget(class_name, id, state=:display, *args) object = constant_for(class_name).new(parent_controller, id, state, *args) yield object if block_given? object end def container(id, *args, &block) widget('apotomo/container_widget', id, *args, &block) end def section(*args) container(*args) end def cell(base_name, states, id, *args) widget(base_name.to_s + '_cell', states, id, *args) end def tab_panel(id, *args) widget('apotomo/tab_panel_widget', :display, id, *args) end def tab(id, *args) widget('apotomo/tab_widget', :display, id, *args) end private def constant_for(class_name) class_name.to_s.camelize.constantize end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
apotomo-1.0.0.beta1 | lib/apotomo/widget_shortcuts.rb |