class Uberkit::Forms::Builder < ActionView::Helpers::FormBuilder include ActionView::Helpers::CaptureHelper include ActionView::Helpers::TextHelper include ActionView::Helpers::UrlHelper include ActionView::Helpers::TagHelper helpers = field_helpers + %w(date_select datetime_select time_select select html_area state_select country_select) - %w(hidden_field label fields_for) helpers.each do |name| define_method(name) do |field, *args| options = args.extract_options! class_names = array_from_classes(options[:class]) class_names << name options[:class] = class_names.join(" ") args << options generic_field(options[:label],field,super(field,*args),{:description => options.delete(:description), :help => options.delete(:help), :required => options.delete(:required)}) end end def generic_field(label_text,field,content,options = {}) required = options.delete(:required) content_tag(:div, :class => "field_row#{' required' if required}#{' labelless' if label_text == ""}") do ret = label(field, (label_text || field.to_s.titleize).to_s + ":") unless label_text == "" ret << content ret << content_tag(:span, options.delete(:help), :class => "help") if options[:help] ret << content_tag(:span, options.delete(:description), :class => "description") if options[:description] ret << "
" ret end end def submit(text) content_tag(:button, text, :type => "submit") end def custom(options = {}, &block) concat("
#{"#{options[:label] + ":" if options[:label]}" if options[:label]}
",block.binding) yield concat("

",block.binding) end def array_from_classes(html_classes) html_classes ? html_classes.split(" ") : [] end def fieldset(legend=nil,&block) concat("
#{"#{legend}" if legend}",block.binding) yield concat("
",block.binding) end def output_buffer @template.output_buffer end def output_buffer=(buf) @template.output_buffer = buf end def is_haml?; false end end