summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
34fe637)
any need to do the parsing of the string.
def index
@election = QuickVote.find_all(["name = ?", params[:votename]])[0]
def index
@election = QuickVote.find_all(["name = ?", params[:votename]])[0]
-
- @voter = QuickVoter.find_all(["session_id = ? and election_id = ?",
+
+ if @election
+ @voter = QuickVoter.find_all(["session_id = ? and election_id = ?",
session.session_id, @election.id])[0]
session.session_id, @election.id])[0]
- unless @voter
- @voter = QuickVoter.new
- @voter.election = QuickVote.find_all( [ "name = ?", params[:votename] ] )[0]
+ unless @voter
+ @voter = QuickVoter.new
+ @voter.election = QuickVote.find_all( [ "name = ?", params[:votename] ] )[0]
+ end
+ else
+ redirect_to :controller => 'site'
end
end
def create
if params[:quickvote]
@quickvote = QuickVote.new(params[:quickvote])
end
end
def create
if params[:quickvote]
@quickvote = QuickVote.new(params[:quickvote])
- if @quickvote.reviewed? and @quickvote.save
- @quickvote = @quickvote.reload
- render :action => 'success'
+
+ # store the candidate grabbed through ajax and stored in flash
+ @quickvote.candidatelist = flash[:candlist]
+
+ # try to save, if it fails, show the page again (the flash should
+ # still be intact
+ if @quickvote.save
+ @quickvote = @quickvote.reload
+ render :action => 'success'
+ else
+ flash.keep(:candlist)
+ else
+ # if we don't have a quickvote param, it means that the person
+ # here has not been hitting this page and we can clear any
+ # candlist in the flash
+ flash.delete(:candlist) if flash.has_key?(:candlist)
+ end
+ 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 ]
+ flash.keep(:candlist)
+ render_partial 'candidate_list'
- def candidatelist=(candstring='')
- @raw_candidates = candstring.split(';').collect {|cand| cand.strip }
- end
-
- def candidatelist
- @raw_candidates.join("; ")
+ def candidatelist=(candlist)
+ @raw_candidates = candlist
--- /dev/null
+<% %>
+<!-- the list of candidates -->
+<% if @flash[:candlist] %>
+ <ul>
+ <% for cand in @flash[:candlist] %>
+ <li><%= cand.capitalize %></li>
+ <% end %>
+ </ul>
+<% end %>
+
+<%= form_remote_tag :update => 'candlist',
+ :url => { :action => 'add_candidate' } %>
+<p>
+ <%= text_field "ajax", "newcandidate", :size => 40 %>
+ <%= submit_tag "Add" %>
+</p>
+<%= end_form_tag %>
-<h1><%= @quickvote ? "Review and Confirm" : "Create QuickVote" %></h1>
+<h1>Create QuickVote</h1>
<%= error_messages_for 'quickvote' %>
<%= error_messages_for 'quickvote' %>
+<p><label for="quickvote_candidatelist">Choices</p>
-<p>Please review the data you've entered and confirm it. The candidates
-for the vote you've submitted include:</p>
-
-<ul>
-<% for candidate in @quickvote.raw_candidates %>
- <li><%= candidate.capitalize %></li>
-<% end %>
-</ul>
-
-<% end %>
+<!-- the list of candidates -->
+<div id="candlist">
+<%= render :partial => 'candidate_list' %>
+</div>
<%= form_tag :action => 'create' %>
<!--[form:election]-->
<%= form_tag :action => 'create' %>
<!--[form:election]-->
<%= text_area 'quickvote', 'description', :cols => 50, :rows => 4 %></p>
<%= text_area 'quickvote', 'description', :cols => 50, :rows => 4 %></p>
-<p><label for="quickvote_candidatelist">Choices/Candidates<em><br />
-<font size="-1">seperate choices with a ";"; at least two are required</font></em></label><br/>
-
-<%= text_area 'quickvote', 'candidatelist', :cols => 50, :rows => 2 %></p>
-
-<p><% if @quickvote -%>
- <%= submit_tag "Confirm" -%>
- <%= hidden_field :quickvote, :reviewed, :value => 1 %>
- <% else %>
- <%= submit_tag "Submit" -%>
- <%- end -%>
-</p>
+<%= submit_tag "Create Quickvote" -%>
# -- just remember to delete public/index.html.
map.connect '', :controller => "site"
# -- just remember to delete public/index.html.
map.connect '', :controller => "site"
- map.connect 'quickvote/create',
+ map.connect 'quickvote/:action/:id',
:controller => 'quickvote',
:controller => 'quickvote',
+ :requirements => { :action => /(create|add_candidate)/ }
+
map.quickaction 'quickvote/:votename/:action',
:controller => 'quickvote',
map.quickaction 'quickvote/:votename/:action',
:controller => 'quickvote',