Compare commits
7 Commits
Author | SHA1 | Date |
---|---|---|
Jean-Christophe Engel | 4bba00f8e5 | |
Jean-Christophe Engel | 8454c15225 | |
Jean-Christophe Engel | c1b9aa25c2 | |
Jean-Christophe Engel | 7575cc8a71 | |
Jean-Christophe Engel | 5e5c470a24 | |
Jean-Christophe Engel | 6b78d480f6 | |
Jean-Christophe Engel | 5eb8fa63fd |
|
@ -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"
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
},
|
},
|
||||||
"output_nature": {
|
"output_nature": {
|
||||||
"description": "Nature des sorties",
|
"description": "Nature des sorties",
|
||||||
"type": ["array", "null"],
|
"type": ["array", "null"],
|
||||||
"items": {
|
"items": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
|
|
|
@ -10,25 +10,60 @@
|
||||||
{{/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"
|
||||||
select="$$.date AS 'Date';
|
select="$$.date AS 'Date';
|
||||||
CASE $$.direction WHEN 'input' THEN 'Entrée' WHEN 'output' THEN 'Sortie' END AS 'Mvt';
|
CASE $$.direction WHEN 'input' THEN 'Entrée' WHEN 'output' THEN 'Sortie' END AS 'Mvt';
|
||||||
CASE $$.direction WHEN 'input' THEN $$.input_nature WHEN 'output' THEN $$.output_nature END AS 'Type';
|
CASE $$.direction WHEN 'input' THEN $$.input_nature WHEN 'output' THEN $$.output_nature END AS 'Type';
|
||||||
$$.amount AS 'Nombre';
|
$$.amount AS 'Nombre';
|
||||||
$$.comment AS 'Commentaire'"
|
$$.comment AS 'Commentaire'"
|
||||||
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}}
|
||||||
|
|
|
@ -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,14 +15,10 @@
|
||||||
{{* 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"}}
|
||||||
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
|
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
|
||||||
{{if $eqpmt.stock !== null && $eqpmt.stock !== 0}}
|
{{if $eqpmt.stock !== null && $eqpmt.stock !== 0}}
|
||||||
{{:assign present=true}}
|
{{:assign present=true}}
|
||||||
{{:break}}
|
{{:break}}
|
||||||
|
@ -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,14 +85,10 @@
|
||||||
{{* 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"}}
|
||||||
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
|
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
|
||||||
{{if $eqpmt.nonproprio !== null && $eqpmt.nonproprio !== 0}}
|
{{if $eqpmt.nonproprio !== null && $eqpmt.nonproprio !== 0}}
|
||||||
{{:assign present=true}}
|
{{:assign present=true}}
|
||||||
{{:break}}
|
{{:break}}
|
||||||
|
@ -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>
|
||||||
|
|
|
@ -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 *}}
|
||||||
|
@ -110,8 +121,8 @@
|
||||||
{{#load key=$mvt_modif.equipment assign="eqpmt"}}{{/load}}
|
{{#load key=$mvt_modif.equipment assign="eqpmt"}}{{/load}}
|
||||||
{{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}}
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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}}
|
||||||
|
|
|
@ -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}}
|
||||||
|
|
Loading…
Reference in New Issue