diff --git a/_calcul_dispo.html b/_calcul_dispo.html index 3723868..11f06dc 100644 --- a/_calcul_dispo.html +++ b/_calcul_dispo.html @@ -1,134 +1,134 @@ {{* - Calcul des entrées/sorties de matériels à une date donnée - paramètres : - - liste de catégories - - date + Calcul des entrées/sorties de matériels à une date donnée + paramètres : + - liste de catégories + - date *}} {{* liste des catégories *}} {{if $categories === null}} - {{#load type="category"}} - {{:assign var="categories." value=$key}} - {{/load}} + {{#load type="category"}} + {{:assign var="categories." value=$key}} + {{/load}} {{/if}} {{* date *}} {{if $date === null}} - {{* :assign date=$now|date:"Y-m-d" *}} - {{:assign date="31/12/9999"|parse_date}} - {{* si on veut aussi lister les mouvements du futur :-) *}} + {{* :assign date=$now|date:"Y-m-d" *}} + {{:assign date="31/12/9999"|parse_date}} + {{* si on veut aussi lister les mouvements du futur :-) *}} {{/if}} {{* Extraire et compiler les infos de la base *}} {{#select - json_extract(mvt.document, '$.date') as 'date', - eqpmt.key as 'eqpmt_key', - json_extract(eqpmt.document, '$.designation') as 'designation', - cat.key as 'cat_key', - json_extract(cat.document, '$.name') as 'category', - mvt.key as 'mvt_key', - json_extract(mvt.document, '$.direction') as 'direction', - CASE json_extract(mvt.document, '$.direction') - WHEN 'input' THEN json_extract(mvt.document, '$.input_nature') - WHEN 'output' THEN json_extract(mvt.document, '$.output_nature') - END - AS 'operation', - json_extract(mvt.document, '$.amount') AS 'nombre' - FROM module_data_equipment as eqpmt - INNER JOIN module_data_equipment as cat - ON json_extract(eqpmt.document, '$.category') = cat.key - INNER JOIN module_data_equipment as mvt - ON json_extract(mvt.document, '$.equipment') = eqpmt.key - WHERE json_extract(eqpmt.document, '$.type') = "equipment" - AND !categories - AND json_extract(mvt.document, '$.date') <= :date - ORDER BY - json_extract(cat.document, '$.name'), - json_extract(eqpmt.document, '$.designation'), - json_extract(mvt.document, '$.date'); - !categories='cat_key'|sql_where:'IN':$categories - :date=$date + json_extract(mvt.document, '$.date') as 'date', + eqpmt.key as 'eqpmt_key', + json_extract(eqpmt.document, '$.designation') as 'designation', + cat.key as 'cat_key', + json_extract(cat.document, '$.name') as 'category', + mvt.key as 'mvt_key', + json_extract(mvt.document, '$.direction') as 'direction', + CASE json_extract(mvt.document, '$.direction') + WHEN 'input' THEN json_extract(mvt.document, '$.input_nature') + WHEN 'output' THEN json_extract(mvt.document, '$.output_nature') + END + AS 'operation', + json_extract(mvt.document, '$.amount') AS 'nombre' + FROM module_data_equipment as eqpmt + INNER JOIN module_data_equipment as cat + ON json_extract(eqpmt.document, '$.category') = cat.key + INNER JOIN module_data_equipment as mvt + ON json_extract(mvt.document, '$.equipment') = eqpmt.key + WHERE json_extract(eqpmt.document, '$.type') = "equipment" + AND !categories + AND json_extract(mvt.document, '$.date') <= :date + ORDER BY + json_extract(cat.document, '$.name'), + json_extract(eqpmt.document, '$.designation'), + json_extract(mvt.document, '$.date'); + !categories='cat_key'|sql_where:'IN':$categories + :date=$date }} - {{:assign - var="equipments.%s.name"|args:$cat_key - value=$category}} - {{:assign - var="equipments.%s.eqpmt.%s.designation"|args:$cat_key:$eqpmt_key - value=$designation}} + {{:assign + var="equipments.%s.name"|args:$cat_key + value=$category}} + {{:assign + var="equipments.%s.eqpmt.%s.designation"|args:$cat_key:$eqpmt_key + value=$designation}} - {{* matériel propriété de l'asso en stock *}} - {{:assign - var="stock" - from="equipments.%s.eqpmt.%s.stock"|args:$cat_key:$eqpmt_key}} - {{if $stock === null}} - {{:assign stock=0}} - {{/if}} + {{* matériel propriété de l'asso en stock *}} + {{:assign + var="stock" + from="equipments.%s.eqpmt.%s.stock"|args:$cat_key:$eqpmt_key}} + {{if $stock === null}} + {{:assign stock=0}} + {{/if}} - {{* matériel propriété de l'asso à l'extérieur *}} - {{:assign - var="exterieur" - from="equipments.%s.eqpmt.%s.exterieur"|args:$cat_key:$eqpmt_key}} - {{if $exterieur === null}} - {{:assign exterieur=0}} - {{/if}} + {{* matériel propriété de l'asso à l'extérieur *}} + {{:assign + var="exterieur" + from="equipments.%s.eqpmt.%s.exterieur"|args:$cat_key:$eqpmt_key}} + {{if $exterieur === null}} + {{:assign exterieur=0}} + {{/if}} - {{* matériel non propriété de l'asso *}} - {{:assign - var="nonproprio" - from="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key}} - {{if $nonproprio === null}} - {{:assign nonproprio=0}} - {{/if}} + {{* matériel non propriété de l'asso *}} + {{:assign + var="nonproprio" + from="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key}} + {{if $nonproprio === null}} + {{:assign nonproprio=0}} + {{/if}} - {{* récupérer la config des entrées/sorties *}} - {{:include file="./_get_config.html" keep="config"}} + {{* récupérer la config des entrées/sorties *}} + {{:include file="./_get_config.html" keep="config"}} - {{if $direction === 'input'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$config.input_nature item="elem"}} - {{if $operation == $elem.label}} - {{if $elem.type == 'définitif'}} - {{:assign stock="%d+%d"|math:$stock:$nombre}} - {{:assign - var="equipments.%s.eqpmt.%s.stock"|args:$cat_key:$eqpmt_key - from=stock}} - {{elseif $elem.type == 'retour'}} - {{:assign exterieur="%d-%d"|math:$exterieur:$nombre}} - {{:assign - var="equipments.%s.eqpmt.%s.exterieur"|args:$cat_key:$eqpmt_key - from=exterieur}} - {{elseif $elem.type == 'temporaire'}} - {{:assign nonproprio="%d+%d"|math:$nonproprio:$nombre}} - {{:assign - var="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key - from=nonproprio}} - {{/if}} - {{:break}} - {{/if}} - {{/foreach}} - {{elseif $direction === 'output'}} - {{* chercher le type de sortie parmi les types de la config *}} - {{#foreach from=$config.output_nature item="elem"}} - {{if $operation == $elem.label}} - {{if $elem.type == 'définitif'}} - {{:assign stock="%d-%d"|math:$stock:$nombre}} - {{:assign - var="equipments.%s.eqpmt.%s.stock"|args:$cat_key:$eqpmt_key - from=stock}} - {{elseif $elem.type == 'temporaire'}} - {{:assign exterieur="%d+%d"|math:$exterieur:$nombre}} - {{:assign - var="equipments.%s.eqpmt.%s.exterieur"|args:$cat_key:$eqpmt_key - from=exterieur}} - {{elseif $elem.type == 'retour'}} - {{:assign nonproprio="%d-%d"|math:$nonproprio:$nombre}} - {{:assign - var="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key - from=nonproprio}} - {{/if}} - {{:break}} - {{/if}} - {{/foreach}} - {{/if}} + {{if $direction === 'input'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$config.input_nature item="elem"}} + {{if $operation == $elem.label}} + {{if $elem.type == 'définitif'}} + {{:assign stock="%d+%d"|math:$stock:$nombre}} + {{:assign + var="equipments.%s.eqpmt.%s.stock"|args:$cat_key:$eqpmt_key + from=stock}} + {{elseif $elem.type == 'retour'}} + {{:assign exterieur="%d-%d"|math:$exterieur:$nombre}} + {{:assign + var="equipments.%s.eqpmt.%s.exterieur"|args:$cat_key:$eqpmt_key + from=exterieur}} + {{elseif $elem.type == 'temporaire'}} + {{:assign nonproprio="%d+%d"|math:$nonproprio:$nombre}} + {{:assign + var="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key + from=nonproprio}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{elseif $direction === 'output'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$config.output_nature item="elem"}} + {{if $operation == $elem.label}} + {{if $elem.type == 'définitif'}} + {{:assign stock="%d-%d"|math:$stock:$nombre}} + {{:assign + var="equipments.%s.eqpmt.%s.stock"|args:$cat_key:$eqpmt_key + from=stock}} + {{elseif $elem.type == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$nombre}} + {{:assign + var="equipments.%s.eqpmt.%s.exterieur"|args:$cat_key:$eqpmt_key + from=exterieur}} + {{elseif $elem.type == 'retour'}} + {{:assign nonproprio="%d-%d"|math:$nonproprio:$nombre}} + {{:assign + var="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key + from=nonproprio}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{/if}} {{/select}} diff --git a/_get_config.html b/_get_config.html index a1b1c36..5da627b 100644 --- a/_get_config.html +++ b/_get_config.html @@ -1,6 +1,6 @@ {{* - Récupérer soit la config enregistrée, soit la config par défaut - résultat : config.input_nature et config.output_nature + Récupérer soit la config enregistrée, soit la config par défaut + résultat : config.input_nature et config.output_nature *}} {{* config par défaut *}} @@ -8,29 +8,27 @@ {{:assign config_defaut=$config_defaut|json_decode}} {{if $module.config.input_nature != null}} - {{:assign var=config.input_nature value=$module.config.input_nature}} + {{:assign var=config.input_nature value=$module.config.input_nature}} {{else}} - {{* pas de config enregistrée : utiliser la config par défaut *}} - {{#foreach from=$config_defaut.inputs item="elem"}} - {{#foreach from=$elem key=label item=value}} - {{:assign var="item.label" value=$label}} - {{:assign var="item.type" value=$value}} - {{:assign var="config.input_nature." value=$item}} - {{/foreach}} - {{/foreach}} + {{* pas de config enregistrée : utiliser la config par défaut *}} + {{#foreach from=$config_defaut.inputs item="elem"}} + {{#foreach from=$elem key=label item=value}} + {{:assign var="item.label" value=$label}} + {{:assign var="item.type" value=$value}} + {{:assign var="config.input_nature." value=$item}} + {{/foreach}} + {{/foreach}} {{/if}} {{if $module.config.output_nature != null}} - {{:assign var=config.output_nature value=$module.config.output_nature}} + {{:assign var=config.output_nature value=$module.config.output_nature}} {{else}} - {{* pas de config enregistrée : utiliser la config par défaut *}} - {{#foreach from=$config_defaut.outputs item="elem"}} - {{#foreach from=$elem key=label item=value}} - {{:assign var="item.label" value=$label}} - {{:assign var="item.type" value=$value}} - {{:assign var="config.output_nature." value=$item}} - {{/foreach}} - {{/foreach}} + {{* pas de config enregistrée : utiliser la config par défaut *}} + {{#foreach from=$config_defaut.outputs item="elem"}} + {{#foreach from=$elem key=label item=value}} + {{:assign var="item.label" value=$label}} + {{:assign var="item.type" value=$value}} + {{:assign var="config.output_nature." value=$item}} + {{/foreach}} + {{/foreach}} {{/if}} - - diff --git a/_nav.html b/_nav.html index 34036a9..4aab958 100644 --- a/_nav.html +++ b/_nav.html @@ -1,9 +1,9 @@ diff --git a/categories/category.schema.json b/categories/category.schema.json index 7ac0daf..aa22047 100644 --- a/categories/category.schema.json +++ b/categories/category.schema.json @@ -1,14 +1,14 @@ { - "$schema": "https://json-schema.org/draft/2020-12/schema", - "type": "object", - "properties": { - "type": { - "type": "string", - "enum": ["category"] - }, - "name": { - "type": "string" - } - }, - "required": ["type", "name"] + "$schema": "https://json-schema.org/draft/2020-12/schema", + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": ["category"] + }, + "name": { + "type": "string" + } + }, + "required": ["type", "name"] } diff --git a/categories/delete_category.html b/categories/delete_category.html index fa24360..a2c5dfc 100644 --- a/categories/delete_category.html +++ b/categories/delete_category.html @@ -7,19 +7,18 @@ {{/load}} {{#form on="delete"}} - {{* Vérifier s'il reste des matériels dans cette catégorie *}} - {{#load type="equipment" category=$_GET.key assign="equipment"}} - {{:redirect force="./index.html?err=1&msg=suppression"}} - {{else}} - {{* supprimer la catégorie sélectionnée*}} - {{:delete where="key = :key" :key=$category.key}} - {{:redirect force="./index.html?ok=1&msg=suppression"}} - {{/load}} - + {{* Vérifier s'il reste des matériels dans cette catégorie *}} + {{#load type="equipment" category=$_GET.key assign="equipment"}} + {{:redirect force="./index.html?err=1&msg=suppression"}} + {{else}} + {{* supprimer la catégorie sélectionnée*}} + {{:delete where="key = :key" :key=$category.key}} + {{:redirect force="./index.html?ok=1&msg=suppression"}} + {{/load}} {{/form}} {{:delete_form - legend="Supprimer une catégorie" - warning="Supprimer la catégorie « %s » ?"|args:$category.name - info="La suppression n'est possible que si la catégorie ne possède plus de matériel" + legend="Supprimer une catégorie" + warning="Supprimer la catégorie « %s » ?"|args:$category.name + info="La suppression n'est possible que si la catégorie ne possède plus de matériel" }} diff --git a/categories/index.html b/categories/index.html index 4d0af27..6693241 100644 --- a/categories/index.html +++ b/categories/index.html @@ -5,68 +5,68 @@ {{:include file="../_nav.html" current="categories"}} {{if $_GET.ok}} - {{if $_GET.msg == "modification"}} -

Modification enregistrée

- {{elseif $_GET.msg == "suppression"}} -

Catégorie supprimée

- {{/if}} + {{if $_GET.msg == "modification"}} +

Modification enregistrée

+ {{elseif $_GET.msg == "suppression"}} +

Catégorie supprimée

+ {{/if}} {{elseif $_GET.err}} - {{if $_GET.msg == "modification"}} -

{{$_GET.msg}}

- {{elseif $_GET.msg == "suppression"}} -

- Cette catégorie ne peut être supprimée car elle contient encore des matériels -

- {{/if}} + {{if $_GET.msg == "modification"}} +

{{$_GET.msg}}

+ {{elseif $_GET.msg == "suppression"}} +

+ Cette catégorie ne peut être supprimée car elle contient encore des matériels +

+ {{/if}} {{/if}} {{* afficher les catégories déjà enregistrées *}}
- {{#list select="$$.name AS 'Catégorie'" order="1" where="$$.type = 'category'"}} - - {{$name}} - - {{:linkbutton label="Liste des matériels" href="list_equipment.html?key=%s&dialog"|args:$key shape="search" target="_dialog"}} - {{:linkbutton label="Modifier" href="modify_category.html?key=%s"|args:$key shape="edit" target="_dialog"}} - {{:linkbutton label="Supprimer" href="delete_category.html?key=%s"|args:$key shape="delete" target="_dialog"}} - - - {{else}} -

Il n'y a aucune catégorie : vous devez en ajouter.

- {{/list}} + {{#list select="$$.name AS 'Catégorie'" order="1" where="$$.type = 'category'"}} + + {{$name}} + + {{:linkbutton label="Liste des matériels" href="list_equipment.html?key=%s&dialog"|args:$key shape="search" target="_dialog"}} + {{:linkbutton label="Modifier" href="modify_category.html?key=%s"|args:$key shape="edit" target="_dialog"}} + {{:linkbutton label="Supprimer" href="delete_category.html?key=%s"|args:$key shape="delete" target="_dialog"}} + + + {{else}} +

Il n'y a aucune catégorie : vous devez en ajouter.

+ {{/list}}
{{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* 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}} - {{:error message="Impossible d'ajouter la catégorie « %s » car elle existe déjà !"|args:$name|trim}} - {{/load}} + {{* 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}} + {{:error message="Impossible d'ajouter la catégorie « %s » car elle existe déjà !"|args:$name|trim}} + {{/load}} - {{:assign key=""|uuid}} - {{:save - key=$key - validate_schema="./category.schema.json" - type="category" - name=$_POST.name|trim - }} - {{:redirect to="./index.html?ok=1&msg=Catégorie enregistrée"}} + {{:assign key=""|uuid}} + {{:save + key=$key + validate_schema="./category.schema.json" + type="category" + name=$_POST.name|trim + }} + {{:redirect to="./index.html?ok=1&msg=Catégorie enregistrée"}} {{/form}} {{:form_errors}} {{* formulaire d'ajout de catégorie *}}
-
- Ajouter une catégorie -
- {{:input type="text" name="name" label="Nom" required=true maxlength="100"}} -
-

- {{:button type="submit" name="save" label="Ajouter" shape="right" class="main"}} -

-
+
+ Ajouter une catégorie +
+ {{:input type="text" name="name" label="Nom" required=true maxlength="100"}} +
+

+ {{:button type="submit" name="save" label="Ajouter" shape="right" class="main"}} +

+
{{:admin_footer}} diff --git a/categories/list_equipment.html b/categories/list_equipment.html index d2dae21..30f8fa2 100644 --- a/categories/list_equipment.html +++ b/categories/list_equipment.html @@ -1,18 +1,18 @@ {{#restrict section="accounting" level="read" block=true}}{{/restrict}} {{#load key=$_GET.key}} - {{:assign cat_name=$name}} + {{:assign cat_name=$name}} {{/load}} {{:admin_header title="Matériels de la catégorie « %s »"|args:$cat_name current="module_equipment"}} {{if $_GET.dialog === null}} - {{* barre de navigation *}} - {{:include file="../_nav.html" current="categories"}} + {{* barre de navigation *}} + {{:include file="../_nav.html" current="categories"}} {{else}} -
-

Matériels de la catégorie « {{$cat_name}} »

-
+
+

Matériels de la catégorie « {{$cat_name}} »

+
{{/if}} {{:assign var="categories." value=$_GET.key}} diff --git a/categories/modify_category.html b/categories/modify_category.html index 1234afc..a94da6c 100644 --- a/categories/modify_category.html +++ b/categories/modify_category.html @@ -8,26 +8,26 @@ {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{:save - key=$category.key - validate_schema="./category.schema.json" - type="category" - name=$_POST.name|trim - }} - {{:redirect force="./index.html?ok=1&msg=modification"}} + {{:save + key=$category.key + validate_schema="./category.schema.json" + type="category" + name=$_POST.name|trim + }} + {{:redirect force="./index.html?ok=1&msg=modification"}} {{/form}} {{:form_errors}} {{* formulaire de modification de catégorie *}}
-
- Modifier la catégorie « {{$category.name}} » -
- {{:input type="text" name="name" label="Nom" default=$category.name required=true maxlength="100"}} -
-

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

-
+
+ Modifier la catégorie « {{$category.name}} » +
+ {{:input type="text" name="name" label="Nom" default=$category.name required=true maxlength="100"}} +
+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

+
diff --git a/config.html b/config.html index afdea1d..24729a7 100644 --- a/config.html +++ b/config.html @@ -5,18 +5,18 @@ {{:include file="_nav.html" current="config"}} {{if $_GET.ok}} -

Configuration enregistrée.

+

Configuration enregistrée.

{{/if}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{:save key="config" - validate_schema="./config.schema.json" - input_nature=$_POST.input_fields|array_transpose - output_nature=$_POST.output_fields|array_transpose - }} - {{:redirect to="./config.html?ok=1"}} + {{:save key="config" + validate_schema="./config.schema.json" + input_nature=$_POST.input_fields|array_transpose + output_nature=$_POST.output_fields|array_transpose + }} + {{:redirect to="./config.html?ok=1"}} {{/form}} {{* config par défaut *}} @@ -25,214 +25,212 @@ {{* types d'entrées *}} {{#foreach from=$config_defaut.inputs item="elem"}} - {{#foreach from=$elem key=label item=value}} - {{:assign var='input_types.%s'|args:$value value=$value}} - {{/foreach}} + {{#foreach from=$elem key=label item=value}} + {{:assign var='input_types.%s'|args:$value value=$value}} + {{/foreach}} {{/foreach}} {{* types de sorties *}} {{#foreach from=$config_defaut.outputs item="elem"}} - {{#foreach from=$elem key=label item=value}} - {{:assign var='output_typess.%s'|args:$value value=$value}} - {{/foreach}} + {{#foreach from=$elem key=label item=value}} + {{:assign var='output_typess.%s'|args:$value value=$value}} + {{/foreach}} {{/foreach}}
-
- Entrées - - - - - - - - - - {{#foreach from=$module.config.input_nature item="input_field"}} +
+ Entrées +
Nature de l'entréeTypeAction
+ + + + + + + + + {{#foreach from=$module.config.input_nature item="input_field"}} - {{* Vérifier si la suppression de ce type d'entrée est possible *}} - {{:assign suppr=true}} - {{#load type="movement" where="$$.input_nature = :libelle" :libelle=$input_field.label}} - {{:assign suppr=false}} - {{/load}} + {{* Vérifier si la suppression de ce type d'entrée est possible *}} + {{:assign suppr=true}} + {{#load type="movement" where="$$.input_nature = :libelle" :libelle=$input_field.label}} + {{:assign suppr=false}} + {{/load}} - - - - - - {{else}} - {{* pas de config enregistrée : utiliser les valeurs par défaut *}} - {{#foreach from=$config_defaut.inputs item="elem"}} - {{#foreach from=$elem key=label item=value}} + + + + + + {{else}} + {{* pas de config enregistrée : utiliser les valeurs par défaut *}} + {{#foreach from=$config_defaut.inputs item="elem"}} + {{#foreach from=$elem key=label item=value}} - {{* Vérifier si la suppression de ce type d'entrée est possible *}} - {{:assign suppr=true}} - {{#load type="movement" where="$$.input_nature = :libelle" :libelle=$label}} - {{:assign suppr=false}} - {{/load}} + {{* Vérifier si la suppression de ce type d'entrée est possible *}} + {{:assign suppr=true}} + {{#load type="movement" where="$$.input_nature = :libelle" :libelle=$label}} + {{:assign suppr=false}} + {{/load}} - - - - - - {{/foreach}} - {{/foreach}} - {{/foreach}} - -
Nature de l'entréeTypeAction
{{:input type="text" name="input_fields[label][]" default=$input_field.label}}{{:input type="select" - name="input_fields[type][]" - options=$input_types - default=$input_field.type - required=true - default_empty="— Choisir un type —"}} - - {{if $suppr}} - {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} - {{else}} - {{:button label="Supprimer" shape="minus" disabled=true}} - {{/if}} -
{{:input type="text" name="input_fields[label][]" default=$input_field.label}}{{:input type="select" + name="input_fields[type][]" + options=$input_types + default=$input_field.type + required=true + default_empty="— Choisir un type —"}} + + {{if $suppr}} + {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} + {{else}} + {{:button label="Supprimer" shape="minus" disabled=true}} + {{/if}} +
{{:input type="text" name="input_fields[label][]" default=$label}}{{:input - type="select" - name="input_fields[type][]" - options=$input_types - required=true - default=$value - default_empty="— Choisir un type —"}} - - {{if $suppr}} - {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} - {{else}} - {{:button label="Supprimer" shape="minus" disabled=true}} - {{/if}} -
-

- {{:button shape="plus" - label="Ajouter un champ" - onclick="addLine('#input_body')"}} -

-
-

Signification du type d'entrée

-
    -
  • définitif : l'asso devient propriétaire du matériel (ex : achat, don)
  • -
  • temporaire : l'asso ne devient pas propriétaire du matériel (ex : location, emprunt)
  • -
  • retour : matériel qui revient après une sortie temporaire (ex : retour de location ou de prêt)
  • -
-
-
+ + {{:input type="text" name="input_fields[label][]" default=$label}} + {{:input + type="select" + name="input_fields[type][]" + options=$input_types + required=true + default=$value + default_empty="— Choisir un type —"}} + + + {{if $suppr}} + {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} + {{else}} + {{:button label="Supprimer" shape="minus" disabled=true}} + {{/if}} + + + {{/foreach}} + {{/foreach}} + {{/foreach}} + + +

+ {{:button shape="plus" label="Ajouter un champ" onclick="addLine('#input_body')"}} +

+
+

Signification du type d'entrée

+ +
+ -
- Sorties - - - - - - - - - - {{#foreach from=$module.config.output_nature item="output_field"}} +
+ Sorties +
Nature de la sortieTypeAction
+ + + + + + + + + {{#foreach from=$module.config.output_nature item="output_field"}} - {{* Vérifier si la suppression de ce type de sortie est possible *}} - {{:assign suppr=true}} - {{#load type="movement" where="$$.output_nature = :libelle" :libelle=$output_field.label}} - {{:assign suppr=false}} - {{/load}} + {{* Vérifier si la suppression de ce type de sortie est possible *}} + {{:assign suppr=true}} + {{#load type="movement" where="$$.output_nature = :libelle" :libelle=$output_field.label}} + {{:assign suppr=false}} + {{/load}} - - - - - - {{else}} - {{* pas de config enregistrée : utiliser les valeurs par défaut *}} - {{#foreach from=$config_defaut.outputs item="elem"}} - {{#foreach from=$elem key=label item=value}} + + + + + + {{else}} + {{* pas de config enregistrée : utiliser les valeurs par défaut *}} + {{#foreach from=$config_defaut.outputs item="elem"}} + {{#foreach from=$elem key=label item=value}} - {{* Vérifier si la suppression de ce type de sortie est possible *}} - {{:assign suppr=true}} - {{#load type="movement" where="$$.input_nature = :libelle" :libelle=$label}} - {{:assign suppr=false}} - {{/load}} + {{* Vérifier si la suppression de ce type de sortie est possible *}} + {{:assign suppr=true}} + {{#load type="movement" where="$$.input_nature = :libelle" :libelle=$label}} + {{:assign suppr=false}} + {{/load}} - - - - - - {{/foreach}} - {{/foreach}} - {{/foreach}} - -
Nature de la sortieTypeAction
{{:input type="text" name="output_fields[label][]" default=$output_field.label}}{{:input - type="select" - name="output_fields[type][]" - options=$output_typess - default=$output_field.type - required=true - default_empty="— Choisir un type —"}} - - {{if $suppr}} - {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} - {{else}} - {{:button label="Supprimer" shape="minus" disabled=true}} - {{/if}} -
{{:input type="text" name="output_fields[label][]" default=$output_field.label}}{{:input + type="select" + name="output_fields[type][]" + options=$output_typess + default=$output_field.type + required=true + default_empty="— Choisir un type —"}} + + {{if $suppr}} + {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} + {{else}} + {{:button label="Supprimer" shape="minus" disabled=true}} + {{/if}} +
{{:input type="text" name="output_fields[label][]" default=$label}}{{:input - type="select" - name="output_fields[type][]" - options=$output_typess - required=true - default=$value - default_empty="— Choisir un type —"}} - - {{if $suppr}} - {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} - {{else}} - {{:button label="Supprimer" shape="minus" disabled=true}} - {{/if}} -
-

- {{:button shape="plus" - label="Ajouter un champ" - onclick="addLine('#output_body')"}} -

-
-

Signification du type de sortie

-
    -
  • définitif : le matériel n'appartient plus à l'asso (ex : vente, casse, perte, vol, ...)
  • -
  • temporaire : le matériel sort temporairement de l'asso qui en reste propriétaire (ex : location, prêt)
  • -
  • retour : le matériel non propriété de l'asso est rendu à son propriétaire (ex : retour de location ou d'emprunt)
  • - -
-
+ + {{:input type="text" name="output_fields[label][]" default=$label}} + {{:input + type="select" + name="output_fields[type][]" + options=$output_typess + required=true + default=$value + default_empty="— Choisir un type —"}} + + + {{if $suppr}} + {{:button label="Supprimer" shape="minus" onclick="this.parentNode.parentNode.remove();"}} + {{else}} + {{:button label="Supprimer" shape="minus" disabled=true}} + {{/if}} + + + {{/foreach}} + {{/foreach}} + {{/foreach}} + + +

+ {{:button shape="plus" + label="Ajouter un champ" + onclick="addLine('#output_body')"}} +

+
+

Signification du type de sortie

+
+ -

- {{:button - type="submit" - name="save" - label="Enregistrer" - shape="right" - class="main" - }} -

+

+ {{:button + type="submit" + name="save" + label="Enregistrer" + shape="right" + class="main" + }} +

{{:admin_footer}} diff --git a/config.schema.json b/config.schema.json index 78c909e..0bd2fcb 100644 --- a/config.schema.json +++ b/config.schema.json @@ -1,38 +1,38 @@ { - "$schema": "https://json-schema.org/draft/2020-12/schema", - "type": "object", - "properties": { - "input_nature": { - "description": "Nature des entrées", - "type": ["array", "null"], - "items": { - "type": "object", - "properties": { - "label" : { - "type" : "string" - }, - "type" : { - "type" : "string", - "enum" : ["définitif", "temporaire", "retour"] - } - } - } - }, - "output_nature": { - "description": "Nature des sorties", - "type": ["array", "null"], - "items": { - "type": "object", - "properties": { - "label" : { - "type" : "string" - }, - "type" : { - "type" : "string", - "enum" : ["définitif", "temporaire", "retour"] - } - } - } - } - } + "$schema": "https://json-schema.org/draft/2020-12/schema", + "type": "object", + "properties": { + "input_nature": { + "description": "Nature des entrées", + "type": ["array", "null"], + "items": { + "type": "object", + "properties": { + "label" : { + "type" : "string" + }, + "type" : { + "type" : "string", + "enum" : ["définitif", "temporaire", "retour"] + } + } + } + }, + "output_nature": { + "description": "Nature des sorties", + "type": ["array", "null"], + "items": { + "type": "object", + "properties": { + "label" : { + "type" : "string" + }, + "type" : { + "type" : "string", + "enum" : ["définitif", "temporaire", "retour"] + } + } + } + } + } } diff --git a/defaut.json b/defaut.json index 710f9e1..404b161 100644 --- a/defaut.json +++ b/defaut.json @@ -1,12 +1,12 @@ { - "inputs" : [ - { "Achat" : "définitif" }, - { "Location" : "temporaire" }, - { "Retour de Location/Prêt" : "retour" } - ], - "outputs" : [ - { "Vente" : "définitif" }, - { "Prêt" : "temporaire" }, - { "Retour de Location/Emprunt" : "retour" } - ] + "inputs" : [ + { "Achat" : "définitif" }, + { "Location" : "temporaire" }, + { "Retour de Location/Prêt" : "retour" } + ], + "outputs" : [ + { "Vente" : "définitif" }, + { "Prêt" : "temporaire" }, + { "Retour de Location/Emprunt" : "retour" } + ] } diff --git a/equipment.schema.json b/equipment.schema.json index c6c5758..4757344 100644 --- a/equipment.schema.json +++ b/equipment.schema.json @@ -1,19 +1,19 @@ { - "$schema": "https://json-schema.org/draft/2020-12/schema", - "type": "object", - "properties": { - "type": { - "type": "string", - "enum": ["equipment"] + "$schema": "https://json-schema.org/draft/2020-12/schema", + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": ["equipment"] + }, + "category" : { + "description": "Clé de la catégorie", + "type": "string" + }, + "designation": { + "description": "Désignation du matériel", + "type": "string" + } }, - "category" : { - "description": "Clé de la catégorie", - "type": "string" - }, - "designation": { - "description": "Désignation du matériel", - "type": "string" - } - }, - "required": ["type", "category", "designation"] + "required": ["type", "category", "designation"] } diff --git a/historique.html b/historique.html index 2d98b80..6f9972b 100644 --- a/historique.html +++ b/historique.html @@ -4,37 +4,37 @@ {{:assign equipment_key=$_GET.key|trim}} {{#load key=$_GET.key assign="equipment"}} {{else}} - {{:error message="Pas de matériel avec la clé %s"|args:$equipment_key}} + {{:error message="Pas de matériel avec la clé %s"|args:$equipment_key}} {{/load}} {{#load type="category" where="key = :cle" :cle=$equipment.category assign="category"}} {{else}} - {{:error message="Le matériel %s n'appartient à aucune catégorie"|args:$equipment.designation}} + {{:error message="Le matériel %s n'appartient à aucune catégorie"|args:$equipment.designation}} {{/load}}
-

Historique des mouvements de {{$equipment.designation}} ({{$category.name}})

+

Historique des mouvements de {{$equipment.designation}} ({{$category.name}})

{{* lister tous les mouvements du matériel passé en paramètre *}} {{#list - type="movement" - select="$$.date AS 'Date'; - 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'; - $$.amount AS 'Nombre'; - $$.comment AS 'Commentaire'" - equipment=$equipment_key - order=1 + type="movement" + select="$$.date AS 'Date'; + 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'; + $$.amount AS 'Nombre'; + $$.comment AS 'Commentaire'" + equipment=$equipment_key + order=1 }} - - {{$date|date_short}} - {{$col2}} - {{$col3}} - {{$amount}} - {{$comment}} - - + + {{$date|date_short}} + {{$col2}} + {{$col3}} + {{$amount}} + {{$comment}} + + {{/list}} {{:admin_footer}} diff --git a/index.html b/index.html index beb1e95..fa18dc9 100644 --- a/index.html +++ b/index.html @@ -4,19 +4,19 @@ {{:include file="_nav.html" current="index"}} {{if $_GET.ok}} -

Modification effectuée

+

Modification effectuée

{{elseif $_GET.err}} -

Modification refusée

+

Modification refusée

{{/if}} {{#load type="category"}} - {{:assign var="categories." value=$key}} + {{:assign var="categories." value=$key}} {{/load}} {{if $categories|count == 0}} -

Il n'y a aucune catégorie : vous devez en ajouter.

+

Il n'y a aucune catégorie : vous devez en ajouter.

{{else}} - {{:include file="./inventaire.html" print_cat_name=true}} + {{:include file="./inventaire.html" print_cat_name=true}} {{/if}} {{:admin_footer}} diff --git a/inventaire.html b/inventaire.html index e72fe5b..e705abf 100644 --- a/inventaire.html +++ b/inventaire.html @@ -6,140 +6,139 @@ {{* Afficher les résultats *}} {{if $equipments === null}} - {{if $categories|count == 1}} -

Il n'y a aucun matériel dans cette catégorie.

- {{else}} -

Il n'y a aucun matériel dans ces catégories.

- {{/if}} + {{if $categories|count == 1}} +

Il n'y a aucun matériel dans cette catégorie.

+ {{else}} +

Il n'y a aucun matériel dans ces catégories.

+ {{/if}} {{else}} +
+

Matériels dont l'association est propriétaire

-
-

Matériels dont l'association est propriétaire

+ {{* itérer sur les catégories *}} + {{#foreach from=$equipments key="cat_key" item="category"}} - {{* itérer sur les catégories *}} - {{#foreach from=$equipments key="cat_key" item="category"}} + {{* vérifier s'il y a des matériels dans cette catégorie *}} + {{:assign present=false}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} + {{if $eqpmt.stock !== null && $eqpmt.stock !== 0}} + {{:assign present=true}} + {{:break}} + {{/if}} + {{/foreach}} - {{* vérifier s'il y a des matériels dans cette catégorie *}} - {{:assign present=false}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{if $eqpmt.stock !== null && $eqpmt.stock !== 0}} - {{:assign present=true}} - {{:break}} - {{/if}} - {{/foreach}} + {{if $print_cat_name}} +

{{$category.name}}

+ {{/if}} - {{if $print_cat_name}} -

{{$category.name}}

- {{/if}} + {{if $present}} + + + + + + + + + + + - {{if $present}} -
DésignationStockSortieDisponible
- - - - - - - - - - + {{* itérer sur les matériels de la catégorie *}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{* itérer sur les matériels de la catégorie *}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} + {{:assign keys=$eqpmt|keys}} + {{if "stock"|in:$keys && $eqpmt.stock !== 0}} + {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} + + + + + + + + {{/if}} + {{else}} +

Il n'y a aucun matériel dans cette catégorie.

+ {{/foreach}} + +
DésignationStockSortieDisponible
{{$eqpmt.designation}}{{$eqpmt.stock}}{{if $eqpmt.exterieur == null}}0{{else}}{{$eqpmt.exterieur}}{{/if}}{{$dispo}} + {{:linkbutton + label="Historique des mouvements" + href="%shistorique.html?key=%s"|args:$module.url:$eqpmt_key + shape="table" + target="_dialog"}} + {{:linkbutton + label="Modifier" + href="%smodifier_materiel.html?key=%s"|args:$module.url:$eqpmt_key + shape="edit" + target="_dialog"}} +
+ {{else}} +

Il n'y a aucun matériel dans cette catégorie.

+ {{/if}} + {{/foreach}} - {{:assign keys=$eqpmt|keys}} - {{if "stock"|in:$keys && $eqpmt.stock !== 0}} - {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} - - {{$eqpmt.designation}} - {{$eqpmt.stock}} - {{if $eqpmt.exterieur == null}}0{{else}}{{$eqpmt.exterieur}}{{/if}} - {{$dispo}} - - {{:linkbutton - label="Historique des mouvements" - href="%shistorique.html?key=%s"|args:$module.url:$eqpmt_key - shape="table" - target="_dialog"}} - {{:linkbutton - label="Modifier" - href="%smodifier_materiel.html?key=%s"|args:$module.url:$eqpmt_key - shape="edit" - target="_dialog"}} - - - {{/if}} - {{else}} -

Il n'y a aucun matériel dans cette catégorie.

- {{/foreach}} - - - {{else}} -

Il n'y a aucun matériel dans cette catégorie.

- {{/if}} - {{/foreach}} +

Matériels dont l'association n'est pas propriétaire

-

Matériels dont l'association n'est pas propriétaire

+ {{* itérer sur les catégories *}} + {{#foreach from=$equipments key="cat_key" item="category"}} - {{* itérer sur les catégories *}} - {{#foreach from=$equipments key="cat_key" item="category"}} + {{* vérifier s'il y a des matériels dans cette catégorie *}} + {{:assign present=false}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} + {{if $eqpmt.nonproprio !== null && $eqpmt.nonproprio !== 0}} + {{:assign present=true}} + {{:break}} + {{/if}} + {{/foreach}} - {{* vérifier s'il y a des matériels dans cette catégorie *}} - {{:assign present=false}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{if $eqpmt.nonproprio !== null && $eqpmt.nonproprio !== 0}} - {{:assign present=true}} - {{:break}} - {{/if}} - {{/foreach}} + {{if $print_cat_name}} +

{{$category.name}}

+ {{/if}} - {{if $print_cat_name}} -

{{$category.name}}

- {{/if}} + {{if $present}} + + + + + + + + + - {{if $present}} -
DésignationQuantité
- - - - - - - - + {{* itérer sur les matériels de la catégorie *}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{* itérer sur les matériels de la catégorie *}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - - {{:assign keys=$eqpmt|keys}} - {{if "nonproprio"|in:$keys && $eqpmt.nonproprio !== 0}} - {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} - - - - - - {{/if}} - {{else}} -

Il n'y a aucun matériel dans cette catégorie.

- {{/foreach}} - -
DésignationQuantité
{{$eqpmt.designation}}{{$eqpmt.nonproprio}} - {{:linkbutton - label="Historique des mouvements" - href="%shistorique.html?key=%s"|args:$module.url:$eqpmt_key - shape="table" - target="_dialog"}} - {{:linkbutton - label="Modifier" - href="%smodifier_materiel.html?key=%s"|args:$module.url:$eqpmt_key - shape="edit" - target="_dialog"}} -
- {{else}} -

Il n'y a aucun matériel dans cette catégorie.

- {{/if}} - {{/foreach}} -
+ {{:assign keys=$eqpmt|keys}} + {{if "nonproprio"|in:$keys && $eqpmt.nonproprio !== 0}} + {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} + + {{$eqpmt.designation}} + {{$eqpmt.nonproprio}} + + {{:linkbutton + label="Historique des mouvements" + href="%shistorique.html?key=%s"|args:$module.url:$eqpmt_key + shape="table" + target="_dialog"}} + {{:linkbutton + label="Modifier" + href="%smodifier_materiel.html?key=%s"|args:$module.url:$eqpmt_key + shape="edit" + target="_dialog"}} + + + {{/if}} + {{else}} +

Il n'y a aucun matériel dans cette catégorie.

+ {{/foreach}} + + + {{else}} +

Il n'y a aucun matériel dans cette catégorie.

+ {{/if}} + {{/foreach}} +
{{/if}} diff --git a/modifier_materiel.html b/modifier_materiel.html index f19f482..e44fce9 100644 --- a/modifier_materiel.html +++ b/modifier_materiel.html @@ -3,72 +3,72 @@ {{:assign equipment_key=$_GET.key|trim}} {{#load key=$_GET.key assign="equipment"}} - {{:assign default_category=$equipment.category}} + {{:assign default_category=$equipment.category}} {{else}} - {{:error message="Pas de matériel avec la clé %s"|args:$equipment_key}} + {{:error message="Pas de matériel avec la clé %s"|args:$equipment_key}} {{/load}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* récupérer les infos de la catégorie *}} - {{#load type="category" key=$_POST.category assign="category"}} - {{/load}} + {{* récupérer les infos de la catégorie *}} + {{#load type="category" key=$_POST.category assign="category"}} + {{/load}} - {{* vérifier la validité des changements demandés *}} - {{:assign chgt_ok=true}} - {{if $_POST.category != $default_category}} + {{* vérifier la validité des changements demandés *}} + {{:assign chgt_ok=true}} + {{if $_POST.category != $default_category}} - {{* catégorie change : vérifier le nom *}} - {{#load key=$equipment_key}} - {{if $designation|trim|tolower != $_POST.designation|trim|tolower}} - {{* le nom change => 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 chgt_ok=false}} - {{/load}} - {{else}} - {* le nom ne change pas : ok *}} - {{/if}} - {{/load}} + {{* catégorie change : vérifier le nom *}} + {{#load key=$equipment_key}} + {{if $designation|trim|tolower != $_POST.designation|trim|tolower}} + {{* le nom change => 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 chgt_ok=false}} + {{/load}} + {{else}} + {* le nom ne change pas : ok *}} + {{/if}} + {{/load}} - {{else}} - {{* catégorie ne change pas => vérifier le nom*}} - {{#load type="equipment" where="lower($$.designation) = :name" :name=$_POST.designation|trim|tolower}} - {{:assign chgt_ok=false}} - {{/load}} - {{/if}} + {{else}} + {{* catégorie ne change pas => vérifier le nom*}} + {{#load type="equipment" where="lower($$.designation) = :name" :name=$_POST.designation|trim|tolower}} + {{:assign chgt_ok=false}} + {{/load}} + {{/if}} - {{if !$chgt_ok}} - {{:error message="Erreur : il existe déjà un matériel avec cette désignation"}} - {{/if}} + {{if !$chgt_ok}} + {{:error message="Erreur : il existe déjà un matériel avec cette désignation"}} + {{/if}} - {{* enregistrer les modifications *}} - {{:save - key=$equipment_key - category=$category.key - designation=$_POST.designation|trim - }} - {{:redirect force="index.html?ok=1"}} + {{* enregistrer les modifications *}} + {{:save + key=$equipment_key + category=$category.key + designation=$_POST.designation|trim + }} + {{:redirect force="index.html?ok=1"}} {{else}} - {{:form_errors}} + {{:form_errors}} {{/form}} {{* lister les catégories disponibles *}} {{#load type="category" assign="category" order="$$.name"}} - {{:assign var="categories.%s"|args:$category.key value=$category.name}} + {{:assign var="categories.%s"|args:$category.key value=$category.name}} {{/load}}
-
- Modifier un matériel -
- {{:input type="select" name="category" label="Catégorie" default=$default_category required=true options=$categories}} - {{:input type="text" name="designation" label="Désignation" default=$equipment.designation required=true}} -
-
+
+ Modifier un matériel +
+ {{:input type="select" name="category" label="Catégorie" default=$default_category required=true options=$categories}} + {{:input type="text" name="designation" label="Désignation" default=$equipment.designation required=true}} +
+
-

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

diff --git a/mouvements/entrees/delete_entree.html b/mouvements/entrees/delete_entree.html index 47b140c..8cd0aa7 100644 --- a/mouvements/entrees/delete_entree.html +++ b/mouvements/entrees/delete_entree.html @@ -4,7 +4,7 @@ {{* récupérer les infos du mouvement à supprimer et du matériel associé *}} {{#load key=$_GET.key assign="mvt_suppr"}} {{else}} - {{:error message="Aucune entrée avec la clé « %s »"|args:$_GET.key}} + {{:error message="Aucune entrée avec la clé « %s »"|args:$_GET.key}} {{/load}} {{:assign amount_suppr=$mvt_suppr.amount}} @@ -13,78 +13,78 @@ {{#load key=$key_eqpmt_suppr assign="eqpmt_suppr"}} {{else}} - {{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_suppr}} + {{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_suppr}} {{/load}} {{#form on="delete"}} - {{* récupérer la config des entrées/sorties *}} - {{:include file="../../_get_config.html" keep="config"}} + {{* récupérer la config des entrées/sorties *}} + {{:include file="../../_get_config.html" keep="config"}} - {{* vérifier s'il est possible de supprimer l'entrée *}} - {{:assign dispo=0}} - {{:assign nonprop=0}} - {{* parcourir la liste des mouvements du matériel *}} + {{* vérifier s'il est possible de supprimer l'entrée *}} + {{:assign dispo=0}} + {{:assign nonprop=0}} + {{* parcourir la liste des mouvements du matériel *}} - {{#load - type="movement" - where="$$.equipment = :key" :key=$key_eqpmt_suppr - assign="movement" - order="$$.date"}} + {{#load + type="movement" + where="$$.equipment = :key" :key=$key_eqpmt_suppr + assign="movement" + order="$$.date"}} - {{if $key != $_GET.key}} - {{* ce n'est pas le mouvement à supprimer : cumuler les entrées/sorties *}} - {{if $movement.direction == 'input'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$config.input_nature item="elem"}} - {{if $movement.input_nature == $elem.label}} - {{if $elem.type == 'temporaire'}} - {{:assign nonprop="%d+%d"|math:$nonprop:$movement.amount}} - {{else}} - {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} - {{/if}} - {{/if}} - {{/foreach}} - {{elseif $movement.direction == 'output'}} - {{* chercher le type de sortie parmi les types de la config *}} - {{#foreach from=$config.output_nature item="elem"}} - {{if $movement.output_nature == $elem.label}} - {{if $elem.type == 'retour'}} - {{:assign nonprop="%d-%d"|math:$nonprop:$movement.amount}} - {{else}} - {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} - {{/if}} - {{/if}} - {{/foreach}} - {{/if}} + {{if $key != $_GET.key}} + {{* ce n'est pas le mouvement à supprimer : cumuler les entrées/sorties *}} + {{if $movement.direction == 'input'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$config.input_nature item="elem"}} + {{if $movement.input_nature == $elem.label}} + {{if $elem.type == 'temporaire'}} + {{:assign nonprop="%d+%d"|math:$nonprop:$movement.amount}} + {{else}} + {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} + {{/if}} + {{/if}} + {{/foreach}} + {{elseif $movement.direction == 'output'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$config.output_nature item="elem"}} + {{if $movement.output_nature == $elem.label}} + {{if $elem.type == 'retour'}} + {{:assign nonprop="%d-%d"|math:$nonprop:$movement.amount}} + {{else}} + {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} + {{/if}} + {{/if}} + {{/foreach}} + {{/if}} - {{* problème ? *}} - {{if $dispo < 0 || $nonprop < 0}} - {{:redirect force="./index.html?err=1&msg=suppression"}} - {{/if}} + {{* problème ? *}} + {{if $dispo < 0 || $nonprop < 0}} + {{:redirect force="./index.html?err=1&msg=suppression"}} + {{/if}} - {{/if}} - {{/load}} + {{/if}} + {{/load}} - {{* vérification réussie : supprimer l'entrée *}} - {{:delete key=$_GET.key}} - {{:assign var="msg" value="suppression"}} + {{* vérification réussie : supprimer l'entrée *}} + {{:delete key=$_GET.key}} + {{:assign var="msg" value="suppression"}} - {{* voir s'il reste des mouvements pour le matériel concerné par le mouvement supprimé *}} - {{#load type="movement" where="$$.equipment = :eqpmt_key" :eqpmt_key=$key_eqpmt_suppr}} - {{else}} - {{* supprimer le matériel *}} - {{:delete key=$key_eqpmt_suppr}} - {{:assign var="msg" value="%s - matériel"|args:$msg}} - {{/load}} + {{* voir s'il reste des mouvements pour le matériel concerné par le mouvement supprimé *}} + {{#load type="movement" where="$$.equipment = :eqpmt_key" :eqpmt_key=$key_eqpmt_suppr}} + {{else}} + {{* supprimer le matériel *}} + {{:delete key=$key_eqpmt_suppr}} + {{:assign var="msg" value="%s - matériel"|args:$msg}} + {{/load}} - {{:redirect force="./index.html?ok=1&msg=%s"|args:$msg}} + {{:redirect force="./index.html?ok=1&msg=%s"|args:$msg}} {{/form}} {{:delete_form - legend="Supprimer cette entrée ?" - warning="Supprimer l'entrée « %s %s (%d) en date du %s » ?"|args:$mvt_suppr.input_nature:$eqpmt_suppr.designation:$amount_suppr:$date_suppr - info="S'il ne reste aucun mouvement pour ce matériel, le matériel sera supprimé" + legend="Supprimer cette entrée ?" + warning="Supprimer l'entrée « %s %s (%d) en date du %s » ?"|args:$mvt_suppr.input_nature:$eqpmt_suppr.designation:$amount_suppr:$date_suppr + info="S'il ne reste aucun mouvement pour ce matériel, le matériel sera supprimé" }} {{:form_errors}} diff --git a/mouvements/entrees/index.html b/mouvements/entrees/index.html index 6c1a798..f3b1ce4 100644 --- a/mouvements/entrees/index.html +++ b/mouvements/entrees/index.html @@ -5,75 +5,74 @@ {{:include file="../../_nav.html" current="entrees"}} {{if $_GET.ok}} - {{if $_GET.msg|match:"suppression"}} - {{:assign msg="Entrée supprimée"}} - {{if $_GET.msg|match:"matériel"}} - {{:assign var="msg" value="%s - Matériel supprimé"|args:$msg}} - {{/if}} - {{elseif $_GET.msg == "entrée"}} - {{:assign msg="Entrée enregistrée"}} - {{elseif $_GET.msg == "modification"}} - {{:assign msg="Entrée modifiée"}} - {{/if}} -

{{$msg}}

+ {{if $_GET.msg|match:"suppression"}} + {{:assign msg="Entrée supprimée"}} + {{if $_GET.msg|match:"matériel"}} + {{:assign var="msg" value="%s - Matériel supprimé"|args:$msg}} + {{/if}} + {{elseif $_GET.msg == "entrée"}} + {{:assign msg="Entrée enregistrée"}} + {{elseif $_GET.msg == "modification"}} + {{:assign msg="Entrée modifiée"}} + {{/if}} +

{{$msg}}

{{elseif $_GET.err}} - {{if $_GET.msg == "suppression"}} -

Impossible de supprimer l'entrée

- {{/if}} + {{if $_GET.msg == "suppression"}} +

Impossible de supprimer l'entrée

+ {{/if}} {{/if}}
-
- Ajouter une entrée -
- {{:linkbutton label="Matériel répertorié" shape="plus" href="repertorie.html" target="_dialog"}} - {{:linkbutton label="Matériel non répertorié" shape="plus" href="non_repertorie.html" target="_dialog"}} - {{:linkbutton label="Retour de sortie temporaire" shape="plus" href="retour.html" target="_dialog"}} -
-
+
+ Ajouter une entrée +
+ {{:linkbutton label="Matériel répertorié" shape="plus" href="repertorie.html" target="_dialog"}} + {{:linkbutton label="Matériel non répertorié" shape="plus" href="non_repertorie.html" target="_dialog"}} + {{:linkbutton label="Retour de sortie temporaire" shape="plus" href="retour.html" target="_dialog"}} +
+
{{* lister les entrées *}}
-

Liste des entrées

+

Liste des entrées

- {{#list - select=" - $$.date AS 'Date' ; - $$.input_nature AS 'Type' ; - $$.amount AS 'Nombre' ; - (SELECT $$.designation - FROM @TABLE AS b - WHERE b.key = @TABLE.$$.equipment) - AS 'Matériel' ; - $$.comment AS 'Remarques'" - type="movement" - direction="input" - order=1}} + {{#list + select=" + $$.date AS 'Date' ; + $$.input_nature AS 'Type' ; + $$.amount AS 'Nombre' ; + (SELECT $$.designation + FROM @TABLE AS b + WHERE b.key = @TABLE.$$.equipment) AS 'Matériel' ; + $$.comment AS 'Remarques'" + type="movement" + direction="input" + order=1}} - {{:assign var='mvt_key' value=$key}} - - {{$date|date_short}} - {{$input_nature}} - {{$amount}} - {{$col4}} - {{$comment}} - - {{:linkbutton - label="Supprimer" - href="delete_entree.html?key=%s"|args:$mvt_key - shape="delete" - target="_dialog"}} - {{:linkbutton - label="Modifier" - href="../modifier_mouvement.html?key=%s&direction=input&caller=%s"|args:$mvt_key:$request_url - shape="edit" - target="_dialog"}} - - - {{else}} -

Il n'y a aucune entrée.

- {{/list}} + {{:assign var='mvt_key' value=$key}} + + {{$date|date_short}} + {{$input_nature}} + {{$amount}} + {{$col4}} + {{$comment}} + + {{:linkbutton + label="Supprimer" + href="delete_entree.html?key=%s"|args:$mvt_key + shape="delete" + target="_dialog"}} + {{:linkbutton + label="Modifier" + href="../modifier_mouvement.html?key=%s&direction=input&caller=%s"|args:$mvt_key:$request_url + shape="edit" + target="_dialog"}} + + + {{else}} +

Il n'y a aucune entrée.

+ {{/list}}
{{:admin_footer}} diff --git a/mouvements/entrees/non_repertorie.html b/mouvements/entrees/non_repertorie.html index 73269cb..a00b378 100644 --- a/mouvements/entrees/non_repertorie.html +++ b/mouvements/entrees/non_repertorie.html @@ -3,7 +3,7 @@ {{* barre de navigation *}} {{if ! $dialog}} - {{:include file="../../_nav.html" current="entrees"}} + {{:include file="../../_nav.html" current="entrees"}} {{/if}} {{* récupérer la config des entrées/sorties *}} @@ -11,55 +11,55 @@ {{* types d'entrées *}} {{#foreach from=$config.input_nature item="elem"}} - {{if $elem.type != 'retour'}} - {{:assign var='input_types.' value="%s"|args:$elem.label}} - {{/if}} + {{if $elem.type != 'retour'}} + {{:assign var='input_types.' value="%s"|args:$elem.label}} + {{/if}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* récupérer les infos de la catégorie *}} - {{#load type="category" key=$_POST.category assign="category"}} - {{/load}} + {{* récupérer les infos de la catégorie *}} + {{#load type="category" key=$_POST.category assign="category"}} + {{/load}} - {{* vérifier l'existence d'un matériel du même nom *}} - {{#load type="equipment" where="lower($$.designation) = :name" :name=$_POST.designation|trim|tolower}} - {{* utiliser la clé du matériel trouvé *}} - {{:assign equipment_key=$key}} - {{else}} - {{* nouveau matériel => nouvelle clé *}} - {{:assign equipment_key=""|uuid}} + {{* vérifier l'existence d'un matériel du même nom *}} + {{#load type="equipment" where="lower($$.designation) = :name" :name=$_POST.designation|trim|tolower}} + {{* utiliser la clé du matériel trouvé *}} + {{:assign equipment_key=$key}} + {{else}} + {{* nouveau matériel => nouvelle clé *}} + {{:assign equipment_key=""|uuid}} - {{* enregistrer un nouveau matériel *}} - {{:save - key=$equipment_key - validate_schema="../../equipment.schema.json" - type="equipment" - category=$category.key - designation=$_POST.designation|trim - }} - {{/load}} + {{* enregistrer un nouveau matériel *}} + {{:save + key=$equipment_key + validate_schema="../../equipment.schema.json" + type="equipment" + category=$category.key + designation=$_POST.designation|trim + }} + {{/load}} - {{* Enregistrer le mouvement *}} - {{:assign mvt_key=""|uuid}} - {{:assign var="operation" from="input_types.%d"|args:$_POST.type_operation}} + {{* Enregistrer le mouvement *}} + {{:assign mvt_key=""|uuid}} + {{:assign var="operation" from="input_types.%d"|args:$_POST.type_operation}} - {{:save - key=$mvt_key - validate_schema="../movement.schema.json" - type="movement" - direction="input" - input_nature=$operation - amount=$_POST.quantite|intval - equipment=$equipment_key - date=$_POST.date|parse_date - comment=$_POST.remarques|trim - }} + {{:save + key=$mvt_key + validate_schema="../movement.schema.json" + type="movement" + direction="input" + input_nature=$operation + amount=$_POST.quantite|intval + equipment=$equipment_key + date=$_POST.date|parse_date + comment=$_POST.remarques|trim + }} - {{:redirect force="index.html?ok=1&msg=entrée"}} + {{:redirect force="index.html?ok=1&msg=entrée"}} {{else}} - {{:form_errors}} + {{:form_errors}} {{/form}} {{* lister les catégories disponibles *}} @@ -71,27 +71,27 @@ {{* formulaire d'ajout de matériel *}}
-
- Ajouter une entrée d'un matériel non répertorié -
- {{:input type="select" name="type_operation" label="Type" required=true options=$input_types}} - {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} - {{:input type="number" name="quantite" label="Quantité" required=true default=1}} -
-
+
+ Ajouter une entrée d'un matériel non répertorié +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$input_types}} + {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} + {{:input type="number" name="quantite" label="Quantité" required=true default=1}} +
+
-
- Matériel -
- {{:input type="select" name="category" label="Catégorie" required=true options=$categories}} - {{:input type="text" name="designation" label="Désignation" required=true}} - {{:input type="textarea" name="remarques" label="Remarques" cols="40", rows="3" required=false}} -
-
+
+ Matériel +
+ {{:input type="select" name="category" label="Catégorie" required=true options=$categories}} + {{:input type="text" name="designation" label="Désignation" required=true}} + {{:input type="textarea" name="remarques" label="Remarques" cols="40", rows="3" required=false}} +
+
-

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

{{:admin_footer}} diff --git a/mouvements/entrees/repertorie.html b/mouvements/entrees/repertorie.html index ec860ec..de17285 100644 --- a/mouvements/entrees/repertorie.html +++ b/mouvements/entrees/repertorie.html @@ -3,7 +3,7 @@ {{* barre de navigation *}} {{if ! $dialog}} - {{:include file="../../_nav.html" current="entrees"}} + {{:include file="../../_nav.html" current="entrees"}} {{/if}} {{* récupérer la config des entrées/sorties *}} @@ -11,77 +11,73 @@ {{* types d'entrées *}} {{#foreach from=$config.input_nature item="elem"}} - {{if $elem.type != 'retour'}} - {{:assign var='input_types.' value="%s"|args:$elem.label}} - {{/if}} + {{if $elem.type != 'retour'}} + {{:assign var='input_types.' value="%s"|args:$elem.label}} + {{/if}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* récupérer les infos du matériel *}} - {{#load type="equipment" key=$_POST.equipment assign="equipment"}} - {{/load}} + {{* récupérer les infos du matériel *}} + {{#load type="equipment" key=$_POST.equipment assign="equipment"}} + {{/load}} - {{* Enregistrer le mouvement *}} - {{:assign mvt_key=""|uuid}} - {{:assign var="operation" from="input_types.%d|args:$_POST.type_operation}} + {{* Enregistrer le mouvement *}} + {{:assign mvt_key=""|uuid}} + {{:assign var="operation" from="input_types.%d|args:$_POST.type_operation}} - {{:save - key=$mvt_key - validate_schema="../movement.schema.json" - type="movement" - direction="input" - input_nature=$operation - amount=$_POST.quantite|intval - equipment=$equipment.key - date=$_POST.date|parse_date - comment=$_POST.remarques|trim - }} + {{:save + key=$mvt_key + validate_schema="../movement.schema.json" + type="movement" + direction="input" + input_nature=$operation + amount=$_POST.quantite|intval + equipment=$equipment.key + date=$_POST.date|parse_date + comment=$_POST.remarques|trim + }} - {{:redirect force="index.html?ok=1&msg=entrée"}} + {{:redirect force="index.html?ok=1&msg=entrée"}} {{else}} - {{:form_errors}} + {{:form_errors}} {{/form}} {{* lister les catégories et matériels associés *}} {{#load type="category" assign="category" order="$$.name"}} - {{:assign nom_cat=$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}} + {{:assign nom_cat=$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}} {{* Vérifier s'il y a au moins un matériel enregistré *}} {{if $equipments != null}} - {{* formulaire d'entrée de matériel *}} + {{* formulaire d'entrée de matériel *}} -
- -
- Ajouter une entrée d'un matériel répertorié -
- {{:input type="select" name="type_operation" label="Type" required=true options=$input_types}} - {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} - {{:input type="number" name="quantite" label="Quantité" required=true default=1}} -
-
- -
- Matériel -
- {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments}} - {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} -
-
- -

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

- -
+
+
+ Ajouter une entrée d'un matériel répertorié +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$input_types}} + {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} + {{:input type="number" name="quantite" label="Quantité" required=true default=1}} +
+
+
+ Matériel +
+ {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments}} + {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} +
+
+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

+
{{else}} -

Il n'y a aucun matériel

+

Il n'y a aucun matériel

{{/if}} {{:admin_footer}} diff --git a/mouvements/entrees/retour.html b/mouvements/entrees/retour.html index 53121c6..aeacc7d 100644 --- a/mouvements/entrees/retour.html +++ b/mouvements/entrees/retour.html @@ -3,7 +3,7 @@ {{* barre de navigation *}} {{if ! $dialog}} - {{:include file="../../_nav.html" current="entrees"}} + {{:include file="../../_nav.html" current="entrees"}} {{/if}} {{* récupérer la config des entrées/sorties *}} @@ -11,52 +11,52 @@ {{* types d'entrées *}} {{#foreach from=$config.input_nature item="elem"}} - {{if $elem.type == 'retour'}} - {{:assign var='input_types.' value="%s"|args:$elem.label}} - {{/if}} + {{if $elem.type == 'retour'}} + {{:assign var='input_types.' value="%s"|args:$elem.label}} + {{/if}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* récupérer les infos du matériel *}} - {{#load type="equipment" key=$_POST.equipment assign="equipment"}} - {{:assign designation=$equipment.designation}} - {{:assign var="categories." value=$equipment.category}} - {{/load}} + {{* récupérer les infos du matériel *}} + {{#load type="equipment" key=$_POST.equipment assign="equipment"}} + {{:assign designation=$equipment.designation}} + {{:assign var="categories." value=$equipment.category}} + {{/load}} - {{* Extraire et compiler les infos de la base *}} - {{:include - file="../../_calcul_dispo.html" - keep="equipments" - date=$_POST.date|parse_date - }} + {{* Extraire et compiler les infos de la base *}} + {{:include + file="../../_calcul_dispo.html" + keep="equipments" + date=$_POST.date|parse_date + }} - {{* déterminer la quantité sortie temporairement de ce matriel à la date donnée *}} - {{:assign var=sorti from="equipments.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_POST.equipment}} + {{* déterminer la quantité sortie temporairement de ce matriel à la date donnée *}} + {{:assign var=sorti from="equipments.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_POST.equipment}} - {{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}} - {{/if}} + {{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}} + {{/if}} - {{* Enregistrer le mouvement *}} - {{:assign mvt_key=""|uuid}} - {{:assign var="operation" from="input_types.%d|args:$_POST.type_operation}} + {{* Enregistrer le mouvement *}} + {{:assign mvt_key=""|uuid}} + {{:assign var="operation" from="input_types.%d|args:$_POST.type_operation}} - {{:save - key=$mvt_key - validate_schema="../movement.schema.json" - type="movement" - direction="input" - input_nature=$operation - amount=$_POST.quantite|intval - equipment=$equipment.key - date=$_POST.date|parse_date - comment=$_POST.remarques|trim - }} + {{:save + key=$mvt_key + validate_schema="../movement.schema.json" + type="movement" + direction="input" + input_nature=$operation + amount=$_POST.quantite|intval + equipment=$equipment.key + date=$_POST.date|parse_date + comment=$_POST.remarques|trim + }} - {{:redirect force="index.html?ok=1&msg=entrée"}} + {{:redirect force="index.html?ok=1&msg=entrée"}} {{else}} - {{:form_errors}} + {{:form_errors}} {{/form}} {{* Extraire et compiler les infos de la base *}} @@ -64,51 +64,47 @@ {{if $equipments !== null}} - {{* déterminer la quantité des matériels sortis temporairement *}} - {{#foreach from=$equipments key="cat_key" item="category"}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{:assign quantite=$eqpmt.exterieur}} - {{if $quantite != 0}} - {{:assign - var="temporaire.%s.%s"|args:$category.name:$eqpmt_key - value="%s (quantité : %d)"|args:$eqpmt.designation:$quantite - }} - {{/if}} - {{/foreach}} - {{/foreach}} + {{* déterminer la quantité des matériels sortis temporairement *}} + {{#foreach from=$equipments key="cat_key" item="category"}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} + {{:assign quantite=$eqpmt.exterieur}} + {{if $quantite != 0}} + {{:assign + var="temporaire.%s.%s"|args:$category.name:$eqpmt_key + value="%s (quantité : %d)"|args:$eqpmt.designation:$quantite + }} + {{/if}} + {{/foreach}} + {{/foreach}} - {{if $temporaire != null}} + {{if $temporaire != null}} - {{* formulaire d'entrée de matériel *}} -
- -
- Ajouter une entrée pour un retour de matériel -
- {{:input type="select" name="type_operation" label="Type" required=true options=$input_types}} - {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} - {{:input type="number" name="quantite" label="Quantité" required=true default=1}} -
-
- -
- Matériel -
- {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$temporaire}} - {{:input type="textarea" name="remarques" label="Remarques" cols="40", rows="3" required=false}} -
-
- -

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

- -
- {{else}} -

Il n'y a aucun matériel

- {{/if}} + {{* formulaire d'entrée de matériel *}} +
+
+ Ajouter une entrée pour un retour de matériel +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$input_types}} + {{:input type="date" name="date" label="Date" required=true default=$now|date_short}} + {{:input type="number" name="quantite" label="Quantité" required=true default=1}} +
+
+
+ Matériel +
+ {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$temporaire}} + {{:input type="textarea" name="remarques" label="Remarques" cols="40", rows="3" required=false}} +
+
+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

+
+ {{else}} +

Il n'y a aucun matériel

+ {{/if}} {{else}} -

Il n'y a aucun matériel

+

Il n'y a aucun matériel

{{/if}} {{:admin_footer}} diff --git a/mouvements/modifier_mouvement.html b/mouvements/modifier_mouvement.html index dbacb85..3c587ab 100644 --- a/mouvements/modifier_mouvement.html +++ b/mouvements/modifier_mouvement.html @@ -5,7 +5,7 @@ {{:assign url=$_GET.caller}} {{:assign pos=$url|strpos:"?"}} {{if $pos|intval > 0}} - {{:assign url=$url|truncate:$pos:"":true}} + {{:assign url=$url|truncate:$pos:"":true}} {{/if}} {{:assign direction=$_GET.direction}} @@ -14,12 +14,12 @@ {{* récupérer les infos du mouvement à modifier *}} {{#load key=$key_mvt assign="mvt_modif"}} {{else}} - {{:error message="Aucune %s avec la clé %s"|args:$_GET.direction:$key_mvt}} + {{:error message="Aucune %s avec la clé %s"|args:$_GET.direction:$key_mvt}} {{/load}} {{if $direction == "input"}} - {{:assign input_init=$mvt_modif.input_nature}} + {{:assign input_init=$mvt_modif.input_nature}} {{else}} - {{:assign output_init=$mvt_modif.output_nature}} + {{:assign output_init=$mvt_modif.output_nature}} {{/if}} {{:assign amount_init=$mvt_modif.amount}} {{:assign date_init=$mvt_modif.date|date_short}} @@ -31,173 +31,173 @@ {{:include file="../_get_config.html" keep="config"}} {{if $direction == "input"}} - {{* types d'entrées *}} - {{#foreach from=$config.input_nature key="rang" item="elem"}} - {{:assign var='input_types.' value="%s"|args:$elem.label}} - {{if $elem.label == $mvt_modif.input_nature}} - {{:assign type_defaut=$rang}} - {{/if}} - {{/foreach}} + {{* types d'entrées *}} + {{#foreach from=$config.input_nature key="rang" item="elem"}} + {{:assign var='input_types.' value="%s"|args:$elem.label}} + {{if $elem.label == $mvt_modif.input_nature}} + {{:assign type_defaut=$rang}} + {{/if}} + {{/foreach}} {{else}} - {{* types de sorties *}} - {{#foreach from=$config.output_nature key="rang" item="elem"}} - {{:assign var='types_sorties.' value="%s"|args:$elem.label}} - {{if $elem.label == $mvt_modif.output_nature}} - {{:assign type_defaut=$rang}} - {{/if}} - {{/foreach}} + {{* types de sorties *}} + {{#foreach from=$config.output_nature key="rang" item="elem"}} + {{:assign var='types_sorties.' value="%s"|args:$elem.label}} + {{if $elem.label == $mvt_modif.output_nature}} + {{:assign type_defaut=$rang}} + {{/if}} + {{/foreach}} {{/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}} + {{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_init}} {{/load}} {{* - -------------------- Traiter la saisie -------------------- + -------------------- Traiter la saisie -------------------- *}} {{#form on="change"}} - {{* préparer le mouvement modifié *}} - {{if $direction == "input"}} - {{:assign var="mvt_modif.input_nature" from="input_types.%d"|args:$_POST.type_operation}} - {{else}} - {{:assign var="mvt_modif.output_nature" from="types_sorties.%d"|args:$_POST.type_operation}} - {{/if}} - {{:assign var="mvt_modif.amount" value=$_POST.amount}} - {{:assign var="mvt_modif.equipment" value=$_POST.equipment}} - {{:assign var="mvt_modif.date" value=$_POST.date|parse_date}} - {{:assign var="mvt_modif.comment" value=$_POST.comment}} + {{* préparer le mouvement modifié *}} + {{if $direction == "input"}} + {{:assign var="mvt_modif.input_nature" from="input_types.%d"|args:$_POST.type_operation}} + {{else}} + {{:assign var="mvt_modif.output_nature" from="types_sorties.%d"|args:$_POST.type_operation}} + {{/if}} + {{:assign var="mvt_modif.amount" value=$_POST.amount}} + {{:assign var="mvt_modif.equipment" value=$_POST.equipment}} + {{:assign var="mvt_modif.date" value=$_POST.date|parse_date}} + {{:assign var="mvt_modif.comment" value=$_POST.comment}} - {{* - lister les mouvements et remplacer le mouvement sélectionné par sa version modifiée - en l'insérant à sa place par date croissante - *}} - {{:assign insere=false}} - {{#select - id, key, - json_extract(document, '$.type') as 'type', - json_extract(document, '$.direction') as 'direction', - json_extract(document, '$.input_nature') as 'input_nature', - json_extract(document, '$.output_nature') as 'output_nature', - json_extract(document, '$.amount') as 'amount', - json_extract(document, '$.equipment') as 'equipment', - json_extract(document, '$.date') as 'date', - json_extract(document, '$.comment') as 'comment' - FROM module_data_equipment - WHERE - json_extract(document, '$.type') = 'movement' - AND - (json_extract(document, '$.equipment') = :old_eqpmt_key - OR - json_extract(document, '$.equipment') = :new_eqpmt_key) - ORDER BY json_extract(document, '$.date'); - :old_eqpmt_key=$key_eqpmt_init - :new_eqpmt_key=$_POST.equipment - assign="movement" - }} - {{if $key != $key_mvt}} - {{if $date > $mvt_modif.date && ! $insere}} - {{:assign var=movements_modif." from=mvt_modif}} - {{:assign insere=true}} - {{/if}} - {{:assign var=movements_modif." from=movement}} - {{/if}} - {{/select}} - {{if ! $insere}} - {{:assign var=movements_modif." from=mvt_modif}} - {{/if}} + {{* + lister les mouvements et remplacer le mouvement sélectionné par sa version modifiée + en l'insérant à sa place par date croissante + *}} + {{:assign insere=false}} + {{#select + id, key, + json_extract(document, '$.type') as 'type', + json_extract(document, '$.direction') as 'direction', + json_extract(document, '$.input_nature') as 'input_nature', + json_extract(document, '$.output_nature') as 'output_nature', + json_extract(document, '$.amount') as 'amount', + json_extract(document, '$.equipment') as 'equipment', + json_extract(document, '$.date') as 'date', + json_extract(document, '$.comment') as 'comment' + FROM module_data_equipment + WHERE + json_extract(document, '$.type') = 'movement' + AND + (json_extract(document, '$.equipment') = :old_eqpmt_key + OR + json_extract(document, '$.equipment') = :new_eqpmt_key) + ORDER BY json_extract(document, '$.date'); + :old_eqpmt_key=$key_eqpmt_init + :new_eqpmt_key=$_POST.equipment + assign="movement" + }} + {{if $key != $key_mvt}} + {{if $date > $mvt_modif.date && ! $insere}} + {{:assign var=movements_modif." from=mvt_modif}} + {{:assign insere=true}} + {{/if}} + {{:assign var=movements_modif." from=movement}} + {{/if}} + {{/select}} + {{if ! $insere}} + {{:assign var=movements_modif." from=mvt_modif}} + {{/if}} - {{* Vérifier la cohérence des opérations de l'ancien matériel *}} - {{:include - file="./valider_modification.html" - keep="erreur" - movements=$movements_modif - eqpmt_key=$key_eqpmt_init - }} + {{* Vérifier la cohérence des opérations de l'ancien matériel *}} + {{:include + file="./valider_modification.html" + keep="erreur" + movements=$movements_modif + eqpmt_key=$key_eqpmt_init + }} - {{* Si le matériel a changé, vérifier la cohérence des opérations du nouveau matériel *}} - {{if ! $erreur && $key_eqpmt_init != $_POST.equipment}} - {{:include - file="./valider_modification.html" - keep="erreur" - movements=$movements_modif - eqpmt_key=$_POST.equipment - }} - {{/if}} + {{* Si le matériel a changé, vérifier la cohérence des opérations du nouveau matériel *}} + {{if ! $erreur && $key_eqpmt_init != $_POST.equipment}} + {{:include + file="./valider_modification.html" + keep="erreur" + movements=$movements_modif + eqpmt_key=$_POST.equipment + }} + {{/if}} - {{#load key=$mvt_modif.equipment assign="eqpmt"}}{{/load}} - {{if $erreur}} -

- Modification demandée impossible : - {{if $direction == "input"}} - « {{$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}} » - {{else}} - « {{$output_init}} de {{$eqpmt_init.designation}} (qté : {{$amount_init}}) en date du {{$date_init}} » vers - « {{$mvt_modif.output_nature}} de {{$eqpmt.designation}} (qté : {{$mvt_modif.amount}}) à la date du {{$mvt_modif.date|date_short}} » - {{/if}} -

- {{else}} - {{* vérification réussie : modifier le mouvement *}} - {{:save - key=$key_mvt - validate_schema="./movement.schema.json" - type="movement" - direction=$direction - input_nature=$mvt_modif.input_nature - output_nature=$mvt_modif.output_nature - amount=$mvt_modif.amount|intval - equipment=$mvt_modif.equipment - date=$mvt_modif.date - comment=$mvt_modif.comment - }} - {{:redirect force="%s?ok=1&msg=modification"|args:$url}} - {{/if}} + {{#load key=$mvt_modif.equipment assign="eqpmt"}}{{/load}} + {{if $erreur}} +

+ Modification demandée impossible : + {{if $direction == "input"}} + « {{$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}} » + {{else}} + « {{$output_init}} de {{$eqpmt_init.designation}} (qté : {{$amount_init}}) en date du {{$date_init}} » vers + « {{$mvt_modif.output_nature}} de {{$eqpmt.designation}} (qté : {{$mvt_modif.amount}}) à la date du {{$mvt_modif.date|date_short}} » + {{/if}} +

+ {{else}} + {{* vérification réussie : modifier le mouvement *}} + {{:save + key=$key_mvt + validate_schema="./movement.schema.json" + type="movement" + direction=$direction + input_nature=$mvt_modif.input_nature + output_nature=$mvt_modif.output_nature + amount=$mvt_modif.amount|intval + equipment=$mvt_modif.equipment + date=$mvt_modif.date + comment=$mvt_modif.comment + }} + {{:redirect force="%s?ok=1&msg=modification"|args:$url}} + {{/if}} {{/form}} {{* - -------------------- Préparer la saisie -------------------- + -------------------- Préparer la saisie -------------------- *}} {{* lister les catégories et matériels associés *}} {{#load type="category" assign="category" order="$$.name"}} - {{:assign nom_cat=$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}} + {{:assign nom_cat=$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}} {{* formulaire de modification du mouvement *}}
-
- {{if $direction == "input"}} - Modifier l'entrée « {{$input_init}} {{$eqpmt_init.designation}} ({{$amount_init}}) en date du {{$date_init}} » -
- {{:input type="select" name="type_operation" label="Type" required=true options=$input_types default=$type_defaut}} - {{else}} - Modifier la sortie « {{$output_init}} {{$eqpmt_init.designation}} ({{$amount_init}}) en date du {{$date_init}} » -
- {{:input type="select" name="type_operation" label="Type" required=true options=$types_sorties default=$type_defaut}} - {{/if}} - {{:input type="date" name="date" label="Date" required=true default=$mvt_modif.date}} - {{:input type="number" name="amount" label="Quantité" required=true default=$mvt_modif.amount}} -
-
+
+ {{if $direction == "input"}} + Modifier l'entrée « {{$input_init}} {{$eqpmt_init.designation}} ({{$amount_init}}) en date du {{$date_init}} » +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$input_types default=$type_defaut}} + {{else}} + Modifier la sortie « {{$output_init}} {{$eqpmt_init.designation}} ({{$amount_init}}) en date du {{$date_init}} » +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$types_sorties default=$type_defaut}} + {{/if}} + {{:input type="date" name="date" label="Date" required=true default=$mvt_modif.date}} + {{:input type="number" name="amount" label="Quantité" required=true default=$mvt_modif.amount}} +
+
-
- Matériel -
- {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments default=$key_eqpmt_init}} - {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false default=$mvt_modif.comment}} -
-
+
+ Matériel +
+ {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments default=$key_eqpmt_init}} + {{:input type="textarea" name="comment" label="Remarques" cols="40", rows="3" required=false default=$mvt_modif.comment}} +
+
-

- {{:button type="submit" name="change" label="Enregistrer" shape="right" class="main"}} -

+

+ {{:button type="submit" name="change" label="Enregistrer" shape="right" class="main"}} +

diff --git a/mouvements/movement.schema.json b/mouvements/movement.schema.json index 81ddb9e..b0fcda7 100644 --- a/mouvements/movement.schema.json +++ b/mouvements/movement.schema.json @@ -1,42 +1,42 @@ { - "$schema": "https://json-schema.org/draft/2020-12/schema", - "type": "object", - "properties": { - "type": { - "type": "string", - "enum": ["movement"] + "$schema": "https://json-schema.org/draft/2020-12/schema", + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": ["movement"] + }, + "direction" : { + "description": "Entrée ou sortie", + "type": "string", + "enum": ["input", "output"] + }, + "input_nature": { + "description": "Nature de l'entrée", + "type": ["null", "string"] + }, + "output_nature": { + "description": "Nature de la sortie", + "type": ["null", "string"] + }, + "amount": { + "description": "Quantité ajoutée ou retirée", + "type": "integer", + "minimum": 1 + }, + "equipment": { + "description": "Clé du matériel", + "type": "string" + }, + "date" : { + "description": "Date de l'opération", + "type": "string", + "format": "date" + }, + "comment": { + "description": "Commentaire additionnel", + "type": ["null", "string"] + } }, - "direction" : { - "description": "Entrée ou sortie", - "type": "string", - "enum": ["input", "output"] - }, - "input_nature": { - "description": "Nature de l'entrée", - "type": ["null", "string"] - }, - "output_nature": { - "description": "Nature de la sortie", - "type": ["null", "string"] - }, - "amount": { - "description": "Quantité ajoutée ou retirée", - "type": "integer", - "minimum": 1 - }, - "equipment": { - "description": "Clé du matériel", - "type": "string" - }, - "date" : { - "description": "Date de l'opération", - "type": "string", - "format": "date" - }, - "comment": { - "description": "Commentaire additionnel", - "type": ["null", "string"] - } - }, - "required": ["type", "direction", "amount", "equipment", "date", "comment"] + "required": ["type", "direction", "amount", "equipment", "date", "comment"] } diff --git a/mouvements/sorties/delete_sortie.html b/mouvements/sorties/delete_sortie.html index 69b5c16..1a5075a 100644 --- a/mouvements/sorties/delete_sortie.html +++ b/mouvements/sorties/delete_sortie.html @@ -4,7 +4,7 @@ {{* récupérer les infos du mouvement à supprimer et du matériel associé *}} {{#load key=$_GET.key assign="mvt_suppr"}} {{else}} - {{:error message="Aucune sortie avec la clé « %s »"|args:$_GET.key}} + {{:error message="Aucune sortie avec la clé « %s »"|args:$_GET.key}} {{/load}} {{:assign amount_suppr=$mvt_suppr.amount}} @@ -13,78 +13,78 @@ {{#load key=$key_eqpmt_suppr assign="eqpmt_suppr"}} {{else}} - {{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_suppr}} + {{:error message="Aucun matériel avec la clé « %s »"|args:$key_eqpmt_suppr}} {{/load}} {{#form on="delete"}} - {{* récupérer la config des entrées/sorties *}} - {{:include file="../../_get_config.html" keep="config"}} + {{* récupérer la config des entrées/sorties *}} + {{:include file="../../_get_config.html" keep="config"}} - {{* déterminer s'il s'agit d'une sortie temporaire *}} - {{:assign temporaire=false}} - {{#foreach from=$config.output_nature item="elem"}} - {{if $mvt_suppr.output_nature == $elem.label && $elem.type == 'temporaire'}} - {{:assign temporaire=true}} - {{:break}} - {{/if}} - {{/foreach}} + {{* déterminer s'il s'agit d'une sortie temporaire *}} + {{:assign temporaire=false}} + {{#foreach from=$config.output_nature item="elem"}} + {{if $mvt_suppr.output_nature == $elem.label && $elem.type == 'temporaire'}} + {{:assign temporaire=true}} + {{:break}} + {{/if}} + {{/foreach}} - {{* dans le cas d'une sortie temporaire, vérifier s'il est possible de la supprimer *}} - {{if $temporaire}} - {{:assign exterieur=0}} - {{#load - type="movement" - where="$$.equipment = :key" :key=$key_eqpmt_suppr - assign="movement" - order="$$.date"}} + {{* dans le cas d'une sortie temporaire, vérifier s'il est possible de la supprimer *}} + {{if $temporaire}} + {{:assign exterieur=0}} + {{#load + type="movement" + where="$$.equipment = :key" :key=$key_eqpmt_suppr + assign="movement" + order="$$.date"}} - {{if $key != $_GET.key}} - {{* ce n'est pas le mouvement à supprimer : cumuler les entrées/sorties *}} - {{if $movement.direction == 'input'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$config.input_nature item="elem"}} - {{if $movement.input_nature == $elem.label && $elem.type == 'retour'}} - {{:assign exterieur="%d-%d"|math:$exterieur:$movement.amount}} - {{/if}} - {{/foreach}} - {{elseif $movement.direction == 'output'}} - {{* chercher le type de sortie parmi les types de la config *}} - {{#foreach from=$config.output_nature item="elem"}} - {{if $movement.output_nature == $elem.label && $elem.type == 'temporaire'}} - {{:assign exterieur="%d+%d"|math:$exterieur:$movement.amount}} - {{/if}} - {{/foreach}} - {{/if}} + {{if $key != $_GET.key}} + {{* ce n'est pas le mouvement à supprimer : cumuler les entrées/sorties *}} + {{if $movement.direction == 'input'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$config.input_nature item="elem"}} + {{if $movement.input_nature == $elem.label && $elem.type == 'retour'}} + {{:assign exterieur="%d-%d"|math:$exterieur:$movement.amount}} + {{/if}} + {{/foreach}} + {{elseif $movement.direction == 'output'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$config.output_nature item="elem"}} + {{if $movement.output_nature == $elem.label && $elem.type == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$movement.amount}} + {{/if}} + {{/foreach}} + {{/if}} - {{* problème ? *}} - {{if $exterieur < 0}} - {{:redirect force="./index.html?err=1&msg=suppression"}} - {{/if}} + {{* problème ? *}} + {{if $exterieur < 0}} + {{:redirect force="./index.html?err=1&msg=suppression"}} + {{/if}} - {{/if}} - {{/load}} - {{/if}} + {{/if}} + {{/load}} + {{/if}} - {{* vérification réussie : supprimer la sortie *}} - {{:delete key=$_GET.key}} - {{:assign var="msg" value="suppression"}} + {{* vérification réussie : supprimer la sortie *}} + {{:delete key=$_GET.key}} + {{:assign var="msg" value="suppression"}} - {{* voir s'il reste des mouvements pour le matériel concerné par le mouvement supprimé *}} - {{#load type="movement" where="$$.equipment = :eqpmt_key" :eqpmt_key=$key_eqpmt_suppr}} - {{else}} - {{* supprimer le matériel *}} - {{:delete key=$key_eqpmt_suppr}} - {{:assign var="msg" value="%s - matériel"|args:$msg}} - {{/load}} + {{* voir s'il reste des mouvements pour le matériel concerné par le mouvement supprimé *}} + {{#load type="movement" where="$$.equipment = :eqpmt_key" :eqpmt_key=$key_eqpmt_suppr}} + {{else}} + {{* supprimer le matériel *}} + {{:delete key=$key_eqpmt_suppr}} + {{:assign var="msg" value="%s - matériel"|args:$msg}} + {{/load}} - {{:redirect force="./index.html?ok=1&msg=%s"|args:$msg}} + {{:redirect force="./index.html?ok=1&msg=%s"|args:$msg}} {{/form}} {{:delete_form - legend="Supprimer cette sortie ?" - warning="Supprimer la sortie « %s %s (%d) en date du %s » ?"|args:$mvt_suppr.output_nature:$eqpmt_suppr.designation:$amount_suppr:$date_suppr - info="S'il ne reste aucun mouvement pour ce matériel, le matériel sera supprimé" + legend="Supprimer cette sortie ?" + warning="Supprimer la sortie « %s %s (%d) en date du %s » ?"|args:$mvt_suppr.output_nature:$eqpmt_suppr.designation:$amount_suppr:$date_suppr + info="S'il ne reste aucun mouvement pour ce matériel, le matériel sera supprimé" }} {{:form_errors}} diff --git a/mouvements/sorties/emprunte.html b/mouvements/sorties/emprunte.html index 47cfd40..2add0e3 100644 --- a/mouvements/sorties/emprunte.html +++ b/mouvements/sorties/emprunte.html @@ -2,8 +2,8 @@ {{:admin_header title="Sortie de matériel" current="module_equipment"}} {{if ! $dialog}} - {{* barre de navigation *}} - {{:include file="../../_nav.html" current="sorties"}} + {{* barre de navigation *}} + {{:include file="../../_nav.html" current="sorties"}} {{/if}} {{* récupérer la config des entrées/sorties *}} @@ -11,114 +11,111 @@ {{* types de sorties *}} {{#foreach from=$config.output_nature item="elem"}} - {{if $elem.type == 'retour'}} - {{:assign var='output_types.' value="%s"|args:$elem.label}} - {{/if}} + {{if $elem.type == 'retour'}} + {{:assign var='output_types.' value="%s"|args:$elem.label}} + {{/if}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* récupérer les infos du matériel *}} - {{#load type="equipment" key=$_POST.equipment assign="equipment"}} - {{:assign designation=$equipment.designation}} - {{:assign var="categories." value=$equipment.category}} - {{/load}} + {{* récupérer les infos du matériel *}} + {{#load type="equipment" key=$_POST.equipment assign="equipment"}} + {{:assign designation=$equipment.designation}} + {{:assign var="categories." value=$equipment.category}} + {{/load}} - {{* Extraire et compiler les infos de la base *}} - {{:include - file="../../_calcul_dispo.html" - keep="equipments" - date=$_POST.date|parse_date - }} + {{* Extraire et compiler les infos de la base *}} + {{:include + file="../../_calcul_dispo.html" + keep="equipments" + date=$_POST.date|parse_date + }} - {{* déterminer la quantité présente de ce matériel à la date donnée *}} - {{:assign var=present from="equipments.%s.eqpmt.%s.nonproprio"|args:$equipment.category:$_POST.equipment}} + {{* déterminer la quantité présente de ce matériel à la date donnée *}} + {{:assign var=present from="equipments.%s.eqpmt.%s.nonproprio"|args:$equipment.category:$_POST.equipment}} - {{if $_POST.quantite|intval > $present}} - {{: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}} + {{if $_POST.quantite|intval > $present}} + {{: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}} - {{* Enregistrer le mouvement *}} + {{* Enregistrer le mouvement *}} - {{:assign mvt_key=""|uuid}} - {{:assign var="operation" from="output_types.%d|args:$_POST.type_operation}} - {{:save - key=$mvt_key - validate_schema="../movement.schema.json" - type="movement" - direction="output" - output_nature=$operation - amount=$_POST.quantite|intval - equipment=$equipment.key - date=$_POST.date|parse_date - comment=$_POST.remarques|trim - }} - {{:redirect force="index.html?ok=1&msg=sortie"}} + {{:assign mvt_key=""|uuid}} + {{:assign var="operation" from="output_types.%d|args:$_POST.type_operation}} + {{:save + key=$mvt_key + validate_schema="../movement.schema.json" + type="movement" + direction="output" + output_nature=$operation + amount=$_POST.quantite|intval + equipment=$equipment.key + date=$_POST.date|parse_date + comment=$_POST.remarques|trim + }} + {{:redirect force="index.html?ok=1&msg=sortie"}} {{else}} - {{:form_errors}} + {{:form_errors}} {{/form}} {{* Extraire et compiler les infos de la base *}} {{:include file="../../_calcul_dispo.html" keep="equipments"}} {{if $equipments !== null}} - {{* calculer les quantité de matériels dont l'asso n'est pas propriétaire *}} - {{#foreach from=$equipments key="cat_key" item="category"}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{:assign quantite="%d-%d"|math:$eqpmt.nonproprio:$eqpmt.retour}} - {{if $quantite != 0}} - {{:assign - var="temporaire.%s.%s"|args:$category.name:$eqpmt_key - value="%s (quantité : %d)"|args:$eqpmt.designation:$quantite - }} - {{/if}} - {{/foreach}} - {{/foreach}} + {{* calculer les quantité de matériels dont l'asso n'est pas propriétaire *}} + {{#foreach from=$equipments key="cat_key" item="category"}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} + {{:assign quantite="%d-%d"|math:$eqpmt.nonproprio:$eqpmt.retour}} + {{if $quantite != 0}} + {{:assign + var="temporaire.%s.%s"|args:$category.name:$eqpmt_key + value="%s (quantité : %d)"|args:$eqpmt.designation:$quantite + }} + {{/if}} + {{/foreach}} + {{/foreach}} - {{if $temporaire != null}} - {{* formulaire de sortie de matériel *}} -
- -
- Ajouter une sortie d'un matériel disponible en stock -
- {{:input type="select" name="type_operation" label="Type" required=true options=$output_types}} - {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} - {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} -
-
- -
- Matériel -

La quantité disponible est celle à la date du jour

-
- {{: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}} -
-
- -

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

-
- {{else}} -

Il n'y a aucun matériel

- {{/if}} + {{if $temporaire != null}} + {{* formulaire de sortie de matériel *}} +
+
+ Ajouter une sortie d'un matériel disponible en stock +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$output_types}} + {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} + {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} +
+
+
+ Matériel +

La quantité disponible est celle à la date du jour

+
+ {{: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}} +
+
+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

+
+ {{else}} +

Il n'y a aucun matériel

+ {{/if}} {{else}} -

Il n'y a aucun matériel

+

Il n'y a aucun matériel

{{/if}} {{:admin_footer}} diff --git a/mouvements/sorties/index.html b/mouvements/sorties/index.html index d48d837..5b49c1a 100644 --- a/mouvements/sorties/index.html +++ b/mouvements/sorties/index.html @@ -5,74 +5,73 @@ {{:include file="../../_nav.html" current="sorties"}} {{if $_GET.ok}} - {{if $_GET.msg|match:"suppression"}} - {{:assign msg="Sortie supprimée"}} - {{if $_GET.msg|match:"matériel"}} - {{:assign var="msg" value="%s - Matériel supprimé"|args:$msg}} - {{/if}} - {{elseif $_GET.msg == "sortie"}} - {{:assign msg="Sortie enregistrée"}} - {{elseif $_GET.msg == "modification"}} - {{:assign msg="Sortie modifiée"}} - {{/if}} -

{{$msg}}

+ {{if $_GET.msg|match:"suppression"}} + {{:assign msg="Sortie supprimée"}} + {{if $_GET.msg|match:"matériel"}} + {{:assign var="msg" value="%s - Matériel supprimé"|args:$msg}} + {{/if}} + {{elseif $_GET.msg == "sortie"}} + {{:assign msg="Sortie enregistrée"}} + {{elseif $_GET.msg == "modification"}} + {{:assign msg="Sortie modifiée"}} + {{/if}} +

{{$msg}}

{{elseif $_GET.err}} - {{if $_GET.msg == "suppression"}} -

Impossible de supprimer la sortie

- {{/if}} + {{if $_GET.msg == "suppression"}} +

Impossible de supprimer la sortie

+ {{/if}} {{/if}}
-
- Ajouter une sortie -
- {{:linkbutton label="Matériel en stock disponible" shape="plus" href="stock_disponible.html" target="_dialog"}} - {{:linkbutton label="Matériel emprunté" shape="plus" href="emprunte.html" target="_dialog"}} -
-
+
+ Ajouter une sortie +
+ {{:linkbutton label="Matériel en stock disponible" shape="plus" href="stock_disponible.html" target="_dialog"}} + {{:linkbutton label="Matériel emprunté" shape="plus" href="emprunte.html" target="_dialog"}} +
+
{{* lister les sorties *}}
-

Liste des sorties

+

Liste des sorties

- {{#list - select=" - $$.date AS 'Date' ; - $$.output_nature AS 'Type' ; - $$.amount AS 'Nombre' ; - (SELECT $$.designation - FROM @TABLE AS b - WHERE b.key = @TABLE.$$.equipment) - AS 'Matériel' ; - $$.comment AS 'Remarques'" - type="movement" - direction="output" - order=1}} + {{#list + select=" + $$.date AS 'Date' ; + $$.output_nature AS 'Type' ; + $$.amount AS 'Nombre' ; + (SELECT $$.designation + FROM @TABLE AS b + WHERE b.key = @TABLE.$$.equipment) AS 'Matériel' ; + $$.comment AS 'Remarques'" + type="movement" + direction="output" + order=1}} - {{:assign var='mvt_key' value=$key}} - - {{$date|date_short}} - {{$output_nature}} - {{$amount}} - {{$col4}} - {{$comment}} - - {{:linkbutton - label="Supprimer" - href="delete_sortie.html?key=%s"|args:$mvt_key - shape="delete" - target="_dialog"}} - {{:linkbutton - label="Modifier" - href="../modifier_mouvement.html?key=%s&direction=output&caller=%s"|args:$mvt_key:$request_url - shape="edit" - target="_dialog"}} - - - {{else}} -

Il n'y a aucune sortie.

- {{/list}} + {{:assign var='mvt_key' value=$key}} + + {{$date|date_short}} + {{$output_nature}} + {{$amount}} + {{$col4}} + {{$comment}} + + {{:linkbutton + label="Supprimer" + href="delete_sortie.html?key=%s"|args:$mvt_key + shape="delete" + target="_dialog"}} + {{:linkbutton + label="Modifier" + href="../modifier_mouvement.html?key=%s&direction=output&caller=%s"|args:$mvt_key:$request_url + shape="edit" + target="_dialog"}} + + + {{else}} +

Il n'y a aucune sortie.

+ {{/list}}
{{:admin_footer}} diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 53381d1..3ec8d48 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -2,8 +2,8 @@ {{:admin_header title="Sortie de matériel" current="module_equipment"}} {{if ! $dialog}} - {{* barre de navigation *}} - {{:include file="../../_nav.html" current="sorties"}} + {{* barre de navigation *}} + {{:include file="../../_nav.html" current="sorties"}} {{/if}} {{* récupérer la config des entrées/sorties *}} @@ -11,114 +11,110 @@ {{* types de sorties *}} {{#foreach from=$config.output_nature item="elem"}} - {{if $elem.type != 'retour'}} - {{:assign var='output_types.' value="%s"|args:$elem.label}} - {{/if}} + {{if $elem.type != 'retour'}} + {{:assign var='output_types.' value="%s"|args:$elem.label}} + {{/if}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{* récupérer les infos du matériel *}} - {{#load type="equipment" key=$_POST.equipment assign="equipment"}} - {{:assign designation=$equipment.designation}} - {{:assign var="categories." value=$equipment.category}} - {{/load}} + {{* récupérer les infos du matériel *}} + {{#load type="equipment" key=$_POST.equipment assign="equipment"}} + {{:assign designation=$equipment.designation}} + {{:assign var="categories." value=$equipment.category}} + {{/load}} - {{* Extraire et compiler les infos de la base *}} - {{:include - file="../../_calcul_dispo.html" - keep="equipments" - date=$_POST.date|parse_date - }} + {{* Extraire et compiler les infos de la base *}} + {{:include + file="../../_calcul_dispo.html" + keep="equipments" + date=$_POST.date|parse_date + }} - {{* déterminer la quantité disponible de ce matériel à la date donnée *}} - {{:assign var=stock from="equipments.%s.eqpmt.%s.stock"|args:$equipment.category:$_POST.equipment}} - {{:assign var=exterieur from="equipments.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_POST.equipment}} - {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + {{* déterminer la quantité disponible de ce matériel à la date donnée *}} + {{:assign var=stock from="equipments.%s.eqpmt.%s.stock"|args:$equipment.category:$_POST.equipment}} + {{:assign var=exterieur from="equipments.%s.eqpmt.%s.exterieur"|args:$equipment.category:$_POST.equipment}} + {{:assign dispo="%d-%d"|math:$stock:$exterieur}} - {{if $_POST.quantite|intval > $dispo}} - {{: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}} + {{if $_POST.quantite|intval > $dispo}} + {{: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}} - {{* Enregistrer le mouvement *}} + {{* Enregistrer le mouvement *}} - {{:assign mvt_key=""|uuid}} - {{:assign var="operation" from="output_types.%d|args:$_POST.type_operation}} - {{:save - key=$mvt_key - validate_schema="../movement.schema.json" - type="movement" - direction="output" - output_nature=$operation - amount=$_POST.quantite|intval - equipment=$equipment.key - date=$_POST.date|parse_date - comment=$_POST.remarques|trim - }} - {{:redirect force="index.html?ok=1&msg=sortie"}} + {{:assign mvt_key=""|uuid}} + {{:assign var="operation" from="output_types.%d|args:$_POST.type_operation}} + {{:save + key=$mvt_key + validate_schema="../movement.schema.json" + type="movement" + direction="output" + output_nature=$operation + amount=$_POST.quantite|intval + equipment=$equipment.key + date=$_POST.date|parse_date + comment=$_POST.remarques|trim + }} + {{:redirect force="index.html?ok=1&msg=sortie"}} {{else}} - {{:form_errors}} + {{:form_errors}} {{/form}} {{* Extraire et compiler les infos de la base *}} {{:include file="../../_calcul_dispo.html" keep="equipments"}} {{if $equipments !== null}} - {{* calculer les disponibilités *}} - {{#foreach from=$equipments key="cat_key" item="category"}} - {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} - {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} - {{:assign - var="disponibilites.%s.%s"|args:$category.name:$eqpmt_key - value="%s (dispo : %d)"|args:$eqpmt.designation:$dispo - }} - {{/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}} + {{* calculer les disponibilités *}} + {{#foreach from=$equipments key="cat_key" item="category"}} + {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} + {{:assign dispo="%d-%d"|math:$eqpmt.stock:$eqpmt.exterieur}} + {{:assign + var="disponibilites.%s.%s"|args:$category.name:$eqpmt_key + value="%s (dispo : %d)"|args:$eqpmt.designation:$dispo + }} + {{/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 *}} -
- -
- Ajouter une sortie d'un matériel disponible en stock -
- {{:input type="select" name="type_operation" label="Type" required=true options=$output_types}} - {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} - {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} -
-
- -
- Matériel -

La quantité disponible est celle à la date du jour

-
- {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$disponibilites onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} - {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} -
-
- -

- {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} -

- -
+ {{* formulaire de sortie de matériel *}} +
+
+ Ajouter une sortie d'un matériel disponible en stock +
+ {{:input type="select" name="type_operation" label="Type" required=true options=$output_types}} + {{:input type="date" name="date" label="Date de sortie" required=true default=$now|date_short}} + {{:input type="number" name="quantite" label="Quantité" required=true default=1 min=1}} +
+
+
+ Matériel +

La quantité disponible est celle à la date du jour

+
+ {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$disponibilites onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} + {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}} +
+
+

+ {{:button type="submit" name="save" label="Enregistrer" shape="right" class="main"}} +

+
{{else}} -

Il n'y a aucun matériel

+

Il n'y a aucun matériel

{{/if}} {{:admin_footer}} diff --git a/mouvements/valider_modification.html b/mouvements/valider_modification.html index 11fffe5..97cc344 100644 --- a/mouvements/valider_modification.html +++ b/mouvements/valider_modification.html @@ -1,8 +1,8 @@ {{* - Vérifier la cohérence des E/S d'un matériel - - paramètres : - - movements : liste de mouvements - - eqpmt_key : clé du matériel à vérifier + Vérifier la cohérence des E/S d'un matériel + - paramètres : + - movements : liste de mouvements + - eqpmt_key : clé du matériel à vérifier *}} {{* récupérer la config des entrées/sorties *}} @@ -13,38 +13,38 @@ {{:assign exterieur=0}} {{:assign nonprop=0}} {{#foreach from=$movements item="movement"}} - {{if $movement.equipment == $eqpmt_key}} - {{if $movement.direction == 'input'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$config.input_nature item="elem"}} - {{if $movement.input_nature == $elem.label}} - {{if $elem.type == 'définitif'}} - {{:assign stock="%d+%d"|math:$stock:$movement.amount}} - {{elseif $elem.type == 'retour'}} - {{:assign exterieur="%d-%d"|math:$exterieur:$movement.amount}} - {{elseif $elem.type == 'temporaire'}} - {{:assign nonprop="%d+%d"|math:$nonprop:$movement.amount}} - {{/if}} - {{/if}} - {{/foreach}} - {{elseif $movement.direction == 'output'}} - {{* chercher le type de sortie parmi les types de la config *}} - {{#foreach from=$config.output_nature item="elem"}} - {{if $movement.output_nature == $elem.label}} - {{if $elem.type == 'définitif'}} - {{:assign stock="%d-%d"|math:$stock:$movement.amount}} - {{elseif $elem.type == 'temporaire'}} - {{:assign exterieur="%d+%d"|math:$exterieur:$movement.amount}} - {{elseif $elem.type == 'retour'}} - {{:assign nonprop="%d-%d"|math:$nonprop:$movement.amount}} - {{/if}} - {{/if}} - {{/foreach}} - {{/if}} - {{:assign dispo="%d-%d"|math:$stock:$exterieur}} - {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonprop < 0}} - {{:assign erreur=true}} - {{:break}} - {{/if}} - {{/if}} + {{if $movement.equipment == $eqpmt_key}} + {{if $movement.direction == 'input'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$config.input_nature item="elem"}} + {{if $movement.input_nature == $elem.label}} + {{if $elem.type == 'définitif'}} + {{:assign stock="%d+%d"|math:$stock:$movement.amount}} + {{elseif $elem.type == 'retour'}} + {{:assign exterieur="%d-%d"|math:$exterieur:$movement.amount}} + {{elseif $elem.type == 'temporaire'}} + {{:assign nonprop="%d+%d"|math:$nonprop:$movement.amount}} + {{/if}} + {{/if}} + {{/foreach}} + {{elseif $movement.direction == 'output'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$config.output_nature item="elem"}} + {{if $movement.output_nature == $elem.label}} + {{if $elem.type == 'définitif'}} + {{:assign stock="%d-%d"|math:$stock:$movement.amount}} + {{elseif $elem.type == 'temporaire'}} + {{:assign exterieur="%d+%d"|math:$exterieur:$movement.amount}} + {{elseif $elem.type == 'retour'}} + {{:assign nonprop="%d-%d"|math:$nonprop:$movement.amount}} + {{/if}} + {{/if}} + {{/foreach}} + {{/if}} + {{:assign dispo="%d-%d"|math:$stock:$exterieur}} + {{if $dispo < 0 || $stock < 0 || $exterieur < 0 || $nonprop < 0}} + {{:assign erreur=true}} + {{:break}} + {{/if}} + {{/if}} {{/foreach}}