diff options
| author | polo <ordipolo@gmx.fr> | 2025-07-09 00:54:15 +0200 |
|---|---|---|
| committer | polo <ordipolo@gmx.fr> | 2025-07-09 00:54:15 +0200 |
| commit | 010702f67d2560d6435c4e7f39fe7a567aac080b (patch) | |
| tree | 159f2abb3633a1e333d187f0c6862ce4ead047c5 /bin | |
| parent | 4accca2c57b5f12169afe6a75c74efadd86d835d (diff) | |
| download | AppliGestionPHP-010702f67d2560d6435c4e7f39fe7a567aac080b.tar.gz AppliGestionPHP-010702f67d2560d6435c4e7f39fe7a567aac080b.tar.bz2 AppliGestionPHP-010702f67d2560d6435c4e7f39fe7a567aac080b.zip | |
mieux comme ça
Diffstat (limited to 'bin')
| -rwxr-xr-x | bin/livre_recettes.php | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/bin/livre_recettes.php b/bin/livre_recettes.php new file mode 100755 index 0000000..28c08a1 --- /dev/null +++ b/bin/livre_recettes.php | |||
| @@ -0,0 +1,66 @@ | |||
| 1 | #!/usr/bin/env php | ||
| 2 | <?php | ||
| 3 | // bin/livre_recettes.php | ||
| 4 | // | ||
| 5 | // pour l'obtenir: | ||
| 6 | // php bin/livre_recettes.php > bin/livre_recettes.csv | ||
| 7 | // | ||
| 8 | // en ouvrant le CSV, choisir le pipe | comme séparateur | ||
| 9 | |||
| 10 | |||
| 11 | // chemins des dossiers et nom de la base | ||
| 12 | require('src/files.php'); | ||
| 13 | require('src/Config.php'); // lit le config.ini et gère certaines erreurs (exemple les / aux chemins manquants) | ||
| 14 | Config::readFile('config/config.ini'); | ||
| 15 | Config::hydrate(); | ||
| 16 | |||
| 17 | // créer les dossiers si nécéssaire | ||
| 18 | makeFolder(Config::$db_path); | ||
| 19 | makeFolder(Config::$latex_path); | ||
| 20 | makeFolder(Config::$pdf_path); | ||
| 21 | |||
| 22 | //require 'src/model/doctrine-bootstrap.php'; | ||
| 23 | require __DIR__ . '/../src/model/doctrine-bootstrap.php'; // chemin absolu | ||
| 24 | |||
| 25 | // requête | ||
| 26 | $date_debut = '2024-01-01'; | ||
| 27 | $date_fin = '2024-12-31'; | ||
| 28 | |||
| 29 | $debut = new DateTime($date_debut, new DateTimeZone('Europe/Paris')); | ||
| 30 | $fin = new DateTime($date_fin, new DateTimeZone('Europe/Paris'));; | ||
| 31 | $fin->setTime(23, 59, 59); | ||
| 32 | |||
| 33 | $dql = 'SELECT n FROM Prestation n WHERE n.date >= :debut AND n.date <= :fin'; | ||
| 34 | $bulk_data = $entityManager | ||
| 35 | ->createQuery($dql) | ||
| 36 | ->setParameter('debut', $debut->getTimestamp()) | ||
| 37 | ->setParameter('fin', $fin->getTimestamp()) | ||
| 38 | ->getResult(); | ||
| 39 | |||
| 40 | // affichage | ||
| 41 | echo "client|date|type|mode paiement|débours|total HT|salaire CESU|code presta\n"; | ||
| 42 | |||
| 43 | foreach($bulk_data as $presta){ | ||
| 44 | if($presta->getTypePresta() !== 'devis'){ | ||
| 45 | $date = new DateTime()->setTimestamp($presta->getDate()); | ||
| 46 | |||
| 47 | echo $presta->getClient()->getPrenomNom() . '|' | ||
| 48 | . $date->format('d/m/Y') . '|' | ||
| 49 | . $presta->getTypePresta() . '|' | ||
| 50 | . $presta->getModePaiement() . '|'; | ||
| 51 | |||
| 52 | if($presta->getTypePresta() === 'facture'){ | ||
| 53 | echo $presta->getFacture()->getTotalPieces() . '|'; | ||
| 54 | echo $presta->getFacture()->getTotalHT() . '||'; | ||
| 55 | } | ||
| 56 | elseif($presta->getTypePresta() === 'cesu'){ | ||
| 57 | echo '||' . $presta->getCESU()->getSalaire() . '|'; | ||
| 58 | } | ||
| 59 | elseif($presta->getTypePresta() === 'location'){ | ||
| 60 | echo '|' . (string)($presta->getLocation()->getLoyer() * (float)$presta->getLocation()->getLoyersPayes()) . '||'; | ||
| 61 | } | ||
| 62 | |||
| 63 | echo $presta->getCodePresta(); | ||
| 64 | echo "\n"; | ||
| 65 | } | ||
| 66 | } | ||
