From a4d88fd1913758cc95b395eefcf5e9d730450382 Mon Sep 17 00:00:00 2001 From: polo Date: Sat, 23 Dec 2023 10:00:24 +0100 Subject: =?UTF-8?q?devis=20payant,=20cr=C3=A9er=20devis=20depuis=20facture?= =?UTF-8?q?,=20changement=20dans=20getIDsByIdClient(),=20suppression=20d?= =?UTF-8?q?=C3=A9pendance=20paquet=20latex=20"ulem",=20(string)=20dans=20s?= =?UTF-8?q?etTelephone()?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/sections/1_customer.php | 14 ++--- src/sections/2_service.php | 118 ++++++++++++++++++++++------------------- src/sections/3-1_windows.php | 2 +- src/sections/3_modify_data.php | 39 +++++++------- 4 files changed, 89 insertions(+), 84 deletions(-) (limited to 'src/sections') diff --git a/src/sections/1_customer.php b/src/sections/1_customer.php index ca20d08..ae8067f 100644 --- a/src/sections/1_customer.php +++ b/src/sections/1_customer.php @@ -6,19 +6,19 @@ function newCustomer(): array { // fenêtres - $TypeDeClient = new ZenityList(ZenitySetup::$type_client_text, ZenitySetup::$type_client_entrees); + $TypeDeClient = new ZenityList(ZenitySetup::$type_client['text'], ZenitySetup::$type_client['entrees']); //~ $NouveauClient = new ZenityForms(ZenitySetup::$nouveau_client_text, ZenitySetup::$nouveau_client_entrees); - $FinSection1 = new ZenityList(ZenitySetup::$fin_section_1_text, ZenitySetup::$fin_section_1_entrees); + $FinSection1 = new ZenityList(ZenitySetup::$fin_section_1['text'], ZenitySetup::$fin_section_1['entrees']); // -- partie 1: client ou prospect? -- $Client = new Clients; $choix_niv2 = exec($TypeDeClient->get()); - if($choix_niv2 === ZenitySetup::$type_client_entrees[0]) + if($choix_niv2 === ZenitySetup::$type_client['entrees'][0]) { echo "choix: " . $choix_niv2 . "\n"; $Client->setType('client'); } - elseif($choix_niv2 === ZenitySetup::$type_client_entrees[1]) + elseif($choix_niv2 === ZenitySetup::$type_client['entrees'][1]) { echo "choix: " . $choix_niv2 . "\n"; $Client->setType('prospect'); @@ -33,15 +33,15 @@ function newCustomer(): array { // -- partie 3: on fait quoi maintenant -- $choix_niv3 = exec($FinSection1->get()); - if($choix_niv3 === ZenitySetup::$fin_section_1_entrees[0]) + if($choix_niv3 === ZenitySetup::$fin_section_1['entrees'][0]) { return [2, $Client]; // section 2: newService() } - elseif($choix_niv3 === ZenitySetup::$fin_section_1_entrees[1]) + elseif($choix_niv3 === ZenitySetup::$fin_section_1['entrees'][1]) { return [3, $Client]; // section 3: modifyData() } - elseif($choix_niv3 === ZenitySetup::$fin_section_1_entrees[2]) + elseif($choix_niv3 === ZenitySetup::$fin_section_1['entrees'][2]) { return [1, null]; // relancer section 1: newCustomer() } diff --git a/src/sections/2_service.php b/src/sections/2_service.php index 1d58606..9683ef9 100644 --- a/src/sections/2_service.php +++ b/src/sections/2_service.php @@ -8,13 +8,14 @@ function newService($Client): array // $Client est un Client ou null // fenêtres $MenuEnregistrement = new ZenityList(ZenitySetup::$menu_enregistrement_text, ZenitySetup::$menu_enregistrement_entrees); $Calendrier = new ZenityCalendar(ZenitySetup::$calendar['section2']); - $FormulaireDevis = new ZenityForms(ZenitySetup::$formulaire_text, ZenitySetup::$formulaire_devis_entrees); - $FormulaireFacture = new ZenityForms(ZenitySetup::$formulaire_text, ZenitySetup::$formulaire_facture_entrees); - $FormulaireCesu = new ZenityForms(ZenitySetup::$formulaire_text, ZenitySetup::$formulaire_cesu_entrees); - $FormulaireLocation = new ZenityForms(ZenitySetup::$formulaire_text, ZenitySetup::$formulaire_location_entrees); + $FormulaireDevis = new ZenityForms(ZenitySetup::$formulaire['text'], ZenitySetup::$formulaire['devis_entrees']); + $FormulaireFacture = new ZenityForms(ZenitySetup::$formulaire['text'], ZenitySetup::$formulaire['facture_entrees']); + $FormulaireFactureReduit = new ZenityForms(ZenitySetup::$formulaire['text'], ZenitySetup::$formulaire['facture_entrees_reduit']); + $FormulaireCesu = new ZenityForms(ZenitySetup::$formulaire['text'], ZenitySetup::$formulaire['cesu_entrees']); + $FormulaireLocation = new ZenityForms(ZenitySetup::$formulaire['text'], ZenitySetup::$formulaire['location_entrees']); $CommentairePrestation = new ZenityEntry(ZenitySetup::$commentaire_prestation_text); //$Recapitulatif = new ZenityList(ZenitySetup::$recapitulatif_text, ZenitySetup::$recapitulatif_entrees); // tableau à multiples colonnes - $FinSection2 = new ZenityList(ZenitySetup::$fin_section_2_text, ZenitySetup::$fin_section_2_entrees); + $FinSection2 = new ZenityList(ZenitySetup::$fin_section_2['text'], ZenitySetup::$fin_section_2['entrees']); // -- partie 1: le client -- @@ -57,44 +58,38 @@ function newService($Client): array // $Client est un Client ou null case ZenitySetup::$menu_enregistrement_entrees[0]: // "Devis" $PrestaDetails = new DevisFactures('devis'); $Presta->setTypePresta('devis'); - $input = exec($FormulaireDevis->get()); + $answers = exec($FormulaireDevis->get()); break; case ZenitySetup::$menu_enregistrement_entrees[1]: // "Facture" + $PrestaDetails = new DevisFactures('factures'); // attention! type "facture" mais table "factures" + $Presta->setTypePresta('facture'); + $answers = exec($FormulaireFacture->get()); + break; + case ZenitySetup::$menu_enregistrement_entrees[2]: // "Facture à partir d'un devis" + // recherche du devis + $Quotation = getServices($Client, 'devis'); // rechercher un devis, type 'devis' spécifié pour $Presta->getIDsByIdClient() + if(!is_object($Quotation) || get_class($Quotation) != 'Prestations' || $Quotation->getTypePresta() != 'devis') + { + echo "debug: annulation sélection client\n"; + return [2, $Client]; // menu précédent + } + $QuotationDetails = new DevisFactures('devis'); + // facture: objet vide et formulaire $PrestaDetails = new DevisFactures('factures'); $Presta->setTypePresta('facture'); - $input =exec($FormulaireFacture->get()); + $answers = exec($FormulaireFactureReduit->get()); + //$answers = '' + answers[0], answers[1], answers[2], answers[3], '', '', '', '', '', answers[4]; + //var_dump($answers); break; - - //~ case ZenitySetup::$menu_enregistrement_entrees[2]: // "Facture à partir d'un devis" - //~ $PrestaDetails = new DevisFactures('facture'); - //~ $Presta->setTypePresta('facture'); - // 1 choix d'un devis - //makeObjectService(); // liste les devis existants pour ce client - // - // 2 hydratation - // - // 3 préremplissage du formulaire - //$FormulaireFacture->set($Data) - // - // et plus loin: - // 4 édition de la facture - //$input = exec($FormulaireFacture->get()); - // - // 5 hydratation avec les changements - // - //echo $FormulaireFacture->get() . "\n"; - //~ $input = exec($FormulaireFacture->get()); - //~ break; - case ZenitySetup::$menu_enregistrement_entrees[3]: // "CESU" $PrestaDetails = new CESU(); $Presta->setTypePresta('cesu'); - $input = exec($FormulaireCesu->get()); + $answers = exec($FormulaireCesu->get()); break; case ZenitySetup::$menu_enregistrement_entrees[4]: // "Location" $PrestaDetails = new Locations(); $Presta->setTypePresta('location'); - $input = exec($FormulaireLocation->get()); + $answers = exec($FormulaireLocation->get()); break; case ZenitySetup::$menu_enregistrement_entrees[5]: // "Prestation non vendue" $Presta->setTypePresta('non_vendue'); @@ -106,28 +101,12 @@ function newService($Client): array // $Client est un Client ou null $Presta->makeCodePresta($Date, $Client->getCodeClient()); // d'un objet à l'autre - // hydratation ou saut étape 3/3 si presta non vendu - if($choix_niv2 != ZenitySetup::$menu_enregistrement_entrees[5]) - { - if($input == '') // annulation - { - echo "debug: annulation lors de l'enregistrement des détails de la prestation\n"; - return [0, null]; - } - 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, null]; - } - unset($input); - } - // commentaire - étape 3/3 - $input = exec($CommentairePrestation->get()); - if($input == '') + $comment = exec($CommentairePrestation->get()); + if($comment == '') { echo "debug: pas de commentaire saisi\n"; - // on n'interrompt pas le script et on enregistre dans tous les cas (annulatation, chaîne vide) + // on n'interrompt pas le script et on enregistre dans tous les cas (annulatation comprise) } // Cliquer sur annuler (ou appuyer sur échap) revient dont à valider avec une chaîne vide et enregistrer la prestation // la commande 'echo $?' ($? est le code de sortie de la commande précédente) renvoit 1 si on annule avec la touche échap () @@ -140,13 +119,39 @@ function newService($Client): array // $Client est un Client ou null //~ echo "debug: annulation à la saisie d'un commentaire\n"; //~ return 0; //~ } - $Presta->setCommentaires($input); - unset($input); + $Presta->setCommentaires($comment); + + // hydratation d'une facture à partir d'un devis + if($choix_niv2 === ZenitySetup::$menu_enregistrement_entrees[2]) // cas: facture à partir d'un devis + { + // devis retrouvé ($Quotation est déjà hydraté) + $QuotationDetails->setIDPresta($Quotation->getID()); + $QuotationDetails->hydrate($QuotationDetails->getDetailsByIdPresta()); + + // facture avec le devis + $QuotationDetails->hydrateReceiptWithQuotation($PrestaDetails); + } + + // hydratation avec la saisie du formulaire + if($choix_niv2 != ZenitySetup::$menu_enregistrement_entrees[5]) // cas: tous les cas sauf presta non vendue + { + if($answers == '') // annulation + { + echo "debug: annulation lors de l'enregistrement des détails de la prestation\n"; + return [0, null]; + } + elseif(isset($PrestaDetails) && !$PrestaDetails->hydrateFromForm($answers, $Presta)) // echec de l'hydratation + { + echo "debug: erreur de hydrateFromForm()\n"; // messages d'erreur à mettre ici ou dans hydrateFromForm()? + return [0, null]; + } + } + // mise à jour base de données $Presta->create(); $Presta->setID(); // sans paramètre, exécute un $this->db->lastInsertId() - if(isset($PrestaDetails)) // presta non vendue + if(isset($PrestaDetails)) // presta vendue { $PrestaDetails->setIDPresta($Presta->getID()); // d'un objet à l'autre $PrestaDetails->create(); @@ -210,18 +215,19 @@ function newService($Client): array // $Client est un Client ou null //~ $imprimer_facture = exec('zenity --question --width=250 --title="Base de données mise à jour" --text="Imprimer la facture?"'); //~ $imprimer_enveloppe = exec('zenity --question --width=250 --title="Base de données mise à jour" --text="Imprimer l\'adresse sur une enveloppe? (insérer une enveloppe DL sans fenêtre dans l\'imprimante"'); + // ? modifications avec le menu de la section 3 obtenu avec makeModifyCustomerWindow() // -- partie 5: on fait quoi maintenant -- $choix_niv2 = exec($FinSection2->get()); - if($choix_niv2 === ZenitySetup::$fin_section_2_entrees[0]) + if($choix_niv2 === ZenitySetup::$fin_section_2['entrees'][0]) // afficher le document { return [4, null]; // section 4: getDocument() } - elseif($choix_niv2 === ZenitySetup::$fin_section_2_entrees[1]) + elseif($choix_niv2 === ZenitySetup::$fin_section_2['entrees'][1]) // modifier les informations { return [3, $Client]; // section 3: modifyData() } - elseif($choix_niv2 === ZenitySetup::$fin_section_2_entrees[2]) + elseif($choix_niv2 === ZenitySetup::$fin_section_2['entrees'][2]) // enregistrer une autre prestation { return [2, null]; // relancer section 2: newService() } diff --git a/src/sections/3-1_windows.php b/src/sections/3-1_windows.php index 7952f6d..7e7367b 100644 --- a/src/sections/3-1_windows.php +++ b/src/sections/3-1_windows.php @@ -55,7 +55,7 @@ function makeModifyServiceWindow(Prestations $Service, $ServiceDetails = null): if($Service->getTypePresta() === 'devis') { - $entrees[$i][] = ZenitySetup::$modification_presta['devis_facture']; // option changer le devis en facture + $entrees[$i][] = ZenitySetup::$modification_presta['devis_facture']; // option créer une facture à partir du devis $entrees[$i][] = ''; //~ $i++; } diff --git a/src/sections/3_modify_data.php b/src/sections/3_modify_data.php index 5da7ed9..0a67cea 100644 --- a/src/sections/3_modify_data.php +++ b/src/sections/3_modify_data.php @@ -7,6 +7,11 @@ require('3-1_windows.php'); function modifyData($Client): array { + // fenêtres fixes + $TypeDeClient = new ZenityList(ZenitySetup::$type_client['text'], ZenitySetup::$type_client['entrees']); + $Calendrier = new ZenityCalendar(ZenitySetup::$calendar['section3']); + + // -- partie 1: rechercher un client -- if($Client == null || get_class($Client) !== 'Clients') // étape sautable { @@ -25,22 +30,21 @@ function modifyData($Client): array $ModificationClientMenu = makeModifyCustomerWindow($Client); $choix_niv2 = exec($ModificationClientMenu->get()); - if($choix_niv2 === ZenitySetup::$modification_client['service']) // ne pas modifier le client mais une prestation + if($choix_niv2 === ZenitySetup::$modification_client['service']) // clic sur "Modifier une prestation" { echo "choix: modifier une prestation\n"; - // on passe à la suite + // ne rien faire dans cette partie et passer à la suite } - elseif($choix_niv2 === "Client ou Prospect?") // modifier type de client + elseif($choix_niv2 === "Client ou Prospect?") { echo "choix: modifier" . $choix_niv2 . "\n"; - $TypeDeClient = new ZenityList(ZenitySetup::$type_client_text, ZenitySetup::$type_client_entrees); $input = exec($TypeDeClient->get()); - if($input === ZenitySetup::$type_client_entrees[0]) + if($input === ZenitySetup::$type_client['entrees'][0]) { echo "choix: " . $input . "\n"; $Client->setType('client'); } - elseif($input === ZenitySetup::$type_client_entrees[1]) + elseif($input === ZenitySetup::$type_client['entrees'][1]) { echo "choix: " . $input . "\n"; $Client->setType('prospect'); @@ -52,7 +56,7 @@ function modifyData($Client): array $Client->update(); return [3, $Client]; // menu précédent } - elseif(is_string($choix_niv2) && $choix_niv2 != '') // modifier une valeur + elseif(is_string($choix_niv2) && $choix_niv2 != '') // autres choix, modifier une valeur { echo "choix: modifier" . $choix_niv2 . "\n"; $ModificationClient = new ZenityEntry($choix_niv2); @@ -74,7 +78,7 @@ function modifyData($Client): array } return [3, $Client]; // menu précédent } - else // annuler + else { echo "annulation: retour au menu principal\n"; return [0, null]; // menu principal @@ -95,7 +99,6 @@ function modifyData($Client): array case 'facture': $PrestaDetails = new DevisFactures('factures'); break; - case 'devis': $PrestaDetails = new DevisFactures('devis'); break; @@ -122,16 +125,13 @@ function modifyData($Client): array $ModificationPrestaMenu = makeModifyServiceWindow($Presta, $PrestaDetails); $choix_niv3 = exec($ModificationPrestaMenu->get()); - if($choix_niv3 === ZenitySetup::$modification_presta['devis_facture']) // devis -> facture - { - echo "choix: changer un devis en facture\n"; - return [3, $Client]; // menu "client" - } - elseif($choix_niv3 === 'Date:') + //~ if($choix_niv3 === ZenitySetup::$modification_presta['devis_facture']) // devis -> facture + //~ { + //~ echo "choix: changer un devis en facture\n"; + //~ return [2, $Client]; // menu "client" + //~ } + if($choix_niv3 === 'Date:') { - // fenêtre - $Calendrier = new ZenityCalendar(ZenitySetup::$calendar['section3']); - $Date = new Dates(exec($Calendrier->get())); // exec() renvoie soit une chaîne soit un false if($Date->getDate() == '') // clic sur "annuler", touche "échap" { @@ -157,7 +157,7 @@ function modifyData($Client): array } //~ elseif($choix_niv3 === 'Type de Presta:') // choix impossible pour le moment //~ { - //~ echo "choix: Impossible de modifier le type de prestation\n"; + //~ echo "choix: changer le type de prestation (devis, facture, etc)\n"; //~ return [3, $Client]; // menu "client" //~ } elseif(is_string($choix_niv3) && $choix_niv3 != '') // modifier une valeur @@ -179,7 +179,6 @@ function modifyData($Client): array } // mettre à jour les documents - //$type = $Presta->getTypePresta(); if($type === 'devis' || $type === 'facture' || $type === 'location') { $DocumentPresta = Latex::makeInstance($type); -- cgit v1.2.3