Vérification quantité matériel disponible à la date de la sortie

This commit is contained in:
Jean-Christophe Engel 2023-11-18 21:36:05 +01:00
parent 2779f99ad3
commit c18865a467

View File

@ -18,20 +18,51 @@
{{#form on="save"}} {{#form on="save"}}
{{* récupérer les infos du matériel *}} {{* récupérer les infos du matériel *}}
{{#load type="equipment" key=$_POST.equipment assign="equipment"}} {{#load type="equipment" key=$_POST.equipment assign="equipment"}}
{{:assign designation=$equipment.designation}}
{{/load}} {{/load}}
{{* TODO vérifier si qté sortie <= dispo *}} {{* déterminer la quantité disponible de ce matériel à la date donnée *}}
{{:include file="./_calcul_dispo.html" keep="dispo" }} {{: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}} {{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}} {{/if}}
{{* Enregistrer le mouvement *}} {{* Enregistrer le mouvement *}}
{{:assign mvt_key=""|uuid}} {{:assign mvt_key=""|uuid}}
{{:assign var="operation" from="types_sorties.%d|args:$_POST.type_operation}} {{:assign var="operation" from="types_sorties.%d|args:$_POST.type_operation}}
{{:save {{:save
key=$mvt_key key=$mvt_key
validate_schema="/%s/mouvements/movement.schema.json"|args:$module.name validate_schema="/%s/mouvements/movement.schema.json"|args:$module.name
@ -43,25 +74,60 @@
date=$_POST.date|parse_date date=$_POST.date|parse_date
comment=$_POST.remarques|trim comment=$_POST.remarques|trim
}} }}
{{:redirect force="index.html?ok=1&msg=Sortie de « %s » (%d) enregistrée"|args:$designation:$_POST.quantite}}
{{:redirect force="index.html?ok=1&msg=Sortie de « %s » enregistrée"|args:$equipment.designation}}
{{else}} {{else}}
{{:form_errors}} {{:form_errors}}
{{/form}} {{/form}}
{{* lister les catégories et matériels associés *}} {{* itérer sur les catégories *}}
{{#load type="category" assign="category" order="$$.name"}} {{#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 *}} {{* déterminer la quantité disponible de ce matériel,
{{:include file="./_calcul_dispo.html" keep="dispo" }} 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}} {{if $movement.direction === 'entrée'}}
{{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$equipment.designation:$dispo}} {{* chercher le type d'entrée parmi les types de la config *}}
{{/if}} {{#foreach from=$module.config.inputNature item="elem"}}
{{/load}} {{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}}
<p class="block alert">Il n'y a aucun movement dans cette période.</p>
{{/load}}
{{if $dispo > 0}}
{{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$designation:$dispo}}
{{/if}}
{{/load}}
{{/load}} {{/load}}
{{* formulaire de sortie de matériel *}} {{* 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="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="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}} {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}}
<fieldset> <fieldset>
<legend>Matériel</legend> <legend>Matériel</legend>
<p><span class="alert">La quantité disponible est celle à la date du jour</span></p>
{{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} {{: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}} {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}}
</fieldset> </fieldset>