rankings.html 4.9 KB
{% 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)) }}
            &nbsp;
            {{ '<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>