* refactored the system so that it keeps pictures in a seperate table
[selectricity] / app / models / candidate.rb
index 41d743b3a55ed07c0184605cbba600ba2ebc5c84..eeba4d228032499b8d15474123b03e9aa8129208 100644 (file)
@@ -1,2 +1,37 @@
 class Candidate < ActiveRecord::Base
+  belongs_to :election
+  validates_presence_of :name
+
+  # i have to call this picture_assoc because picture= does not overload
+  # the normal association method made by has_one
+  has_one :picture_obj, :class_name => "Picture"
+
+  # validate uniqueness of a name *within a given election*
+
+  def <=>(other)
+    self.name <=> other.name 
+  end
+  
+  def to_s
+    name
+  end
+
+  def picture
+    picture_obj
+  end
+
+  def picture=(field)
+    if field and field.length > 0
+      self.picture_obj = Picture.new.set_from_field(field)
+      return picture_obj.save
+    else
+      return false
+    end
+  end
+
+  def picture?
+    !self.picture_obj.nil?
+  end
+
 end
+

Benjamin Mako Hill || Want to submit a patch?