From 144a909494f7e05c670fc01cb046fed1f022857a Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Thu, 20 Mar 2025 17:15:18 +0100 Subject: [PATCH] ajout liaison entre sortie temporaire et retour --- historique.html | 39 +++++++++++++++--- inventaire.html | 7 ---- .../{return.html => output_return.html} | 41 +++++++++++++++++-- mouvements/supprimer_mouvement.html | 39 +++++------------- 4 files changed, 81 insertions(+), 45 deletions(-) rename mouvements/{return.html => output_return.html} (78%) diff --git a/historique.html b/historique.html index 9a46aa9..d218d06 100644 --- a/historique.html +++ b/historique.html @@ -85,6 +85,32 @@ {{/if}} {{/foreach}} +{{* calculer la quantité restant à l'extérieur de chaque matériel *}} +{{#foreach from=$config.output_nature key=key}} + {{if $type == "temporaire"}} + {{:assign var="temp_outputs." value=$key|quote_sql}} + {{/if}} +{{/foreach}} +{{:assign operations=$temp_outputs|implode:","}} +{{:assign operations="("|cat:$operations|cat:")"}} + +{{#select + mvt.key AS mvt_key, + json_extract(mvt.document, '$.amount') - IFNULL(SUM(json_extract(mvt2.document, '$.amount')), 0) AS reste + FROM module_data_equipment AS mvt + LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.output') + LEFT JOIN module_data_equipment AS mvt2 ON mvt2.key = json_extract(link.document, '$.return') + WHERE + json_extract(mvt.document, '$.operation') IN !op + AND json_extract(mvt.document, '$.equipment') = :eqpmt_key + GROUP by mvt.key + ; + !op = $operations + :eqpmt_key = $_GET.key +}} + {{:assign var="reste.%s"|args:$mvt_key value=$reste}} +{{/select}} + {{* calculer et mémoriser les quantités pour que le tri de la liste affiche les valeurs correctes *}} {{:assign stock=0}} {{:assign exterieur=0}} @@ -153,11 +179,14 @@ {{if $current != "archives"}} {{if $direction == "output" && $type_mvt == "temporaire"}} - {{:linkbutton - label="Retour" - href="mouvements/return.html?key=%s&prop=%s"|args:$key:$_GET.prop - shape="history" - target="_dialog"}} + {{:assign var="ext" from="reste.%s"|args:$key}} + {{if $ext != null && $ext > 0}} + {{:linkbutton + label="Retour" + href="mouvements/output_return.html?key=%s&prop=%s"|args:$key:$_GET.prop + shape="history" + target="_dialog"}} + {{/if}} {{/if}} {{:linkbutton label="Dupliquer" diff --git a/inventaire.html b/inventaire.html index 7cc58bf..14f2253 100644 --- a/inventaire.html +++ b/inventaire.html @@ -157,13 +157,6 @@ {{$col4}} {{$col5}} - {{if $col4 > 0}} - {{:linkbutton - label="Retour" - href="mouvements/entrees/retour.html?key=%s"|args:$key - shape="history" - target="_dialog"}} - {{/if}} {{if $col5 > 0}} {{:linkbutton label="Sortie" diff --git a/mouvements/return.html b/mouvements/output_return.html similarity index 78% rename from mouvements/return.html rename to mouvements/output_return.html index b01217a..15f122c 100644 --- a/mouvements/return.html +++ b/mouvements/output_return.html @@ -20,6 +20,31 @@ {{* récupérer la config des entrées/sorties *}} {{:include file="../_get_config.html" keep="config"}} +{{* calculer la quantité sortie *}} +{{#foreach from=$config.output_nature key=key}} + {{if $type == "temporaire"}} + {{:assign var="temp_outputs." value=$key|quote_sql}} + {{/if}} +{{/foreach}} +{{:assign operations=$temp_outputs|implode:","}} +{{:assign operations="("|cat:$operations|cat:")"}} + +{{#select + json_extract(mvt.document, '$.amount') - IFNULL(SUM(json_extract(mvt2.document, '$.amount')), 0) AS exterieur + FROM module_data_equipment AS mvt + LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.output') + LEFT JOIN module_data_equipment AS mvt2 ON mvt2.key = json_extract(link.document, '$.return') + WHERE + json_extract(mvt.document, '$.operation') IN !op + AND mvt.key = :mvt_key + GROUP by mvt.key + ; + !op = $operations + :mvt_key = $_GET.key + }} + {{:assign exterieur=$exterieur}} +{{/select}} + {{* -------------------- Traiter la saisie -------------------- *}} @@ -29,8 +54,8 @@ {{:error message="La quantité (%s) doit être strictement positive !!"|args:$_POST.amount}} {{/if}} - {{if $_POST.amount > $mvt_new.amount}} - {{:error message="La quantité (%s) doit être inférieure à la quantité sortie (%s) !!"|args:$_POST.amount:$mvt_new.amount}} + {{if $_POST.amount > $exterieur}} + {{:error message="La quantité (%s) doit être inférieure à la quantité sortie (%s) !!"|args:$_POST.amount:$exterieur}} {{/if}} {{if $_POST.date|parse_date|strtotime > $now}} @@ -90,8 +115,9 @@

{{else}} {{* vérification réussie : enregistrer le mouvement modifié *}} + {{:assign mvt_key=""|uuid}} {{:save - key=""|uuid + key=$mvt_key validate_schema="movement.schema.json" type="movement" direction="input" @@ -101,6 +127,13 @@ date=$_POST.date|parse_date comment=$_POST.comment|trim }} + {{* enregistrer la liaison entre le retour et la sortie temporaire *}} + {{:save + key=""|uuid + type="link" + output=$_GET.key + return=$mvt_key + }} {{:redirect force="../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$mvt_new.equipment}} {{/if}} {{/form}} @@ -133,7 +166,7 @@
{{:input type="select" name="operation" label="Type" required=true options=$return_label}} {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} - {{:input type="number" name="amount" label="Quantité" min=1 max=$mvt_new.amount required=true default=$mvt_new.amount}} + {{:input type="number" name="amount" label="Quantité" min=1 max=$exterieur required=true default=$exterieur}} {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false default=$mvt_new.comment}}
diff --git a/mouvements/supprimer_mouvement.html b/mouvements/supprimer_mouvement.html index 75c63c2..496a7d7 100644 --- a/mouvements/supprimer_mouvement.html +++ b/mouvements/supprimer_mouvement.html @@ -22,6 +22,10 @@ {{#form on="delete"}} + {{#load type="link" where="$$.output = :key OR $$.return = :key" :key=$_GET.key}} + {{:assign link_key=$key}} + {{/load}} + {{* vérifier s'il est possible de supprimer le mouvement *}} {{if $mvt_suppr.direction == 'input'}} {{:assign dispo=0}} @@ -62,43 +66,20 @@ {{else}} {{* sortie *}} - {{:assign temporaire=false}} {{:assign var="type_operation" from="config.output_nature.%s.type"|args:$mvt_suppr.operation}} {{if $type_operation == 'temporaire'}} - {{:assign exterieur=0}} - {{#load - type="movement" - where="$$.equipment = :key" :key=$mvt_suppr.equipment - assign="mvt" - order="$$.date"}} - - {{* déterminer le type de mouvement *}} - {{:assign var="type_mvt" from="config.%s_nature.%s.type"|args:$mvt.direction:$mvt.operation}} - - {{if $key != $_GET.key}} - {{* ce n'est pas le mouvement à supprimer : cumuler les entrées/sorties *}} - {{if $mvt.direction == 'input'}} - {{if $type_mvt == 'retour'}} - {{:assign exterieur="%d-%d"|math:$exterieur:$mvt.amount}} - {{/if}} - {{elseif $mvt.direction == 'output'}} - {{if $type_mvt == 'temporaire'}} - {{:assign exterieur="%d+%d"|math:$exterieur:$mvt.amount}} - {{/if}} - {{/if}} - - {{* problème ? *}} - {{if $exterieur < 0}} - {{:redirect force="../historique.html?key=%s&prop=%s&err=1&msg=suppression"|args:$mvt_suppr.equipment:$_GET.prop}} - {{/if}} - {{/if}} - {{/load}} + {{if $link_key != null}} + {{:redirect force="../historique.html?key=%s&prop=%s&err=1&msg=suppression"|args:$mvt_suppr.equipment:$_GET.prop}} + {{/if}} {{/if}} {{/if}} {{* vérification réussie : supprimer le mouvement *}} {{:delete key=$_GET.key}} + {{if $link_key != null}} + {{:delete key=$link_key}} + {{/if}} {{* voir s'il reste des mouvements pour le matériel concerné par le mouvement supprimé *}} {{#load type="movement" where="$$.equipment = :eqpmt_key" :eqpmt_key=$equipment.key}}