index.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?php
  2. //Regarde si il y a un cookie avec le nom de la session à charger ou l'info en POST
  3. if(isset($_POST['salon'])){
  4. //Création du cookie
  5. setcookie('salon', $_POST['salon'], time() + 60 * 60 * 24, '/', '', false, true);
  6. //Recharge la page
  7. header('Location: ./');
  8. exit;
  9. } else if(!isset($_COOKIE['salon'])){
  10. require 'start.php';
  11. exit;
  12. }
  13. //Activation de la session
  14. if(!isset($_COOKIE['common-sess'])){
  15. //Création du cookie de session commun
  16. setcookie('common-sess', $_COOKIE['salon'], time() + 60 * 60 * 24, '/', '', false, true);
  17. //Recharge la page
  18. header('Location: ./');
  19. exit;
  20. } else if($_COOKIE['common-sess'] != $_COOKIE['salon']){
  21. //Changement de la valeur de la session
  22. setcookie('common-sess', $_COOKIE['salon'], time() + 60 * 60 * 24, '/', '', false, true);
  23. //Recharge la page
  24. header('Location: ./');
  25. exit;
  26. }
  27. //Lancement session
  28. session_name('common-sess');
  29. session_start();
  30. //Valeur message
  31. $type = '';
  32. $value = '';
  33. //Param Get
  34. if(isset($_GET['quit'])){
  35. setcookie('salon', '', 0, '/', '', false, true);
  36. header('Location: ./');
  37. exit;
  38. }
  39. if(isset($_GET['type']) && isset($_GET['value'])){
  40. $type = $_GET['type'];
  41. $value = $_GET['value'];
  42. }
  43. //Setup session si besoins
  44. if(!( isset($_SESSION['user']) && isset($_SESSION['roll']) )){
  45. $_SESSION['user'] = [];
  46. $_SESSION['roll'] = [];
  47. }
  48. //Page web
  49. require 'header.php';
  50. ?>
  51. <style type="text/css">
  52. .center{
  53. text-align: center;
  54. }
  55. .float_message {
  56. position: absolute;
  57. width: 800px;
  58. top: 120px;
  59. right: 80px;
  60. z-index: 100;
  61. box-shadow: 12px 12px 2px 1px rgba(0, 0, 255, .2);
  62. margin: 0 0 0 0;
  63. height: 60px;
  64. cursor: pointer;
  65. }
  66. </style>
  67. <div style="position: absolute; top: 40px; left: 80px; cursor: pointer;">
  68. <i id="quit" class="material-icons tooltipped" data-position="right" data-tooltip="Changer de salon" style="font-size: 4em">arrow_back</i>
  69. </div>
  70. <div style="position: absolute; top: 40px; right: 80px; cursor: pointer;">
  71. <i id="reload" class="material-icons tooltipped" data-position="bottom" data-tooltip="Recharger la page" style="font-size: 4em">refresh</i>
  72. </div>
  73. <div style="position: absolute; top: 40px; right: 160px; cursor: pointer;">
  74. <i id="reset" class="material-icons tooltipped" data-position="left" data-tooltip="Reset les lancer" style="font-size: 4em">settings_backup_restore</i>
  75. </div>
  76. <main class="container">
  77. <div class="row">
  78. <div class="col s12 center">
  79. <h1><b>JdR Roll</b></h1>
  80. </div>
  81. </div>
  82. <form id="form" method="POST" action="./">
  83. <div class="row">
  84. <div class="col m6 s12">
  85. <div class="row">
  86. <div class="input-field col s12">
  87. <input id="name" type="text" name="name">
  88. <label for="name">Nom du lanceur</label>
  89. </div>
  90. </div>
  91. </div>
  92. <div class="col m6 s12">
  93. <div class="row">
  94. <div class="input-field col s12">
  95. <select id="save-name" name="save-name">
  96. </select>
  97. <label>Lanceur enregistr&eacute;</label>
  98. </div>
  99. </div>
  100. </div>
  101. </div>
  102. <div class="row">
  103. <div class="col m6 s12">
  104. <div class="row">
  105. <div class="input-field col s12">
  106. <select name="roll" id="roll">
  107. <option selected>100</option>
  108. <?php
  109. for($i = 90; $i > 0; $i -= 10){
  110. ?>
  111. <option><?= $i ?></option>
  112. <?php
  113. }
  114. ?>
  115. </select>
  116. <label>Valeur</label>
  117. </div>
  118. </div>
  119. </div>
  120. <div class="col m4 s12 center" style="margin-top: 2em">
  121. <label>
  122. <input type="checkbox" name="hide" id="hide">
  123. <span>Cacher le resultat</span>
  124. </label>
  125. </div>
  126. </div>
  127. <div class="row center">
  128. <div class="col s12">
  129. <button id="valid" type="button" class="waves-effect waves-light btn" style="margin-top: 1em"><i class="material-icons right">check</i>Valider</button>
  130. </div>
  131. </div>
  132. </form>
  133. <div class="row">
  134. <div class="col s12 center">
  135. <h3><i>Historique</i></h3>
  136. </div>
  137. </div>
  138. <div class="row">
  139. <div class="col s12">
  140. <table class="responsive-table">
  141. <thead>
  142. <tr>
  143. <td><b>Lanceur</b></td>
  144. <td><b>Valeur</b></td>
  145. <td><b>D&eacute;</b></td>
  146. </tr>
  147. </thead>
  148. <tbody id="tbody">
  149. <?php
  150. $roll = array_reverse($_SESSION['roll']);
  151. foreach ($roll as $val) {
  152. ?>
  153. <tr>
  154. <td><?= $val['name'] ?></td>
  155. <td><?= $val['roll'] ?></td>
  156. <td><?= $val['dice'] ?></td>
  157. </tr>
  158. <?php
  159. }
  160. ?>
  161. </tbody>
  162. </table>
  163. </div>
  164. </div>
  165. </main>
  166. <input type="hidden" id="msg" data-type="<?= $type ?>" value="<?= $value ?>">
  167. <?php
  168. require 'footer.php';