Nenhuma descrição

homeTemplate.html 8.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. {% extends 'baseTemplate.html' %} {% block title %}Compteurs{% endblock %} {% block content %} {% load hashtags %}
  2. <div class="text-center">
  3. <h1><a class="counter-link" href="{% url 'home' %}">SeumBook™</a></h1>
  4. </div>
  5. <div class="container-fluid">
  6. <div class="row" id="my-counter">
  7. <div class="col-sm-6">
  8. <div class="panel panel-primary">
  9. <div class="panel-heading">
  10. <h2 class="panel-title">
  11. <a class="counter-link panel-title" href="{% url 'counter' id_counter=myCounter.id %}">
  12. <b>{{ myCounter.trigramme }}</b> <small>{{ myCounter.name }}</small>
  13. </a>
  14. {% if not myCounter.lastReset.noSeum %}
  15. <span class="pull-right badge" {% if myCounter.likeCount %} data-toggle="tooltip" data-placement="top" title="{{ myCounter.likersString }}" {% endif %}>
  16. <span class="glyphicon glyphicon-heart"></span>&emsp;{{ myCounter.likeCount }}
  17. </span>
  18. {% endif %}
  19. </h2>
  20. </div>
  21. <div class="primary-counter panel-body" id="container{{myCounter.id}}">
  22. <div style="width:100%;">
  23. {% if myCounter.lastReset.noSeum %}
  24. <strong>N'a pas encore eu le seum.</strong>
  25. <br> {% else %}
  26. <strong>
  27. {% if myCounter.lastReset.selfSeum %}
  28. J'ai eu le seum il y a {{ myCounter.lastReset.formatted_delta }}.
  29. {% else %}
  30. {{myCounter.lastReset.who.trigramme}} m'a foutu le seum il y a {{ myCounter.lastReset.formatted_delta }}.
  31. {% endif %}
  32. </strong>
  33. <br> {% endif %}
  34. <p>{{ myCounter.lastReset.reason | hashtag }}</p>
  35. <div class="text-center" id="button{{myCounter.id}}">
  36. <button class="btn btn-default btn-danger" type="button" onclick="revealSeumForm({{myCounter.id}})">Remettre à zéro</button>
  37. </div>
  38. <form style="display:none" id="counter{{myCounter.id}}" action="{% url 'reset-counter' %}" method="post">
  39. {% csrf_token %}
  40. <div class="form-group">
  41. <label for="reason">Motif du seum</label>
  42. <input id="reason{{myCounter.id}}" type="text" class="form-control" name="reason"></input>
  43. </div>
  44. <input type="hidden" name="counter" value="{{myCounter.id}}"></input>
  45. <input type="hidden" name="redirect" value="{% url 'home' %}"></input>
  46. <input type="hidden" name="who" value="{{myCounter.id}}"></input>
  47. <div class="text-center">
  48. <button type="submit" class="btn btn-default btn-success">J'ai le seum</button>
  49. </div>
  50. </form>
  51. </div>
  52. </div>
  53. </div>
  54. </div>
  55. <div class="col-sm-6">
  56. <div class="panel panel-primary">
  57. <div class="panel-heading">
  58. <h2 class="panel-title"><b>QuickSeum™</b> <small>Brise le mur du seum</small></h2>
  59. </div>
  60. <div class="primary-counter panel-body">
  61. <form class="form-horizontal" action="{% url 'reset-counter'%}" method="POST" style="width:100%;">
  62. {% csrf_token %}
  63. <div class="form-group">
  64. <label for="id_quicktrigramme" class="col-sm-3 control-label">Trigramme</label>
  65. <div class="col-sm-9">
  66. <input id="id_quicktrigramme" maxlength="3" type="text" class="form-control text-uppercase" name="trigramme" onkeyup="this.value=this.value.toUpperCase();" required />
  67. </div>
  68. </div>
  69. <div class="form-group">
  70. <label for="id_quickreason" class="col-sm-3 control-label">Motif</label>
  71. <div class="col-sm-9">
  72. <input type="text" class="form-control" id="id_quickreason" name="reason" />
  73. </div>
  74. </div>
  75. <div class="form-group">
  76. <div class="col-sm-offset-3 col-sm-9">
  77. <button type="submit" class="btn btn-danger">Foutre le seum</button>
  78. </div>
  79. </div>
  80. <input type="hidden" name="who" value="{{myCounter.id}}"></input>
  81. <input type="hidden" name="redirect" value="{% url 'home' %}"></input>
  82. </form>
  83. </div>
  84. </div>
  85. </div>
  86. </div>
  87. <div class="row">
  88. {% for counter in counters %}
  89. <div class="col-md-4 col-sm-6 col-lg-3">
  90. <div class="panel panel-{{counter.CSSclass}}">
  91. <div class="panel-heading">
  92. <form action="{% url 'like' %}" method="POST" name="like{{counter.id}}">
  93. {% csrf_token %}
  94. <input type="hidden" name="liker" value="{{myCounter.id}}" />
  95. <input type="hidden" name="redirect" value="{% url 'home' %}" />
  96. <input type="hidden" name="reset" value="{{counter.lastReset.id}}" />
  97. <h2 class="panel-title">
  98. <a class="counter-link panel-title" href="{% url 'counter' id_counter=counter.id %}">
  99. <b>{{ counter.trigramme }}</b> <small>{{ counter.name }}</small>
  100. </a>
  101. {% if not counter.lastReset.noSeum %}
  102. {% if counter.alreadyLiked %}
  103. <span class="pull-right badge" {% if counter.likeCount > 0 %} data-toggle="tooltip" data-placement="top" title="{{ counter.likersString }}" {% endif %}>
  104. <span class="glyphicon glyphicon-ok"></span>&emsp;{{ counter.likeCount }}
  105. </span>
  106. {% elif counter.id == myCounter.id or counter.lastReset.who.id == myCounter.id %}
  107. <span class="pull-right badge" {% if counter.likeCount > 0 %} data-toggle="tooltip" data-placement="top" title="{{ counter.likersString }}" {% endif %}>
  108. <span class="glyphicon glyphicon-heart"></span>&emsp;{{ counter.likeCount }}
  109. </span>
  110. {% else %}
  111. <a class="pull-right badge" onclick="document.forms['like{{counter.id}}'].submit();">
  112. <span class="glyphicon glyphicon-heart"></span>&emsp;{{ counter.likeCount }}
  113. </a>
  114. {% endif %}
  115. {% endif %}
  116. </h2>
  117. </form>
  118. </div>
  119. <div class="seum-counter panel-body">
  120. {% if counter.lastReset.noSeum %}
  121. <strong>N'a pas encore eu le seum.</strong>
  122. <br> {% else %}
  123. <strong>
  124. {% if counter.lastReset.selfSeum %}
  125. A eu le seum il y a {{ counter.lastReset.formatted_delta }}.
  126. {% else %}
  127. {{ counter.lastReset.who.trigramme }} lui a foutu le seum il y a {{ counter.lastReset.formatted_delta }}.
  128. {% endif %}
  129. </strong>
  130. <br> {% endif %}
  131. <p>{{ counter.lastReset.reason | hashtag }}</p>
  132. </div>
  133. </div>
  134. </div>
  135. {% endfor %}
  136. </div>
  137. <div class="row">
  138. <div class="col-sm-12">
  139. <div class="panel panel-info">
  140. <div class="panel-heading">
  141. <h2 class="panel-title">Timeline des 24 heures du seum</h2>
  142. </div>
  143. <div class="panel-body timeline graphs">
  144. {% if noTimeline %}
  145. <div class="text-center text-muted">
  146. <p>Pas de seum dans les dernières 24 heures...</p>
  147. </div>
  148. {% else %} {{ line_chart.as_html }} {% endif %}
  149. </div>
  150. </div>
  151. </div>
  152. </div>
  153. <div class="row">
  154. <div class="col-sm-12">
  155. <div class="panel panel-info">
  156. <div class="panel-heading">
  157. <h2 class="panel-title">Graphe des jours sans seum</h2>
  158. </div>
  159. <div class="panel-body graphs">
  160. {% if noGraph %}
  161. <div class="text-center text-muted">
  162. <p>Personne n'a le seum...</p>
  163. </div>
  164. {% else %} {{ col_chart.as_html }} {% endif %}
  165. </div>
  166. </div>
  167. </div>
  168. </div>
  169. <div class="row">
  170. <div class="col-sm-12">
  171. <div class="panel panel-info">
  172. <div class="panel-heading">
  173. <h2 class="panel-title">Meilleurs seumeurs</h2>
  174. </div>
  175. <div class="panel-body graphs">
  176. {% if noBestSeum %}
  177. <div class="text-center text-muted">
  178. <p>Personne n'a eu le seum...</p>
  179. </div>
  180. {% else %} {{ best_chart.as_html }} {% endif %}
  181. </div>
  182. </div>
  183. </div>
  184. </div>
  185. <div class="row">
  186. <div class="col-sm-12">
  187. <div class="panel panel-info">
  188. <div class="panel-heading">
  189. <h2 class="panel-title">Activité seumesque</h2>
  190. </div>
  191. <div class="panel-body graphs">
  192. {% if noSeumActivity %}
  193. <div class="text-center text-muted">
  194. <p>Personne n'a eu le seum...</p>
  195. </div>
  196. {% else %} {{ activity_chart.as_html }} {% endif %}
  197. </div>
  198. </div>
  199. </div>
  200. </div>
  201. </div>
  202. <div class="row text-center">
  203. <a href="{% url 'logout' %}" class="btn btn-danger">Se déconnecter</a>
  204. <a href="{% url 'password_change' %}" class="btn btn-warning">Changer de mot de passe</a>
  205. <a href="{% url 'toggle_email_notifications' %}" class="btn btn-info">
  206. {% if myCounter.email_notifications %}
  207. Désactiver les notifications par mail
  208. {% else %}
  209. Activer les notifications par mail
  210. {% endif %}
  211. </a>
  212. <a href="{% url 'toggle_sort_score' %}" class="btn btn-success">
  213. {% if myCounter.sort_by_score %}
  214. Trier les seums par ancienneté
  215. {% else %}
  216. Trier les seums par score
  217. {% endif %}
  218. </a>
  219. </div>
  220. <script>
  221. $(function () {
  222. $('[data-toggle="tooltip"]').tooltip()
  223. })
  224. </script>
  225. {% endblock %}