# store the candidate grabbed through ajax and stored in flash
@quickvote.candidatelist = flash[:candlist]
-
+ @quickvote.description=CGI.escapeHTML(@quickvote.description)
# try to save, if it fails, show the page again (the flash should
# still be intact
if @quickvote.save
end
def add_candidate
- candidate_name = params[:ajax][:newcandidate]
- if flash.has_key?(:candlist) and flash[:candlist].instance_of?(Array)
- flash[:candlist] << candidate_name
- else
- flash[:candlist] = [ candidate_name ]
+ candidate_name = CGI.escapeHTML(params[:ajax][:newcandidate])
+ unless candidate_name.strip.empty?
+ if flash.has_key?(:candlist) and flash[:candlist].instance_of?(Array)
+ flash[:candlist] << candidate_name unless flash[:candlist].index(candidate_name)
+ else
+ flash[:candlist] = [ candidate_name ]
+ end
end
flash.keep(:candlist)
render_partial 'candidate_list'
#############################################################
def index
- @election = ident_to_quickvote(params[:ident])
+ @election = QuickVote.ident_to_quickvote(params[:ident])
# if the person has specified an election, we show them the voting
# page. otherwise, we redirect back to main the page
def confirm
# we need the election to verify that we have the right voter
- election = ident_to_quickvote(params[:ident])
+ election = QuickVote.ident_to_quickvote(params[:ident])
# find out who the voter is for this election
@voter = QuickVoter.find_all(["session_id = ? and election_id = ?",
render :nothing => true
end
-
+ def mapvoters
+ @map = GMap.new("map_div_id")
+ @map.control_init(:large_map => true, :map_type => true)
+ center=nil
+ QuickVote.ident_to_quickvote(params[:id]).voters.each do |voter|
+ next unless voter.ipaddress
+ location = GeoKit::Geocoders::IpGeocoder.geocode(voter.ipaddress)
+ next unless location.lng and location.lat
+ unless center
+ center=[location.lat,location.lng]
+ @map.center_zoom_init(center,4)
+ end
+ marker = GMarker.new([location.lat,location.lng], :title => "Voter", :info_window => (voter.ipaddress or "unknown")+" "+voter.vote.votestring)
+ @map.overlay_init(marker)
+ end
+ end
###############################################################
# the following method pertains to displaying the results of a
# quickvote
###############################################################
def results
- @election = ident_to_quickvote(params[:ident])
+ @election = QuickVote.ident_to_quickvote(params[:ident])
@election.results
@candidates = {}
@election.candidates.each {|c| @candidates[c.id] = c}
end
-
- private
- def ident_to_quickvote(ident)
- if ident.match(/^\d+$/)
- quickvote = QuickVote.find(ident)
- else
- quickvote = QuickVote.find_all(["name = ?", ident])[0]
- end
-
- return quickvote
- end
-
end