Compare commits

...

3 Commits

6 changed files with 87 additions and 49 deletions

View File

@ -41,8 +41,11 @@
{{#form on="save"}} {{#form on="save"}}
{{* Vérifier s'il existe déjà une catégorie avec le même nom *}} {{* Vérifier s'il existe déjà une catégorie avec le même nom *}}
{{#load type="category" where="lower($$.name) = :name" :name=$_POST.name|trim|tolower}} {{#load type="category"}}
{{:error message="Impossible d'ajouter la catégorie « %s » car elle existe déjà !"|args:$name|trim}} {{if $name|tolower == $_POST.name|trim|tolower}}
{{:error message="Impossible d'ajouter la catégorie « %s » car elle existe déjà !"|args:$name|trim}}
{{:break}}
{{/if}}
{{/load}} {{/load}}
{{:assign key=""|uuid}} {{:assign key=""|uuid}}
@ -50,7 +53,7 @@
key=$key key=$key
validate_schema="./category.schema.json" validate_schema="./category.schema.json"
type="category" type="category"
name=$_POST.name|trim name=$_POST.name|trim|tolower|ucfirst
}} }}
{{:redirect to="./index.html?ok=1&msg=Catégorie enregistrée"}} {{:redirect to="./index.html?ok=1&msg=Catégorie enregistrée"}}
{{/form}} {{/form}}

View File

@ -99,35 +99,35 @@
{{if $direction === "input" && $type_mvt == 'temporaire'}} {{if $direction === "input" && $type_mvt == 'temporaire'}}
{{:linkbutton {{:linkbutton
label="Retour" label="Retour"
href="mouvements/sorties/emprunte.html?key=%s&prop=%s"|args:$key:$_GET.prop href="%smouvements/sorties/emprunte.html?key=%s&prop=%s"|args:$module.url:$key:$_GET.prop
shape="history" shape="history"
target="_dialog"}} target="_dialog"}}
{{elseif $direction === "input" && $type_mvt == 'définitif'}} {{elseif $direction === "input" && $type_mvt == 'définitif'}}
{{:linkbutton {{:linkbutton
label="Sortir" label="Sortir"
href="mouvements/sorties/stock_disponible.html?key=%s&prop=%s"|args:$key:$_GET.prop href="%smouvements/sorties/stock_disponible.html?key=%s&prop=%s"|args:$module.url:$key:$_GET.prop
shape="minus" shape="minus"
target="_dialog"}} target="_dialog"}}
{{elseif $direction === "output" && $type_mvt == 'temporaire'}} {{elseif $direction === "output" && $type_mvt == 'temporaire'}}
{{:linkbutton {{:linkbutton
label="Retour" label="Retour"
href="mouvements/entrees/retour.html?key=%s&prop=%s"|args:$key:$_GET.prop href="%smouvements/entrees/retour.html?key=%s&prop=%s"|args:$module.url:$key:$_GET.prop
shape="history" shape="history"
target="_dialog"}} target="_dialog"}}
{{/if}} {{/if}}
{{:linkbutton {{:linkbutton
label="Dupliquer" label="Dupliquer"
href="mouvements/dupliquer_mouvement.html?key=%s&direction=%s&prop=%s"|args:$key:$direction:$_GET.prop href="%smouvements/dupliquer_mouvement.html?key=%s&direction=%s&prop=%s"|args:$module.url:$key:$direction:$_GET.prop
shape="plus" shape="plus"
target="_dialog"}} target="_dialog"}}
{{:linkbutton {{:linkbutton
label="Modifier" label="Modifier"
href="mouvements/modifier_mouvement.html?key=%s&direction=%s&prop=%s"|args:$key:$direction:$_GET.prop href="%smouvements/modifier_mouvement.html?key=%s&direction=%s&prop=%s"|args:$module.url:$key:$direction:$_GET.prop
shape="edit" shape="edit"
target="_dialog"}} target="_dialog"}}
{{:linkbutton {{:linkbutton
label="Supprimer" label="Supprimer"
href="mouvements/supprimer_mouvement.html?key=%s&direction=%s&prop=%s"|args:$key:$direction:$_GET.prop href="%smouvements/supprimer_mouvement.html?key=%s&direction=%s&prop=%s"|args:$module.url:$key:$direction:$_GET.prop
shape="delete" shape="delete"
target="_dialog"}} target="_dialog"}}
</td> </td>

View File

@ -8,6 +8,8 @@
{{if $_GET.ok}} {{if $_GET.ok}}
{{if $_GET.msg == "ajout" }} {{if $_GET.msg == "ajout" }}
<p class="block confirm">Ajout effectué</p> <p class="block confirm">Ajout effectué</p>
{{elseif $_GET.msg == "modification" }}
<p class="block confirm">Modification effectuée</p>
{{else}} {{else}}
<p class="block confirm">{{$_GET.msg}}</p> <p class="block confirm">{{$_GET.msg}}</p>
{{/if}} {{/if}}
@ -22,6 +24,9 @@
{{if $category_keys|count == 0}} {{if $category_keys|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}}
<fieldset>
{{:linkbutton label="Ajouter un nouveau matériel" shape="plus" href="mouvements/ajouter_entree.html" target="_dialog"}}
</fieldset>
{{:include file="./inventaire.html" print_cat_name=true}} {{:include file="./inventaire.html" print_cat_name=true}}
{{/if}} {{/if}}

View File

@ -2,10 +2,6 @@
{{* 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 *}}
<fieldset>
{{:linkbutton label="Ajouter un nouveau matériel" shape="plus" href="mouvements/ajouter_entree.html" target="_dialog"}}
</fieldset>
{{* 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,equipments"}} {{:include file="./_calcul_dispo.html" keep="cumul_mvt,category_keys,equipments"}}
@ -57,7 +53,7 @@
{{* itérer sur les matériels de la catégorie *}} {{* itérer sur les matériels de la catégorie *}}
{{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}} {{#foreach from=$cat_elem.eqpmt key="eqpmt_key" item="eqpmt"}}
{{:assign keys=$eqpmt|keys}} {{:assign keys=$eqpmt|keys}}
{{if "stock"|in:$keys && $eqpmt.stock !== 0}} {{if "stock"|in:$keys}} {{* && $eqpmt.stock !== 0}}*}}
{{if "exterieur"|in:$keys}} {{if "exterieur"|in:$keys}}
{{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}}
{{:assign exterieur=$eqpmt.exterieur}} {{:assign exterieur=$eqpmt.exterieur}}
@ -73,11 +69,11 @@
<td class="actions"> <td class="actions">
{{:linkbutton {{:linkbutton
label="Mouvements" label="Mouvements"
href="historique.html?key=%s&prop=1"|args:$eqpmt_key href="%shistorique.html?key=%s&prop=1"|args:$module.url:$eqpmt_key
shape="table"}} shape="table"}}
{{:linkbutton {{:linkbutton
label="Modifier" label="Modifier"
href="modifier_materiel.html?key=%s"|args:$eqpmt_key href="%smodifier_materiel.html?key=%s"|args:$module.url:$eqpmt_key
shape="edit" shape="edit"
target="_dialog"}} target="_dialog"}}
</td> </td>

View File

@ -1,5 +1,10 @@
{{* -*- brindille -*- *}} {{* -*- brindille -*- *}}
{{*
Paramètres :
- key : clé du matériel à modifier
*}}
{{:admin_header title="Modifier matériel" current="module_equipment"}} {{:admin_header title="Modifier matériel" current="module_equipment"}}
{{:assign equipment_key=$_GET.key|trim}} {{:assign equipment_key=$_GET.key|trim}}
@ -49,7 +54,7 @@
category=$category.key category=$category.key
designation=$_POST.designation|trim designation=$_POST.designation|trim
}} }}
{{:redirect force="index.html?ok=1"}} {{:redirect force="index.html?ok=1&msg=modification"}}
{{else}} {{else}}
{{:form_errors}} {{:form_errors}}

View File

@ -17,6 +17,15 @@
{{/if}} {{/if}}
{{/foreach}} {{/foreach}}
{{* lister les catégories et les matériels disponibles *}}
{{#load type="category" assign="category" order="$$.name"}}
{{:assign nom_cat=$category.name}}
{{:assign var="categories.%s"|args:$category.key value=$category.name}}
{{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment"}}
{{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value=$equipment.designation}}
{{/load}}
{{/load}}
{{* Traiter l'envoi du formulaire *}} {{* Traiter l'envoi du formulaire *}}
{{#form on="save"}} {{#form on="save"}}
@ -42,26 +51,42 @@
{{if $_POST.equipment == null}} {{if $_POST.equipment == null}}
{{* récupérer les infos de la catégorie *}} {{* récupérer les infos de la catégorie *}}
{{#load type="category" key=$_POST.category assign="category"}} {{#load type="category" key=$_POST.category assign="post_category"}}
{{/load}} {{/load}}
{{* vérifier l'existence d'un matériel du même nom *}} {{* vérifier l'existence d'un matériel du même nom *}}
{{#load type="equipment" where="lower($$.designation) = :name" :name=$_POST.designation|trim|tolower}} {{:assign post_mat=$_POST.designation|trim|tolower|ucfirst}}
{{:assign present=false}}
{{#foreach from=$equipments key=nom_cat item=eqpmt}}
{{#foreach from=$eqpmt key=key item=nom}}
{{if $_POST.designation|trim|tolower == $nom|tolower}}
{{:assign equipment_key=$key}}
{{:assign present=true}}
{{:break}}
{{/if}}
{{/foreach}}
{{if $present}}{{:break}}{{/if}}
{{/foreach}}
{{if $present}}
{{* voir si le matériel existe dans une autre catégorie *}}
{{if $nom_cat != $post_category.name}}
{{:assign message="Le matériel « %s » est déjà présent dans la catégorie « %s » ..."|args:$post_mat:$nom_cat}}
{{:error message=$message}}
{{/if}}
{{* utiliser la clé du matériel trouvé *}} {{* utiliser la clé du matériel trouvé *}}
{{:assign equipment_key=$key}}
{{else}} {{else}}
{{* nouveau matériel => nouvelle clé *}} {{* nouveau matériel => nouvelle clé *}}
{{:assign equipment_key=""|uuid}} {{:assign equipment_key=""|uuid}}
{{* enregistrer un nouveau matériel *}} {{* enregistrer un nouveau matériel *}}
{{:save {{:save
key=$equipment_key key=$equipment_key
validate_schema="../equipment.schema.json" validate_schema="../equipment.schema.json"
type="equipment" type="equipment"
category=$category.key category=$category.key
designation=$_POST.designation|trim designation=$post_mat
}} }}
{{/load}} {{/if}}
{{/if}} {{/if}}
{{* Enregistrer le mouvement *}} {{* Enregistrer le mouvement *}}
@ -80,28 +105,18 @@
comment=$_POST.remarques|trim comment=$_POST.remarques|trim
}} }}
{{:assign msg="Ajout de l'entrée de « %s (%d) en date du %s » effectué"|args:$_POST.designation:$_POST.quantite:$_POST.date}} {{:assign msg="Ajout de l'entrée « %s (%d) en date du %s » effectué"|args:$post_mat:$_POST.quantite:$_POST.date}}
{{:debug msg=$msg}} {{:redirect force="../index.html?ok=1&msg=%s"|args:$msg}}
{{*:redirect force="./index.html?ok=1&msg=%s"|args:$msg*}}
{{else}} {{else}}
{{:form_errors}} {{:form_errors}}
{{/form}} {{/form}}
{{* lister les catégories disponibles *}}
{{#load type="category" assign="category" order="$$.name"}}
{{:assign nom_cat=$category.name}}
{{:assign var="categories.%s"|args:$category.key value=$category.name}}
{{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment"}}
{{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value=$equipment.designation}}
{{/load}}
{{/load}}
{{if $categories != null}} {{if $categories != null}}
{{* formulaire d'ajout de matériel *}} {{* formulaire ajout matériel *}}
<form method="post" action=""> <form method="post" action="">
<fieldset class="entree"> <fieldset class="entree">
<legend>Ajouter une entrée d'un matériel non répertorié</legend> <legend>Ajouter une entrée de matériel</legend>
<dl> <dl>
{{: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}}
@ -109,22 +124,36 @@
</dl> </dl>
</fieldset> </fieldset>
{{if $equipments != null}}
<h3 style="margin-top: 1em;margin-bottom: 1em;">Choisir un matériel dans la liste ou Sélectionner une catégorie et indiquer le nom du nouveau matériel</h3>
{{/if}}
<fieldset> <fieldset>
<legend>Choisir un matériel dans la liste ou sélectionner une catégorie et indiquer le nom du nouveau matériel</legend> <div class="choix" style="display:flex;">
<dl>
{{if $equipments != null}} {{if $equipments != null}}
<fieldset> <fieldset>
<div class="toto"> <legend>Choisir un matériel dans la liste</legend>
<dl>
{{:input type="select_groups" name="equipment" label="Matériel" options=$equipments}} {{:input type="select_groups" name="equipment" label="Matériel" options=$equipments}}
</div> </dl>
</fieldset> </fieldset>
<h3 style="margin: 1em;">&nbsp;</h3>
{{/if}} {{/if}}
<fieldset> <fieldset>
<div class="toto"> <legend>Sélectionner une catégorie et indiquer le nom du nouveau matériel</legend>
{{:input type="select" name="category" label="Catégorie" options=$categories}} <dl>
{{:input type="text" name="designation" label="Désignation"}} <div class="toto">
</div> {{if $equipments == null}}
{{:assign required=true}}
{{else}}
{{:assign required=false}}
{{/if}}
{{:input type="select" name="category" label="Catégorie" options=$categories required=$required}}
{{:input type="text" name="designation" label="Désignation" required=$required}}
</div>
</dl>
</fieldset> </fieldset>
</div>
<dl>
{{: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>
</fieldset> </fieldset>