Compare commits

..

3 Commits

7 changed files with 151 additions and 165 deletions

View File

@ -3,35 +3,38 @@
{{* {{*
Calcul des entrées/sorties de matériels à une date donnée Calcul des entrées/sorties de matériels à une date donnée
paramètres : paramètres :
- category_keys : liste de clés de catégories - key : clé du matériel concerné
- date : date supérieure des mouvements - cat_key : clé de la catégorie des matériels concernés
résultat : cumul_mvt,category_keys,equipments - date
résultat :
- categories : tableau clé => nom
- equipments : tableau clé => { clé cat, libellé mat, stock, exter, nonproprio }
*}} *}}
{{* liste des catégories *}} {{* liste des matériels *}}
{{if $category_keys === null}} {{:assign equipments=null}}
{{#load type="category"}} {{if $_GET.key}}
{{:assign var="cumul_mvt.%s.name"|args:$key value=$name}} {{* le matériel paramètre *}}
{{#load key=$_GET.key}}
{{:assign var="equipments.%s.category"|args:$key value=$category}}
{{:assign var="equipments.%s.designation"|args:$key value=$designation}}
{{:assign var="in_equipments." value="'%s'"|args:$key}}
{{/load}}
{{elseif $_GET.cat_key}}
{{* matériels de la catégorie paramètre *}}
{{#load type="equipment" where="$$.category = :category_key" :category_key=$_GET.cat_key}}
{{:assign var="equipments.%s.category"|args:$key value=$category}}
{{:assign var="equipments.%s.designation"|args:$key value=$designation}}
{{:assign var="in_equipments." value="'%s'"|args:$key}}
{{/load}} {{/load}}
{{else}} {{else}}
{{#load type="category" where="key"|sql_where:'IN':$category_keys}} {{* tous les matériels *}}
{{:assign var="cumul_mvt.%s.name"|args:$key value=$name}} {{#load type="equipment"}}
{{:assign var="equipments.%s.category"|args:$key value=$category}}
{{:assign var="equipments.%s.designation"|args:$key value=$designation}}
{{:assign var="in_equipments." value="'%s'"|args:$key}}
{{/load}} {{/load}}
{{/if}} {{/if}}
{{#foreach from=$cumul_mvt key="cat_key" item="elem"}}
{{:assign var="in_categories." value="'%s'"|args:$cat_key}}
{{/foreach}}
{{:assign in_categories=$in_categories|implode:","}}
{{:assign in_categories="("|cat:$in_categories|cat:")"}}
{{* liste des matériels dans les catégories passées en paramètre *}}
{{#load type="equipment" where="$$.category IN %s"|args:$in_categories}}
{{:assign var="equipments.%s.category"|args:$key value=$category}}
{{:assign var="equipments.%s.designation"|args:$key value=$designation}}
{{:assign var="in_equipments." value="'%s'"|args:$key}}
{{/load}}
{{:assign in_equipments=$in_equipments|implode:","}} {{:assign in_equipments=$in_equipments|implode:","}}
{{:assign in_equipments="("|cat:$in_equipments|cat:")"}} {{:assign in_equipments="("|cat:$in_equipments|cat:")"}}
@ -109,12 +112,9 @@
from=nonproprio}} from=nonproprio}}
{{/if}} {{/if}}
{{/if}} {{/if}}
{{/load}} {{/load}}
{{* grouper les résultats par catégorie *}} {{* catégories *}}
{{#foreach from=$equipments key="eqpmt_key" item="eqpmt"}} {{#load type="category" order="$$.name"}}
{{:assign {{:assign var="categories.%s"|args:$key value=$name}}
var="cumul_mvt.%s.eqpmt.%s"|args:$eqpmt.category:$eqpmt_key {{/load}}
value=$eqpmt}}
{{/foreach}}

View File

@ -22,11 +22,9 @@
<p class="block error">Modification refusée</p> <p class="block error">Modification refusée</p>
{{/if}} {{/if}}
{{#load type="category"}} {{#load type="category" count=true assign="result"}}{{/load}}
{{:assign var="category_keys." value=$key}}
{{/load}}
{{if $category_keys|count == 0}} {{if $result.count == 0}}
<p class="block alert">Il n'y a aucune catégorie : vous devez en ajouter.</p> <p class="block alert">Il n'y a aucune catégorie : vous devez en ajouter.</p>
{{else}} {{else}}
{{if $_GET.prop == null || $_GET.prop}} {{if $_GET.prop == null || $_GET.prop}}

View File

@ -2,12 +2,28 @@
{{* {{*
inventaire des entrées/sorties des matériels permanents inventaire des entrées/sorties des matériels permanents
paramètres
- category_keys : catégories dont on veut faire l'inventaire
*}} *}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{:include file="./_calcul_dispo.html" keep="cumul_mvt,equipments"}} {{:include file="./_calcul_dispo.html" keep="categories,equipments"}}
{{* Sélecteur catégories *}}
<fieldset class="shortForm" style="width: 30%;">
<legend>Filtrer par catégorie</legend>
<nav class="dropdown">
<ul>
<li><a></a></li>
<li{{if $_GET.cat_key == null}} class="selected"{{/if}}><a href="?prop=1">Toutes les catégories</a></li>
{{#foreach from=$categories key=key item=name}}
<li {{if $_GET.cat_key == $key}}class="selected"{{/if}}>
<a href="?cat_key={{$key}}&prop=1">
<strong>{{$name}}</strong>
</a>
</li>
{{/foreach}}
</ul>
</nav>
</fieldset>
{{* Vérifier s'il y a au moins un matériel propriété de l'asso *}} {{* Vérifier s'il y a au moins un matériel propriété de l'asso *}}
{{:assign mat_present=false}} {{:assign mat_present=false}}
@ -20,50 +36,29 @@
{{if $mat_present}} {{if $mat_present}}
{{* Sélecteur catégories *}}
<fieldset class="shortForm" style="width: 30%;">
<legend>Filtrer par catégorie</legend>
<nav class="dropdown">
<ul>
<li><a></a></li>
<li{{if $_GET.cat_key == null}} class="selected"{{/if}}><a href="?prop=1">Toutes les catégories</a></li>
{{#load type="category" assign="category" order="$$.name"}}
<li {{if $_GET.cat_key == $key}}class="selected"{{/if}}>
<a href="?cat_key={{$key}}&prop=1">
<strong>{{$category.name}}</strong>
</a>
</li>
{{/load}}
</ul>
</nav>
</fieldset>
<h2>Matériels propriété de l'association</h2> <h2>Matériels propriété de l'association</h2>
{{#list {{#list
select=" select="
(SELECT $$.designation $$.designation AS 'Matériel' ;
FROM @TABLE AS b "" AS 'Catégorie' ;
WHERE b.key = @TABLE.$$.equipment) AS 'Matériel' ;
"" as 'Catégorie' ;
"" AS 'Stock' ; "" AS 'Stock' ;
"" AS 'Sorti' ; "" AS 'Sorti' ;
"" AS 'Dispo' "" AS 'Dispo'
" "
type="movement" type="equipment"
group="$$.equipment"
direction="input"
order=1 order=1
}} }}
{{:assign var=eqpmt_key value=$key}}
{{:assign var=cat_key value=$category}}
{{:assign var=cat_name from=categories.%s|args:$cat_key}}
{{:assign var=cat_key from="equipments.%s.category"|args:$equipment}}
{{if $_GET.cat_key != null && $_GET.cat_key != $cat_key}} {{if $_GET.cat_key != null && $_GET.cat_key != $cat_key}}
{{:continue}} {{:continue}}
{{/if}} {{/if}}
{{:assign var=cat_name from="cumul_mvt.%s.name"|args:$cat_key}} {{:assign var=stock from="equipments.%s.stock"|args:$eqpmt_key}}
{{:assign var=stock from="equipments.%s.stock"|args:$equipment}} {{:assign var=exterieur from="equipments.%s.exterieur"|args:$eqpmt_key}}
{{:assign var=exterieur from="equipments.%s.exterieur"|args:$equipment}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}} {{:assign dispo="%d-%d"|math:$stock:$exterieur}}
{{if $stock == null}} {{if $stock == null}}
@ -71,7 +66,7 @@
{{/if}} {{/if}}
<tr> <tr>
<td>{{$col1}}</td> <td>{{$designation}}</td>
<td>{{$cat_name}}</td> <td>{{$cat_name}}</td>
<td>{{$stock}}</td> <td>{{$stock}}</td>
<td>{{if $exterieur == null}}0{{else}}{{$exterieur}}{{/if}}</td> <td>{{if $exterieur == null}}0{{else}}{{$exterieur}}{{/if}}</td>
@ -80,7 +75,7 @@
{{if $exterieur > 0}} {{if $exterieur > 0}}
{{:linkbutton {{:linkbutton
label="Retour" label="Retour"
href="mouvements/entrees/retour.html?key=%s"|args:$equipment href="mouvements/entrees/retour.html?key=%s"|args:$eqpmt_key
shape="history" shape="history"
target="_dialog"}} target="_dialog"}}
{{/if}} {{/if}}
@ -88,21 +83,21 @@
{{:linkbutton {{:linkbutton
label="Sortie" label="Sortie"
shape="plus" shape="plus"
href="mouvements/sorties/stock_disponible.html?key=%s"|args:$equipment href="mouvements/sorties/stock_disponible.html?key=%s"|args:$eqpmt_key
target="_dialog"}} target="_dialog"}}
{{/if}} {{/if}}
{{:linkbutton {{:linkbutton
label="Entrée" label="Entrée"
shape="plus" shape="plus"
href="mouvements/entrees/repertorie.html?key=%s"|args:$equipment href="mouvements/entrees/repertorie.html?key=%s"|args:$eqpmt_key
target="_dialog"}} target="_dialog"}}
{{:linkbutton {{:linkbutton
label="Mouvements" label="Mouvements"
href="historique.html?key=%s&prop=1"|args:$equipment href="historique.html?key=%s&prop=1"|args:$eqpmt_key
shape="table"}} shape="table"}}
{{:linkbutton {{:linkbutton
label="Modifier" label="Modifier"
href="modifier_materiel.html?key=%s&prop=1"|args:$equipment href="modifier_materiel.html?key=%s&prop=1"|args:$eqpmt_key
shape="edit" shape="edit"
target="_dialog"}} target="_dialog"}}
</td> </td>

View File

@ -2,12 +2,28 @@
{{* {{*
inventaire des entrées/sorties des matériels temporaires inventaire des entrées/sorties des matériels temporaires
paramètres
- category_keys : catégories dont on veut faire l'inventaire
*}} *}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{:include file="./_calcul_dispo.html" keep="cumul_mvt,equipments"}} {{:include file="./_calcul_dispo.html" keep="categories,equipments"}}
{{* Sélecteur catégories *}}
<fieldset class="shortForm" style="width: 30%;">
<legend>Filtrer par catégorie</legend>
<nav class="dropdown">
<ul>
<li><a></a></li>
<li{{if $_GET.cat_key == null}} class="selected"{{/if}}><a href="?prop=0">Toutes les catégories</a></li>
{{#foreach from=$categories key=key item=name}}
<li {{if $_GET.cat_key == $key}}class="selected"{{/if}}>
<a href="?cat_key={{$key}}&prop=0">
<strong>{{$name}}</strong>
</a>
</li>
{{/foreach}}
</ul>
</nav>
</fieldset>
{{* Vérifier s'il y a au moins un matériel non propriété de l'asso *}} {{* Vérifier s'il y a au moins un matériel non propriété de l'asso *}}
{{:assign mat_present=false}} {{:assign mat_present=false}}
@ -20,75 +36,55 @@
{{if $mat_present}} {{if $mat_present}}
{{* Sélecteur catégories *}}
<fieldset class="shortForm" style="width: 30%;">
<legend>Filtrer par catégorie</legend>
<nav class="dropdown">
<ul>
<li><a></a></li>
<li{{if $_GET.cat_key == null}} class="selected"{{/if}}><a href="?prop=0">Toutes les catégories</a></li>
{{#load type="category" assign="category" order="$$.name"}}
<li {{if $_GET.cat_key == $key}}class="selected"{{/if}}>
<a href="?cat_key={{$key}}&prop=0">
<strong>{{$category.name}}</strong>
</a>
</li>
{{/load}}
</ul>
</nav>
</fieldset>
<h2>Matériels temporairement dans l'association</h2> <h2>Matériels temporairement dans l'association</h2>
{{#list {{#list
select=" select="
(SELECT $$.designation $$.designation AS 'Matériel' ;
FROM @TABLE AS b "" AS 'Catégorie' ;
WHERE b.key = @TABLE.$$.equipment) AS 'Matériel' ;
"" as 'Catégorie' ;
"" AS 'Quantité' "" AS 'Quantité'
" "
type="movement" type="equipment"
group="$$.equipment"
direction="input"
order=1 order=1
}} }}
{{:assign var=eqpmt_key value=$key}}
{{:assign var=cat_key value=$category}}
{{:assign var=cat_name from=categories.%s|args:$cat_key}}
{{:assign var=cat_key from="equipments.%s.category"|args:$equipment}}
{{if $_GET.cat_key != null && $_GET.cat_key != $cat_key}} {{if $_GET.cat_key != null && $_GET.cat_key != $cat_key}}
{{:continue}} {{:continue}}
{{/if}} {{/if}}
{{:assign var=cat_name from="cumul_mvt.%s.name"|args:$cat_key}} {{:assign var=qte from="equipments.%s.nonproprio"|args:$eqpmt_key}}
{{:assign var=qte from="equipments.%s.nonproprio"|args:$equipment}}
{{if $qte == null}} {{if $qte == null}}
{{:continue}} {{:continue}}
{{/if}} {{/if}}
<tr> <tr>
<td>{{$col1}}</td> <td>{{$designation}}</td>
<td>{{$cat_name}}</td> <td>{{$cat_name}}</td>
<td>{{$qte}}</td> <td>{{$qte}}</td>
<td class="actions"> <td class="actions">
{{if $qte > 0}} {{if $qte > 0}}
{{:linkbutton {{:linkbutton
label="Retour" label="Retour"
href="mouvements/sorties/emprunte.html?key=%s"|args:$equipment href="mouvements/sorties/emprunte.html?key=%s"|args:$eqpmt_key
shape="history" shape="history"
target="_dialog"}} target="_dialog"}}
{{/if}} {{/if}}
{{:linkbutton {{:linkbutton
label="Entrée" label="Entrée"
shape="plus" shape="plus"
href="mouvements/entrees/repertorie.html?key=%s"|args:$equipment href="mouvements/entrees/repertorie.html?key=%s"|args:$eqpmt_key
target="_dialog"}} target="_dialog"}}
{{:linkbutton {{:linkbutton
label="Mouvements" label="Mouvements"
href="historique.html?key=%s&prop=0"|args:$equipment href="historique.html?key=%s&prop=0"|args:$eqpmt_key
shape="table"}} shape="table"}}
{{:linkbutton {{:linkbutton
label="Modifier" label="Modifier"
href="modifier_materiel.html?key=%s&prop=0"|args:$equipment href="modifier_materiel.html?key=%s&prop=0"|args:$eqpmt_key
shape="edit" shape="edit"
target="_dialog"}} target="_dialog"}}
</td> </td>

View File

@ -5,7 +5,7 @@
- key : clé du matériel qui revient - key : clé du matériel qui revient
*}} *}}
{{:admin_header title="Entrée de matériel" current="module_equipment"}} {{:admin_header title="Retour de matériel" current="module_equipment"}}
{{* barre de navigation *}} {{* barre de navigation *}}
{{if ! $dialog}} {{if ! $dialog}}
@ -27,19 +27,18 @@
{{* 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}} {{:assign designation=$equipment.designation}}
{{:assign var="categories." value=$equipment.category}}
{{/load}} {{/load}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{:include {{:include
file="../../_calcul_dispo.html" file="../../_calcul_dispo.html"
keep="cumul_mvt" keep="equipments"
date=$_POST.date|parse_date date=$_POST.date|parse_date
}} }}
{{* déterminer la quantité sortie temporairement de ce matériel à la date donnée *}} {{* déterminer la quantité sortie temporairement de ce matériel à la date donnée *}}
{{:assign var=sorti from="cumul_mvt.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_GET.key}} {{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}}
{{*:debug cumul_mvt=$cumul_mvt sorti=$sorti*}}
{{if $_POST.quantite|intval > $sorti}} {{if $_POST.quantite|intval > $sorti}}
{{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle sortie (%d) à la date du %s"|args:$_POST.quantite:$sorti:$_POST.date}} {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle sortie (%d) à la date du %s"|args:$_POST.quantite:$sorti:$_POST.date}}
{{/if}} {{/if}}
@ -61,13 +60,12 @@
}} }}
{{:redirect force="../../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$_GET.key}} {{:redirect force="../../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$_GET.key}}
{{else}} {{else}}
{{:form_errors}} {{:form_errors}}
{{/form}} {{/form}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{:include file="../../_calcul_dispo.html" keep="cumul_mvt,equipments"}} {{:include file="../../_calcul_dispo.html" keep="categories, equipments"}}
{{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}} {{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}}
{{if $sorti > 0}} {{if $sorti > 0}}
@ -75,8 +73,7 @@
{{* 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}}
{{#load key=$equipment.category assign="category"}} {{:assign var=cat_name from=categories.%s|args:$equipment.category}}
{{/load}}
{{* formulaire d'entrée de matériel *}} {{* formulaire d'entrée de matériel *}}
<form method="post" action=""> <form method="post" action="">
@ -86,9 +83,9 @@
{{:input type="select" name="type_operation" label="Type" required=true options=$input_labels}} {{:input type="select" name="type_operation" label="Type" required=true options=$input_labels}}
{{:input type="date" name="date" label="Date" required=true default=$now|date_short}} {{:input type="date" name="date" label="Date" 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="sorti" label="Qté sortie" disabled=true default=$sorti}} {{:input type="text" name="sorti" label="Quantité sortie" disabled=true default=$sorti}}
<p><span class="alert">La quantité indiquée est celle à la date du jour</span></p> <p><span class="alert">La quantité sortie est celle à la date du jour</span></p>
{{:input type="number" name="quantite" label="Quantité" min=1 required=true default=1}} {{:input type="number" name="quantite" label="Quantité" min=1 required=true default=1}}
{{: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}}
</dl> </dl>

View File

@ -2,9 +2,7 @@
{{* {{*
paramètres : paramètres :
- key : clé du matériel à modifier - key : clé du matériel à rendre
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,11 @@
{{* 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 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 insere=true}}
{{:assign dispo="%d-%d"|math:$stock:$exterieur}} {{:assign dispo_old=$nonproprio}}
{{:assign nonproprio="%d-%d"|math:$nonproprio:$_POST.quantite}}
{{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonproprio < 0}} {{if $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 +71,22 @@
{{/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=$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 *}} {{* 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,7 +106,7 @@
{{/form}} {{/form}}
{{* Extraire et compiler les infos de la base *}} {{* Extraire et compiler les infos de la base *}}
{{:include file="../../_calcul_dispo.html" keep="cumul_mvt,equipments"}} {{:include file="../../_calcul_dispo.html" keep="equipments"}}
{{:assign var=present from="equipments.%s.nonproprio"|args:$_GET.key}} {{:assign var=present from="equipments.%s.nonproprio"|args:$_GET.key}}
{{if $present > 0}} {{if $present > 0}}
@ -129,7 +123,7 @@
{{: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="present" label="Qté présente" disabled=true default=$present}} {{:input type="text" name="present" label="Qté présente" disabled=true default=$present}}
<p><span class="alert">La quantité indiquée est celle à la date du jour</span></p> <p><span class="alert">La quantité présente 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}}
{{: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}}
</dl> </dl>

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">