index.jsp 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ taglib prefix="tag" tagdir="/WEB-INF/tags" %>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="UTF-8">
  8. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  9. <link type="text/css" rel="stylesheet" href="../css/material-icons.css" />
  10. <link type="text/css" rel="stylesheet" href="../css/materialize.min.css" media="screen,projection" />
  11. <link type="text/css" rel="stylesheet" href="../css/style.min.css" media="screen,projection" />
  12. <link rel="icon" href="../img/favicon.ico" />
  13. <title>Scan - Microfolie Lens</title>
  14. </head>
  15. <body class="grey lighten-3">
  16. <!-- Header -->
  17. <header class="navbar-fixed">
  18. <nav class="red">
  19. <div class="nav-wrapper">
  20. <span class="brand-logo center mtop-half hide-on-med-and-down"><img src="../img/logo.png"
  21. title="Logo Microfolie" class="responsive-img" style="max-width: 128px;" /></span>
  22. <span class="brand-logo center hide-on-large-only">Microfolie Lens</span>
  23. <div class="left mleft-2 hide-on-med-and-down">
  24. <span>
  25. <h5>Microfolie Lens</h5>
  26. </span>
  27. </div>
  28. </div>
  29. </nav>
  30. </header>
  31. <div class="mtop-5 hide-on-med-and-down"></div>
  32. <!-- Main -->
  33. <main class="container">
  34. <div class="row">
  35. <div class="col s12 center-align">
  36. <h3 id="title">QR Code Scanner</h3>
  37. </div>
  38. </div>
  39. <div class="row">
  40. <div class="col s12 center-align">
  41. <video id="qr-preview"></video>
  42. </div>
  43. </div>
  44. <div class="row">
  45. <div class="col s12 center-align">
  46. <p id="result"></p>
  47. </div>
  48. </div>
  49. </main>
  50. <!-- Popup -->
  51. <div id="ok-popup" class="modal popup">
  52. <div class="modal-content" style="overflow: hidden;">
  53. <div class="row">
  54. <div class="col offset-m1 m3 s12">
  55. <i class="material-icons green-text" style="font-size: 8em;">check_circle</i>
  56. </div>
  57. <div class="col m7 s12 mtop-3">
  58. <h4>Votre code a bien &eacute;t&eacute; scann&eacute;</h4>
  59. </div>
  60. </div>
  61. </div>
  62. </div>
  63. <div id="err-popup" class="modal popup">
  64. <div class="modal-content" style="overflow: hidden;">
  65. <div class="row">
  66. <div class="col offset-m1 m3 s12">
  67. <i class="material-icons red-text" style="font-size: 8em;">error</i>
  68. </div>
  69. <div class="col m7 s12 mtop-3">
  70. <h4 id="error-text">Error message</h4>
  71. </div>
  72. </div>
  73. </div>
  74. </div>
  75. <!-- Loader -->
  76. <tag:loader name="loader" />
  77. <!-- Script -->
  78. <script type="text/javascript" src="../js/jquery.min.js"></script>
  79. <script type="text/javascript" src="../js/materialize.min.js"></script>
  80. <script type="text/javascript" src="../js/script.js"></script>
  81. <!-- Script pour cette page-->
  82. <script type="text/javascript" src="../js/instascan.min.js"></script>
  83. <script type="text/javascript">
  84. $(document).ready(() => {
  85. const okPopup = M.Modal.getInstance($('#ok-popup'));
  86. const errPopup = M.Modal.getInstance($('#err-popup'));
  87. const loader = M.Modal.getInstance($('#loader'));
  88. // Lecteur cookie espace
  89. const espace = getCookie("microfolies.lens.espace");
  90. // Changement nom titre
  91. if (espace !== undefined) {
  92. $('#title').html(espace.capitalize());
  93. }
  94. //Scanner QRcode
  95. const scanner = new Instascan.Scanner({ video: document.getElementById('qr-preview') });
  96. scanner.addListener('scan', function (content) {
  97. const result = espace ? content + "/" + espace : content;
  98. $('#result').html(result);
  99. okPopup.open();
  100. });
  101. Instascan.Camera.getCameras().then(function (cameras) {
  102. if (cameras.length > 0) {
  103. scanner.start(cameras[0]);
  104. }
  105. else {
  106. console.error('No cameras found.');
  107. }
  108. }).catch(err => {
  109. console.error(err);
  110. });
  111. });
  112. </script>
  113. </body>
  114. </html>