From 8454c15225e6289923d432c2143e7dafb51181b6 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Mon, 21 Oct 2024 12:21:44 +0200 Subject: [PATCH] =?UTF-8?q?Correction=20bug=20incompatibilit=C3=A9=20sorti?= =?UTF-8?q?e=20mat=C3=A9riel?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- mouvements/sorties/emprunte.html | 77 +++++++++++--- mouvements/sorties/stock_disponible.html | 124 ++++++++++++++++------- 2 files changed, 149 insertions(+), 52 deletions(-) diff --git a/mouvements/sorties/emprunte.html b/mouvements/sorties/emprunte.html index 33869d1..f574b23 100644 --- a/mouvements/sorties/emprunte.html +++ b/mouvements/sorties/emprunte.html @@ -1,3 +1,5 @@ +{{* -*- brindille -*- *}} + {{:admin_header title="Sortie de matériel" current="module_equipment"}} {{if ! $dialog}} @@ -23,19 +25,65 @@ {{:assign var="category_keys." value=$equipment.category}} {{/load}} - {{* Extraire et compiler les infos de la base *}} - {{:include - file="../../_calcul_dispo.html" - keep="cumul_mvt" - date=$_POST.date|parse_date - }} + {{:assign stock=0}} + {{:assign exterieur=0}} + {{:assign nonproprio=0}} + {{:assign insere=false}} - {{* déterminer la quantité présente de ce matériel à la date donnée *}} - {{:assign var=present from="cumul_mvt.%s.eqpmt.%s.nonproprio"|args:$equipment.category:$_POST.equipment}} + {{* lister tous les mouvements du matériel *}} + {{#load type="movement" where="$$.equipment = '%s'"|args:$_POST.equipment assign="mvt" order="$$.date ASC"}} - {{if $_POST.quantite|intval > $present}} - {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle présente (%d) à la date du %s"|args:$_POST.quantite:$present:$_POST.date}} - {{/if}} + {{* traiter le nouveau mouvement *}} + {{if ! $insere && $mvt.date > $_POST.date|parse_date}} + {{:assign var="operation" from="output_labels.%s|args:$_POST.type_operation}} + {{:assign var="type_mvt" from="config.output_nature.%s"|args:$operation}} + {{:assign dispo_old=$nonproprio}} + + {{if $type_mvt == 'définitif'}} + {{:assign stock="%d-%d"|math:$stock:$_POST.quantite}} + {{elseif $type_mvt == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$_POST.quantite}} + {{elseif $type_mvt == 'retour'}} + {{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}} + {{/if}} + + {{:assign insere=true}} + {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + + {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}} + {{:assign date_err=$_POST.date|date:"d/m/Y"}} + {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle disponible (%d) à la date du %s"|args:$_POST.quantite:$dispo_old:$date_err}} + {{/if}} + {{/if}} + + {{* traiter le mouvement courant *}} + {{:assign var="mvt_nature" from="mvt.%s_nature"|args:$mvt.direction}} + {{:assign var="type_mvt" from="config.%s_nature.%s"|args:$mvt.direction:$mvt_nature}} + + {{if $mvt.direction === 'input'}} + {{if $type_mvt == 'définitif'}} + {{:assign stock="%d+%d"|math:$stock:$mvt.amount}} + {{elseif $type_mvt == 'retour'}} + {{:assign exterieur="%d-%d"|math:$exterieur:$mvt.amount}} + {{elseif $type_mvt == 'temporaire'}} + {{:assign nonproprio="%d+%d"|math:$nonproprio:$mvt.amount}} + {{/if}} + {{elseif $mvt.direction === 'output'}} + {{if $type_mvt == 'définitif'}} + {{:assign stock="%d-%d"|math:$stock:$mvt.amount}} + {{elseif $type_mvt == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$mvt.amount}} + {{elseif $type_mvt == 'retour'}} + {{:assign nonproprio="%d-%d"|math:$nonproprio:$mvt.amount}} + {{/if}} + {{/if}} + + {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}} + {{:assign date_err=$mvt.date|date:"d/m/Y"}} + {{:error message="Erreur : la quantité indiquée (%s) est incompatible avec la sortie « %s : %s » à la date du %s"|args:$_POST.quantite:$designation:$mvt.amount:$date_err}} + {{/if}} + {{/load}} {{* Enregistrer le mouvement *}} @@ -68,7 +116,7 @@ {{* formulaire de sortie de matériel *}}
- Ajouter une sortie d'un matériel disponible en stock + Ajouter une sortie d'un matériel présent temporairement
{{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}} {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} @@ -77,7 +125,7 @@
Matériel -

La quantité disponible est celle à la date du jour

+

La quantité indiquée est celle à la date du jour

{{:input type="select_groups" name="equipment" label="Matériel" required=true options=$temporaire onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} @@ -88,7 +136,8 @@

{{else}} -

Il n'y a aucun matériel présent temporairement

+ {{:assign date_err=$now|date:'d/m/Y'}} +

Il n'y a aucun matériel présent temporairement à la date du {{$date_err}}

{{/if}} {{else}}

Il n'y a aucun matériel en stock

diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 5ff4d68..0f955d3 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -1,3 +1,5 @@ +{{* -*- brindille -*- *}} + {{:admin_header title="Sortie de matériel" current="module_equipment"}} {{if ! $dialog}} @@ -23,21 +25,65 @@ {{:assign var="category_keys." value=$equipment.category}} {{/load}} - {{* Extraire et compiler les infos de la base *}} - {{:include - file="../../_calcul_dispo.html" - keep="cumul_mvt" - date=$_POST.date|parse_date - }} + {{:assign stock=0}} + {{:assign exterieur=0}} + {{:assign nonproprio=0}} + {{:assign insere=false}} - {{* déterminer la quantité disponible de ce matériel à la date donnée *}} - {{:assign var=stock from="cumul_mvt.%s.eqpmt.%s.stock"|args:$equipment.category:$_POST.equipment}} - {{:assign var=exterieur from="cumul_mvt.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_POST.equipment}} - {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + {{* lister tous les mouvements du matériel *}} + {{#load type="movement" where="$$.equipment = '%s'"|args:$_POST.equipment assign="mvt" order="$$.date ASC"}} - {{if $_POST.quantite|intval > $dispo}} - {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle disponible (%d) à la date du %s"|args:$_POST.quantite:$dispo:$_POST.date}} - {{/if}} + {{* traiter le nouveau mouvement *}} + {{if ! $insere && $mvt.date > $_POST.date|parse_date}} + {{:assign var="operation" from="output_labels.%s|args:$_POST.type_operation}} + {{:assign var="type_mvt" from="config.output_nature.%s"|args:$operation}} + {{:assign dispo_old="%d-%d"|math:$stock:$exterieur}} + + {{if $type_mvt == 'définitif'}} + {{:assign stock="%d-%d"|math:$stock:$_POST.quantite}} + {{elseif $type_mvt == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$_POST.quantite}} + {{elseif $type_mvt == 'retour'}} + {{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}} + {{/if}} + + {{:assign insere=true}} + {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + + {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}} + {{:assign date_err=$_POST.date|date:"d/m/Y"}} + {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle disponible (%d) à la date du %s"|args:$_POST.quantite:$dispo_old:$date_err}} + {{/if}} + {{/if}} + + {{* traiter le mouvement courant *}} + {{:assign var="mvt_nature" from="mvt.%s_nature"|args:$mvt.direction}} + {{:assign var="type_mvt" from="config.%s_nature.%s"|args:$mvt.direction:$mvt_nature}} + + {{if $mvt.direction === 'input'}} + {{if $type_mvt == 'définitif'}} + {{:assign stock="%d+%d"|math:$stock:$mvt.amount}} + {{elseif $type_mvt == 'retour'}} + {{:assign exterieur="%d-%d"|math:$exterieur:$mvt.amount}} + {{elseif $type_mvt == 'temporaire'}} + {{:assign nonproprio="%d+%d"|math:$nonproprio:$mvt.amount}} + {{/if}} + {{elseif $mvt.direction === 'output'}} + {{if $type_mvt == 'définitif'}} + {{:assign stock="%d-%d"|math:$stock:$mvt.amount}} + {{elseif $type_mvt == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$mvt.amount}} + {{elseif $type_mvt == 'retour'}} + {{:assign nonproprio="%d-%d"|math:$nonproprio:$mvt.amount}} + {{/if}} + {{/if}} + + {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}} + {{:assign date_err=$mvt.date|date:"d/m/Y"}} + {{:error message="Erreur : la quantité indiquée (%s) est incompatible avec la sortie « %s : %s » à la date du %s"|args:$_POST.quantite:$designation:$mvt.amount:$date_err}} + {{/if}} + {{/load}} {{* Enregistrer le mouvement *}} @@ -75,32 +121,34 @@ {{/if}} {{/foreach}} {{/foreach}} - {{if $disponibilites === null}} - {{:error message="Le matériel choisi (%s) n'est pas présent à la date du %s"|args:$designation:$_POST.date}} - {{/if}} - {{* formulaire de sortie de matériel *}} -
-
- Ajouter une sortie d'un matériel disponible en stock -
- {{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}} - {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} - {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} -
-
-
- Matériel -

La quantité disponible est celle à la date du jour

-
- {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$disponibilites onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} - {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} -
-
-

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

-
+ {{if $disponibilites != null}} + {{* formulaire de sortie de matériel *}} +
+
+ Ajouter une sortie d'un matériel disponible en stock +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}} + {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} + {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} +
+
+
+ Matériel +

La quantité indiquée est celle à la date du jour

+
+ {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$disponibilites onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} + {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} +
+
+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

+
+ {{else}} + {{:assign date_err=$now|date:'d/m/Y'}} +

Il n'y a aucun matériel disponible à la date du {{$date_err}}

+ {{/if}} {{else}}

Il n'y a aucun matériel en stock

{{/if}}