rankings.html
4.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
{% autoescape %}
<!doctype html>
<html lang="pt-PT">
<head>
<title>{{appname}}</title>
<link rel="icon" href="/static/favicon.ico">
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta name="author" content="Miguel Barão">
<!-- Styles -->
<link rel="stylesheet" href="/static/mdbootstrap/css/bootstrap.min.css">
<link rel="stylesheet" href="/static/mdbootstrap/css/mdb.min.css">
<link rel="stylesheet" href="/static/css/maintopics.css">
<!-- Scripts -->
<script defer src="/static/mdbootstrap/js/jquery.min.js"></script>
<script defer src="/static/mdbootstrap/js/popper.min.js"></script>
<script defer src="/static/mdbootstrap/js/bootstrap.min.js"></script>
<script defer src="/static/mdbootstrap/js/mdb.min.js"></script>
<script defer src="/static/fontawesome-free/js/all.min.js"></script>
<script defer src="/static/js/maintopics.js"></script>
</head>
<!-- ===================================================================== -->
<body>
<nav class="navbar navbar-expand-sm fixed-top navbar-dark bg-primary">
<img src="/static/logo_horizontal.png" height="48" width="120" class="navbar-brand" alt="UEvora">
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarText" aria-controls="navbarText" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarText">
<div class="navbar-nav mr-auto">
<a class="nav-item nav-link" href="/courses">Cursos <span class="sr-only">(actual)</span></a>
<a class="nav-item nav-link" href="/course/{{course_id}}">Tópicos</a>
<a class="nav-item nav-link active" href="#">Classificação</a>
</div>
<ul class="navbar-nav">
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<i class="fas fa-user-graduate" aria-hidden="true"></i>
<span id="name">{{ escape(name) }}</span>
<span class="caret"></span>
</a>
<div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarDropdown">
<a class="dropdown-item" data-toggle="modal" data-target="#password_modal">Mudar Password</a>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="/logout">Sair</a>
</div>
</li>
</ul>
</div>
</nav>
<!-- ===================================================================== -->
<div class="container">
<h4>{{course_title}}</h4>
<table class="table table-hover">
<col width="100">
<thead>
<tr>
<th># Posição</th>
<th>Aluno</th>
<th>Progresso</th>
</tr>
</thead>
<tbody>
{% for i,r in enumerate(rankings) %}
{% if r[0] == uid %}
<tr class="table-primary"> <!-- this is me -->
{% else %}
<tr>
{% end %}
<td class="text-center"> <!-- rank -->
<strong>
{{'<i class="fas fa-crown fa-2x text-warning"></i>' if i==0 else i+1}}
</strong>
</td>
<td> <!-- student name -->
{{ ' '.join(r[1].split()[n] for n in (0,-1)) }}
{{ '<i class="far fa-thumbs-up text-success" title="Mais de 75% de respostas correctas"></i>' if r[3] > 0.75 else '' }}
{{ '<i class="fas fa-bug" title="Menos de 50% de respostas correctas" ></i>' if 0.0 < r[3] < 0.5 else '' }}
</td>
<td> <!-- progress -->
<div class="progress">
<div class="progress-bar" role="progressbar" style="width: {{100*r[2]}}%;" aria-valuenow="{{round(100*r[2])}}%" aria-valuemin="0" aria-valuemax="100">{{round(100*r[2])}}%</div>
</div>
</td>
</tr>
{% end %}
</tbody>
</table>
<!-- === Change Password Modal =========================================== -->
<div id="password_modal" class="modal fade" tabindex="-1" role="dialog">
<div class="modal-dialog" role="document">
<div class="modal-content">
<!-- header -->
<div class="modal-header">
<h5 class="modal-title">Alterar Password</h5>
</div>
<!-- body -->
<div class="modal-body">
<div class="control-group">
<label for="new_password" class="control-label">Introduza a nova password:</label>
<div class="controls">
<input type="password" id="new_password" name="new_password" autocomplete="new-password">
</div>
</div>
</div>
<!-- footer -->
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Cancelar</button>
<button id="change_password" type="button" class="btn btn-danger" data-dismiss="modal">Alterar</button>
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div>
<!-- /.modal -->
</body>
</html>