aboutsummaryrefslogtreecommitdiffhomepage
path: root/services/app/templates/quiz_view.html.twig
blob: ade324a882126516acf149493384ba5e2104fc6c (plain)
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
{% extends '_page.html.twig' %}

{% block content %}
  <nav>
    <ol class="breadcrumb">
      <li class="breadcrumb-item"><a href="{{ url_for('quiz_list') }}">問題一覧</a></li>
      <li class="breadcrumb-item active">{{ quiz.title }}</li>
    </ol>
  </nav>

  <h2>{{ quiz.title }}</h2>
  <p>
    {{ quiz.description }}
  </p>
  {% if is_open %}
    <p>
      <a class="btn btn-primary" href="{{ url_for('answer_new', { qslug: quiz.slug }) }}">回答する</a>
    </p>
  {% endif %}
  <h3>実装例</h3>
  <pre><code class="hljs language-php">{{ quiz.example_code }}</code></pre>
  <h2>ランキング</h2>
  {% if is_ranking_hidden %}
    回答が締め切られるまで、ランキングは表示されません
  {% elseif ranking|length == 0 %}
    <p>
      まだ正解した回答がありません
    </p>
  {% else %}
    <table class="table table-striped table-bordered">
      <thead>
        <tr>
          <th>ランク</th>
          <th>ID</th>
          <th>作者</th>
          <th>サイズ</th>
          <th>投稿日時</th>
        </tr>
      </thead>
      <tbody>
        {% for answer in ranking %}
          <tr>
            <td>{{ loop.index }}</td>
            <td><a href="{{ url_for('answer_view', { qslug: quiz.slug, anum: answer.answer_number }) }}">#{{ answer.answer_number }}</a></td>
            <td>{{ answer.author_name }}{% if answer.author_is_admin %} (staff){% endif %}</td>
            <td>{{ answer.code_size }} byte</td>
            <td>{{ answer.submitted_at|date('Y-m-d H:i:s', 'Asia/Tokyo') }}</td>
          </tr>
        {% endfor %}
      </tbody>
    </table>
    <div>
      <canvas id="chart" data-quiz-id="{{ quiz.quiz_id }}"></canvas>
      <script type="module" src="{{ base_path() }}/assets/chart.js"></script>
    </div>
  {% endif %}
  <p>
    <a href="{{ url_for('answer_list', { qslug: quiz.slug }) }}">すべての回答を見る</a>
  </p>
{% endblock %}