]> projects.mako.cc - selectricity-live/blobdiff - app/models/candidate.rb
merged back from live
[selectricity-live] / app / models / candidate.rb
index dfc8b1fec08fc19e87b320ea3a7c3856d1369c08..eeba4d228032499b8d15474123b03e9aa8129208 100644 (file)
@@ -1,12 +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 
+    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?