diff --git a/historique.html b/historique.html
index 655c0ad..9a46aa9 100644
--- a/historique.html
+++ b/historique.html
@@ -42,6 +42,8 @@
Modification enregistrée
{{elseif $_GET.msg == "copie"}}
Mouvement copié
+ {{elseif $_GET.msg == "retour"}}
+ Retour enregistré
{{elseif $_GET.msg == "suppression"}}
Mouvement supprimé
{{/if}}
@@ -126,7 +128,7 @@
"" as 'Stock';
"" as 'Sorti';
"" as 'Disponible';
- $$.comment AS 'Commentaire'"
+ $$.comment AS 'Remarque'"
equipment=$equipment_key
order=1
}}
@@ -150,7 +152,14 @@
{{$comment}} |
{{if $current != "archives"}}
- {{:linkbutton
+ {{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"}}
+ {{/if}}
+ {{:linkbutton
label="Dupliquer"
href="mouvements/dupliquer_mouvement.html?key=%s&prop=%s"|args:$key:$_GET.prop
shape="plus"
@@ -179,7 +188,7 @@
$$.operation AS 'Opération';
$$.amount AS 'Quantité';
"" as 'Présent';
- $$.comment AS 'Commentaire'"
+ $$.comment AS 'Remarque'"
equipment=$equipment_key
order=1
}}
diff --git a/mouvements/return.html b/mouvements/return.html
new file mode 100644
index 0000000..b01217a
--- /dev/null
+++ b/mouvements/return.html
@@ -0,0 +1,146 @@
+{{* -*- brindille -*- *}}
+
+{{*
+ paramètres :
+ - key : clé du mouvement
+*}}
+
+{{* infos du mouvement *}}
+{{#load key=$_GET.key assign="mvt_new"}}
+{{else}}
+ {{:error message="Aucun mouvement avec la clé %s"|args:$_GET.key}}
+{{/load}}
+
+{{* infos du matériel associé *}}
+{{#load key=$mvt_new.equipment assign="equipment"}}
+{{else}}
+ {{:error message="Aucun matériel avec la clé « %s »"|args:$key}}
+{{/load}}
+
+{{* récupérer la config des entrées/sorties *}}
+{{:include file="../_get_config.html" keep="config"}}
+
+{{*
+ -------------------- Traiter la saisie --------------------
+*}}
+{{#form on="save"}}
+ {{* vérifier validité des données *}}
+ {{if $_POST.amount <= 0}}
+ {{: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}}
+
+ {{if $_POST.date|parse_date|strtotime > $now}}
+ {{:error message="Impossible de saisir une date dans le futur (%s)"|args:$_POST.date}}
+ {{/if}}
+
+ {{* préparer le nouveau mouvement *}}
+ {{:assign var="mvt_new.key" value=""|uuid}}
+ {{:assign var="mvt_new.direction" value="input"}}
+ {{:assign var="mvt_new.date" value=$_POST.date|parse_date}}
+ {{:assign var="mvt_new.operation" value=$_POST.operation}}
+ {{:assign var="mvt_new.amount" value=$_POST.amount}}
+
+ {{*
+ lister les mouvements
+ - insérer le nouveau mvt à sa place par date croissante
+ *}}
+ {{:assign insere=false}}
+ {{#load
+ where="
+ $$.type = 'movement'
+ AND
+ $$.equipment = :eqpmt_key"
+ :eqpmt_key=$equipment.key
+ order="$$.date"
+ assign="movement"
+ }}
+ {{if! $insere}}
+ {{if
+ $mvt_new.direction == "input" && $date >= $mvt_new.date ||
+ $mvt_new.direction == "output" && $date > $mvt_new.date
+ }}
+ {{:assign var="movements_new." from=mvt_new}}
+ {{:assign insere=true}}
+ {{/if}}
+ {{/if}}
+ {{:assign var="movements_new." from=movement}}
+ {{/load}}
+ {{if ! $insere}}
+ {{:assign var="movements_new." from=mvt_new}}
+ {{/if}}
+
+ {{* Vérifier la cohérence des mouvements du matériel *}}
+ {{:include
+ file="./valider_modification.html"
+ keep="erreur, pb"
+ movements=$movements_new
+ }}
+ {{if $erreur}}
+ Impossible d'enregistrer ce mouvement.
+ {{if $pb.mvt.key != $mvt_new.key}}
+ {{:assign var="err_mvt_label" from="config.input_nature.%s.label"|args:$pb.mvt.operation}}
+ Mouvement incompatible avec
+ « {{$err_mvt_label}} » : « {{$equipment.name}} (qté : {{$pb.mvt.amount}})
+ en date du {{$pb.mvt.date|date_short}} ».
+ {{/if}}
+
+ {{else}}
+ {{* vérification réussie : enregistrer le mouvement modifié *}}
+ {{:save
+ key=""|uuid
+ validate_schema="movement.schema.json"
+ type="movement"
+ direction="input"
+ operation=$_POST.operation
+ amount=$_POST.amount|intval
+ equipment=$equipment.key
+ date=$_POST.date|parse_date
+ comment=$_POST.comment|trim
+ }}
+ {{:redirect force="../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$mvt_new.equipment}}
+ {{/if}}
+{{/form}}
+
+{{:admin_header title="Retour de matériel" custom_css="./../../style.css" current="module_equipment"}}
+{{:form_errors}}
+
+{{* barre de navigation *}}
+{{if ! $dialog}}
+ {{:include file="../_nav.html" current="entrees"}}
+{{/if}}
+
+{{*
+ -------------------- Préparer la saisie --------------------
+*}}
+
+{{#foreach from=$config.input_nature key=key}}
+ {{if $type == "retour"}}
+ {{:assign var="return_label.%s"|args:$key value=$label}}
+ {{:break}}
+ {{/if}}
+{{/foreach}}
+
+{{* infos de la catégorie *}}
+{{#load key=$equipment.category assign="category"}}{{/load}}
+
+
+
+{{:admin_footer}}
|