Compare commits
3 Commits
depositair
...
main
Author | SHA1 | Date | |
---|---|---|---|
bea3a2f0e8 | |||
d241546371 | |||
1478f7dbdc |
@ -1,14 +0,0 @@
|
|||||||
{{* -*- brindille -*- *}}
|
|
||||||
|
|
||||||
{{* déterminer la quantité des matériels sortis temporairement *}}
|
|
||||||
{{#foreach from=$cumul_mvt key="cat_key" item="cat_elem"}}
|
|
||||||
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
|
|
||||||
{{:assign quantite=$eqpmt.exterieur}}
|
|
||||||
{{if $quantite != 0}}
|
|
||||||
{{:assign
|
|
||||||
var="temporaire.%s.%s"|args:$cat_elem.name:$eqpmt_key
|
|
||||||
value="%s (quantité : %d)"|args:$eqpmt.name:$quantite
|
|
||||||
}}
|
|
||||||
{{/if}}
|
|
||||||
{{/foreach}}
|
|
||||||
{{/foreach}}
|
|
@ -13,55 +13,89 @@
|
|||||||
{{* 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"}}
|
||||||
|
|
||||||
{{* types d'entrées *}}
|
{{* déterminer le matériel concerné par le mouvement *}}
|
||||||
{{#foreach from=$config.input_nature key=key}}
|
{{#load key=$_GET.key assign="equipment"}}{{/load}}
|
||||||
{{if $type == 'retour'}}
|
|
||||||
{{:assign var="input_labels.%s"|args:$key value=$label}}
|
|
||||||
{{/if}}
|
|
||||||
{{/foreach}}
|
|
||||||
|
|
||||||
{{* Traiter l'envoi du formulaire *}}
|
{{*
|
||||||
|
-------------------- Traiter l'envoi du formulaire --------------------
|
||||||
|
*}}
|
||||||
{{#form on="save"}}
|
{{#form on="save"}}
|
||||||
{{* interdire date dans le futur *}}
|
{{* vérifier les données saisies *}}
|
||||||
|
{{if $_POST.amount <= 0}}
|
||||||
|
{{:error message="La quantité (%s) doit être strictement positive !!"|args:$_POST.amount}}
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
{{if $_POST.date|parse_date|strtotime > $now}}
|
{{if $_POST.date|parse_date|strtotime > $now}}
|
||||||
{{:error message="Impossible de saisir une date dans le futur (%s)"|args:$_POST.date}}
|
{{:error message="Impossible de saisir une date dans le futur (%s)"|args:$_POST.date}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
||||||
{{* récupérer les infos du matériel *}}
|
{{* préparer le nouveau mouvement *}}
|
||||||
{{#load type="equipment" key=$_GET.key assign="equipment"}}
|
{{:assign var="mvt_new.key" value=""|uuid}}
|
||||||
{{:assign name=$equipment.name}}
|
{{:assign var="mvt_new.direction" value="input"}}
|
||||||
{{/load}}
|
{{:assign var="mvt_new.date" value=$_POST.date|parse_date}}
|
||||||
|
{{:assign var="mvt_new.operation" value=$_POST.operation}}
|
||||||
|
{{:assign var="mvt_new.amount" value=$_POST.amount}}
|
||||||
|
|
||||||
{{* Extraire et compiler les infos de la base *}}
|
{{*
|
||||||
{{:include
|
lister les mouvements
|
||||||
file="../../_calcul_dispo.html"
|
- insérer le nouveau mvt à sa place par date croissante
|
||||||
keep="equipments"
|
*}}
|
||||||
eqpmt_key=$_GET.key
|
{{:assign insere=false}}
|
||||||
date=$_POST.date|parse_date
|
{{#load
|
||||||
|
where="
|
||||||
|
$$.type = 'movement'
|
||||||
|
AND
|
||||||
|
$$.equipment = :eqpmt_key"
|
||||||
|
:eqpmt_key=$equipment.key
|
||||||
|
order="$$.date"
|
||||||
|
assign="movement"
|
||||||
}}
|
}}
|
||||||
|
{{if! $insere}}
|
||||||
{{* déterminer la quantité sortie temporairement de ce matériel à la date donnée *}}
|
{{if
|
||||||
{{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}}
|
$mvt_new.direction == "input" && $date >= $mvt_new.date ||
|
||||||
|
$mvt_new.direction == "output" && $date > $mvt_new.date
|
||||||
{{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}}
|
{{:assign var="movements_new." from=mvt_new}}
|
||||||
|
{{:assign insere=true}}
|
||||||
|
{{/if}}
|
||||||
|
{{/if}}
|
||||||
|
{{:assign var="movements_new." from=movement}}
|
||||||
|
{{/load}}
|
||||||
|
{{if ! $insere}}
|
||||||
|
{{:assign var="movements_new." from=mvt_new}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
||||||
{{* Enregistrer le mouvement *}}
|
{{* Vérifier la cohérence des mouvements du matériel *}}
|
||||||
{{:assign mvt_key=""|uuid}}
|
{{:include
|
||||||
{{:save
|
file="../valider_modification.html"
|
||||||
key=$mvt_key
|
keep="erreur, pb"
|
||||||
validate_schema="../movement.schema.json"
|
movements=$movements_new
|
||||||
type="movement"
|
|
||||||
direction="input"
|
|
||||||
operation=$_POST.operation
|
|
||||||
amount=$_POST.quantite|intval
|
|
||||||
equipment=$equipment.key
|
|
||||||
date=$_POST.date|parse_date
|
|
||||||
comment=$_POST.remarques|trim
|
|
||||||
}}
|
}}
|
||||||
|
|
||||||
{{:redirect force="../../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$_GET.key}}
|
{{if $erreur}}
|
||||||
|
<p class="block error">Impossible d'enregistrer ce mouvement.
|
||||||
|
{{if $pb.mvt.key != $mvt_new.key}}
|
||||||
|
{{:assign var="err_mvt_label" from="config.input_nature.%s.label"|args:$pb.mvt.operation}}
|
||||||
|
<br />Mouvement incompatible avec
|
||||||
|
« {{$err_mvt_label}} de {{$equipment.name}} (qté : {{$pb.mvt.amount}})
|
||||||
|
en date du {{$pb.mvt.date|date_short}} ».
|
||||||
|
{{/if}}
|
||||||
|
</p>
|
||||||
|
{{else}}
|
||||||
|
{{* vérification réussie : enregistrer le mouvement modifié *}}
|
||||||
|
{{:save
|
||||||
|
key=""|uuid
|
||||||
|
validate_schema="../movement.schema.json"
|
||||||
|
type="movement"
|
||||||
|
direction="input"
|
||||||
|
operation=$_POST.operation
|
||||||
|
amount=$_POST.amount|intval
|
||||||
|
equipment=$equipment.key
|
||||||
|
date=$_POST.date|parse_date
|
||||||
|
comment=$_POST.comment|trim
|
||||||
|
}}
|
||||||
|
{{:redirect force="../../historique.html?ok=1&key=%s&prop=1&msg=retour"|args:$_GET.key}}
|
||||||
|
{{/if}}
|
||||||
{{/form}}
|
{{/form}}
|
||||||
|
|
||||||
{{:admin_header title="Retour de matériel" custom_css="./../../style.css" current="module_equipment"}}
|
{{:admin_header title="Retour de matériel" custom_css="./../../style.css" current="module_equipment"}}
|
||||||
@ -71,13 +105,15 @@
|
|||||||
{{:include file="../../_calcul_dispo.html" eqpmt_key=$_GET.key keep="categories, equipments"}}
|
{{:include file="../../_calcul_dispo.html" eqpmt_key=$_GET.key keep="categories, equipments"}}
|
||||||
{{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}}
|
{{:assign var=sorti from="equipments.%s.exterieur"|args:$_GET.key}}
|
||||||
|
|
||||||
|
{{* types d'entrées *}}
|
||||||
|
{{#foreach from=$config.input_nature key=key}}
|
||||||
|
{{if $type == 'retour'}}
|
||||||
|
{{:assign var="input_labels.%s"|args:$key value=$label}}
|
||||||
|
{{/if}}
|
||||||
|
{{/foreach}}
|
||||||
|
|
||||||
{{if $sorti > 0}}
|
{{if $sorti > 0}}
|
||||||
|
|
||||||
{{* déterminer le matériel concerné par le mouvement *}}
|
|
||||||
{{#load key=$_GET.key assign="equipment"}}
|
|
||||||
{{/load}}
|
|
||||||
{{:assign var=cat_name from=categories.%s|args:$equipment.category}}
|
{{:assign var=cat_name from=categories.%s|args:$equipment.category}}
|
||||||
|
|
||||||
{{* formulaire d'entrée de matériel *}}
|
{{* formulaire d'entrée de matériel *}}
|
||||||
<form method="post" action="">
|
<form method="post" action="">
|
||||||
<fieldset class="informations">
|
<fieldset class="informations">
|
||||||
@ -96,8 +132,8 @@
|
|||||||
<dl>
|
<dl>
|
||||||
{{:input type="select" name="operation" label="Type" required=true options=$input_labels|sort}}
|
{{:input type="select" name="operation" label="Type" required=true options=$input_labels|sort}}
|
||||||
{{: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="number" name="quantite" label="Quantité" min=1 required=true default=$sorti max=$sorti}}
|
{{:input type="number" name="amount" label="Quantité" min=1 required=true default=$sorti max=$sorti}}
|
||||||
{{:input type="textarea" name="remarques" label="Remarques" cols="40", rows="3" required=false}}
|
{{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false}}
|
||||||
</dl>
|
</dl>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<p class="submit">
|
<p class="submit">
|
||||||
|
@ -1,14 +0,0 @@
|
|||||||
{{* -*- brindille -*- *}}
|
|
||||||
|
|
||||||
{{* calculer les quantité de matériels dont l'asso n'est pas propriétaire *}}
|
|
||||||
{{#foreach from=$cumul_mvt key="cat_key" item="cat_elem"}}
|
|
||||||
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
|
|
||||||
{{:assign quantite="%d-%d"|math:$eqpmt.nonproprio:$eqpmt.retour}}
|
|
||||||
{{if $quantite != 0}}
|
|
||||||
{{:assign
|
|
||||||
var="temporaire.%s.%s"|args:$cat_elem.name:$eqpmt_key
|
|
||||||
value="%s (quantité : %d)"|args:$eqpmt.name:$quantite
|
|
||||||
}}
|
|
||||||
{{/if}}
|
|
||||||
{{/foreach}}
|
|
||||||
{{/foreach}}
|
|
@ -17,9 +17,10 @@
|
|||||||
{{:error message="Aucun matériel avec la clé « %s »"|args:$mvt_suppr.equipment}}
|
{{:error message="Aucun matériel avec la clé « %s »"|args:$mvt_suppr.equipment}}
|
||||||
{{/load}}
|
{{/load}}
|
||||||
|
|
||||||
|
{{* récupérer la config des entrées/sorties *}}
|
||||||
|
{{:include file="../_get_config.html" keep="config"}}
|
||||||
|
|
||||||
{{#form on="delete"}}
|
{{#form on="delete"}}
|
||||||
{{* récupérer la config des entrées/sorties *}}
|
|
||||||
{{:include file="../_get_config.html" keep="config"}}
|
|
||||||
|
|
||||||
{{* vérifier s'il est possible de supprimer le mouvement *}}
|
{{* vérifier s'il est possible de supprimer le mouvement *}}
|
||||||
{{if $mvt_suppr.direction == 'input'}}
|
{{if $mvt_suppr.direction == 'input'}}
|
||||||
@ -115,10 +116,11 @@
|
|||||||
{{:form_errors}}
|
{{:form_errors}}
|
||||||
|
|
||||||
{{:assign var="date_suppr" value="%s"|args:$mvt_suppr.date|date_short}}
|
{{:assign var="date_suppr" value="%s"|args:$mvt_suppr.date|date_short}}
|
||||||
|
{{:assign var="mvt_label" from="config.%s_nature.%s.label"|args:$mvt_suppr.direction:$mvt_suppr.operation}}
|
||||||
|
|
||||||
{{:delete_form
|
{{:delete_form
|
||||||
legend="Supprimer ?"
|
legend="Supprimer ?"
|
||||||
warning="Supprimer « %s (%d) en date du %s » ?"|args:$equipment.name:$mvt_suppr.amount:$date_suppr
|
warning="Supprimer le mouvement « %s de %s (quantité : %d) en date du %s » ?"|args:$mvt_label:$equipment.name:$mvt_suppr.amount:$date_suppr
|
||||||
}}
|
}}
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,6 +38,7 @@
|
|||||||
{{: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}}
|
||||||
|
{{:assign var="pb.mvt" value=$mvt}}
|
||||||
{{:break}}
|
{{:break}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{/foreach}}
|
{{/foreach}}
|
||||||
|
Loading…
Reference in New Issue
Block a user