Description:
added problem date_added bulk update
git-svn-id: http://theory.cpe.ku.ac.th/grader/web/trunk@432 6386c4cd-e34a-4fa8-8920-d93eb39b512e
Commit status:
[Not Reviewed]
References:
Diff options:
Comments:
0 Commit comments
0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
r201:ac6aa35270da - - 3 files changed: 78 inserted, 4 deleted
@@ -0,0 +1,32 | |||
|
1 | + - content_for :head do | |
|
2 | + = stylesheet_link_tag 'problems' | |
|
3 | + = javascript_include_tag :defaults | |
|
4 | + | |
|
5 | + %h1 Manage problems | |
|
6 | + | |
|
7 | + %p= link_to '[Back to problem list]', :action => 'list' | |
|
8 | + | |
|
9 | + - form_tag :action=>'do_manage' do | |
|
10 | + .submitbox | |
|
11 | + What do you want to do? | |
|
12 | + %br/ | |
|
13 | + %ul | |
|
14 | + %li | |
|
15 | + Change date added to | |
|
16 | + = select_date Date.current, :prefix => 'date_added' | |
|
17 | + | |
|
18 | + = submit_tag 'Change', :name => 'change_date_added' | |
|
19 | + %table | |
|
20 | + %tr | |
|
21 | + %th/ | |
|
22 | + %th Name | |
|
23 | + %th Full name | |
|
24 | + %th Date added | |
|
25 | + | |
|
26 | + - for problem in @problems | |
|
27 | + %tr{:id => "row-prob-#{problem.id}", :name=> "prob-#{problem.id}"} | |
|
28 | + %td= check_box_tag "prob-#{problem.id}" | |
|
29 | + %td= problem.name | |
|
30 | + %td= problem.full_name | |
|
31 | + %td= problem.date_added | |
|
32 | + |
@@ -3,25 +3,28 | |||
|
3 | 3 | before_filter :authenticate, :authorization |
|
4 | 4 | |
|
5 | 5 | in_place_edit_for :problem, :name |
|
6 | 6 | in_place_edit_for :problem, :full_name |
|
7 | 7 | in_place_edit_for :problem, :full_score |
|
8 | 8 | |
|
9 | 9 | def index |
|
10 | 10 | list |
|
11 | 11 | render :action => 'list' |
|
12 | 12 | end |
|
13 | 13 | |
|
14 | 14 | # GETs should be safe (see http://www.w3.org/2001/tag/doc/whenToUseGet.html) |
|
15 |
- verify :method => :post, :only => [ :destroy, |
|
|
15 | + verify :method => :post, :only => [ :destroy, | |
|
16 | + :create, :quick_create, | |
|
17 | + :do_manage, | |
|
18 | + :update ], | |
|
16 | 19 | :redirect_to => { :action => :list } |
|
17 | 20 | |
|
18 | 21 | def list |
|
19 | 22 | @problems = Problem.find(:all, :order => 'date_added DESC') |
|
20 | 23 | end |
|
21 | 24 | |
|
22 | 25 | def show |
|
23 | 26 | @problem = Problem.find(params[:id]) |
|
24 | 27 | end |
|
25 | 28 | |
|
26 | 29 | def new |
|
27 | 30 | @problem = Problem.new |
@@ -121,13 +124,51 | |||
|
121 | 124 | end |
|
122 | 125 | redirect_to :action => 'list' |
|
123 | 126 | end |
|
124 | 127 | |
|
125 | 128 | def stat |
|
126 | 129 | @problem = Problem.find(params[:id]) |
|
127 | 130 | if !@problem.available |
|
128 | 131 | redirect_to :controller => 'main', :action => 'list' |
|
129 | 132 | else |
|
130 | 133 | @submissions = Submission.find_all_last_by_problem(params[:id]) |
|
131 | 134 | end |
|
132 | 135 | end |
|
136 | + | |
|
137 | + def manage | |
|
138 | + @problems = Problem.find(:all, :order => 'date_added DESC') | |
|
133 | 139 | end |
|
140 | + | |
|
141 | + def do_manage | |
|
142 | + if params.has_key? 'change_date_added' | |
|
143 | + change_date_added | |
|
144 | + end | |
|
145 | + redirect_to :action => 'manage' | |
|
146 | + end | |
|
147 | + | |
|
148 | + ################################## | |
|
149 | + protected | |
|
150 | + | |
|
151 | + def change_date_added | |
|
152 | + problems = get_problems_from_params | |
|
153 | + year = params[:date_added][:year].to_i | |
|
154 | + month = params[:date_added][:month].to_i | |
|
155 | + day = params[:date_added][:day].to_i | |
|
156 | + date = Date.new(year,month,day) | |
|
157 | + problems.each do |p| | |
|
158 | + p.date_added = date | |
|
159 | + p.save | |
|
160 | + end | |
|
161 | + end | |
|
162 | + | |
|
163 | + def get_problems_from_params | |
|
164 | + problems = [] | |
|
165 | + params.keys.each do |k| | |
|
166 | + if k.index('prob-')==0 | |
|
167 | + name, id = k.split('-') | |
|
168 | + problems << Problem.find(id) | |
|
169 | + end | |
|
170 | + end | |
|
171 | + problems | |
|
172 | + end | |
|
173 | + | |
|
174 | + end |
@@ -1,23 +1,24 | |||
|
1 | 1 | <% content_for :head do %> |
|
2 | 2 | <%= stylesheet_link_tag 'problems' %> |
|
3 | 3 | <%= javascript_include_tag :defaults %> |
|
4 | 4 | <% end %> |
|
5 | 5 | |
|
6 | 6 | <h1>Listing problems</h1> |
|
7 | 7 | |
|
8 | 8 | <p> |
|
9 | - <%= link_to 'New problem', :action => 'new' %> | |
|
10 |
- <%= link_to ' |
|
|
11 |
- <%= link_to 'Turn o |
|
|
9 | + <%= link_to '[New problem]', :action => 'new' %> | |
|
10 | + <%= link_to '[Manage problems]', :action => 'manage' %> | |
|
11 | + <%= link_to '[Turn off all problems]', :action => 'turn_all_off' %> | |
|
12 | + <%= link_to '[Turn on all problems]', :action => 'turn_all_on' %> | |
|
12 | 13 | </p> |
|
13 | 14 | |
|
14 | 15 | <div class="submitbox"> |
|
15 | 16 | <% form_tag :action => 'quick_create' do %> |
|
16 | 17 | <b>Quick New:</b> |
|
17 | 18 | <label for="problem_name">Name</label> |
|
18 | 19 | <%= text_field 'problem', 'name' %> | |
|
19 | 20 | <label for="problem_full_name">Full name</label> |
|
20 | 21 | <%= text_field 'problem', 'full_name' %> |
|
21 | 22 | <%= submit_tag "Create" %> |
|
22 | 23 | <% end %> |
|
23 | 24 | </div> |
You need to be logged in to leave comments.
Login now