Compare commits
3 Commits
0970030669
...
9eac39ad5e
Author | SHA1 | Date | |
---|---|---|---|
|
9eac39ad5e | ||
|
9d9b7bf38c | ||
|
1a7e420d20 |
@ -216,4 +216,20 @@ class Class_newFiche
|
||||
|
||||
return $result->execute();
|
||||
}
|
||||
|
||||
/**
|
||||
* Passe la
|
||||
*/
|
||||
public function validSheet(): bool
|
||||
{
|
||||
$req = 'UPDATE remboursement
|
||||
SET "rEtat" = \'RB\'
|
||||
WHERE "rVisiteur" = :visiteur AND "rMois" = :mois;
|
||||
';
|
||||
$result = $this->pdo->prepare($req);
|
||||
$result->bindParam('visiteur', $this->userId);
|
||||
$result->bindParam('mois', $this->month);
|
||||
|
||||
return $result->execute();
|
||||
}
|
||||
}
|
||||
|
@ -35,6 +35,9 @@ class Class_user
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Update les lignes remboursement de la bdd a la connexion du comptable
|
||||
*/
|
||||
public function updateBdd(): void
|
||||
{
|
||||
$curMonth = date('Ym');
|
||||
|
@ -1,10 +1,8 @@
|
||||
<?php
|
||||
|
||||
//var_dump($_REQUEST['fraisHF']);
|
||||
require_once(__DIR__ . '/../Class/class.pdo.php');
|
||||
require_once(__DIR__ . '/../Class/class.newFiche.php');
|
||||
|
||||
|
||||
$id = explode('-', $_GET['fiche']); //id de la fiche "userID-date"
|
||||
$pdo = new PdoGsb;
|
||||
$pdoNewFiche = new Class_newFiche($pdo, $id[0], $id[1]);
|
||||
@ -38,6 +36,24 @@ switch ($_GET['action']) {
|
||||
//mise a jour de la fiche remboursement
|
||||
$pdoNewFiche->updateRemboursement($nbJustif, $mttValid);
|
||||
|
||||
break;
|
||||
case 'valid':
|
||||
$mttValid = 0;
|
||||
//FRAIS FORFAITAIRES
|
||||
foreach ($_REQUEST['fraisF'] as $value) {
|
||||
$mttValid = $mttValid + $value['montant'];
|
||||
$pdoNewFiche->updateFraisF(
|
||||
$value['quantité'],
|
||||
intval($value['montant']),
|
||||
$value['id']
|
||||
);
|
||||
}
|
||||
$nbJustif = $_REQUEST['nbJustif'];
|
||||
|
||||
//mise a jour de la fiche remboursement
|
||||
$pdoNewFiche->updateRemboursement($nbJustif, $mttValid);
|
||||
$pdoNewFiche->validSheet();
|
||||
|
||||
break;
|
||||
case 'suprFraisHF':
|
||||
$pdoNewFiche->suprLigneHF($_GET['idFrais']);
|
||||
|
@ -2,6 +2,7 @@
|
||||
require_once(__DIR__ . '/../Class/class.user.php');
|
||||
|
||||
$userClass = new Class_user($pdo);
|
||||
|
||||
if (isset($_POST['login']) && isset($_POST['password'])) {
|
||||
//Récupère les données de l'utilisateur
|
||||
$data = $userClass->connectUser($_POST['login'], $_POST['password']);
|
||||
|
@ -23,7 +23,5 @@ if(isset($_GET['page']) && !empty($_GET['page'])){
|
||||
}
|
||||
|
||||
$pages = ceil($gestionFiche->get_nbFicheAvalider() / $gestionFiche::$NB_LIGNES_FICHEAVALIDER);
|
||||
|
||||
$lesFiches = $gestionFiche->get_ficheAvalider($currentPage);
|
||||
|
||||
include("vues/v_fichesAvalider.php");
|
||||
|
@ -3,7 +3,6 @@
|
||||
require_once(__DIR__ . '/../Class/class.gestionFiche.php');
|
||||
|
||||
$typeU = $_SESSION['uType'];
|
||||
|
||||
$gestionFiche = new Class_gestionFiche($pdo);
|
||||
$LesUtilisateurs = $gestionFiche->getLesUtilisateurs(); //RENVOIE LISTE USERS
|
||||
|
||||
@ -26,8 +25,6 @@ if(isset($_GET['page']) && !empty($_GET['page'])){
|
||||
}
|
||||
|
||||
$pages = ceil($gestionFiche->get_nbRemboursement($userId) / $gestionFiche::$NB_LIGNES_PAGINATION);
|
||||
|
||||
|
||||
$lesFiches = $gestionFiche->get_Page($currentPage, $userId);
|
||||
|
||||
include("vues/v_gestionFiches.php");
|
||||
|
@ -35,13 +35,12 @@ if (isset($_GET['currentList'])) {
|
||||
|
||||
//Date du formulaire HF
|
||||
$dateFormHFMin = substr($date, 0, 4) . '-' . substr($date, 4) . '-01';
|
||||
$dateFormHFMax = date("Y-m-t", mktime(0, 0, 0, date('m', $dateTimeStamp), 1, date('Y', $dateTimeStamp))); // retourne le dernier jour du mois (30 ou 31)
|
||||
|
||||
// retourne le dernier jour du mois (30 ou 31)
|
||||
$dateFormHFMax = date("Y-m-t", mktime(0, 0, 0, date('m', $dateTimeStamp), 1, date('Y', $dateTimeStamp)));
|
||||
}
|
||||
|
||||
//Date du header en français
|
||||
try {
|
||||
|
||||
$format = new IntlDateFormatter(
|
||||
'fr_FR',
|
||||
IntlDateFormatter::FULL,
|
||||
@ -90,5 +89,4 @@ if (
|
||||
$disabled = 'disabled';
|
||||
}
|
||||
|
||||
|
||||
include(__DIR__ . '/../vues/v_newFiche.php');
|
||||
|
@ -7,7 +7,6 @@ $(document).ready(function () {
|
||||
* Partie enregistrement frais F
|
||||
*/
|
||||
$('.frsFrt').on('change', function (e) {
|
||||
console.log($(this).val())
|
||||
val = $(this).val();
|
||||
val = val.replace(',', '.')
|
||||
|
||||
@ -97,7 +96,6 @@ $(document).on('click', '.btnRefuseFraisHf', function () {
|
||||
idFrais = $(this).parent().parent().attr('data-id')
|
||||
fiche = $('#idFiche').attr('data-id')
|
||||
etatLigne = $(this).attr('data-status')
|
||||
console.log(etatLigne)
|
||||
//set on refus
|
||||
$.ajax({
|
||||
// url: "../controleurs/c_actionFiche.php?action=refusFraisHF&fiche=" + fiche + "&idFrais=" + idFrais + "&state=" + etatLigne,
|
||||
@ -174,10 +172,49 @@ $(document).on('click', '#sendFileBtn', function () {
|
||||
method: "POST",
|
||||
data: data,
|
||||
}).done(function () {
|
||||
//location.reload();
|
||||
location.reload();
|
||||
})
|
||||
})
|
||||
|
||||
/**
|
||||
* Partie Validation fiche par le comptable
|
||||
*/
|
||||
$(document).on('click', '#validSheetBtn', function () {
|
||||
//FRAIS FORFAITAIRES
|
||||
var listeFraisF = []
|
||||
$('tr.fraisForfaitaire').each(function () {
|
||||
quantite = parseInt($(this).find('.frsFrt').val())
|
||||
montant = parseFloat($(this).find('.mttFrsTotal').html())
|
||||
id = $(this).attr('data-id')
|
||||
|
||||
tabData = {
|
||||
'quantité': quantite,
|
||||
'montant': montant,
|
||||
'id': id
|
||||
}
|
||||
listeFraisF.push(tabData);
|
||||
})
|
||||
|
||||
nbFraisHf = $('tr.fraisHF').length
|
||||
|
||||
data = {
|
||||
fraisF: listeFraisF,
|
||||
nbJustif: nbFraisHf,
|
||||
mttFrsHf: mttFrsHf
|
||||
}
|
||||
fiche = $('#idFiche').attr('data-id')
|
||||
|
||||
$.ajax({
|
||||
url: "controleurs/c_actionFiche.php?action=valid&fiche=" + fiche,
|
||||
// url: "../controleurs/c_actionFiche.php?action=update&fiche=" + fiche,
|
||||
method: "POST",
|
||||
data: data,
|
||||
}).done(function () {
|
||||
location.reload();
|
||||
})
|
||||
|
||||
});
|
||||
|
||||
/**
|
||||
* Calcul prix total frais forfaitaires
|
||||
*/
|
||||
@ -195,12 +232,6 @@ function calcPrixTotalFrsF() {
|
||||
*/
|
||||
function calcPrixTotalFrsHorsF() {
|
||||
|
||||
console.log($('td#MttFrsHF').length)
|
||||
|
||||
// if ($('td#MttFrsHF').length == 0) {
|
||||
// vf
|
||||
// }
|
||||
|
||||
var prixTotal = 0;
|
||||
$('td#MttFrsHF').each(function () {
|
||||
prixTotal += parseFloat($(this).html().replace('€', ''))
|
||||
|
@ -1,100 +0,0 @@
|
||||
if(document.images) /* PRECHARGEMENT DE L IMAGE DANS LE CACHE DU NAVIGATEUR */
|
||||
{
|
||||
zTous = new Image;
|
||||
zTous = "images/cocheR.gif";
|
||||
}
|
||||
|
||||
function format_euro(valeur)
|
||||
{
|
||||
// formate un nombre avec 2 chiffres après la virgule et un espace separateur de milliers
|
||||
var ndecimal=2;
|
||||
var separateur=' ';
|
||||
var deci=Math.round( Math.pow(10,ndecimal)*(Math.abs(valeur)-Math.floor(Math.abs(valeur)))) ;
|
||||
var val=Math.floor(Math.abs(valeur));
|
||||
if ((ndecimal==0)||(deci==Math.pow(10,ndecimal))) {val=Math.floor(Math.abs(valeur)); deci=0;}
|
||||
var val_format=val+"";
|
||||
var nb=val_format.length;
|
||||
for (var i=1;i<4;i++)
|
||||
{
|
||||
if (val>=Math.pow(10,(3*i)))
|
||||
{
|
||||
val_format=val_format.substring(0,nb-(3*i))+separateur+val_format.substring(nb-(3*i));
|
||||
}
|
||||
}
|
||||
if (ndecimal>0)
|
||||
{
|
||||
var decim="";
|
||||
for (var j=0;j<(ndecimal-deci.toString().length);j++) {decim+="0";}
|
||||
deci=decim+deci.toString();
|
||||
val_format=val_format+","+deci;
|
||||
}
|
||||
if (parseFloat(valeur)<0) {val_format="-"+val_format;}
|
||||
return val_format;
|
||||
}
|
||||
|
||||
// ========================= fonctions de navigation dans les listes (mois/visiteurs)
|
||||
function premier(statut)
|
||||
{
|
||||
if (statut=='V') {
|
||||
document.choixM.lstMois.value = document.choixM.lstMois.options[0].value;
|
||||
document.choixM.submit();}
|
||||
else {
|
||||
document.choixV.lstVisiteurs.value = document.choixV.lstVisiteurs.options[0].value;
|
||||
document.choixV.submit();}
|
||||
}
|
||||
|
||||
function precedent(statut)
|
||||
{
|
||||
if (statut=='V') {
|
||||
document.choixM.lstMois.value = document.choixM.lstMois.options[Math.max(0,document.choixM.lstMois.selectedIndex-1)].value;
|
||||
document.choixM.submit(statut);}
|
||||
else {
|
||||
document.choixV.lstVisiteurs.value = document.choixV.lstVisiteurs.options[Math.max(0,document.choixV.lstVisiteurs.selectedIndex-1)].value;
|
||||
document.choixV.submit();}
|
||||
}
|
||||
|
||||
function suivant(statut)
|
||||
{
|
||||
if (statut=='V') {
|
||||
document.choixM.lstMois.value = document.choixM.lstMois.options[(Math.min((document.choixM.lstMois.options.length-1),document.choixM.lstMois.selectedIndex+1))].value;
|
||||
document.choixM.submit();}
|
||||
else {
|
||||
document.choixV.lstVisiteurs.value = document.choixV.lstVisiteurs.options[(Math.min((document.choixV.lstVisiteurs.options.length-1),document.choixV.lstVisiteurs.selectedIndex+1))].value;
|
||||
document.choixV.submit();}
|
||||
}
|
||||
|
||||
function dernier(statut)
|
||||
{
|
||||
if (statut=='V') {
|
||||
document.choixM.lstMois.value = document.choixM.lstMois.options[(document.choixM.lstMois.options.length-1)].value;
|
||||
document.choixM.submit();}
|
||||
else {
|
||||
document.choixV.lstVisiteurs.value = document.choixV.lstVisiteurs.options[(document.choixV.lstVisiteurs.options.length-1)].value;
|
||||
document.choixV.submit();}
|
||||
}
|
||||
|
||||
// ========================= acivation/desactivation des cases a cocher "justificatifs" pour les frais hors forfaits
|
||||
function tousLesJustificatifs(frm)
|
||||
{
|
||||
inputs = frm.getElementsByTagName("input");
|
||||
var sens = frm.zSens.value;
|
||||
for(i=0 ; i<inputs.length ; i++)
|
||||
{
|
||||
if(inputs[i].type=="checkbox")
|
||||
{
|
||||
if (sens=="off") {inputs[i].checked = true;} else {inputs[i].checked = false;};
|
||||
}
|
||||
|
||||
}
|
||||
if (sens=="off") {frm.zSens.value="on";} else {frm.zSens.value="off";}
|
||||
}
|
||||
|
||||
function tousLesJustificatifs2(frm)
|
||||
{
|
||||
var sens = frm.zSens.value;
|
||||
for (i = 0; i < frm.justificatifs.length; i++)
|
||||
{
|
||||
if (sens=="off") {frm.justificatifs[i].checked = true;} else {frm.justificatifs[i].checked = false;};
|
||||
}
|
||||
if (sens=="off") {frm.zSens.value="on";} else {frm.zSens.value="off";}
|
||||
}
|
@ -80,6 +80,11 @@ BEGIN
|
||||
SET "rEtat" = 'VA'
|
||||
WHERE "rEtat" = 'CL' AND "rMois" < prevMonth;
|
||||
|
||||
--UPDATE les 'vlaidée et mise en paiement en remboursé
|
||||
UPDATE remboursement
|
||||
SET "rEtat" = 'RB'
|
||||
WHERE "rEtat" = "VA" AND 'rMois' > prevMonth;
|
||||
|
||||
RETURN true;
|
||||
END;
|
||||
$$ LANGUAGE 'plpgsql';
|
||||
|
@ -1,4 +1,6 @@
|
||||
<!-- 03/05/2023 à 11H01 -->
|
||||
<!--
|
||||
Page formulaire de connexion
|
||||
-->
|
||||
<section class="vh-100 gradient-custom">
|
||||
<div class="container py-5 h-100">
|
||||
<div class="row d-flex justify-content-center align-items-center h-100">
|
||||
@ -23,8 +25,6 @@
|
||||
<label class="form-label" for="typePasswordX">Mot-de-passe</label>
|
||||
</div>
|
||||
|
||||
<!-- <p class="small mb-5 pb-lg-2"><a class="text-white-50" href="#!">Forgot password?</a></p> -->
|
||||
|
||||
<button class="btn btn-outline-light btn-lg px-5"
|
||||
type="submit">Connexion</button>
|
||||
</form>
|
||||
@ -44,26 +44,3 @@
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
<!--
|
||||
|
||||
<div id="contenu">
|
||||
<h2>Identification utilisateur</h2>
|
||||
|
||||
|
||||
<form method="POST" action="index.php?uc=connexion&action=valideConnexion">
|
||||
|
||||
|
||||
<p>
|
||||
<label for="nom">Login*</label>
|
||||
<input id="login" type="text" name="login" size="30" maxlength="45">
|
||||
</p>
|
||||
<p>
|
||||
<label for="mdp">Mot de passe*</label>
|
||||
<input id="mdp" type="password" name="mdp" size="30" maxlength="45">
|
||||
</p>
|
||||
<input type="submit" value="Valider" name="valider">
|
||||
<input type="reset" value="Annuler" name="annuler">
|
||||
</p>
|
||||
</form>
|
||||
|
||||
</div>
|
@ -14,7 +14,7 @@
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php foreach ($lesFiches as $uneFiche) { ?>
|
||||
<?php foreach ($lesFiches as $uneFiche): ?>
|
||||
<tr>
|
||||
<th scope="row">
|
||||
<?= $gestionFiche->dateComplete($uneFiche['rMois']) ?>
|
||||
@ -29,17 +29,16 @@
|
||||
<td>
|
||||
<?= $uneFiche['eLibelle'] ?>
|
||||
</td>
|
||||
<td><a
|
||||
href="index.php?direction=nouvelleFiche&userId=<?= $userId ?>&dateListing=<?= $uneFiche['rMois'] ?>">voir</a>
|
||||
<td>
|
||||
<a
|
||||
href="index.php?direction=nouvelleFiche&userId=<?= $uneFiche['rVisiteur'] ?>&dateListing=<?= $uneFiche['rMois'] ?>">voir</a>
|
||||
</td>
|
||||
</tr>
|
||||
<?php } ?>
|
||||
<?php endforeach ?>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
|
||||
<?php if ($pages > 0) { ?>
|
||||
<?php if ($pages > 0): ?>
|
||||
<div class="col-4 d-flex mx-auto">
|
||||
<nav>
|
||||
<ul class="pagination">
|
||||
@ -51,20 +50,16 @@
|
||||
<?php for ($page = 1; $page <= $pages; $page++): ?>
|
||||
<!-- Lien vers chacune des pages (activé si on se trouve sur la page correspondante) -->
|
||||
<li class="page-item <?= ($currentPage == $page) ? "active" : "" ?>">
|
||||
<a href="index.php?direction=ficheAvalider&page=<?= $page ?>"
|
||||
class="page-link">
|
||||
<a href="index.php?direction=ficheAvalider&page=<?= $page ?>" class="page-link">
|
||||
<?= $page ?>
|
||||
</a>
|
||||
</li>
|
||||
<?php endfor ?>
|
||||
<!-- Lien vers la page suivante (désactivé si on se trouve sur la dernière page) -->
|
||||
<li class="page-item <?= ($currentPage == $pages) ? "disabled" : "" ?>">
|
||||
<a href="index.php?direction=ficheAvalider&page=<?= $currentPage + 1 ?>"
|
||||
class="page-link">Suivante</a>
|
||||
<a href="index.php?direction=ficheAvalider&page=<?= $currentPage + 1 ?>" class="page-link">Suivante</a>
|
||||
</li>
|
||||
</ul>
|
||||
</nav>
|
||||
</div>
|
||||
<?php
|
||||
};
|
||||
?>
|
||||
<?php endif; ?>
|
||||
|
@ -7,9 +7,10 @@
|
||||
} else { ?>
|
||||
|
||||
<form action="index.php?direction=gestionFiche" method="POST">
|
||||
|
||||
<h3>Gérer les fiches de frais de :</h3>
|
||||
<select class="form-select" name="selVisiteur" id="">
|
||||
<?php
|
||||
echo '<h3>Gérer les fiches de frais de :</h3>';
|
||||
echo '<select class="form-select" name="selVisiteur" id="">';
|
||||
foreach ($LesUtilisateurs as $key => $value) {
|
||||
$id = $value['uId'];
|
||||
$prenom = $value['uPrenom'];
|
||||
@ -24,8 +25,7 @@
|
||||
echo '</select>'; ?>
|
||||
<button type="submit" class="btn btn-dark m-2">Selectionner</button>
|
||||
<!-- Fin du formulaire -->
|
||||
<?php }
|
||||
?>
|
||||
<?php } ?>
|
||||
|
||||
</div>
|
||||
|
||||
@ -42,7 +42,7 @@
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php foreach ($lesFiches as $uneFiche) { ?>
|
||||
<?php foreach ($lesFiches as $uneFiche): ?>
|
||||
<tr>
|
||||
<th scope="row">
|
||||
<?= $gestionFiche->dateComplete($uneFiche['rMois']) ?>
|
||||
@ -57,7 +57,7 @@
|
||||
href="index.php?direction=nouvelleFiche&userId=<?= $userId ?>&dateListing=<?= $uneFiche['rMois'] ?>">voir</a>
|
||||
</td>
|
||||
</tr>
|
||||
<?php } ?>
|
||||
<?php endforeach ?>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
@ -66,7 +66,7 @@
|
||||
PAGINATION:
|
||||
-->
|
||||
|
||||
<?php if ($pages > 1) { ?>
|
||||
<?php if ($pages > 1): ?>
|
||||
<div class="col-4 d-flex mx-auto">
|
||||
<nav>
|
||||
<ul class="pagination">
|
||||
@ -92,6 +92,4 @@
|
||||
</ul>
|
||||
</nav>
|
||||
</div>
|
||||
<?php
|
||||
};
|
||||
?>
|
||||
<?php endif ?>
|
||||
|
@ -1,4 +1,7 @@
|
||||
<h4 class="d-block mx-auto my-2 text-align-center">BONJOUR <?= strtoupper($_SESSION['uPrenom']) ?> NOUS SOMMES LE <?= date('d-m-Y') ?></h4>
|
||||
<h4 class="d-block mx-auto my-2 text-align-center">BONJOUR
|
||||
<?= strtoupper($_SESSION['uPrenom']) ?> NOUS SOMMES LE
|
||||
<?= date('d-m-Y') ?>
|
||||
</h4>
|
||||
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
|
@ -155,9 +155,18 @@
|
||||
if ($disabled == ''):
|
||||
?>
|
||||
<div class="col-3 d-flex mx-auto my-5 justify-content-center">
|
||||
<?php
|
||||
if ($typeUser == 'comptable' && $status['eId'] == 'CL'): ?>
|
||||
<button type="button" class="btn btn-outline-primary btn-lg" id="validSheetBtn"
|
||||
data-uType="<?= $typeUser ?>">Valider
|
||||
la Fiche
|
||||
</button>
|
||||
<?php else: ?>
|
||||
<button type="button" class="btn btn-outline-primary btn-lg" id="sendFileBtn" data-uType="<?= $typeUser ?>">Envoyer
|
||||
la Fiche
|
||||
</button>
|
||||
<?php endif ?>
|
||||
|
||||
</div>
|
||||
<?php endif ?>
|
||||
<script src="include/newFiche.js"></script>
|
||||
|
Loading…
x
Reference in New Issue
Block a user