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}} + +
+
+ Retour de « {{$equipment.name}} (Catégorie : {{$category.name}}) » +
+ {{: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="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false default=$mvt_new.comment}} +
+
+ +

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

+
+ +{{:admin_footer}}