abonnes.jsp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ taglib prefix="tag" tagdir="/WEB-INF/tags" %>
  4. <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
  5. <%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
  6. <c:set var="req" value="${pageContext.request}" />
  7. <c:set var="url">${req.requestURL}</c:set>
  8. <c:set var="base" value="${fn:substring(url, 0, fn:length(url) - fn:length(req.requestURI))}${req.contextPath}/" />
  9. <!DOCTYPE html>
  10. <html>
  11. <head>
  12. <tag:head title="Abonnés" />
  13. </head>
  14. <body class="grey lighten-3">
  15. <!-- Header -->
  16. <tag:header active="abonnes" />
  17. <!-- Main -->
  18. <main class="container">
  19. <div class="row">
  20. <div class="col s12 center-align">
  21. <h3>Abonn&eacute;s</h3>
  22. </div>
  23. </div>
  24. <div class="row">
  25. <div id="abo" class="col s12 center-align"></div>
  26. </div>
  27. <div class="row">
  28. <div id="pagination-abo" class="col s12 center-align"></div>
  29. </div>
  30. </main>
  31. <!-- Footer -->
  32. <tag:footer />
  33. <!-- Loader -->
  34. <tag:loader name="loader" />
  35. <!-- Script -->
  36. <tag:script />
  37. <script type="text/javascript">
  38. $(document).ready(() => {
  39. const loader = M.Modal.getInstance($('#loader'));
  40. const idPagination = 'usager';
  41. const perPage = 5;
  42. function pagine(numPage) {
  43. loader.open();
  44. $.ajax({
  45. type: "GET",
  46. url: "${base}api/usager/page/" + numPage + "/" + perPage + "/formatted/pagination",
  47. error: () => {
  48. loader.close();
  49. pagination(idPagination, numPage, perPage, 0, $('#abo'), $('#pagination-abo'), []);
  50. let html = '<tr>';
  51. html += '<td class="right-align red-text" width="40%"><i class="material-icons" style="font-size:4em;padding-top:.3em;">error</i></td>';
  52. html += '<td class="left-align red-text" width="60%"><h4>Impossible de charger les usage</td>';
  53. html += '</tr>';
  54. $('#pagination-' + idPagination + '-table').html(html);
  55. },
  56. success: (result) => {
  57. loader.close();
  58. if (result.data.list.length > 0) {
  59. pagination(idPagination, numPage, perPage, result.data.total, $('#abo'), $('#pagination-abo'), result.data.list, 'responsive-table striped', 'action');
  60. $('.tooltipped').tooltip();
  61. } else {
  62. pagination(idPagination, numPage, perPage, 0, $('#abo'), $('#pagination-abo'), []);
  63. let html = '<tr>';
  64. html += '<td class="right-align blue-text" width="40%"><i class="material-icons" style="font-size:4em;padding-top:.3em;">info</i></td>';
  65. html += '<td class="left-align blue-text" width="60%"><h4>Aucun usager</td>';
  66. html += '</tr>';
  67. $('#pagination-' + idPagination + '-table').html(html);
  68. }
  69. },
  70. });
  71. };
  72. pagine(1);
  73. // Detection changement page
  74. $('main').on('click', '.pagination-' + idPagination + '-prev', function () {
  75. console.log(idPagination, 'prev', $(this).attr('data-page'));
  76. pagine($(this).attr('data-page'));
  77. });
  78. $('main').on('click', '.pagination-' + idPagination + '-next', function () {
  79. console.log('abo', 'next', $(this).attr('data-page'));
  80. pagine($(this).attr('data-page'));
  81. });
  82. $('main').on('click', '.pagination-' + idPagination + '-number', function () {
  83. console.log('abo', 'num', $(this).attr('data-page'));
  84. pagine($(this).attr('data-page'));
  85. });
  86. });
  87. </script>
  88. </body>
  89. </html>