cms.proweb-salaries.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. $dateData = get::jsonDateDataExcelProweb();
  3. $date = ($dateData != NULL) ? " (au " . core::convertDate($dateData, FALSE) . ")" : "";
  4. ?>
  5. <header class="d-flex flex-column flex-md-row align-items-md-center p-3 bg-light ">
  6. <h2 class="bd-title" id="content">
  7. <span>Proweb : Liste des salariés<?php echo $date ?></span>
  8. <a href="proweb-salaries-upload.html" style="position: absolute; right: 0; margin: 0 40px 0 0;"><button type="submit" class="btn btn-outline-success btn-sm"><span data-feather="file-plus"></span> Importer un fichier Excel</button></a>
  9. <a href="https://www.cse-invent.com/gestion/beneficiaire/od/export-etat/124/excel?type=EtatListe_od" target="_blank" style="position: absolute; right: 0; margin: 0 250px 0 0;"><button type="submit" class="btn btn-outline-secondary btn-sm"><span data-feather="link"></span> Exporter tous les salariés depuis Proweb</button></a>
  10. </h2>
  11. </header>
  12. <?php
  13. echo core::filAriane(array(
  14. "current" => "Liste des salariés",
  15. "arbo" => array(
  16. "Proweb" => NULL,
  17. "Liste des salariés" => "proweb-salaries.html"
  18. )
  19. ));
  20. ?>
  21. <div>
  22. <div id="toolbar" style="margin-bottom:10px;">
  23. <select id="errorFilter" class="form-select">
  24. <option value="" selected>Aucun filtre</option>
  25. <option value="errorRHProweb">Filtre : Problème car le compte Proweb est actif alors qu'absent de la base RH</option>
  26. <option value="errorLoginID">Filtre : Problème car l'identifiant Proweb est différent de l'identifiant RH</option>
  27. <option value="errorjourSortie">Filtre : Problème sur la date de jour de sortie renseignée alors que présent sur la base RH</option>
  28. <option value="errorDateNaissance">Filtre : Problème sur la date de naissance</option>
  29. <option value="errorNom">Filtre : Problème sur nom</option>
  30. <option value="errorPrenom">Filtre : Problème sur le prénom</option>
  31. <option value="errorjourEntree">Filtre : Problème sur la date de jour d'entrée qui est différence entre Proweb et la RH</option>
  32. <option value="errorAbsent">Filtre : Problème car le salarié n'est plus présent et aucune date de sortie sur Proweb</option>
  33. </select>
  34. </div>
  35. <table id="ProWebSalary" class="table-striped table-hover table-sm" data-page-size="25" data-toggle="table" data-buttons-align="left" data-pagination="true" data-filter-control="true" data-flat="true" data-show-columns-toggle-all="true" data-url="/json.php?file=salaries-proweb">
  36. <thead>
  37. <tr>
  38. <th data-sortable="true" data-field="idProweb" data-filter-control="input" data-formatter="selectFicheProweb" data-width="35">#</th>
  39. <th data-sortable="true" data-field="loginId" data-filter-control="input">Id Proweb</th>
  40. <th data-sortable="true" data-field="loginIdRH" data-filter-control="input">Dif. RH</th>
  41. <th data-sortable="true" data-field="nom" data-filter-control="input">Nom</th>
  42. <th data-sortable="true" data-field="prenom" data-filter-control="input">Prénom</th>
  43. <th data-sortable="true" data-field="dateNaissance" data-filter-control="input">Naissance</th>
  44. <th data-sortable="true" data-field="jourEntree" data-filter-control="input">Entrée Proweb</th>
  45. <th data-sortable="true" data-field="jourEntreeRH" data-filter-control="input">Entrée RH</th>
  46. <th data-sortable="true" data-field="jourSortie" data-filter-control="input">Sortie</th>
  47. <th data-sortable="true" data-field="texteContrat" data-filter-control="select">Contrat</th>
  48. <th data-sortable="true" data-field="texteActif" data-filter-control="select">Actif</th>
  49. <th data-sortable="true" data-field="texteRHBase" data-filter-control="select">Base RH</th>
  50. <th data-sortable="true" data-field="texteError" data-filter-control="select">Erreur</th>
  51. <th data-sortable="true" data-field="errorJson" data-filter-control="input">Erreur info</th>
  52. </tr>
  53. </thead>
  54. </table>
  55. </div>
  56. <script>
  57. function selectFicheProweb(value, row) {
  58. return '<a href="<?php echo FICHE_SALARIE_PROWEB ?>' + row.idProweb + '" target="_blank" class="btn btn-secondary btn-sm" style="width:60px;">' + row.idProweb + '</a>';
  59. }
  60. function initFilter(col, data){
  61. if(data === ""){
  62. $(".bootstrap-table-filter-control-"+col).val("").change();
  63. } else {
  64. $(".bootstrap-table-filter-control-"+col).val('"'+data+'"').change();
  65. }
  66. $(".bootstrap-table-filter-control-"+col).trigger('keyup');
  67. }
  68. function initAllFilter(){
  69. initFilter("idProweb", "");
  70. initFilter("loginId", "");
  71. initFilter("loginIdRH", "");
  72. initFilter("nom", "");
  73. initFilter("prenom", "");
  74. initFilter("dateNaissance", "");
  75. initFilter("jourEntree", "");
  76. initFilter("jourEntreeRH", "");
  77. initFilter("jourSortie", "");
  78. initFilter("texteContrat", "");
  79. initFilter("texteActif", "");
  80. initFilter("texteRHBase", "");
  81. initFilter("texteError", "");
  82. initFilter("errorJson", "");
  83. }
  84. $(document).ready(function() {
  85. $(function() {
  86. $('#errorFilter').on( "change", function() {
  87. initAllFilter();
  88. switch($(this).val()) {
  89. case "errorRHProweb":
  90. $(".bootstrap-table-filter-control-texteRHBase").val("Absent").change();
  91. $(".bootstrap-table-filter-control-texteActif").val("Actif").change();
  92. break;
  93. case "errorLoginID":
  94. initFilter("errorJson", "loginId");
  95. break;
  96. case "errorDateNaissance":
  97. initFilter("errorJson", "dateNaissance");
  98. break;
  99. case "errorNom":
  100. initFilter("errorJson", "nom");
  101. break;
  102. case "errorPrenom":
  103. initFilter("errorJson", "prenom");
  104. break;
  105. case "errorjourEntree":
  106. initFilter("errorJson", "jourEntree");
  107. break;
  108. case "errorAbsent":
  109. initFilter("errorJson", "absent");
  110. break;
  111. case "errorjourSortie":
  112. initFilter("errorJson", "jourSortie");
  113. break;
  114. default:
  115. initAllFilter();
  116. }
  117. });
  118. });
  119. });
  120. </script>