def start_election
@election = Election.find(params[:id])
-
@election.voters.each do |voter|
+ voter.vote = Vote.new
email = VoterNotify.deliver_votestart(voter)
#render(:text => "<pre>" + email.encoded + "</pre>")
end
@election.activate!
redirect_to :action => 'show', :id => @election.id
end
-
- def change_notices
- election = Election.find(params[:id])
- if election.notices == 0
- election.notices = 1
- else
- election.notices = 0
- end
- end
# methods fod display, adding, deleting, and manipulating candidate
# information for elections
def lessinfo_candidate
@show_details = false
- @candidate = Candidate.find( params[:id] )
+ @current_candidate = Candidate.find( params[:id] )
render :partial => 'candidate_line'
end
def moreinfo_candidate
@show_details = true
- @candidate = Candidate.find( params[:id] )
+ @current_candidate = Candidate.find( params[:id] )
render :partial => 'candidate_line'
end
if params.has_key?( :raw_voter_list )
process_incoming_voters( params[:raw_voter_list] )
end
-
@raw_voter_list = RawVoterList.new
end
@election.voters. each do |voter|
if voter.vote and voter.vote.confirmed?
@voter_list << voter.email
- @vote_list << voter.vote
+ @vote_list << voter.vote
end
end
unless incoming_voters.entries.empty?
incoming_voters.each do |new_voter|
-
+ new_voter.email.strip! # There's a trailing \r on all but the last in
+ # the list!
if incoming_voters.email == 0
new_voter.contacted = 1
elsif incoming_voters.email == 1
else
new_voter.contacted = 0
end
-
- # the new voter should be in good shape. save add to the election
- @election.voters << new_voter
- new_voter.save
+ if new_voter.valid?
+ # the new voter should be in good shape. save add to the election
+ @election.voters << new_voter
+ new_voter.save
+ end
+ # TODO: Can we do some kind of AJAX error message for the voter being invalid?
end
+ @election.save
end
# reset the next time to have a the same default value for emailing