custom_value.rb 1.99 KB
Newer Older
1
#-- encoding: UTF-8
2 3
#-- copyright
# ChiliProject is a project management system.
4
#
Holger Just's avatar
Holger Just committed
5
# Copyright (C) 2010-2013 the ChiliProject Team
6
#
7 8 9 10
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
11
#
12 13 14
# See doc/COPYRIGHT.rdoc for more details.
#++

15 16 17 18
class CustomValue < ActiveRecord::Base
  belongs_to :custom_field
  belongs_to :customized, :polymorphic => true

19
  def after_initialize
20
    if new_record? && custom_field && (customized_type.blank? || (customized && customized.new_record?))
21 22 23
      self.value ||= custom_field.default_value
    end
  end
24

25 26 27 28
  # Returns true if the boolean custom value is true
  def true?
    self.value == '1'
  end
29

30 31 32
  def editable?
    custom_field.editable?
  end
33

34 35 36
  def visible?
    custom_field.visible?
  end
37

38 39 40
  def required?
    custom_field.is_required?
  end
41

42 43 44
  def to_s
    value.to_s
  end
45

46 47
protected
  def validate
48
    if value.blank?
49
      errors.add(:value, :blank) if custom_field.is_required? and value.blank?
50
    else
51
      errors.add(:value, :invalid) unless custom_field.regexp.blank? or value =~ Regexp.new(custom_field.regexp)
52 53
      errors.add(:value, :too_short, :count => custom_field.min_length) if custom_field.min_length > 0 and value.length < custom_field.min_length
      errors.add(:value, :too_long, :count => custom_field.max_length) if custom_field.max_length > 0 and value.length > custom_field.max_length
54

55 56 57
      # Format specific validations
      case custom_field.field_format
      when 'int'
58
        errors.add(:value, :not_a_number) unless value =~ /^[+-]?\d+$/
59
      when 'float'
60
        begin; Kernel.Float(value); rescue; errors.add(:value, :invalid) end
61
      when 'date'
62
        errors.add(:value, :not_a_date) unless value =~ /^\d{4}-\d{2}-\d{2}$/
63
      when 'list'
64
        errors.add(:value, :inclusion) unless custom_field.possible_values.include?(value)
65
      end
66
    end
Jean-Philippe Lang's avatar
Jean-Philippe Lang committed
67
  end
68
end