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}}
|