Module: Spree::Admin::BaseHelper
- Defined in:
- app/helpers/spree/admin/base_helper.rb
Instance Method Summary collapse
- #class_for_error(model, method) ⇒ Object
- #error_message_on(object, method, options = {}) ⇒ Object
- #field_container(model, method, options = {}, &block) ⇒ Object
-
#generate_html(form_builder, method, options = {}) ⇒ Object
This method demonstrates the use of the :child_index option to render a form partial for, for instance, client side addition of new nested records.
- #generate_template(form_builder, method, options = {}) ⇒ Object
- #link_to_add_fields(name, target) ⇒ Object
-
#link_to_remove_fields(name, f) ⇒ Object
renders hidden field and link to remove record using nested_attributes.
- #preference_field_for(form, field, options) ⇒ Object
- #preference_field_options(options) ⇒ Object
- #preference_field_tag(name, value, options) ⇒ Object
- #preference_fields(object, form) ⇒ Object
- #product_picker_field(name, value) ⇒ Object
- #remove_nested(fields) ⇒ Object
- #spree_dom_id(record) ⇒ Object
Instance Method Details
#class_for_error(model, method) ⇒ Object
24 25 26 27 |
# File 'app/helpers/spree/admin/base_helper.rb', line 24 def class_for_error(model, method) if :product, :name end end |
#error_message_on(object, method, options = {}) ⇒ Object
12 13 14 15 16 17 18 19 20 21 22 |
# File 'app/helpers/spree/admin/base_helper.rb', line 12 def (object, method, = {}) object = convert_to_model(object) obj = object.respond_to?(:errors) ? object : instance_variable_get("@#{object}") if obj && obj.errors[method].present? errors = obj.errors[method].map { |err| h(err) }.join('<br />').html_safe content_tag(:span, errors, :class => 'formError') else '' end end |
#field_container(model, method, options = {}, &block) ⇒ Object
4 5 6 7 8 9 10 |
# File 'app/helpers/spree/admin/base_helper.rb', line 4 def field_container(model, method, = {}, &block) css_classes = [:class].to_a if (model, method).present? css_classes << 'withError' end content_tag('p', capture(&block), :class => css_classes.join(' '), :id => "#{model}_#{method}_field") end |
#generate_html(form_builder, method, options = {}) ⇒ Object
This method demonstrates the use of the :child_index option to render a form partial for, for instance, client side addition of new nested records.
This specific example creates a link which uses javascript to add a new form partial to the DOM.
<%= form_for @project do |project_form| %>
<div id="tasks">
<%= project_form.fields_for :tasks do |task_form| %>
<%= render :partial => 'task', :locals => { :f => task_form } %>
<% end %>
</div>
<% end %>
43 44 45 46 47 48 49 50 51 52 |
# File 'app/helpers/spree/admin/base_helper.rb', line 43 def generate_html(form_builder, method, = {}) [:object] ||= form_builder.object.class.reflect_on_association(method).klass.new [:partial] ||= method.to_s.singularize [:form_builder_local] ||= :f form_builder.fields_for(method, [:object], :child_index => 'NEW_RECORD') do |f| render(:partial => [:partial], :locals => { [:form_builder_local] => f }) end end |
#generate_template(form_builder, method, options = {}) ⇒ Object
54 55 56 |
# File 'app/helpers/spree/admin/base_helper.rb', line 54 def generate_template(form_builder, method, = {}) escape_javascript generate_html(form_builder, method, ) end |
#link_to_add_fields(name, target) ⇒ Object
145 146 147 |
# File 'app/helpers/spree/admin/base_helper.rb', line 145 def link_to_add_fields(name, target) link_to icon('add') + name, 'javascript:', :data => { :target => target }, :class => "add_fields" end |
#link_to_remove_fields(name, f) ⇒ Object
renders hidden field and link to remove record using nested_attributes
150 151 152 |
# File 'app/helpers/spree/admin/base_helper.rb', line 150 def link_to_remove_fields(name, f) f.hidden_field(:_destroy) + link_to_with_icon(:delete, name, '#', :class => 'remove_fields') end |
#preference_field_for(form, field, options) ⇒ Object
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
# File 'app/helpers/spree/admin/base_helper.rb', line 83 def preference_field_for(form, field, ) case [:type] when :integer form.text_field(field, ()) when :boolean form.check_box(field, ()) when :string form.text_field(field, ()) when :password form.password_field(field, ()) when :text form.text_area(field, ()) else form.text_field(field, ()) end end |
#preference_field_options(options) ⇒ Object
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 |
# File 'app/helpers/spree/admin/base_helper.rb', line 100 def () = case [:type] when :integer { :size => 10, :class => 'input_integer' } when :boolean {} when :string { :size => 10, :class => 'input_string' } when :password { :size => 10, :class => 'password_string' } when :text { :rows => 15, :cols => 85 } else { :size => 10, :class => 'input_string' } end .merge!({ :readonly => [:readonly], :disabled => [:disabled], :size => [:size] }) end |
#preference_field_tag(name, value, options) ⇒ Object
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
# File 'app/helpers/spree/admin/base_helper.rb', line 65 def preference_field_tag(name, value, ) case [:type] when :integer text_field_tag(name, value, ()) when :boolean hidden_field_tag(name, 0) + check_box_tag(name, 1, value, ()) when :string text_field_tag(name, value, ()) when :password password_field_tag(name, value, ()) when :text text_area_tag(name, value, ()) else text_field_tag(name, value, ()) end end |
#preference_fields(object, form) ⇒ Object
128 129 130 131 132 133 134 135 136 |
# File 'app/helpers/spree/admin/base_helper.rb', line 128 def preference_fields(object, form) return unless object.respond_to?(:preferences) object.preferences.keys.map{ |key| form.label("preferred_#{key}", t(key) + ": ") + preference_field_for(form, "preferred_#{key}", :type => object.preference_type(key)) }.join("<br />").html_safe end |
#product_picker_field(name, value) ⇒ Object
138 139 140 141 142 143 |
# File 'app/helpers/spree/admin/base_helper.rb', line 138 def product_picker_field(name, value) products = Product.with_ids(value.split(',')) product_names = products.inject({}){|memo,item| memo[item.id] = item.name; memo} product_rules = products.collect{ |p| { :id => p.id, :name => p.name } } %(<input type="text" name="#{name}" value="#{value}" class="tokeninput products" data-names='#{product_names.to_json}' data-pre='#{product_rules.to_json}'/>).html_safe end |
#remove_nested(fields) ⇒ Object
58 59 60 61 62 63 |
# File 'app/helpers/spree/admin/base_helper.rb', line 58 def remove_nested(fields) out = '' out << fields.hidden_field(:_destroy) unless fields.object.new_record? out << (link_to icon('delete'), "#", :class => 'remove') out.html_safe end |
#spree_dom_id(record) ⇒ Object
154 155 156 |
# File 'app/helpers/spree/admin/base_helper.rb', line 154 def spree_dom_id(record) dom_id(record, 'spree') end |