]> projects.mako.cc - selectricity-live/blobdiff - app/controllers/voter_controller.rb
Created a partial to DRY the aja voting method. Modified the voter class to
[selectricity-live] / app / controllers / voter_controller.rb
index e94f4a76f0faed8e1994d30356c41fef851b0387..6693b0fa6baa9090cfa6c72b146a240f3d95024e 100644 (file)
@@ -1,29 +1,24 @@
 class VoterController < ApplicationController
   layout 'main'
-  model :voter
-  model :vote
-  model :election
+  require_dependency "voter"
+  require_dependency "vote"
+  require_dependency "election"
 
   def index
     password = params[:id]
     password = params[:vote][:password] if params[:vote]
     if @voter = FullVoter.find(:all, :conditions => [ "password = ?", password ] )[0]
-      render :action => 'fullvote'
+      @voter.vote = Vote.new if @voter.vote.nil?
+      @voter.vote.set_defaults! if @voter.vote.rankings.empty?
+      render :action => 'full_vote'
     end
   end
   
   def review
     if authenticate
-      # remove any existing votes and reload
-      if @voter.vote
-        @voter.vote.destroy
-        @voter.reload
-      end
-    
-      @vote = Vote.new
-      @voter.vote = @vote
-      @vote.votestring = params[:vote][:votestring] 
-      @vote.save
+      @voter.vote.time = Time.now
+      @voter.vote.save
+      @voter.reload
     else
       redirect_to :action => 'index'
     end

Benjamin Mako Hill || Want to submit a patch?