index.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  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. $_SESSION['id'] = '0';
  48. }
  49. //Page web
  50. require 'header.php';
  51. ?>
  52. <style type="text/css">
  53. .center{
  54. text-align: center;
  55. }
  56. .float_message {
  57. position: absolute;
  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. @media only screen and (min-width: 601px){
  67. .float_message{
  68. width: 800px;
  69. }
  70. }
  71. @media only screen and (max-width: 600px){
  72. .float_message{
  73. width: 245px;
  74. }
  75. }
  76. </style>
  77. <div class="hide-on-small-only">
  78. <div style="position: absolute; top: 40px; left: 80px; cursor: pointer;">
  79. <i class="quit material-icons tooltipped" data-position="right" data-tooltip="Changer de salon" style="font-size: 4em">arrow_back</i>
  80. </div>
  81. <div style="position: absolute; top: 40px; right: 80px; cursor: pointer;">
  82. <i class="reload material-icons tooltipped" data-position="bottom" data-tooltip="Recharger la page" style="font-size: 4em">refresh</i>
  83. </div>
  84. <div style="position: absolute; top: 40px; right: 160px; cursor: pointer;">
  85. <i class="reset material-icons tooltipped" data-position="left" data-tooltip="Reset les lancer" style="font-size: 4em">settings_backup_restore</i>
  86. </div>
  87. </div>
  88. <div class="hide-on-med-and-up">
  89. <div style="position: absolute; top: 100px; left: 80px; cursor: pointer;">
  90. <i class="quit material-icons tooltipped" data-position="right" data-tooltip="Changer de salon" style="font-size: 4em">arrow_back</i>
  91. </div>
  92. <div style="position: absolute; top: 100px; right: 80px; cursor: pointer;">
  93. <i class="reload material-icons tooltipped" data-position="bottom" data-tooltip="Recharger la page" style="font-size: 4em">refresh</i>
  94. </div>
  95. <div style="position: absolute; top: 100px; right: 160px; cursor: pointer;">
  96. <i class="reset material-icons tooltipped" data-position="left" data-tooltip="Reset les lancer" style="font-size: 4em">settings_backup_restore</i>
  97. </div>
  98. </div>
  99. <main class="container">
  100. <div class="row">
  101. <div class="col s12 center">
  102. <h1><b>JdR Roll</b></h1>
  103. </div>
  104. </div>
  105. <form id="form" method="POST" action="./" style="margin-top: 1em">
  106. <div class="row">
  107. <div class="col m6 s12">
  108. <div class="row">
  109. <div class="input-field col s12">
  110. <input id="name" type="text" name="name">
  111. <label for="name">Nom du lanceur</label>
  112. </div>
  113. </div>
  114. </div>
  115. <div class="col m6 s12">
  116. <div class="row">
  117. <div class="input-field col s12">
  118. <select id="save-name" name="save-name">
  119. </select>
  120. <label>Lanceur enregistr&eacute;</label>
  121. </div>
  122. </div>
  123. </div>
  124. </div>
  125. <div class="row">
  126. <div class="col m6 s12">
  127. <div class="row">
  128. <div class="input-field col s12">
  129. <select name="roll" id="roll">
  130. <option selected>100</option>
  131. <?php
  132. for($i = 90; $i > 0; $i -= 10){
  133. ?>
  134. <option><?= $i ?></option>
  135. <?php
  136. }
  137. ?>
  138. </select>
  139. <label>Valeur</label>
  140. </div>
  141. </div>
  142. </div>
  143. <div class="col m4 s12 center" style="margin-top: 2em">
  144. <label>
  145. <input type="checkbox" name="hide" id="hide">
  146. <span>Cacher le resultat</span>
  147. </label>
  148. </div>
  149. </div>
  150. <div class="row center">
  151. <div class="col s12">
  152. <button id="valid" type="button" class="waves-effect waves-light btn" style="margin-top: 1em"><i class="material-icons right">check</i>Valider</button>
  153. </div>
  154. </div>
  155. </form>
  156. <div class="row">
  157. <div class="col s12 center">
  158. <h3><i>Historique</i></h3>
  159. </div>
  160. </div>
  161. <div class="row">
  162. <div class="col s12">
  163. <table class="responsive-table">
  164. <thead>
  165. <tr>
  166. <td><b>Lanceur</b></td>
  167. <td><b>Valeur</b></td>
  168. <td><b>D&eacute;</b></td>
  169. </tr>
  170. </thead>
  171. <tbody id="tbody">
  172. <?php
  173. $roll = array_reverse($_SESSION['roll']);
  174. foreach ($roll as $val) {
  175. ?>
  176. <tr>
  177. <td><?= $val['name'] ?></td>
  178. <td><?= $val['roll'] ?></td>
  179. <td><?= $val['dice'] ?></td>
  180. </tr>
  181. <?php
  182. }
  183. ?>
  184. </tbody>
  185. </table>
  186. </div>
  187. </div>
  188. </main>
  189. <input type="hidden" id="msg" data-type="<?= $type ?>" value="<?= $value ?>">
  190. <?php
  191. require 'footer.php';