annotate app/models/custom_value.rb @ 1170:bfd49444c276 feature_523

Close obsolete branch feature_523
author Chris Cannam
date Wed, 17 Oct 2012 16:48:02 +0100
parents cbb26bc654de
children 433d4f72a19b
rev   line source
Chris@909 1 # Redmine - project management software
Chris@909 2 # Copyright (C) 2006-2011 Jean-Philippe Lang
Chris@0 3 #
Chris@0 4 # This program is free software; you can redistribute it and/or
Chris@0 5 # modify it under the terms of the GNU General Public License
Chris@0 6 # as published by the Free Software Foundation; either version 2
Chris@0 7 # of the License, or (at your option) any later version.
Chris@909 8 #
Chris@0 9 # This program is distributed in the hope that it will be useful,
Chris@0 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 12 # GNU General Public License for more details.
Chris@909 13 #
Chris@0 14 # You should have received a copy of the GNU General Public License
Chris@0 15 # along with this program; if not, write to the Free Software
Chris@0 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@0 17
Chris@0 18 class CustomValue < ActiveRecord::Base
Chris@0 19 belongs_to :custom_field
Chris@0 20 belongs_to :customized, :polymorphic => true
Chris@0 21
Chris@909 22 validate :validate_custom_value
Chris@909 23
Chris@0 24 def after_initialize
Chris@0 25 if new_record? && custom_field && (customized_type.blank? || (customized && customized.new_record?))
Chris@0 26 self.value ||= custom_field.default_value
Chris@0 27 end
Chris@0 28 end
Chris@909 29
Chris@0 30 # Returns true if the boolean custom value is true
Chris@0 31 def true?
Chris@0 32 self.value == '1'
Chris@0 33 end
Chris@909 34
Chris@0 35 def editable?
Chris@0 36 custom_field.editable?
Chris@0 37 end
Chris@909 38
chris@37 39 def visible?
chris@37 40 custom_field.visible?
chris@37 41 end
Chris@909 42
Chris@0 43 def required?
Chris@0 44 custom_field.is_required?
Chris@0 45 end
Chris@909 46
Chris@0 47 def to_s
Chris@0 48 value.to_s
Chris@0 49 end
Chris@909 50
Chris@0 51 protected
Chris@909 52 def validate_custom_value
Chris@0 53 if value.blank?
Chris@909 54 errors.add(:value, :blank) if custom_field.is_required? and value.blank?
Chris@0 55 else
Chris@0 56 errors.add(:value, :invalid) unless custom_field.regexp.blank? or value =~ Regexp.new(custom_field.regexp)
Chris@0 57 errors.add(:value, :too_short, :count => custom_field.min_length) if custom_field.min_length > 0 and value.length < custom_field.min_length
Chris@0 58 errors.add(:value, :too_long, :count => custom_field.max_length) if custom_field.max_length > 0 and value.length > custom_field.max_length
Chris@909 59
Chris@0 60 # Format specific validations
Chris@0 61 case custom_field.field_format
Chris@0 62 when 'int'
Chris@0 63 errors.add(:value, :not_a_number) unless value =~ /^[+-]?\d+$/
Chris@0 64 when 'float'
Chris@0 65 begin; Kernel.Float(value); rescue; errors.add(:value, :invalid) end
Chris@0 66 when 'date'
Chris@909 67 errors.add(:value, :not_a_date) unless value =~ /^\d{4}-\d{2}-\d{2}$/ && begin; value.to_date; rescue; false end
Chris@0 68 when 'list'
Chris@0 69 errors.add(:value, :inclusion) unless custom_field.possible_values.include?(value)
Chris@0 70 end
Chris@0 71 end
Chris@0 72 end
Chris@0 73 end