Description:
- countdown timer
Commit status:
[Not Reviewed]
References:
Diff options:
Comments:
0 Commit comments
0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
r572:10160025d8ee - - 9 files changed: 65 inserted, 14 deleted
@@ -47,6 +47,7 | |||
|
47 | 47 | gem 'jquery-ui-sass-rails' |
|
48 | 48 | gem 'jquery-timepicker-addon-rails' |
|
49 | 49 | gem 'jquery-tablesorter' |
|
50 | + gem 'jquery-countdown-rails' | |
|
50 | 51 | |
|
51 | 52 | #syntax highlighter |
|
52 | 53 | gem 'rouge' |
@@ -71,6 +71,7 | |||
|
71 | 71 | i18n (0.7.0) |
|
72 | 72 | in_place_editing (1.2.0) |
|
73 | 73 | journey (1.0.4) |
|
74 | + jquery-countdown-rails (2.0.2) | |
|
74 | 75 | jquery-rails (3.1.2) |
|
75 | 76 | railties (>= 3.0, < 5.0) |
|
76 | 77 | thor (>= 0.14, < 2.0) |
@@ -182,6 +183,7 | |||
|
182 | 183 | haml |
|
183 | 184 | haml-rails |
|
184 | 185 | in_place_editing |
|
186 | + jquery-countdown-rails | |
|
185 | 187 | jquery-rails |
|
186 | 188 | jquery-tablesorter |
|
187 | 189 | jquery-timepicker-addon-rails |
@@ -17,7 +17,6 | |||
|
17 | 17 | //= require moment |
|
18 | 18 | //= require bootstrap-sortable |
|
19 | 19 | //= require select2 |
|
20 | - //= require custom | |
|
21 | 20 | //= require ace-rails-ap |
|
22 | 21 | //= require ace/mode-c_cpp |
|
23 | 22 | //= require ace/mode-ruby |
@@ -25,7 +24,15 | |||
|
25 | 24 | //= require ace/mode-javascript |
|
26 | 25 | //= require ace/mode-java |
|
27 | 26 | //= require ace/theme-merbivore |
|
28 | - | |
|
27 | + //= require custom | |
|
28 | + //= require jquery.countdown | |
|
29 | + //-------------- addition from local_jquery ----------- | |
|
30 | + //= require jquery.ui.datepicker | |
|
31 | + //= require jquery.ui.slider | |
|
32 | + //= require jquery-ui-timepicker-addon | |
|
33 | + //= require jquery-tablesorter | |
|
34 | + //= require best_in_place | |
|
35 | + //= require best_in_place.jquery-ui | |
|
29 | 36 | |
|
30 | 37 | // since this is after blank line, it is not downloaded |
|
31 | 38 | //x= require prototype |
@@ -14,7 +14,7 | |||
|
14 | 14 | $ -> |
|
15 | 15 | $(".select2").select2() |
|
16 | 16 | #$(".bootstrap-switch").bootstrapSwitch() |
|
17 | - $(".bootstrap-toggle").bootstrapToggle() | |
|
17 | + #$(".bootstrap-toggle").bootstrapToggle() | |
|
18 | 18 | $('.btn-file :file').on 'fileselect', (event, numFiles, label) -> |
|
19 | 19 | input = $(this).parents('.input-group').find(':text') |
|
20 | 20 | log = if numFiles > 1 then numFiles + ' files selected' else label |
@@ -38,10 +38,15 | |||
|
38 | 38 | target.text '...' |
|
39 | 39 | return |
|
40 | 40 | |
|
41 | + | |
|
41 | 42 | #ace editor |
|
42 | - e = ace.edit("editor") | |
|
43 | - e.setTheme('ace/theme/merbivore') | |
|
44 | - e.getSession().setTabSize(2) | |
|
45 |
- e.getSession().set |
|
|
43 | + if $("#editor").length > 0 | |
|
44 | + e = ace.edit("editor") | |
|
45 | + e.setTheme('ace/theme/merbivore') | |
|
46 | + e.getSession().setTabSize(2) | |
|
47 | + e.getSession().setUseSoftTabs(true) | |
|
48 | + | |
|
49 | + #best in place | |
|
50 | + jQuery(".best_in_place").best_in_place() | |
|
46 | 51 | |
|
47 | 52 | return |
@@ -17,12 +17,12 | |||
|
17 | 17 | |
|
18 | 18 | @import jquery.ui.all |
|
19 | 19 | @import jquery.ui.core |
|
20 | - @import jquery.ui.core | |
|
21 | 20 | @import jquery.ui.theme |
|
22 | 21 | @import jquery.ui.datepicker |
|
23 | 22 | @import jquery.ui.slider |
|
24 | 23 | @import jquery-ui-timepicker-addon |
|
25 | 24 | @import jquery-tablesorter/theme.metro-dark |
|
25 | + @import jquery.countdown | |
|
26 | 26 | @import tablesorter-theme.cafe |
|
27 | 27 | |
|
28 | 28 | //bootstrap |
@@ -134,6 +134,7 | |||
|
134 | 134 | end |
|
135 | 135 | end |
|
136 | 136 | |
|
137 | + | |
|
137 | 138 | def user_title_bar(user) |
|
138 | 139 | header = '' |
|
139 | 140 | time_left = '' |
@@ -1,5 +1,5 | |||
|
1 | - - content_for :header do | |
|
2 |
- |
|
|
1 | + /- content_for :header do | |
|
2 | + / = javascript_include_tag 'local_jquery' | |
|
3 | 3 | |
|
4 | 4 | %h1 System configuration |
|
5 | 5 | |
@@ -13,9 +13,11 | |||
|
13 | 13 | - @grader_configuration = conf |
|
14 | 14 | %tr{:class => cycle("info-odd", "info-even")} |
|
15 | 15 | %td |
|
16 | - = in_place_editor_field :grader_configuration, :key, {}, :rows=>1 | |
|
16 | + /= in_place_editor_field :grader_configuration, :key, {}, :rows=>1 | |
|
17 | + = @grader_configuration.key | |
|
17 | 18 | %td |
|
18 | - = in_place_editor_field :grader_configuration, :value_type, {}, :rows=>1 | |
|
19 | + /= in_place_editor_field :grader_configuration, :value_type, {}, :rows=>1 | |
|
20 | + = @grader_configuration.value_type | |
|
19 | 21 | %td |
|
20 | 22 | = best_in_place @grader_configuration, :value, ok_button: "ok", cancel_button: "cancel" |
|
21 | 23 | %td= conf.description |
@@ -18,6 +18,19 | |||
|
18 | 18 | = add_menu("Self Test", 'test', 'index') |
|
19 | 19 | - if GraderConfiguration['right.user_hall_of_fame'] |
|
20 | 20 | = add_menu("#{I18n.t 'menu.hall_of_fame'}", 'report', 'problem_hof') |
|
21 | + / display MODE button (with countdown in contest mode) | |
|
22 | + - if GraderConfiguration.analysis_mode? | |
|
23 | + %div.navbar-btn.btn.btn-success#countdown= "ANALYSIS MODE" | |
|
24 | + - elsif GraderConfiguration.time_limit_mode? | |
|
25 | + - if @current_user.contest_finished? | |
|
26 | + %div.navbar-btn.btn.btn-danger#countdown= "Contest is over" | |
|
27 | + - elsif !@current_user.contest_started? | |
|
28 | + %div.navbar-btn.btn.btn-primary#countdown= (t 'title_bar.contest_not_started') | |
|
29 | + - else | |
|
30 | + %div.navbar-btn.btn.btn-primary#countdown asdf | |
|
31 | + :javascript | |
|
32 | + $("#countdown").countdown({until: "+#{@current_user.contest_time_left.to_i}s", layout: 'Time left: {hnn}:{mnn}:{snn}'}); | |
|
33 | + / admin section | |
|
21 | 34 | - if (@current_user!=nil) and (session[:admin]) |
|
22 | 35 | %li.dropdown |
|
23 | 36 | %a.dropdown-toggle{href: '#', data: {toggle:'dropdown'}, aria: {haspopup:"true", expanded:"false"}, role: "button"} |
@@ -45,8 +58,6 | |||
|
45 | 58 | =link_to "#{ungraded} backlogs!", |
|
46 | 59 | grader_list_path, |
|
47 | 60 | class: 'navbar-btn btn btn-default btn-warning', data: {toggle: 'tooltip'},title: 'Number of ungraded submission' |
|
48 | - =link_to 'Contest Mode, time remain: 00:20:33',grader_list_path, | |
|
49 | - class: 'navbar-btn btn btn-primary' | |
|
50 | 61 | |
|
51 | 62 | %ul.nav.navbar-nav.navbar-right |
|
52 | 63 | = add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-question-sign')}".html_safe, 'main', 'help') |
@@ -22,6 +22,28 | |||
|
22 | 22 | = text_field 'user', 'email', :size => 10,class: 'form-control' |
|
23 | 23 | =submit_tag "Create", class: 'btn btn-primary' |
|
24 | 24 | |
|
25 | + .panel.panel-primary | |
|
26 | + .panel-title.panel-heading | |
|
27 | + Import from site management | |
|
28 | + .panel-body | |
|
29 | + = form_tag( {method: 'post',multipart: true, action: 'import'}, {class: 'form-inline'}) do | |
|
30 | + .form-group | |
|
31 | + = label_tag 'user_login', 'Login' | |
|
32 | + = text_field 'user', 'login', :size => 10,class: 'form-control' | |
|
33 | + .form-group | |
|
34 | + = label_tag 'user_full_name', 'Full Name' | |
|
35 | + = text_field 'user', 'full_name', :size => 10,class: 'form-control' | |
|
36 | + .form-group | |
|
37 | + = label_tag 'user_password', 'Password' | |
|
38 | + = text_field 'user', 'password', :size => 10,class: 'form-control' | |
|
39 | + .form-group | |
|
40 | + = label_tag 'user_password_confirmation', 'Confirm' | |
|
41 | + = text_field 'user', 'password_confirmation', :size => 10,class: 'form-control' | |
|
42 | + .form-group | |
|
43 | + = label_tag 'user_email', 'email' | |
|
44 | + = text_field 'user', 'email', :size => 10,class: 'form-control' | |
|
45 | + =submit_tag "Create", class: 'btn btn-primary' | |
|
46 | + | |
|
25 | 47 | .submitbox |
|
26 | 48 | %b Import from site management |
|
27 | 49 | = form_tag({:action => 'import'}, :multipart => true) do |
You need to be logged in to leave comments.
Login now