simplification et correction erreur stock_disponible

This commit is contained in:
Jean-Christophe Engel 2024-12-11 16:39:46 +01:00
parent 11806b11da
commit 1c395c48e0

View File

@ -2,9 +2,7 @@
{{* {{*
paramètres : paramètres :
- key : clé du matériel à modifier - key : clé du matériel à sortir
TODO : simplifier
*}} *}}
{{:admin_header title="Sortie de matériel" current="module_equipment"}} {{:admin_header title="Sortie de matériel" current="module_equipment"}}
@ -28,7 +26,6 @@
{{#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=$_GET.key assign="equipment"}} {{#load type="equipment" key=$_GET.key assign="equipment"}}
{{:assign designation=$equipment.designation}}
{{/load}} {{/load}}
{{:assign stock=0}} {{:assign stock=0}}
@ -41,22 +38,19 @@
{{* traiter le nouveau mouvement *}} {{* traiter le nouveau mouvement *}}
{{if ! $insere && $mvt.date > $_POST.date|parse_date}} {{if ! $insere && $mvt.date > $_POST.date|parse_date}}
{{:assign insere=true}}
{{:assign dispo_old="%d-%d"|math:$stock:$exterieur}}
{{:assign var="operation" from="output_labels.%s|args:$_POST.type_operation}} {{:assign var="operation" from="output_labels.%s|args:$_POST.type_operation}}
{{:assign var="type_mvt" from="config.output_nature.%s"|args:$operation}} {{:assign var="type_mvt" from="config.output_nature.%s"|args:$operation}}
{{:assign dispo_old="%d-%d"|math:$stock:$exterieur}}
{{if $type_mvt == 'définitif'}} {{if $type_mvt == 'définitif'}}
{{:assign stock="%d-%d"|math:$stock:$_POST.quantite}} {{:assign stock="%d-%d"|math:$stock:$_POST.quantite}}
{{elseif $type_mvt == 'temporaire'}} {{elseif $type_mvt == 'temporaire'}}
{{:assign exterieur="%d+%d"|math:$exterieur:$_POST.quantite}} {{:assign exterieur="%d+%d"|math:$exterieur:$_POST.quantite}}
{{elseif $type_mvt == 'retour'}}
{{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}}
{{/if}} {{/if}}
{{:assign insere=true}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}} {{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}}
{{:assign date_err=$_POST.date|date:"d/m/Y"}} {{: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}} {{: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}}
@ -85,14 +79,31 @@
{{/if}} {{/if}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}} {{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}} {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}}
{{:assign date_err=$mvt.date|date:"d/m/Y"}} {{:assign date_err=$mvt.date|date:"d/m/Y"}}
{{:error message="Erreur : la quantité indiquée (%s) est incompatible avec la sortie « %s : %s » à la date du %s"|args:$_POST.quantite:$designation:$mvt.amount:$date_err}} {{: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}} {{/if}}
{{/load}} {{/load}}
{{if ! $insere}}
{{:assign dispo_old="%d-%d"|math:$stock:$exterieur}}
{{:assign var="operation" from="output_labels.%s|args:$_POST.type_operation}}
{{:assign var="type_mvt" from="config.output_nature.%s"|args:$operation}}
{{if $type_mvt == 'définitif'}}
{{:assign stock="%d-%d"|math:$stock:$_POST.quantite}}
{{elseif $type_mvt == 'temporaire'}}
{{:assign exterieur="%d+%d"|math:$exterieur:$_POST.quantite}}
{{/if}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 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 *}} {{* Enregistrer le mouvement *}}
{{:assign mvt_key=""|uuid}} {{:assign mvt_key=""|uuid}}
{{:assign var="operation" from="output_labels.%d|args:$_POST.type_operation}} {{:assign var="operation" from="output_labels.%d|args:$_POST.type_operation}}
{{:save {{:save
@ -112,20 +123,16 @@
{{/form}} {{/form}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{* TODO simplifier et peut-être mutualiser *}} {{:include file="../../_calcul_dispo.html" keep="categories,equipments"}}
{{:include file="../../_calcul_dispo.html" keep="cumul_mvt,equipments"}}
{{:assign var=stock from="equipments.%s.stock"|args:$_GET.key}} {{:assign var=stock from="equipments.%s.stock"|args:$_GET.key}}
{{:assign var=exterieur from="equipments.%s.exterieur"|args:$_GET.key}} {{:assign var=exterieur from="equipments.%s.exterieur"|args:$_GET.key}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}} {{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{:assign var=category_key from="equipments.%s.category"|args:$_GET.key}}
{{:assign var=category from="cumul_mvt.%s.name"|args:$category_key}}
{{if $dispo > 0}} {{if $dispo > 0}}
{{* déterminer le matériel concerné par le mouvement *}} {{* déterminer le matériel concerné par le mouvement *}}
{{#load key=$_GET.key assign="equipment"}} {{#load key=$_GET.key assign="equipment"}}{{/load}}
{{/load}} {{:assign var=cat_name from=categories.%s|args:$equipment.category}}
{{* formulaire de sortie de matériel *}} {{* formulaire de sortie de matériel *}}
<form method="post" action=""> <form method="post" action="">
@ -135,7 +142,7 @@
{{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}} {{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}}
{{: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="text" name="equipment" label="Matériel" required=true disabled=true default=$equipment.designation}} {{:input type="text" name="equipment" label="Matériel" required=true disabled=true default=$equipment.designation}}
{{:input type="text" name="category" label="Catégorie" required=true disabled=true default=$category.name}} {{:input type="text" name="category" label="Catégorie" required=true disabled=true default=$cat_name}}
{{:input type="text" name="dispo" label="Qté disponible" disabled=true default=$dispo}} {{:input type="text" name="dispo" label="Qté disponible" disabled=true default=$dispo}}
<p><span class="alert">La quantité indiquée est celle à la date du jour</span></p> <p><span class="alert">La quantité indiquée est celle à la date du jour</span></p>
{{: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}}
@ -147,8 +154,7 @@
</p> </p>
</form> </form>
{{else}} {{else}}
{{:assign date_err=$now|date:'d/m/Y'}} <p class="block error">Il y a 0 unité de ce matériel disponible à la date du {{$now|date_short}}</p>
<p class="block error">Il n'y a aucun matériel disponible à la date du {{$date_err}}</p>
{{/if}} {{/if}}
<script type="text/javascript"> <script type="text/javascript">