X-Git-Url: https://projects.mako.cc/source/selectricity/blobdiff_plain/4efa3e9bc47cc649205a399fde51ed7e61bef7f8..34fe63727a8929d7e9c529feee1f0c1e827acdfa:/app/controllers/election_controller.rb diff --git a/app/controllers/election_controller.rb b/app/controllers/election_controller.rb index f4b89b4..3a43c8e 100644 --- a/app/controllers/election_controller.rb +++ b/app/controllers/election_controller.rb @@ -1,6 +1,6 @@ class ElectionController < ApplicationController model :raw_voter_list, :voter, :vote, :candidate - layout 'vb' + layout 'hc' before_filter :login_required @@ -22,7 +22,7 @@ class ElectionController < ApplicationController if @election.save flash[:notice] = 'Election was successfully created.' - redirect_to :action => 'new_candidates', :id => @election.id + redirect_to :action => 'edit_candidates', :id => @election.id else render :action => 'new' end @@ -48,27 +48,36 @@ class ElectionController < ApplicationController end end - def destroy - election = Election.find(params[:id]).destroy - redirect_to :action => 'list' + def start_election + @election = Election.find(params[:id]) + + @election.voters.each do |voter| + email = VoterNotify.deliver_votestart(voter) + #render(:text => "
" + email.encoded + "
") + end + + @election.activate! + redirect_to :action => 'show', :id => @election.id end # methods fod display, adding, deleting, and manipulating candidate # information for elections #################################################################### - def new_candidates + def edit_candidates @election = Election.find( params[:id] ) end def add_candidate - election = Election.find( params[:id] ) - @candidate = Candidate.new - @candidate.name = params[:newcandidate][:name] - @candidate.description = params[:newcandidate][:description] + @election = Election.find(params[:id]) + @candidate = Candidate.new(params[:candidate]) - @candidate.save - election.candidates << @candidate - render :partial => 'candidate_line' + if @candidate.save + @election.candidates << @candidate + @candidate = Candidate.new + redirect_to :action => 'edit_candidates', :id => @election.id + else + render :action => 'edit_candidates', :id => @election.id + end end def delete_candidate @@ -76,8 +85,40 @@ class ElectionController < ApplicationController candidate.destroy end - def edit_candidates - @election = Election.find( params[:id] ) + def lessinfo_candidate + @show_details = false + @candidate = Candidate.find( params[:id] ) + render :partial => 'candidate_line' + end + + def moreinfo_candidate + @show_details = true + @candidate = Candidate.find( params[:id] ) + render :partial => 'candidate_line' + end + + def edit_candidate + @candidate = Candidate.find( params[:id] ) + @election = @candidate.election + end + + def update_candidate + @candidate = Candidate.find(params[:id]) + @election = @candidate.election + + if @candidate.update_attributes(params[:candidate]) + redirect_to :action => 'edit_candidates', :id => @candidate.election.id + else + render :action => 'edit_candidate' + end + end + + def candidate_picture + candidate = Candidate.find( params[:id] ) + send_data( candidate.picture_data, + :filename => candidate.picture_filename, + :type => candidate.picture_type, + :disposition => 'inline' ) end ## methods for displaying, adding, deleting, and manipulating voters @@ -173,7 +214,10 @@ class ElectionController < ApplicationController @raw_voter_list.email = incoming_voters.email end - def email_voter + def email_voter(email=nil) + if email + + end end end