##// END OF EJS Templates
Use #get instead of #[] to read errors on the attribute....
Jean-Philippe Lang -
r15606:e610fda877a4
parent child
Show More
@@ -1,64 +1,64
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2016 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 require 'action_view/helpers/form_helper'
19 19
20 20 class Redmine::Views::LabelledFormBuilder < ActionView::Helpers::FormBuilder
21 21 include Redmine::I18n
22 22
23 23 (field_helpers.map(&:to_s) - %w(radio_button hidden_field fields_for check_box label) +
24 24 %w(date_select)).each do |selector|
25 25 src = <<-END_SRC
26 26 def #{selector}(field, options = {})
27 27 label_for_field(field, options) + super(field, options.except(:label)).html_safe
28 28 end
29 29 END_SRC
30 30 class_eval src, __FILE__, __LINE__
31 31 end
32 32
33 33 def check_box(field, options={}, checked_value="1", unchecked_value="0")
34 34 label_for_field(field, options) + super(field, options.except(:label), checked_value, unchecked_value).html_safe
35 35 end
36 36
37 37 def select(field, choices, options = {}, html_options = {})
38 38 label_for_field(field, options) + super(field, choices, options, html_options.except(:label)).html_safe
39 39 end
40 40
41 41 def time_zone_select(field, priority_zones = nil, options = {}, html_options = {})
42 42 label_for_field(field, options) + super(field, priority_zones, options, html_options.except(:label)).html_safe
43 43 end
44 44
45 45 # A field for entering hours value
46 46 def hours_field(field, options={})
47 47 # display the value before type cast when the entered value is not valid
48 if @object.errors[field].blank?
48 if @object.errors.get(field).blank?
49 49 options = options.merge(:value => format_hours(@object.send field))
50 50 end
51 51 text_field field, options
52 52 end
53 53
54 54 # Returns a label tag for the given field
55 55 def label_for_field(field, options = {})
56 56 return ''.html_safe if options.delete(:no_label)
57 57 text = options[:label].is_a?(Symbol) ? l(options[:label]) : options[:label]
58 58 text ||= l(("field_" + field.to_s.gsub(/\_id$/, "")).to_sym)
59 59 text += @template.content_tag("span", " *", :class => "required") if options.delete(:required)
60 60 @template.content_tag("label", text.html_safe,
61 61 :class => (@object && @object.errors[field].present? ? "error" : nil),
62 62 :for => (@object_name.to_s + "_" + field.to_s))
63 63 end
64 64 end
General Comments 0
You need to be logged in to leave comments. Login now