From 95db394d7a7bbd2afe4de9da85018e9b904714fd Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Thu, 6 Mar 2025 13:27:37 +0100 Subject: [PATCH 1/5] Bouton retour dans historique --- historique.html | 15 ++++- mouvements/return.html | 146 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 158 insertions(+), 3 deletions(-) create mode 100644 mouvements/return.html 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}} From 144a909494f7e05c670fc01cb046fed1f022857a Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Thu, 20 Mar 2025 17:15:18 +0100 Subject: [PATCH 2/5] 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}} From ce87720d41bcb6baca4d1376cd155fec5377c36c Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Fri, 21 Mar 2025 14:58:52 +0100 Subject: [PATCH 3/5] =?UTF-8?q?ajout=20liaison=20entre=20entr=C3=A9e=20tem?= =?UTF-8?q?poraire=20et=20retour?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- historique.html | 99 ++++++++++----- inventaire_nonprop.html | 7 -- mouvements/input_return.html | 181 ++++++++++++++++++++++++++++ mouvements/link.schema.json | 23 ++++ mouvements/output_return.html | 4 +- mouvements/supprimer_mouvement.html | 85 +++++++------ 6 files changed, 322 insertions(+), 77 deletions(-) create mode 100644 mouvements/input_return.html create mode 100644 mouvements/link.schema.json diff --git a/historique.html b/historique.html index d218d06..39311a6 100644 --- a/historique.html +++ b/historique.html @@ -85,32 +85,6 @@ {{/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}} @@ -145,6 +119,32 @@ {{* lister tous les mouvements du matériel passé en paramètre *}} {{if $_GET.prop}} + {{* calculer la quantité temporairement 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}} + {{#list type="movement" select="$$.date AS 'Date'; @@ -154,7 +154,7 @@ "" as 'Stock'; "" as 'Sorti'; "" as 'Disponible'; - $$.comment AS 'Remarque'" + $$.comment AS 'Commentaire'" equipment=$equipment_key order=1 }} @@ -179,8 +179,8 @@ {{if $current != "archives"}} {{if $direction == "output" && $type_mvt == "temporaire"}} - {{:assign var="ext" from="reste.%s"|args:$key}} - {{if $ext != null && $ext > 0}} + {{:assign var="temp_ext" from="reste.%s"|args:$key}} + {{if $temp_ext != null && $temp_ext > 0}} {{:linkbutton label="Retour" href="mouvements/output_return.html?key=%s&prop=%s"|args:$key:$_GET.prop @@ -210,6 +210,33 @@ {{/list}} {{else}} + {{* calculer la quantité présente temporairement de chaque matériel *}} + {{#foreach from=$config.input_nature key=key}} + {{if $type == "temporaire"}} + {{:assign var="temp_inputs." value=$key|quote_sql}} + {{/if}} + {{/foreach}} + {{:assign operations=$temp_inputs|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 present + FROM module_data_equipment AS mvt + LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.input') + 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="present.%s"|args:$mvt_key value=$present}} + {{/select}} +{{*:debug present=$present*}} +{{*:debug direction=$direction type_mvt=$type_mvt in=$in*}} {{#list type="movement" select="$$.date AS 'Date'; @@ -217,11 +244,11 @@ $$.operation AS 'Opération'; $$.amount AS 'Quantité'; "" as 'Présent'; - $$.comment AS 'Remarque'" + $$.comment AS 'Commentaire'" equipment=$equipment_key order=1 }} - {{:assign var="type_mvt" from="config.%s_nature.%s"|args:$direction:$col3}} + {{:assign var="type_mvt" from="config.%s_nature.%s.type"|args:$direction:$col3}} {{:assign var="op_label" from="config.%s_nature.%s.label"|args:$direction:$operation}} {{if $direction === "input" && $op_label|in:$input_types || @@ -236,6 +263,16 @@ {{$stock}} {{$comment}} + {{if $direction == "input" && $type_mvt == "temporaire"}} + {{:assign var="temp_in" from="present.%s"|args:$key}} + {{if $temp_in != null && $temp_in > 0}} + {{:linkbutton + label="Retour" + href="mouvements/input_return.html?key=%s&prop=%s"|args:$key:$_GET.prop + shape="history" + target="_dialog"}} + {{/if}} + {{/if}} {{:linkbutton label="Dupliquer" href="mouvements/dupliquer_mouvement.html?key=%s&prop=%s"|args:$key:$_GET.prop diff --git a/inventaire_nonprop.html b/inventaire_nonprop.html index 049bef0..fc96b88 100644 --- a/inventaire_nonprop.html +++ b/inventaire_nonprop.html @@ -95,13 +95,6 @@ {{$cat_name}} {{$col3}} - {{if $col3 > 0}} - {{:linkbutton - label="Retour" - href="mouvements/sorties/emprunte.html?key=%s"|args:$key - shape="history" - target="_dialog"}} - {{/if}} {{:linkbutton label="Entrée" shape="plus" diff --git a/mouvements/input_return.html b/mouvements/input_return.html new file mode 100644 index 0000000..dd778f4 --- /dev/null +++ b/mouvements/input_return.html @@ -0,0 +1,181 @@ +{{* -*- brindille -*- *}} + +{{* + Enregistrer un retour d'entrée temporaire + 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"}} + +{{* calculer la quantité entrée temporairement *}} +{{#foreach from=$config.input_nature key=key}} + {{if $type == "temporaire"}} + {{:assign var="temp_inputs." value=$key|quote_sql}} + {{/if}} +{{/foreach}} +{{:assign operations=$temp_inputs|implode:","}} +{{:assign operations="("|cat:$operations|cat:")"}} + +{{#select + json_extract(mvt.document, '$.amount') - IFNULL(SUM(json_extract(mvt2.document, '$.amount')), 0) AS present + FROM module_data_equipment AS mvt + LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.input') + 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 present=$present}} +{{/select}} + +{{* + -------------------- 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 > $present}} + {{:error message="La quantité (%s) doit être inférieure à la quantité présente (%s) !!"|args:$_POST.amount:$present}} + {{/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é *}} + {{:assign mvt_key=""|uuid}} + {{:save + key=$mvt_key + validate_schema="movement.schema.json" + type="movement" + direction="output" + operation=$_POST.operation + amount=$_POST.amount|intval + equipment=$equipment.key + date=$_POST.date|parse_date + comment=$_POST.comment|trim + }} + {{* enregistrer la liaison entre le retour et la sortie temporaire *}} + {{:save + key=""|uuid + validate_schema="link.schema.json" + type="link" + input=$_GET.key + return=$mvt_key + }} + {{:redirect force="../historique.html?ok=1&key=%s&prop=0&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.output_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=$present required=true default=$present}} + {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false}} +
+
+ +

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

+
+ +{{:admin_footer}} diff --git a/mouvements/link.schema.json b/mouvements/link.schema.json new file mode 100644 index 0000000..0048f8a --- /dev/null +++ b/mouvements/link.schema.json @@ -0,0 +1,23 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": ["link"] + }, + "input" : { + "description": "clé d'une entrée temporaire", + "type": "string" + }, + "output" : { + "description": "clé d'une sortie temporaire", + "type": "string" + }, + "return": { + "description": "clé d'un retour", + "type": "string" + } + }, + "required": ["type", "return"] +} diff --git a/mouvements/output_return.html b/mouvements/output_return.html index 15f122c..30f0878 100644 --- a/mouvements/output_return.html +++ b/mouvements/output_return.html @@ -1,6 +1,7 @@ {{* -*- brindille -*- *}} {{* + Enregistrer un retour de sortie temporaire paramètres : - key : clé du mouvement *}} @@ -130,6 +131,7 @@ {{* enregistrer la liaison entre le retour et la sortie temporaire *}} {{:save key=""|uuid + validate_schema="link.schema.json" type="link" output=$_GET.key return=$mvt_key @@ -167,7 +169,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=$exterieur required=true default=$exterieur}} - {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false default=$mvt_new.comment}} + {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false}} diff --git a/mouvements/supprimer_mouvement.html b/mouvements/supprimer_mouvement.html index 496a7d7..e603a2f 100644 --- a/mouvements/supprimer_mouvement.html +++ b/mouvements/supprimer_mouvement.html @@ -21,54 +21,63 @@ {{:include file="../_get_config.html" keep="config"}} {{#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}} - {{:assign nonprop=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 == 'temporaire'}} - {{:assign nonprop="%d+%d"|math:$nonprop:$mvt.amount}} - {{else}} - {{:assign dispo="%d+%d"|math:$dispo:$mvt.amount}} - {{/if}} - {{elseif $mvt.direction == 'output'}} - {{if $type_mvt == 'retour'}} - {{:assign nonprop="%d-%d"|math:$nonprop:$mvt.amount}} - {{else}} - {{:assign dispo="%d-%d"|math:$dispo:$mvt.amount}} - {{/if}} - {{/if}} - - {{* problème ? *}} - {{if $dispo < 0 || $nonprop < 0}} - {{:redirect force="../historique.html?key=%s&prop=%s&err=1&msg=suppression"|args:$mvt_suppr.equipment:$_GET.prop}} - {{/if}} + {{:assign var="type_operation" from="config.input_nature.%s.type"|args:$mvt_suppr.operation}} + {{if $type_operation == 'temporaire'}} + {{#load type="link" where="$$.input = :key OR $$.return = :key" :key=$_GET.key}} + {{:assign link_key=$key}} + {{/load}} + {{if $link_key != null}} + {{:redirect force="../historique.html?key=%s&prop=%s&err=1&msg=suppression"|args:$mvt_suppr.equipment:$_GET.prop}} {{/if}} - {{/load}} + {{else}} + {{:assign dispo=0}} + {{:assign nonprop=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 == 'temporaire'}} + {{:assign nonprop="%d+%d"|math:$nonprop:$mvt.amount}} + {{else}} + {{:assign dispo="%d+%d"|math:$dispo:$mvt.amount}} + {{/if}} + {{elseif $mvt.direction == 'output'}} + {{if $type_mvt == 'retour'}} + {{:assign nonprop="%d-%d"|math:$nonprop:$mvt.amount}} + {{else}} + {{:assign dispo="%d-%d"|math:$dispo:$mvt.amount}} + {{/if}} + {{/if}} + + {{* problème ? *}} + {{if $dispo < 0 || $nonprop < 0}} + {{:redirect force="../historique.html?key=%s&prop=%s&err=1&msg=suppression"|args:$mvt_suppr.equipment:$_GET.prop}} + {{/if}} + + {{/if}} + {{/load}} + {{/if}} {{else}} {{* sortie *}} {{:assign var="type_operation" from="config.output_nature.%s.type"|args:$mvt_suppr.operation}} {{if $type_operation == 'temporaire'}} + {{#load type="link" where="$$.output = :key OR $$.return = :key" :key=$_GET.key}} + {{:assign link_key=$key}} + {{/load}} {{if $link_key != null}} {{:redirect force="../historique.html?key=%s&prop=%s&err=1&msg=suppression"|args:$mvt_suppr.equipment:$_GET.prop}} {{/if}} From 16d6ac752a28b77df0bb3816e28d359c74845bda Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Fri, 21 Mar 2025 15:41:07 +0100 Subject: [PATCH 4/5] suppression fichiers inutiles --- mouvements/entrees/retour.html | 148 ------------------------------ mouvements/sorties/emprunte.html | 149 ------------------------------- 2 files changed, 297 deletions(-) delete mode 100644 mouvements/entrees/retour.html delete mode 100644 mouvements/sorties/emprunte.html diff --git a/mouvements/entrees/retour.html b/mouvements/entrees/retour.html deleted file mode 100644 index 347b8fd..0000000 --- a/mouvements/entrees/retour.html +++ /dev/null @@ -1,148 +0,0 @@ -{{* -*- brindille -*- *}} - -{{* - paramètres : - - key : clé du matériel qui revient -*}} - -{{* barre de navigation *}} -{{if ! $dialog}} - {{:include file="../../_nav.html" current="entrees"}} -{{/if}} - -{{* récupérer la config des entrées/sorties *}} -{{:include file="../../_get_config.html" keep="config"}} - -{{* déterminer le matériel concerné par le mouvement *}} -{{#load key=$_GET.key assign="equipment"}}{{/load}} - -{{* - -------------------- Traiter l'envoi du formulaire -------------------- -*}} -{{#form on="save"}} - {{* vérifier les données saisies *}} - {{if $_POST.amount <= 0}} - {{:error message="La quantité (%s) doit être strictement positive !!"|args:$_POST.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}} de {{$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:$_GET.key}} -{{/if}} -{{/form}} - -{{:admin_header title="Retour de matériel" custom_css="./../../style.css" current="module_equipment"}} -{{:form_errors}} - -{{* Extraire et compiler les infos de la base *}} -{{:include file="../../_calcul_dispo.html" eqpmt_key=$_GET.key keep="categories, equipments"}} -{{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}} - -{{* types d'entrées *}} -{{#foreach from=$config.input_nature key=key}} - {{if $type == 'retour'}} - {{:assign var="input_labels.%s"|args:$key value=$label}} - {{/if}} -{{/foreach}} - - -{{if $sorti > 0}} - {{:assign var=cat_name from=categories.%s|args:$equipment.category}} - {{* formulaire d'entrée de matériel *}} -
-
- Informations matériel -
-
Matériel
-
{{$equipment.name}}
-
Catégorie
-
{{$cat_name}}
-
Quantité sortie
-
{{$sorti}} (à la date du {{$now|date_short}})
-
-
-
- Ajouter un retour de matériel -
- {{:input type="select" name="operation" label="Type" required=true options=$input_labels|sort}} - {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} - {{:input type="number" name="amount" label="Quantité" min=1 required=true default=$sorti max=$sorti}} - {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false}} -
-
-

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

-
-{{else}} -

Il n'y a aucun matériel

-{{/if}} - -{{:admin_footer}} diff --git a/mouvements/sorties/emprunte.html b/mouvements/sorties/emprunte.html deleted file mode 100644 index 6b94afa..0000000 --- a/mouvements/sorties/emprunte.html +++ /dev/null @@ -1,149 +0,0 @@ -{{* -*- brindille -*- *}} - -{{* - paramètres : - - key : clé du matériel à rendre -*}} - -{{if ! $dialog}} - {{* barre de navigation *}} - {{:include file="../../_nav.html" current="sorties"}} -{{/if}} - -{{* récupérer la config des entrées/sorties *}} -{{:include file="../../_get_config.html" keep="config"}} - -{{* types de sorties *}} -{{#foreach from=$config.output_nature key=key}} - {{if $type == 'retour'}} - {{:assign var="output_labels.%s"|args:$key value=$label}} - {{/if}} -{{/foreach}} - -{{* Traiter l'envoi du formulaire *}} -{{#form on="save"}} - {{* interdire date dans le futur *}} - {{if $_POST.date|parse_date|strtotime > $now}} - {{:error message="Impossible de saisir une date dans le futur (%s)"|args:$_POST.date}} - {{/if}} - - {{* récupérer les infos du matériel *}} - {{#load type="equipment" key=$_GET.key assign="equipment"}} - {{/load}} - - {{:assign stock=0}} - {{:assign exterieur=0}} - {{:assign nonproprio=0}} - {{:assign insere=false}} - - {{* lister tous les mouvements du matériel *}} - {{#load type="movement" where="$$.equipment = '%s'"|args:$_GET.key assign="mvt" order="$$.date ASC"}} - - {{* traiter le nouveau mouvement *}} - {{if ! $insere && $mvt.date > $_POST.date|parse_date}} - {{:assign insere=true}} - {{:assign dispo_old=$nonproprio}} - {{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}} - - {{if $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="type_mvt" from="config.%s_nature.%s.type"|args:$mvt.direction:$mvt.operation}} - - {{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 de %s unités à la date du %s"|args:$_POST.quantite:$mvt.amount:$date_err}} - {{/if}} - {{/load}} - {{if ! $insere}} - {{:assign dispo_old=$nonproprio}} - {{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}} - {{if $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}} - - {{* Enregistrer le mouvement *}} - {{:assign mvt_key=""|uuid}} - {{:save - key=$mvt_key - validate_schema="../movement.schema.json" - type="movement" - direction="output" - operation=$_POST.operation - amount=$_POST.quantite|intval - equipment=$equipment.key - date=$_POST.date|parse_date - comment=$_POST.remarques|trim - }} - {{:redirect force="../../historique.html?ok=1&key=%s&prop=0&msg=sortie"|args:$_GET.key}} -{{/form}} - -{{:admin_header title="Sortie de matériel" custom_css="./../../style.css" current="module_equipment"}} -{{:form_errors}} - -{{* Extraire et compiler les infos de la base *}} -{{:include file="../../_calcul_dispo.html" eqpmt_key=$_GET.key keep="categories,equipments"}} -{{:assign var=present from="equipments.%s.nonproprio"|args:$_GET.key}} - -{{if $present > 0}} - {{* déterminer le matériel concerné par le mouvement *}} - {{#load key=$_GET.key assign="equipment"}}{{/load}} - {{:assign var=cat_name from=categories.%s|args:$equipment.category}} - - {{* formulaire de sortie de matériel *}} -
-
- Informations matériel -
-
Matériel
-
{{$equipment.name}}
-
Catégorie
-
{{$cat_name}}
-
Quantité présente
-
{{$present}}
-
-
-
- Ajouter une sortie d'un matériel présent temporairement -
- {{:input type="select" name="operation" label="Type" required=true options=$output_labels|sort}} - {{: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=$present min=1 max=$present}} - {{: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}} -

Il n'y a aucun matériel en stock

-{{/if}} - -{{:admin_footer}} From 3ba67d0c65554abae82ad7bff90853d346236316 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Sat, 22 Mar 2025 11:33:35 +0100 Subject: [PATCH 5/5] =?UTF-8?q?modification=20sch=C3=A9ma=20entr=C3=A9es/s?= =?UTF-8?q?orties=20temporaires=20li=C3=A9es?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- historique.html | 4 ++-- mouvements/input_return.html | 5 +++-- mouvements/link.schema.json | 14 +++++++------- mouvements/output_return.html | 7 ++++--- mouvements/supprimer_mouvement.html | 4 ++-- 5 files changed, 18 insertions(+), 16 deletions(-) diff --git a/historique.html b/historique.html index 39311a6..b9273f9 100644 --- a/historique.html +++ b/historique.html @@ -132,7 +132,7 @@ 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 link ON mvt.key = json_extract(link.document, '$.temp_key') LEFT JOIN module_data_equipment AS mvt2 ON mvt2.key = json_extract(link.document, '$.return') WHERE json_extract(mvt.document, '$.operation') IN !op @@ -223,7 +223,7 @@ mvt.key AS mvt_key, json_extract(mvt.document, '$.amount') - IFNULL(SUM(json_extract(mvt2.document, '$.amount')), 0) AS present FROM module_data_equipment AS mvt - LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.input') + LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.temp_key') LEFT JOIN module_data_equipment AS mvt2 ON mvt2.key = json_extract(link.document, '$.return') WHERE json_extract(mvt.document, '$.operation') IN !op diff --git a/mouvements/input_return.html b/mouvements/input_return.html index dd778f4..5c615b5 100644 --- a/mouvements/input_return.html +++ b/mouvements/input_return.html @@ -33,7 +33,7 @@ {{#select json_extract(mvt.document, '$.amount') - IFNULL(SUM(json_extract(mvt2.document, '$.amount')), 0) AS present FROM module_data_equipment AS mvt - LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.input') + LEFT JOIN module_data_equipment AS link ON mvt.key = json_extract(link.document, '$.temp_key') LEFT JOIN module_data_equipment AS mvt2 ON mvt2.key = json_extract(link.document, '$.return') WHERE json_extract(mvt.document, '$.operation') IN !op @@ -133,7 +133,8 @@ key=""|uuid validate_schema="link.schema.json" type="link" - input=$_GET.key + direction="input" + temp_key=$_GET.key return=$mvt_key }} {{:redirect force="../historique.html?ok=1&key=%s&prop=0&msg=retour"|args:$mvt_new.equipment}} diff --git a/mouvements/link.schema.json b/mouvements/link.schema.json index 0048f8a..57c6846 100644 --- a/mouvements/link.schema.json +++ b/mouvements/link.schema.json @@ -6,18 +6,18 @@ "type": "string", "enum": ["link"] }, - "input" : { - "description": "clé d'une entrée temporaire", - "type": "string" + "direction" : { + "type" : "string", + "enum" : ["input", "output"] }, - "output" : { - "description": "clé d'une sortie temporaire", + "temp_key" : { + "description": "clé d'une entrée ou sortie temporaire", "type": "string" }, "return": { - "description": "clé d'un retour", + "description": "clé du retour associé", "type": "string" } }, - "required": ["type", "return"] + "required": ["type", "direction", "temp_key", "return"] } diff --git a/mouvements/output_return.html b/mouvements/output_return.html index 30f0878..595774b 100644 --- a/mouvements/output_return.html +++ b/mouvements/output_return.html @@ -3,7 +3,7 @@ {{* Enregistrer un retour de sortie temporaire paramètres : - - key : clé du mouvement + - key : clé de la sortie temporaire *}} {{* infos du mouvement *}} @@ -33,7 +33,7 @@ {{#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 link ON mvt.key = json_extract(link.document, '$.temp_key') LEFT JOIN module_data_equipment AS mvt2 ON mvt2.key = json_extract(link.document, '$.return') WHERE json_extract(mvt.document, '$.operation') IN !op @@ -133,7 +133,8 @@ key=""|uuid validate_schema="link.schema.json" type="link" - output=$_GET.key + direction="output" + temp_key=$_GET.key return=$mvt_key }} {{:redirect force="../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$mvt_new.equipment}} diff --git a/mouvements/supprimer_mouvement.html b/mouvements/supprimer_mouvement.html index e603a2f..0d94d55 100644 --- a/mouvements/supprimer_mouvement.html +++ b/mouvements/supprimer_mouvement.html @@ -26,7 +26,7 @@ {{:assign var="type_operation" from="config.input_nature.%s.type"|args:$mvt_suppr.operation}} {{if $type_operation == 'temporaire'}} - {{#load type="link" where="$$.input = :key OR $$.return = :key" :key=$_GET.key}} + {{#load type="link" where="$$.temp_key = :key OR $$.return = :key" :key=$_GET.key}} {{:assign link_key=$key}} {{/load}} {{if $link_key != null}} @@ -75,7 +75,7 @@ {{:assign var="type_operation" from="config.output_nature.%s.type"|args:$mvt_suppr.operation}} {{if $type_operation == 'temporaire'}} - {{#load type="link" where="$$.output = :key OR $$.return = :key" :key=$_GET.key}} + {{#load type="link" where="$$.temp_key = :key OR $$.return = :key" :key=$_GET.key}} {{:assign link_key=$key}} {{/load}} {{if $link_key != null}}