From 22b941b3526dd3aaf6976eb4ed30aa2ecc30f921 Mon Sep 17 00:00:00 2001 From: polo Date: Thu, 22 Jun 2023 15:22:23 +0200 Subject: factorisation 1_new_service.php vers functions.php --- src/sections/1_new_service.php | 153 +++++++++-------------------------------- 1 file changed, 31 insertions(+), 122 deletions(-) (limited to 'src/sections/1_new_service.php') diff --git a/src/sections/1_new_service.php b/src/sections/1_new_service.php index ae2d2ef..f9105b7 100644 --- a/src/sections/1_new_service.php +++ b/src/sections/1_new_service.php @@ -1,15 +1,11 @@ get()) == '0') // $? = 0 signifie oui, double égal == pour le transtypage + $Client = makeObjectCLient(); + if($Client === 0) { - echo "choix: recherche d'une client\n"; - $input = exec($RechercheClient->get()); - if($input == '') - { - echo "debug: recherche annulée ou saisie vide\n"; - return(0); - } - - echo "debug: recherche effectuée\n"; - $ResultatsRechercheClient->setListRows(rechercheClient($input, $Client), $Client->getTable()); // recherche silencieuse - unset($input); - - // niveau 4: sélection parmi les résultats - $choix_niv4 = exec($ResultatsRechercheClient->get()); // renvoie l'ID de la table 'clients' - $ResultatsRechercheClient->cleanCommand(); - - if($choix_niv4 == '') - { - echo "debug: client pas trouvé ou pas sélectionné\n"; - return(0); - } - - echo "debug: client sélectionné\n"; - $Client->hydrate($Client->findById($choix_niv4)); - $client_inconnu = false; - } - else - { - echo "choix: nouveau client\n"; - } - - // on n'a pas cherché OU on n'a pas trouvé - if($client_inconnu) - { - $input = exec($NouveauClient->get()); - if($input == '') - { - echo "debug: annulation lors de l'enregistrement d'un nouveau client\n"; - return(0); - } - if(!$Client->hydrateFromForm($input)) - { - // messages d'erreur dans hydrateFromForm() - return(0); - } - unset($input); - $Client->create(); - $Client->setID(); // sans paramètre, exécute un $this->db->lastInsertId() + return 0; // menu principal } @@ -87,7 +32,7 @@ function newService(): int // code de retour, si 0 retour menu principal, si 2 a if($choix_niv2 === '') { echo "debug: annulation menu enregistrement\n"; - return(0); // menu principal + return 0; // menu principal } $Presta = new Prestations($Client->getID()); @@ -98,7 +43,7 @@ function newService(): int // code de retour, si 0 retour menu principal, si 2 a if($Date->getDate() == '') // on n'a pas cliqué sur "annuler" { echo "debug: annulation à la saisie d'une date\n"; - return(0); // menu principal + return 0; // menu principal } $Presta->setDate($Date->getTimestamp()); // un entier pour la BDD @@ -106,47 +51,47 @@ function newService(): int // code de retour, si 0 retour menu principal, si 2 a switch($choix_niv2) { // formulaire - étape 2/3 - case ZenitySetup::$menu_enregistrement_entrees[0]: // "Devis" - $Details = new DevisFactures('devis'); - $Presta->setTypePresta('devis'); - $input = exec($FormulaireDevis->get()); - break; - case ZenitySetup::$menu_enregistrement_entrees[1]: // "Facture" - $Details = new DevisFactures('factures'); // 'factures' est le nom de la table, pas le type de presta + //~ case ZenitySetup::$menu_enregistrement_entrees[0]: // "Devis" + //~ $PrestaDetails = new DevisFactures('devis'); + //~ $Presta->setTypePresta('devis'); + //~ $input = exec($FormulaireDevis->get()); + //~ break; + case ZenitySetup::$menu_enregistrement_entrees[0]: // "Facture" + $PrestaDetails = new DevisFactures('factures'); // 'factures' est le nom de la table, pas le type de presta $Presta->setTypePresta('facture'); $input =exec($FormulaireFacture->get()); break; - case ZenitySetup::$menu_enregistrement_entrees[2]: // "CESU" - $Details = new CESU(); + case ZenitySetup::$menu_enregistrement_entrees[1]: // "CESU" + $PrestaDetails = new CESU(); $Presta->setTypePresta('cesu'); $input = exec($FormulaireCesu->get()); break; - case ZenitySetup::$menu_enregistrement_entrees[3]: // "Location" - $Details = new Locations(); + case ZenitySetup::$menu_enregistrement_entrees[2]: // "Location" + $PrestaDetails = new Locations(); $Presta->setTypePresta('location'); $input = exec($FormulaireLocation->get()); break; - case ZenitySetup::$menu_enregistrement_entrees[4]: // "Prestation non vendue" + case ZenitySetup::$menu_enregistrement_entrees[3]: // "Prestation non vendue" $Presta->setTypePresta('non_vendue'); break; default: // inutile normallement, cas déjà géré avant echo "debug: sortie du menu enregistrement incorrect\n"; - return(0); + return 0; } $Presta->makeCodePresta($Date, $Client->getCodeClient()); // d'un objet à l'autre - if($choix_niv2 != ZenitySetup::$menu_enregistrement_entrees[4]) // si presta non vendue, saut étape 3/3 + if($choix_niv2 != ZenitySetup::$menu_enregistrement_entrees[3]) // si presta non vendue, saut étape 3/3 { if($input == '') // annulation { echo "debug: annulation lors de l'enregistrement des détails de la prestation\n"; - return(0); + return 0; } - elseif(isset($Details) && !$Details->hydrateFromForm($input, $Presta)) // echec de l'hydratation + elseif(isset($PrestaDetails) && !$PrestaDetails->hydrateFromForm($input, $Presta)) // echec de l'hydratation { echo "debug: erreur de hydrateFromForm()\n"; // messages d'erreur à mettre ici ou dans hydrateFromForm()? - return(0); + return 0; } unset($input); } @@ -167,7 +112,7 @@ function newService(): int // code de retour, si 0 retour menu principal, si 2 a //~ if(exec('echo $?') != 1) //~ { //~ echo "debug: annulation à la saisie d'un commentaire\n"; - //~ return(0); + //~ return 0; //~ } $Presta->setCommentaires($input); unset($input); @@ -175,53 +120,17 @@ function newService(): int // code de retour, si 0 retour menu principal, si 2 a $Presta->create(); $Presta->setID(); // sans paramètre, exécute un $this->db->lastInsertId() - if(isset($Details)) // presta non vendue + if(isset($PrestaDetails)) // presta non vendue { - $Details->setIDPresta($Presta->getID()); // d'un objet à l'autre - $Details->create(); - $Details->setID(); // sans paramètre, exécute un $this->db->lastInsertId() + $PrestaDetails->setIDPresta($Presta->getID()); // d'un objet à l'autre + $PrestaDetails->create(); + $PrestaDetails->setID(); // sans paramètre, exécute un $this->db->lastInsertId() } // -- partie 3: LaTeX -- - // document de la prestation - switch($choix_niv2) - { - case ZenitySetup::$menu_enregistrement_entrees[0]: // "Devis" - $type = 'devis'; - makeLatexAndPdfDocument($type, $Client, $Presta, $Details); - break; - case ZenitySetup::$menu_enregistrement_entrees[1]: // "Facture" - $type = 'facture'; - makeLatexAndPdfDocument($type, $Client, $Presta, $Details); - break; - case ZenitySetup::$menu_enregistrement_entrees[2]: // "CESU" - // pas de facture - break; - case ZenitySetup::$menu_enregistrement_entrees[3]: // "Location" - $type = 'location'; - makeLatexAndPdfDocument($type, $Client, $Presta, $Details); - break; - case ZenitySetup::$menu_enregistrement_entrees[4]: // "Prestation non vendue" - // pas de facture - break; - default: // inutile normallement, cas déjà géré avant - echo "debug: sortie du menu enregistrement incorrect\n"; - return(0); - } - - // enveloppe recto - $type = 'enveloppe_recto'; - makeLatexAndPdfDocument($type, $Client); - - // le verso ne dépend pas du client mais de l'entreprise, dans la classe Config - if(!file_exists(Config::$pdf_path . 'enveloppe_verso.pdf')) - { - $type = 'enveloppe_verso'; - makeLatexAndPdfDocument($type); - } - + makeLatexAndPdfDocument($Client, $Presta, $PrestaDetails); // -- partie 4: récapitulatif -- @@ -237,10 +146,10 @@ function newService(): int // code de retour, si 0 retour menu principal, si 2 a // zenityQuestion if(exec($QuestionModifierPrestation->get()) == '0') { - return(2); // section 2 + return 3; // section "Modifier un enregistrement" } else { - return(0); // menu principal + return 0; // menu principal } } -- cgit v1.2.3