Compare commits

...

7 Commits
0.1 ... main

8 changed files with 254 additions and 109 deletions

View File

@ -37,7 +37,13 @@
{{:include file="./_get_config.html" keep="config"}} {{:include file="./_get_config.html" keep="config"}}
{{* parcourir les mouvements et cumuler les entrées/sorties *}} {{* parcourir les mouvements et cumuler les entrées/sorties *}}
{{#load type="movement" where="$$.equipment IN %s"|args:$in_equipments assign="mvt"}} {{if $date == null}}
{{:assign condition="$$.equipment IN %s"|args:$in_equipments}}
{{else}}
{{:assign condition="$$.equipment IN %s AND $$.date <= '%s'"|args:$in_equipments:$date}}
{{/if}}
{{#load type="movement" where="%s"|args:$condition assign="mvt" order="$$.date ASC"}}
{{* matériel propriété de l'asso en stock *}} {{* matériel propriété de l'asso en stock *}}
{{:assign {{:assign
var="stock" var="stock"

View File

@ -10,6 +10,37 @@
{{/load}} {{/load}}
{{:admin_header title="Historique des mouvements de %s (%s)"|args:$equipment.designation:$category.name current="module_equipment"}} {{:admin_header title="Historique des mouvements de %s (%s)"|args:$equipment.designation:$category.name current="module_equipment"}}
{{* récupérer la config des entrées/sorties *}}
{{:include file="./_get_config.html" keep="config"}}
{{* déterminer les type de mouvements selon l'affection du matériel *}}
{{#foreach from=$config.input_nature key=mvt item=type_mvt}}
{{if $_GET.prop}}
{{* matériel propriété de l'asso *}}
{{if $type_mvt != 'temporaire'}}
{{:assign var="input_types." value=$mvt}}
{{/if}}
{{else}}
{{* matériel non propriété de l'asso *}}
{{if $type_mvt == 'temporaire'}}
{{:assign var="input_types." value=$mvt}}
{{/if}}
{{/if}}
{{/foreach}}
{{#foreach from=$config.output_nature key=mvt item=type_mvt}}
{{if $_GET.prop}}
{{* matériel propriété de l'asso *}}
{{if $type_mvt != 'retour'}}
{{:assign var="output_types." value=$mvt}}
{{/if}}
{{else}}
{{* matériel non propriété de l'asso *}}
{{if $type_mvt == 'retour'}}
{{:assign var="output_types." value=$mvt}}
{{/if}}
{{/if}}
{{/foreach}}
{{* lister tous les mouvements du matériel passé en paramètre *}} {{* lister tous les mouvements du matériel passé en paramètre *}}
{{#list {{#list
type="movement" type="movement"
@ -21,14 +52,18 @@
equipment=$equipment_key equipment=$equipment_key
order=1 order=1
}} }}
<tr> {{if $direction === "input" && $input_nature|in:$input_types ||
<td>{{$date|date_short}}</td> $direction === "output" && $output_nature|in:$output_types
<td>{{$col2}}</td> }}
<td>{{$col3}}</td> <tr>
<td>{{$amount}}</td> <td>{{$date|date_short}}</td>
<td>{{$comment}}</td> <td>{{$col2}}</td>
<td></td> <td>{{$col3}}</td>
</tr> <td>{{$amount}}</td>
<td>{{$comment}}</td>
<td></td>
</tr>
{{/if}}
{{/list}} {{/list}}
{{:admin_footer}} {{:admin_footer}}

View File

@ -1,15 +1,13 @@
{{* -*- brindille -*- *}}
{{* inventaire des entrées/sorties des matériels des catégories de la variable category_keys *}} {{* inventaire des entrées/sorties des matériels des catégories de la variable category_keys *}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{:include file="./_calcul_dispo.html" keep="cumul_mvt,category_keys"}} {{:include file="./_calcul_dispo.html" keep="cumul_mvt,category_keys,equipments"}}
{{* Afficher les résultats *}} {{* Afficher les résultats *}}
{{if $cumul_mvt === null}} {{if $equipments === null}}
{{if $category_keys|count == 1}} <p class="block alert">Aucun matériel.</p>
<p class="block alert">Il n'y a aucun matériel dans cette catégorie.</p>
{{else}}
<p class="block alert">Il n'y a aucun matériel dans ces catégories.</p>
{{/if}}
{{else}} {{else}}
<section class="inventaire"> <section class="inventaire">
<h2 class="ruler">Matériels dont l'association est propriétaire</h2> <h2 class="ruler">Matériels dont l'association est propriétaire</h2>
@ -17,10 +15,6 @@
{{* itérer sur les catégories *}} {{* itérer sur les catégories *}}
{{#foreach from=$cumul_mvt key="cat_key" item="cat_elem"}} {{#foreach from=$cumul_mvt key="cat_key" item="cat_elem"}}
{{if $print_cat_name}}
<h3>{{$cat_elem.name}}</h3>
{{/if}}
{{* vérifier s'il y a des matériels dans cette catégorie *}} {{* vérifier s'il y a des matériels dans cette catégorie *}}
{{:assign present=false}} {{:assign present=false}}
{{if $cat_elem|keys|has:"eqpmt"}} {{if $cat_elem|keys|has:"eqpmt"}}
@ -32,6 +26,10 @@
{{/foreach}} {{/foreach}}
{{/if}} {{/if}}
{{if $present}} {{if $present}}
{{if $print_cat_name}}
<h3>{{$cat_elem.name}}</h3>
{{/if}}
<table class="list"> <table class="list">
<thead> <thead>
<tr> <tr>
@ -63,7 +61,7 @@
<td class="actions"> <td class="actions">
{{:linkbutton {{:linkbutton
label="Historique des mouvements" label="Historique des mouvements"
href="%shistorique.html?key=%s"|args:$module.url:$eqpmt_key href="%shistorique.html?key=%s&prop=1"|args:$module.url:$eqpmt_key
shape="table" shape="table"
target="_dialog"}} target="_dialog"}}
{{:linkbutton {{:linkbutton
@ -79,8 +77,6 @@
{{/foreach}} {{/foreach}}
</tbody> </tbody>
</table> </table>
{{else}}
<p class="block alert">Il n'y a aucun matériel dans cette catégorie.</p>
{{/if}} {{/if}}
{{/foreach}} {{/foreach}}
@ -89,10 +85,6 @@
{{* itérer sur les catégories *}} {{* itérer sur les catégories *}}
{{#foreach from=$cumul_mvt key="cat_key" item="cat_elem"}} {{#foreach from=$cumul_mvt key="cat_key" item="cat_elem"}}
{{if $print_cat_name}}
<h3>{{$cat_elem.name}}</h3>
{{/if}}
{{* vérifier s'il y a des matériels dans cette catégorie *}} {{* vérifier s'il y a des matériels dans cette catégorie *}}
{{:assign present=false}} {{:assign present=false}}
{{if $cat_elem|keys|has:"eqpmt"}} {{if $cat_elem|keys|has:"eqpmt"}}
@ -104,6 +96,11 @@
{{/foreach}} {{/foreach}}
{{/if}} {{/if}}
{{if $present}} {{if $present}}
{{if $print_cat_name}}
<h3>{{$cat_elem.name}}</h3>
{{/if}}
<table class="list"> <table class="list">
<thead> <thead>
<tr> <tr>
@ -142,8 +139,6 @@
{{/foreach}} {{/foreach}}
</tbody> </tbody>
</table> </table>
{{else}}
<p class="block alert">Il n'y a aucun matériel dans cette catégorie.</p>
{{/if}} {{/if}}
{{/foreach}} {{/foreach}}
</section> </section>

View File

@ -1,28 +1,43 @@
{{:admin_header title="Modifier une %s"|args:$_GET.direction current="module_equipment"}} {{* -*- brindille -*- *}}
{{:assign direction=$_GET.direction}} {{if $_GET.direction == "input"}}
{{:assign msg_direction="entrée"}}
{{else}}
{{:assign msg_direction="sortie"}}
{{/if}}
{{:admin_header title="Modifier une %s"|args:$msg_direction current="module_equipment"}}
{{:assign direction_mvt=$_GET.direction}}
{{:assign key_mvt=$_GET.key}} {{:assign key_mvt=$_GET.key}}
{{* récupérer les infos du mouvement à modifier *}} {{* récupérer les infos du mouvement à modifier *}}
{{#load key=$key_mvt assign="mvt_modif"}} {{#load key=$key_mvt assign="mvt_modif"}}
{{else}} {{else}}
{{:error message="Aucune %s avec la clé %s"|args:$_GET.direction:$key_mvt}} {{:error message="Aucune %s avec la clé %s"|args:$msg_direction:$key_mvt}}
{{/load}} {{/load}}
{{if $direction == "input"}}
{{if $direction_mvt == "input"}}
{{:assign input_init=$mvt_modif.input_nature}} {{:assign input_init=$mvt_modif.input_nature}}
{{:assign url="entrees/index.html"}} {{:assign url="entrees/index.html"}}
{{else}} {{else}}
{{:assign output_init=$mvt_modif.output_nature}} {{:assign output_init=$mvt_modif.output_nature}}
{{:assign url="sorties/index.html"}} {{:assign url="sorties/index.html"}}
{{/if}} {{/if}}
{{:assign amount_init=$mvt_modif.amount}} {{:assign amount_init=$mvt_modif.amount}}
{{:assign date_init=$mvt_modif.date|date_short}} {{:assign date_init=$mvt_modif.date|date_short}}
{{:assign key_eqpmt_init=$mvt_modif.equipment}} {{:assign key_eqpmt_init=$mvt_modif.equipment}}
{{* récupérer les infos du matériel associé *}}
{{#load key=$key_eqpmt_init assign="eqpmt_init"}}
{{else}}
{{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_init}}
{{/load}}
{{* récupérer la config des entrées/sorties *}} {{* récupérer la config des entrées/sorties *}}
{{:include file="../_get_config.html" keep="config"}} {{:include file="../_get_config.html" keep="config"}}
{{if $direction == "input"}} {{if $direction_mvt == "input"}}
{{* types d'entrées *}} {{* types d'entrées *}}
{{#foreach from=$config.input_nature key="label" item="type"}} {{#foreach from=$config.input_nature key="label" item="type"}}
{{:assign var="input_labels.%s"|args:$label value="%s"|args:$label}} {{:assign var="input_labels.%s"|args:$label value="%s"|args:$label}}
@ -40,18 +55,12 @@
{{/foreach}} {{/foreach}}
{{/if}} {{/if}}
{{* récupérer les infos du matériel associé *}}
{{#load key=$key_eqpmt_init assign="eqpmt_init"}}
{{else}}
{{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_init}}
{{/load}}
{{* {{*
-------------------- Traiter la saisie -------------------- -------------------- Traiter la saisie --------------------
*}} *}}
{{#form on="change"}} {{#form on="change"}}
{{* préparer le mouvement modifié *}} {{* préparer le mouvement modifié *}}
{{if $direction == "input"}} {{if $direction_mvt == "input"}}
{{:assign var="mvt_modif.input_nature" from="input_labels.%s"|args:$_POST.type_operation}} {{:assign var="mvt_modif.input_nature" from="input_labels.%s"|args:$_POST.type_operation}}
{{else}} {{else}}
{{:assign var="mvt_modif.output_nature" from="output_labels.%s"|args:$_POST.type_operation}} {{:assign var="mvt_modif.output_nature" from="output_labels.%s"|args:$_POST.type_operation}}
@ -66,7 +75,6 @@
en l'insérant à sa place par date croissante en l'insérant à sa place par date croissante
*}} *}}
{{:assign insere=false}} {{:assign insere=false}}
{{#load {{#load
where=" where="
$$.type = 'movement' $$.type = 'movement'
@ -78,15 +86,18 @@
assign="movement" assign="movement"
}} }}
{{if $key != $key_mvt}} {{if $key != $key_mvt}}
{{if $date > $mvt_modif.date && ! $insere}} {{if $direction_mvt == "input" && ! $insere && $date >= $mvt_modif.date}}
{{:assign var=movements_modif." from=mvt_modif}} {{:assign var="movements_modif." from=mvt_modif}}
{{:assign insere=true}}
{{elseif $direction_mvt == "output" && ! $insere && $date > $mvt_modif.date}}
{{:assign var="movements_modif." from=mvt_modif}}
{{:assign insere=true}} {{:assign insere=true}}
{{/if}} {{/if}}
{{:assign var=movements_modif." from=movement}} {{:assign var="movements_modif." from=movement}}
{{/if}} {{/if}}
{{/load}} {{/load}}
{{if ! $insere}} {{if ! $insere}}
{{:assign var=movements_modif." from=mvt_modif}} {{:assign var="movements_modif." from=mvt_modif}}
{{/if}} {{/if}}
{{* Vérifier la cohérence des opérations de l'ancien matériel *}} {{* Vérifier la cohérence des opérations de l'ancien matériel *}}
@ -111,7 +122,7 @@
{{if $erreur}} {{if $erreur}}
<p class="block error"> <p class="block error">
Modification demandée impossible : Modification demandée impossible :
{{if $direction == "input"}} {{if $direction_mvt == "input"}}
« {{$input_init}} de {{$eqpmt_init.designation}} (qté : {{$amount_init}}) en date du {{$date_init}} » vers « {{$input_init}} de {{$eqpmt_init.designation}} (qté : {{$amount_init}}) en date du {{$date_init}} » vers
« {{$mvt_modif.input_nature}} de {{$eqpmt.designation}} (qté : {{$mvt_modif.amount}}) à la date du {{$mvt_modif.date|date_short}} » « {{$mvt_modif.input_nature}} de {{$eqpmt.designation}} (qté : {{$mvt_modif.amount}}) à la date du {{$mvt_modif.date|date_short}} »
{{else}} {{else}}
@ -125,7 +136,7 @@
key=$key_mvt key=$key_mvt
validate_schema="./movement.schema.json" validate_schema="./movement.schema.json"
type="movement" type="movement"
direction=$direction direction=$direction_mvt
input_nature=$mvt_modif.input_nature input_nature=$mvt_modif.input_nature
output_nature=$mvt_modif.output_nature output_nature=$mvt_modif.output_nature
amount=$mvt_modif.amount|intval amount=$mvt_modif.amount|intval
@ -154,7 +165,7 @@
<form method="post" action=""> <form method="post" action="">
<fieldset class="entree"> <fieldset class="entree">
{{if $direction == "input"}} {{if $direction_mvt == "input"}}
<legend>Modifier l'entrée « {{$input_init}} {{$eqpmt_init.designation}} ({{$amount_init}}) en date du {{$date_init}} »</legend> <legend>Modifier l'entrée « {{$input_init}} {{$eqpmt_init.designation}} ({{$amount_init}}) en date du {{$date_init}} »</legend>
<dl> <dl>
{{:input type="select" name="type_operation" label="Type" required=true options=$input_labels default=$type_defaut}} {{:input type="select" name="type_operation" label="Type" required=true options=$input_labels default=$type_defaut}}

View File

@ -1,3 +1,5 @@
{{* -*- brindille -*- *}}
{{:admin_header title="Sortie de matériel" current="module_equipment"}} {{:admin_header title="Sortie de matériel" current="module_equipment"}}
{{if ! $dialog}} {{if ! $dialog}}
@ -23,19 +25,65 @@
{{:assign var="category_keys." value=$equipment.category}} {{:assign var="category_keys." value=$equipment.category}}
{{/load}} {{/load}}
{{* Extraire et compiler les infos de la base *}} {{:assign stock=0}}
{{:include {{:assign exterieur=0}}
file="../../_calcul_dispo.html" {{:assign nonproprio=0}}
keep="cumul_mvt" {{:assign insere=false}}
date=$_POST.date|parse_date
}}
{{* déterminer la quantité présente de ce matériel à la date donnée *}} {{* lister tous les mouvements du matériel *}}
{{:assign var=present from="cumul_mvt.%s.eqpmt.%s.nonproprio"|args:$equipment.category:$_POST.equipment}} {{#load type="movement" where="$$.equipment = '%s'"|args:$_POST.equipment assign="mvt" order="$$.date ASC"}}
{{if $_POST.quantite|intval > $present}} {{* traiter le nouveau mouvement *}}
{{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle présente (%d) à la date du %s"|args:$_POST.quantite:$present:$_POST.date}} {{if ! $insere && $mvt.date > $_POST.date|parse_date}}
{{/if}} {{:assign var="operation" from="output_labels.%s|args:$_POST.type_operation}}
{{:assign var="type_mvt" from="config.output_nature.%s"|args:$operation}}
{{:assign dispo_old=$nonproprio}}
{{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}}
{{elseif $type_mvt == 'retour'}}
{{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}}
{{/if}}
{{:assign insere=true}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $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="mvt_nature" from="mvt.%s_nature"|args:$mvt.direction}}
{{:assign var="type_mvt" from="config.%s_nature.%s"|args:$mvt.direction:$mvt_nature}}
{{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 « %s : %s » à la date du %s"|args:$_POST.quantite:$designation:$mvt.amount:$date_err}}
{{/if}}
{{/load}}
{{* Enregistrer le mouvement *}} {{* Enregistrer le mouvement *}}
@ -68,7 +116,7 @@
{{* formulaire de sortie de matériel *}} {{* formulaire de sortie de matériel *}}
<form method="post" action=""> <form method="post" action="">
<fieldset class="sortie"> <fieldset class="sortie">
<legend>Ajouter une sortie d'un matériel disponible en stock</legend> <legend>Ajouter une sortie d'un matériel présent temporairement</legend>
<dl> <dl>
{{: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}}
@ -77,7 +125,7 @@
</fieldset> </fieldset>
<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> <p><span class="alert">La quantité indiquée est celle à la date du jour</span></p>
<dl> <dl>
{{:input type="select_groups" name="equipment" label="Matériel" required=true options=$temporaire onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$temporaire 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}}
@ -88,7 +136,8 @@
</p> </p>
</form> </form>
{{else}} {{else}}
<p class="block error">Il n'y a aucun matériel présent temporairement</p> {{:assign date_err=$now|date:'d/m/Y'}}
<p class="block error">Il n'y a aucun matériel présent temporairement à la date du {{$date_err}}</p>
{{/if}} {{/if}}
{{else}} {{else}}
<p class="block error">Il n'y a aucun matériel en stock</p> <p class="block error">Il n'y a aucun matériel en stock</p>

View File

@ -1,3 +1,5 @@
{{* -*- brindille -*- *}}
{{:admin_header title="Sortie de matériel" current="module_equipment"}} {{:admin_header title="Sortie de matériel" current="module_equipment"}}
{{if ! $dialog}} {{if ! $dialog}}
@ -23,21 +25,65 @@
{{:assign var="category_keys." value=$equipment.category}} {{:assign var="category_keys." value=$equipment.category}}
{{/load}} {{/load}}
{{* Extraire et compiler les infos de la base *}} {{:assign stock=0}}
{{:include {{:assign exterieur=0}}
file="../../_calcul_dispo.html" {{:assign nonproprio=0}}
keep="cumul_mvt" {{:assign insere=false}}
date=$_POST.date|parse_date
}}
{{* déterminer la quantité disponible de ce matériel à la date donnée *}} {{* lister tous les mouvements du matériel *}}
{{:assign var=stock from="cumul_mvt.%s.eqpmt.%s.stock"|args:$equipment.category:$_POST.equipment}} {{#load type="movement" where="$$.equipment = '%s'"|args:$_POST.equipment assign="mvt" order="$$.date ASC"}}
{{:assign var=exterieur from="cumul_mvt.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_POST.equipment}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $_POST.quantite|intval > $dispo}} {{* traiter le nouveau mouvement *}}
{{: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 ! $insere && $mvt.date > $_POST.date|parse_date}}
{{/if}} {{:assign var="operation" from="output_labels.%s|args:$_POST.type_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'}}
{{:assign stock="%d-%d"|math:$stock:$_POST.quantite}}
{{elseif $type_mvt == 'temporaire'}}
{{:assign exterieur="%d+%d"|math:$exterieur:$_POST.quantite}}
{{elseif $type_mvt == 'retour'}}
{{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}}
{{/if}}
{{:assign insere=true}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $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="mvt_nature" from="mvt.%s_nature"|args:$mvt.direction}}
{{:assign var="type_mvt" from="config.%s_nature.%s"|args:$mvt.direction:$mvt_nature}}
{{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 « %s : %s » à la date du %s"|args:$_POST.quantite:$designation:$mvt.amount:$date_err}}
{{/if}}
{{/load}}
{{* Enregistrer le mouvement *}} {{* Enregistrer le mouvement *}}
@ -75,32 +121,34 @@
{{/if}} {{/if}}
{{/foreach}} {{/foreach}}
{{/foreach}} {{/foreach}}
{{if $disponibilites === null}}
{{:error message="Le matériel choisi (%s) n'est pas présent à la date du %s"|args:$designation:$_POST.date}}
{{/if}}
{{* formulaire de sortie de matériel *}} {{if $disponibilites != null}}
<form method="post" action=""> {{* formulaire de sortie de matériel *}}
<fieldset class="sortie"> <form method="post" action="">
<legend>Ajouter une sortie d'un matériel disponible en stock</legend> <fieldset class="sortie">
<dl> <legend>Ajouter une sortie d'un matériel disponible en stock</legend>
{{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}} <dl>
{{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} {{:input type="select" name="type_operation" label="Type" required=true options=$output_labels}}
{{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}}
</dl> {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}}
</fieldset> </dl>
<fieldset> </fieldset>
<legend>Matériel</legend> <fieldset>
<p><span class="alert">La quantité disponible est celle à la date du jour</span></p> <legend>Matériel</legend>
<dl> <p><span class="alert">La quantité indiquée est celle à la date du jour</span></p>
{{:input type="select_groups" name="equipment" label="Matériel" required=true options=$disponibilites onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} <dl>
{{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$disponibilites onchange="fixerValeurMax('f_equipment', 'f_quantite')"}}
</dl> {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}}
</fieldset> </dl>
<p class="submit"> </fieldset>
{{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} <p class="submit">
</p> {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}}
</form> </p>
</form>
{{else}}
{{:assign date_err=$now|date:'d/m/Y'}}
<p class="block error">Il n'y a aucun matériel disponible à la date du {{$date_err}}</p>
{{/if}}
{{else}} {{else}}
<p class="block error">Il n'y a aucun matériel en stock</p> <p class="block error">Il n'y a aucun matériel en stock</p>
{{/if}} {{/if}}

View File

@ -1,4 +1,5 @@
{{* {{* -*- brindille -*-
Vérifier la cohérence des E/S d'un matériel Vérifier la cohérence des E/S d'un matériel
- paramètres : - paramètres :
- movements : liste de mouvements - movements : liste de mouvements
@ -8,7 +9,7 @@
{{* récupérer la config des entrées/sorties *}} {{* récupérer la config des entrées/sorties *}}
{{:include file="../_get_config.html" keep="config"}} {{:include file="../_get_config.html" keep="config"}}
{{:assign erreur = false}} {{:assign erreur=false}}
{{:assign stock=0}} {{:assign stock=0}}
{{:assign exterieur=0}} {{:assign exterieur=0}}
{{:assign nonprop=0}} {{:assign nonprop=0}}
@ -35,7 +36,7 @@
{{:assign nonprop="%d-%d"|math:$nonprop:$mvt.amount}} {{:assign nonprop="%d-%d"|math:$nonprop:$mvt.amount}}
{{/if}} {{/if}}
{{/if}} {{/if}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}} {{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonprop < 0}} {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonprop < 0}}
{{:assign erreur=true}} {{:assign erreur=true}}
{{:break}} {{:break}}