From c18865a4670f517c8f1abce1c018d68e5ea8d420 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Sat, 18 Nov 2023 21:36:05 +0100 Subject: [PATCH] =?UTF-8?q?V=C3=A9rification=20quantit=C3=A9=20mat=C3=A9ri?= =?UTF-8?q?el=20disponible=20=C3=A0=20la=20date=20de=20la=20sortie?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- mouvements/sorties/stock_disponible.html | 100 +++++++++++++++++++---- 1 file changed, 83 insertions(+), 17 deletions(-) diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 660c773..9d970db 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -18,20 +18,51 @@ {{#form on="save"}} {{* récupérer les infos du matériel *}} {{#load type="equipment" key=$_POST.equipment assign="equipment"}} + {{:assign designation=$equipment.designation}} {{/load}} - {{* TODO vérifier si qté sortie <= dispo *}} - {{:include file="./_calcul_dispo.html" keep="dispo" }} + {{* déterminer la quantité disponible de ce matériel à la date donnée *}} + {{:assign var="dispo" value=0}} + {{#load + type="movement" + where="$$.equipment = :eqpmt_key AND $$.date <= :date" + :eqpmt_key=$equipment.key + :date=$_POST.date|parse_date + assign="movement" + }} + {{if $movement.direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature item="elem"}} + {{if $movement.inputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'retour'}} + {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{else}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.outputNature item="elem"}} + {{if $movement.outputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'temporaire'}} + {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{/if}} + {{else}} + {{:error message="Erreur : il n'y a aucun mouvement pour le matériel « %s » avant la date du %s."|args:$equipment.designation:$_POST.date}} + {{/load}} - {{* cumuler les entrées et les sorties de ce matériel *}} {{if $_POST.quantite|intval > $dispo}} - {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle disponible (%d)"|args:$_POST.quantite:$dispo}} + {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle disponible (%d) à la date du %s"|args:$_POST.quantite:$dispo:$_POST.date}} {{/if}} {{* Enregistrer le mouvement *}} + {{:assign mvt_key=""|uuid}} {{:assign var="operation" from="types_sorties.%d|args:$_POST.type_operation}} - {{:save key=$mvt_key validate_schema="/%s/mouvements/movement.schema.json"|args:$module.name @@ -43,25 +74,60 @@ date=$_POST.date|parse_date comment=$_POST.remarques|trim }} - - {{:redirect force="index.html?ok=1&msg=Sortie de « %s » enregistrée"|args:$equipment.designation}} + {{:redirect force="index.html?ok=1&msg=Sortie de « %s » (%d) enregistrée"|args:$designation:$_POST.quantite}} {{else}} {{:form_errors}} {{/form}} -{{* lister les catégories et matériels associés *}} +{{* itérer sur les catégories *}} {{#load type="category" assign="category" order="$$.name"}} - {{:assign nom_cat=$category.name}} + {{:assign nom_cat=$category.name}} - {{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment" order="$$.designation"}} + {{* lister les matériels de la catégorie *}} + {{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment" order="$$.designation"}} + {{:assign designation=$equipment.designation}} - {{* cumuler les entrées et les sorties de ce matériel *}} - {{:include file="./_calcul_dispo.html" keep="dispo" }} + {{* déterminer la quantité disponible de ce matériel, + ie propriété de l'asso et pas en prêt à la date du jour *}} + {{:assign var="dispo" value=0}} + {{#load + type="movement" + where="$$.equipment = :eqpmt_key AND $$.date <= :date" + :eqpmt_key=$equipment.key + :date=$now|date:"Y-m-d" + assign="movement" + }} - {{if $dispo > 0}} - {{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$equipment.designation:$dispo}} - {{/if}} - {{/load}} + {{if $movement.direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature item="elem"}} + {{if $movement.inputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'retour'}} + {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{else}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.outputNature item="elem"}} + {{if $movement.outputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'temporaire'}} + {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{/if}} + {{else}} +

Il n'y a aucun movement dans cette période.

+ {{/load}} + + {{if $dispo > 0}} + {{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$designation:$dispo}} + {{/if}} + + {{/load}} {{/load}} {{* formulaire de sortie de matériel *}} @@ -73,9 +139,9 @@ {{:input type="select" name="type_operation" label="Type" required=true options=$types_sorties}} {{: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=1 min=1}} -
Matériel +

La quantité disponible est celle à la date du jour

{{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}}