Commit c2f89a7b819f18f38f762bdfb4acc249eb5ea4d9
1 parent
4a961828
Exists in
master
and in
1 other branch
- everything working.
Showing
7 changed files
with
34 additions
and
51 deletions
Show diff stats
BUGS.md
1 | 1 | |
2 | 2 | # BUGS |
3 | 3 | |
4 | -- reset password nao funciona no admin | |
5 | 4 | - qual a diferenca entre md_to_html e md_to_html_review, parece desnecessario haver dois. |
6 | 5 | - servir imagens das perguntas |
7 | 6 | - como alterar configuracao para mostrar logs de debug? |
... | ... | @@ -12,6 +11,7 @@ |
12 | 11 | |
13 | 12 | # TODO |
14 | 13 | |
14 | +- cancelar teste no menu admin. Dado o numero de aluno remove teste e faz logout do aluno. | |
15 | 15 | - decorador para user 0, evita o "if uid==0" em muitas funcoes. |
16 | 16 | - mathjax-node: |
17 | 17 | sudo pkg install node npm |
... | ... | @@ -35,6 +35,7 @@ |
35 | 35 | |
36 | 36 | # FIXED |
37 | 37 | |
38 | +- reset password nao funciona no admin | |
38 | 39 | - reload a intervalos não funciona. |
39 | 40 | - allow/deny nao funciona no /admin. |
40 | 41 | - Review de um teste que foi apagado rebenta. | ... | ... |
app.py
... | ... | @@ -252,9 +252,7 @@ class App(object): |
252 | 252 | 'start_time': self.online.get(uid, {}).get('test', {}).get('start_time',''), |
253 | 253 | 'password_defined': pw != '', |
254 | 254 | 'grades': self.get_student_grades_from_test(uid, self.testfactory['ref']), |
255 | - 'ip_address': self.online.get(uid, {}).get('student', {}).get('ip_address',''), | |
256 | - 'user_agent': self.online.get(uid, {}).get('student', {}).get('user_agent',''), | |
257 | - 'focus': self.online.get(uid, {}).get('student', {}).get('focus', True), | |
255 | + 'focus': self.online.get(uid, {}).get('student', {}).get('focus', True), # FIXME | |
258 | 256 | }) |
259 | 257 | return l |
260 | 258 | |
... | ... | @@ -284,11 +282,11 @@ class App(object): |
284 | 282 | s.commit() |
285 | 283 | logger.info(f'Student {uid}: password reset to ""') |
286 | 284 | |
287 | - def set_user_agent(self, uid, user_agent=''): | |
288 | - self.online[uid]['student']['user_agent'] = user_agent | |
285 | + # def set_user_agent(self, uid, user_agent=''): | |
286 | + # self.online[uid]['student']['user_agent'] = user_agent | |
289 | 287 | |
290 | - def set_user_ip(self, uid, ipaddress=''): | |
291 | - self.online[uid]['student']['ip_address'] = ipaddress | |
288 | + # def set_user_ip(self, uid, ipaddress=''): | |
289 | + # self.online[uid]['student']['ip_address'] = ipaddress | |
292 | 290 | |
293 | 291 | def insert_new_student(self, uid, name): |
294 | 292 | try: | ... | ... |
serve.py
static/css/test.css
1 | 1 | /* Fixes navigation panel overlaying content */ |
2 | 2 | html { |
3 | - font-size: 14px; | |
3 | + font-size: 13px; | |
4 | 4 | } |
5 | 5 | |
6 | 6 | body { |
... | ... | @@ -14,20 +14,15 @@ body { |
14 | 14 | color: inherit; |
15 | 15 | } |
16 | 16 | |
17 | -/*.card { | |
17 | +.card { | |
18 | 18 | margin-top: 70px; |
19 | 19 | } |
20 | -*/ | |
21 | 20 | |
22 | -/*.drop-shadow { | |
23 | - -webkit-box-shadow: 0 0 5px 2px rgba(0, 0, 0, .5); | |
24 | - box-shadow: 0px 2px 10px 3px rgba(0, 0, 0, .2); | |
25 | - border-radius:5px; | |
26 | -} | |
27 | -*/ | |
21 | + | |
28 | 22 | textarea { |
29 | 23 | font-family: monospace !important; |
30 | 24 | } |
25 | + | |
31 | 26 | /* make markdown tables beautiful */ |
32 | 27 | table { |
33 | 28 | border-collapse: collapse; | ... | ... |
static/js/admin.js
1 | 1 | $(document).ready(function() { |
2 | - // button handlers (runs once) | |
3 | 2 | function button_handlers() { |
4 | - | |
3 | + // button handlers (runs once) | |
5 | 4 | $("#allow_all").click( |
6 | 5 | function() { |
7 | 6 | $(":checkbox").prop("checked", true).trigger('change'); |
... | ... | @@ -39,7 +38,6 @@ $(document).ready(function() { |
39 | 38 | }); |
40 | 39 | } |
41 | 40 | ); |
42 | - | |
43 | 41 | // authorization checkboxes in the students_table: |
44 | 42 | $("tbody", "#students_table").on("change", "input", autorizeStudent); |
45 | 43 | } |
... | ... | @@ -86,7 +84,7 @@ $(document).ready(function() { |
86 | 84 | $.ajax({ |
87 | 85 | url: "/admin", |
88 | 86 | data: {"cmd": "test", "value": ""}, |
89 | - // dataType: "json", | |
87 | + dataType: "json", | |
90 | 88 | success: function(data) { |
91 | 89 | // fill jumbotron data |
92 | 90 | $("#title").html(data['data']['title']); |
... | ... | @@ -114,8 +112,9 @@ $(document).ready(function() { |
114 | 112 | emptyTable: "Não há alunos inscritos", |
115 | 113 | }, |
116 | 114 | ajax: { |
117 | - data: {"cmd": "students_table", "value": ""}, | |
118 | 115 | url: "admin", // students_table |
116 | + data: {"cmd": "students_table", "value": ""}, | |
117 | + dataType: "json", | |
119 | 118 | dataSrc: function ( json ) { |
120 | 119 | var t = []; |
121 | 120 | for ( var i=0; i<json.data.length ; i++ ) { |
... | ... | @@ -145,7 +144,7 @@ $(document).ready(function() { |
145 | 144 | }, 3000 ); |
146 | 145 | } |
147 | 146 | |
148 | - // populateHeader(); // run once when the page is loaded | |
147 | + populateHeader(); // run once when the page is loaded | |
149 | 148 | populateStudentsTable(); |
150 | 149 | button_handlers(); // assign handlers to buttons |
151 | 150 | }); | ... | ... |
templates/admin.html
... | ... | @@ -43,7 +43,7 @@ |
43 | 43 | </a> |
44 | 44 | <div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarDropdownAluno"> |
45 | 45 | <a class="dropdown-item" href="#" id="novo_aluno" data-toggle="modal" data-target="#novo_aluno_modal">Inserir novo...</a> |
46 | - <a class="dropdown-item" href="#" id="reset_password" data-toggle="modal" data-target="#reset_password_modal">Reset password...</a> | |
46 | + <a class="dropdown-item" href="#" id="reset_password_menu" data-toggle="modal" data-target="#reset_password_modal">Reset password...</a> | |
47 | 47 | <a class="dropdown-item" href="#" id="allow_all">Autorizar todos</a> |
48 | 48 | <a class="dropdown-item" href="#" id="deny_all">Desautorizar todos</a> |
49 | 49 | </div> |
... | ... | @@ -105,7 +105,6 @@ |
105 | 105 | </div> |
106 | 106 | |
107 | 107 | <div class="modal-footer"> |
108 | - <!-- <button type="button" class="btn btn-danger" data-dismiss="modal">Cancelar</button> --> | |
109 | 108 | <button id="inserir_novo_aluno" class="btn btn-primary" role="button" data-dismiss="modal">Inserir</button> |
110 | 109 | </div> |
111 | 110 | |
... | ... | @@ -124,15 +123,20 @@ |
124 | 123 | </div> |
125 | 124 | |
126 | 125 | <div class="modal-body"> |
127 | - <div class="input-group input-group-sm"> | |
128 | - <input id="reset_number" type="text" class="form-control" placeholder="Número"> | |
129 | - <span class="input-group-btn"> | |
130 | - <button id="reset_password" class="btn btn-primary" type="button">Reset password!</button> | |
131 | - </span> | |
126 | + <div class="form-group row"> | |
127 | + <label for="reset_number" class="col-sm-2 col-form-label">Número</label> | |
128 | + <div class="col-sm-10"> | |
129 | + <input id="reset_number" type="text" class="form-control"> | |
130 | + <!-- <input type="text" class="form-control" id="novo_numero" value=""> --> | |
131 | + </div> | |
132 | 132 | </div> |
133 | 133 | </div> |
134 | + | |
135 | + <div class="modal-footer"> | |
136 | + <button id="reset_password" class="btn btn-primary" role="button" data-dismiss="modal">Reset password</button> | |
137 | + </div> | |
134 | 138 | </div> |
135 | - </div> | |
139 | + </div> <!-- modal --> | |
136 | 140 | </div> |
137 | 141 | |
138 | 142 | ... | ... |
templates/test.html
... | ... | @@ -42,22 +42,10 @@ |
42 | 42 | </ul> |
43 | 43 | |
44 | 44 | <span class="navbar-text"> |
45 | - | |
46 | - | |
47 | -<!-- <span class="navbar-text dropdown"> | |
48 | - <a class="nav-link dropdown-toggle" href="http://example.com" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> | |
49 | - --> | |
50 | - | |
51 | 45 | <i class="fa fa-user" aria-hidden="true"></i> |
52 | 46 | <span id="name">{{ escape(t['student']['name']) }}</span> |
53 | 47 | (<span id="number">{{ escape(t['student']['number']) }}</span>) |
54 | 48 | <span class="caret"></span> |
55 | - | |
56 | -<!-- </a> | |
57 | - <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink"> | |
58 | - <a class="dropdown-item" href="#">Password</a> | |
59 | - </div> | |
60 | - --> | |
61 | 49 | </span> |
62 | 50 | </div> |
63 | 51 | </nav> |
... | ... | @@ -65,17 +53,16 @@ |
65 | 53 | |
66 | 54 | <div class="jumbotron"> |
67 | 55 | <h1 class="display-5">{{ t['title'] }}</h1> |
68 | - {{ t.get('duration', '') }} | |
69 | 56 | <hr> |
70 | 57 | |
71 | 58 | <h5> |
72 | 59 | <div class="row"> |
73 | - <label for="inicio" class="col-sm-2">Início:</label> | |
74 | - <div class="col-sm-10" id="inicio">{{ str(t['start_time'].time())[:8]}}</div> | |
60 | + <label for="inicio" class="col-sm-3">Início:</label> | |
61 | + <div class="col-sm-9" id="inicio">{{ str(t['start_time'].time())[:8]}}</div> | |
75 | 62 | </div> |
76 | 63 | <div class="row"> |
77 | - <label for="duracao" class="col-sm-2">Duração:</label> | |
78 | - <div class="col-sm-10" id="duracao">{{ t.get('duration', chr(8734)) }}</div> | |
64 | + <label for="duracao" class="col-sm-3">Duração:</label> | |
65 | + <div class="col-sm-9" id="duracao">{{ t.get('duration', chr(8734)) }}</div> | |
79 | 66 | </div> |
80 | 67 | </h5> |
81 | 68 | </div> |
... | ... | @@ -86,10 +73,10 @@ |
86 | 73 | {% end %} |
87 | 74 | |
88 | 75 | <div class="form-row"> |
89 | - <div class="col-9"> | |
76 | + <div class="col-12"> | |
90 | 77 | <button type="button" class="btn btn-success btn-lg btn-block" data-toggle="modal" data-target="#confirmar" id="form-button-submit">Submeter teste</button> |
91 | 78 | </div> |
92 | -<!-- <div class="col-3"> | |
79 | +<!-- <div class="col-2"> | |
93 | 80 | <button type="button" class="btn btn-danger btn-lg btn-block" data-toggle="modal" data-target="#sair" id="form-button-sair">Desisto</button> |
94 | 81 | </div> --> |
95 | 82 | </div> | ... | ... |