From 43270faf380e5be7bd9a510aeae1815c164c654e Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Wed, 15 Nov 2023 14:49:34 +0100 Subject: [PATCH 01/10] =?UTF-8?q?Nouvelle=20organisation=20des=20entr?= =?UTF-8?q?=C3=A9es=20et=20sorties?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- config.html | 118 +++++++++++++++++---------------------------- config.schema.json | 12 +++-- 2 files changed, 52 insertions(+), 78 deletions(-) diff --git a/config.html b/config.html index 4215003..023948d 100644 --- a/config.html +++ b/config.html @@ -11,34 +11,29 @@ {{* Traiter l'envoi du formulaire *}} {{#form on="save"}} - {{#foreach from=$_POST.input_fields|array_transpose item="field"}} - {{:assign var="input_fields." label=$field.label|trim owner=$field.owner|boolval}} - {{/foreach}} - - {{#foreach from=$_POST.output_fields|array_transpose item="field"}} - {{:assign var="output_fields." label=$field.label|trim final=$field.final|boolval}} - {{/foreach}} - {{:save key="config" validate_schema="./config.schema.json" - inputNature=$input_fields - outputNature=$output_fields + inputNature=$_POST.input_fields|array_transpose + outputNature=$_POST.output_fields|array_transpose }} {{:redirect to="./config.html?ok=1"}} {{/form}} -{{* types d'entrées par défaut *}} -{{:assign var='types_entrees.Achat' value=1}} -{{:assign var='types_entrees.Don' value=1}} -{{:assign var='types_entrees.Récupération' value=1}} -{{:assign var='types_entrees.Location' value=0}} -{{:assign var='types_entrees.Emprunt' value=0}} +{{* types d'entrées *}} +{{:assign var='types_entrees' définitif="définitif" temporaire="temporaire" retour="retour"}} -{{* types de sorties par défaut *}} -{{:assign var='types_sorties.Vente' value=1}} -{{:assign var='types_sorties.Don' value=1}} -{{:assign var='types_sorties.Location' value=0}} -{{:assign var='types_sorties.Prêt' value=0}} +{{* entrées par défaut *}} +{{:assign var='entrees_defaut.Achat' value='définitif'}} +{{:assign var='entrees_defaut.Location' value='temporaire'}} +{{:assign var='entrees_defaut.Retour de Location/Prêt' value='retour'}} + +{{* types de sorties *}} +{{:assign var='types_sorties' définitif="définitif" temporaire="temporaire" retour="retour"}} + +{{* sorties par défaut *}} +{{:assign var='sorties_defaut.Vente' value='définitif'}} +{{:assign var='sorties_defaut.Prêt' value='temporaire'}} +{{:assign var='sorties_defaut.Retour de Location/Prêt' value='retour'}}
@@ -46,8 +41,8 @@ - - + + @@ -55,28 +50,16 @@ {{#foreach from=$module.config.inputNature item="input_field"}} - + {{else}} - {{#foreach from=$types_entrees key="label" item="value"}} + {{#foreach from=$entrees_defaut key="label" item="value"}} - + @@ -90,6 +73,14 @@ 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)
  • +
+
@@ -97,8 +88,8 @@
Type d'entréePropriétaire ?
Cocher si l'association devient propriétaire du matériel
Nature de l'entréeType Action
{{:input type="text" name="input_fields[label][]" default=$input_field.label}} - - {{:input type="select" name="input_fields[type][]" options=$types_entrees default=$input_field.type required=true default_empty="— Choisir un type —"}} {{:button label="Retirer" shape="minus" onclick="this.parentNode.parentNode.remove();"}}
{{:input type="text" name="input_fields[label][]" default=$label}} - - {{:input type="select" name="input_fields[type][]" options=$types_entrees required=true default=$value default_empty="— Choisir un type —"}} {{:button label="Retirer" shape="minus" onclick="this.parentNode.parentNode.remove();"}}
- - + + @@ -106,28 +97,16 @@ {{#foreach from=$module.config.outputNature item="output_field"}} - + {{else}} - {{#foreach from=$types_sorties key="label" item="value"}} + {{#foreach from=$sorties_defaut key="label" item="value"}} - + @@ -141,6 +120,14 @@ 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 de prêt)
  • + +

@@ -150,7 +137,6 @@ label="Enregistrer" shape="right" class="main" - onclick="return desactiverCache('#input_body', '#output_body');" }}

@@ -162,26 +148,12 @@ var nelle = ligne.cloneNode(true); let text = nelle.querySelector('input[type="text"]'); text.value = null; - let cb = nelle.querySelector('input[type="checkbox"]') - if (cb != null) { - cb.checked = false; + let menu = nelle.querySelector('select') + if (menu != null) { + menu[0].selected = 'selected'; } ligne.parentNode.appendChild(nelle); text.focus(); } - - // Désactiver les champs caché des checkbox cochés - function desactiverCache(...id_body) { - for (const id of id_body) { - for (let ligne of document.querySelector(id).children) { - let idCase = ligne.querySelector("input[type=checkbox]"); - let cache = ligne.querySelector("input[type=hidden]"); // le champ caché - if (idCase.checked) { - cache.disabled = true; - } - } - } - } - {{:admin_footer}} diff --git a/config.schema.json b/config.schema.json index 0acbb84..82a7198 100644 --- a/config.schema.json +++ b/config.schema.json @@ -4,15 +4,16 @@ "properties": { "inputNature": { "description": "Nature des entrées", - "type": "array", + "type": ["array", "null"], "items": { "type": "object", "properties": { "label" : { "type" : "string" }, - "owner" : { - "type" : "boolean" + "type" : { + "type" : "string", + "enum" : ["définitif", "temporaire", "retour"] } } } @@ -26,8 +27,9 @@ "label" : { "type" : "string" }, - "final" : { - "type" : "boolean" + "type" : { + "type" : "string", + "enum" : ["définitif", "temporaire", "retour"] } } } From 77fd548effdb7b155d3152f08c9cd09905f8aba3 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Thu, 16 Nov 2023 17:42:23 +0100 Subject: [PATCH 02/10] =?UTF-8?q?Inventaire=20diff=C3=A9renci=C3=A9=20prop?= =?UTF-8?q?ri=C3=A9taire/non=20propri=C3=A9taire?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- index.html | 242 ++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 204 insertions(+), 38 deletions(-) diff --git a/index.html b/index.html index e37af82..4b2d2d7 100644 --- a/index.html +++ b/index.html @@ -5,51 +5,217 @@
- {{* itérer sur les catégories *}} - {{#load type="category" assign="category" order="$$.name"}} - {{:assign key_cat=$key}} + {{* Extraire et compiler les infos de la base *}} -

{{$category.name}}

- - {{* itérer sur les matériels de la catégorie courante *}} - {{#list - select="$$.designation AS 'Désignation'; '' AS 'Stock' ; '' AS 'Sortie' ; '' AS 'Disponible'" - type="equipment" - category=$key_cat - order=1 + {{#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 'entrée' THEN json_extract(mvt.document, '$.inputNature') + WHEN 'sortie' THEN json_extract(mvt.document, '$.outputNature') + 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" + ORDER BY + json_extract(cat.document, '$.name'), + json_extract(eqpmt.document, '$.designation'), + json_extract(mvt.document, '$.date'); }} - {{:assign equipment_key=$key}} - {{:assign var="stock" value=0}} - {{:assign var="sortie" value=0}} + {{:assign + var="equipments.%s.name"|args:$cat_key + value=$category}} + {{:assign + var="equipments.%s.eqpmt.%s.designation"|args:$cat_key:$eqpmt_key + value=$designation}} - {{* itérer sur les mouvements du matériel courant *}} - {{#load type="movement" equipment=$equipment_key assign="movement"}} - {{if $movement.direction === 'entrée'}} - {{:assign stock="%d+%d"|math:$stock:$movement.amount}} - {{else}} - {{:assign sortie="%d+%d"|math:$sortie:$movement.amount}} - {{/if}} - {{/load}} - {{:assign dispo="%d-%d"|math:$stock:$sortie}} + {{* 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}} -
- - - - - - - {{else}} -

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

- {{/list}} + {{* 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}} - {{else}} -

Il n'y a aucune catégorie => il faut en créer au moins une.

- {{/load}} + {{* 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}} + {{if $direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature 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 === 'sortie'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$module.config.outputNature 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}} + + {{* Afficher les résultats *}} + +

Matériels dont l'association est propriétaire

+ + {{* 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}} + + {{if $present}} +

{{$category.name}}

+ +
Type de sortieDéfinitif ?
Cocher si la sortie est définitive
Nature de la sortieType Action
{{:input type="text" name="output_fields[label][]" default=$output_field.label}} - - {{:input type="select" name="output_fields[type][]" options=$types_sorties default=$output_field.type required=true default_empty="— Choisir un type —"}} {{:button label="Retirer" shape="minus" onclick="this.parentNode.parentNode.remove();"}}
{{:input type="text" name="output_fields[label][]" default=$label}} - - {{:input type="select" name="output_fields[type][]" options=$types_sorties required=true default=$value default_empty="— Choisir un type —"}} {{:button label="Retirer" shape="minus" onclick="this.parentNode.parentNode.remove();"}}
{{$designation}}{{$stock}}{{$sortie}}{{$dispo}} - {{:linkbutton label="Historique des mouvements" href="historique.html?key=%s"|args:$equipment_key shape="table" target="_dialog"}} -
+ + + + + + + + + + + + {{* 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="historique.html?key=%s"|args:$eqpmt_key shape="table" target="_dialog"}} +
+ {{/if}} + {{/foreach}} + +

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

+ + {{* 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}} + + {{if $present}} +

{{$category.name}}

+ + + + + + + + + + + + {{* 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="historique.html?key=%s"|args:$eqpmt_key shape="table" target="_dialog"}} +
+ {{/if}} + {{/foreach}} {{:admin_footer}} From cd9abd4674c255e489fd35d7a6d6e10907843e31 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Fri, 17 Nov 2023 11:15:26 +0100 Subject: [PATCH 03/10] =?UTF-8?q?Mutualisation=20inventaire=20g=C3=A9n?= =?UTF-8?q?=C3=A9ral=20et=20par=20cat=C3=A9gorie?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- categories/list_equipment.html | 41 +----- index.html | 221 ++---------------------------- inventaire.html | 242 +++++++++++++++++++++++++++++++++ 3 files changed, 252 insertions(+), 252 deletions(-) create mode 100644 inventaire.html diff --git a/categories/list_equipment.html b/categories/list_equipment.html index eb0f70b..76725a0 100644 --- a/categories/list_equipment.html +++ b/categories/list_equipment.html @@ -15,44 +15,7 @@ {{/if}} -{{* afficher les matériels de la catégorie sélectionnée avec le stock, les entrées et les sorties *}} -
- - {{#list - select="$$.designation AS 'Désignation'; '' AS 'Stock' ; '' AS 'Sortie' ; '' AS 'Disponible'" - type="equipment" - category=$_GET.key - order=1}} - - {{:assign equipment_key=$key}} - {{:assign var="stock" value=0}} - {{:assign var="sortie" value=0}} - - {{* récupérer les mouvements du matériel courant *}} - {{#load - type="movement" - equipment=$equipment_key - assign="movement"}} - - {{if $movement.direction === 'entrée'}} - {{:assign stock="%d+%d"|math:$stock:$movement.amount}} - {{else}} - {{:assign sortie="%d+%d"|math:$sortie:$movement.amount}} - {{/if}} - {{/load}} - - {{:assign dispo="%d-%d"|math:$stock:$sortie}} - - {{$designation}} - {{$stock}} - {{$sortie}} - {{$dispo}} - - -{{else}} -

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

-{{/list}} - -
+{{:assign var="categories." value=$_GET.key}} +{{:include file="/%s/inventaire.html"|args:$module.name}} {{:admin_footer}} diff --git a/index.html b/index.html index 4b2d2d7..bd59724 100644 --- a/index.html +++ b/index.html @@ -3,219 +3,14 @@ {{* barre de navigation *}} {{:include file="/%s/_nav.html"|args:$module.name current="index"}} -
+{{* liste des catégories *}} +{{#select + key + FROM module_data_equipment as cat + WHERE json_extract(cat.document, '$.type') = 'category'}} + {{:assign var="categories." value=$key}} +{{/select}} - {{* 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 'entrée' THEN json_extract(mvt.document, '$.inputNature') - WHEN 'sortie' THEN json_extract(mvt.document, '$.outputNature') - 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" - ORDER BY - json_extract(cat.document, '$.name'), - json_extract(eqpmt.document, '$.designation'), - json_extract(mvt.document, '$.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}} - - {{* 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 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}} - - {{if $direction === 'entrée'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$module.config.inputNature 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 === 'sortie'}} - {{* chercher le type de sortie parmi les types de la config *}} - {{#foreach from=$module.config.outputNature 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}} - - {{* Afficher les résultats *}} - -

Matériels dont l'association est propriétaire

- - {{* 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}} - - {{if $present}} -

{{$category.name}}

- - - - - - - - - - - - - - {{* 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="historique.html?key=%s"|args:$eqpmt_key shape="table" target="_dialog"}} -
- {{/if}} - {{/foreach}} - -

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

- - {{* 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}} - - {{if $present}} -

{{$category.name}}

- - - - - - - - - - - - {{* 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="historique.html?key=%s"|args:$eqpmt_key shape="table" target="_dialog"}} -
- {{/if}} - {{/foreach}} -
+{{:include file="./inventaire.html" print_cat_name=true}} {{:admin_footer}} diff --git a/inventaire.html b/inventaire.html new file mode 100644 index 0000000..b025330 --- /dev/null +++ b/inventaire.html @@ -0,0 +1,242 @@ +{{* inventaire des entrées/sorties des matériels des catégories de la variable $categories *}} + +{{:assign base_path="/m/%s"|args:$module.name}} + +{{* 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 'entrée' THEN json_extract(mvt.document, '$.inputNature') + WHEN 'sortie' THEN json_extract(mvt.document, '$.outputNature') + 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 + ORDER BY + json_extract(cat.document, '$.name'), + json_extract(eqpmt.document, '$.designation'), + json_extract(mvt.document, '$.date'); + !categories='cat_key'|sql_where:'IN':$categories +}} + + {{: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 à 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}} + + {{if $direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature 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 === 'sortie'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$module.config.outputNature 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}} + +{{* 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}} +{{else}} + +
+

Matériels dont l'association est propriétaire

+ + {{* 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}} + + {{if $print_cat_name}} +

{{$category.name}}

+ {{/if}} + + {{if $present}} + + + + + + + + + + + + + {{* 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="%s/historique.html?key=%s"|args:$base_path:$eqpmt_key + shape="table" + target="_dialog"}} +
+ {{else}} +

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

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

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

+ + {{* 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}} + + {{if $print_cat_name}} +

{{$category.name}}

+ {{/if}} + + {{if $present}} + + + + + + + + + + + {{* 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="%s/historique.html?key=%s"|args:$base_path:$eqpmt_key + shape="table" + target="_dialog"}} +
+ {{else}} +

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

+ {{/if}} + {{/foreach}} +
+{{/if}} From 2779f99ad3b5be32dc562903740221f2c8be2b67 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Sat, 18 Nov 2023 21:34:10 +0100 Subject: [PATCH 04/10] =?UTF-8?q?Modification=20cosm=C3=A9tique?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- config.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config.html b/config.html index 023948d..24631ba 100644 --- a/config.html +++ b/config.html @@ -125,7 +125,7 @@
  • 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 de prêt)
  • +
  • retour : le matériel non propriété de l'asso est rendu à son propriétaire (ex : retour de location ou d'emprunt)
From c18865a4670f517c8f1abce1c018d68e5ea8d420 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Sat, 18 Nov 2023 21:36:05 +0100 Subject: [PATCH 05/10] =?UTF-8?q?V=C3=A9rification=20quantit=C3=A9=20mat?= =?UTF-8?q?=C3=A9riel=20disponible=20=C3=A0=20la=20date=20de=20la=20sortie?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- mouvements/sorties/stock_disponible.html | 100 +++++++++++++++++++---- 1 file changed, 83 insertions(+), 17 deletions(-) diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 660c773..9d970db 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -18,20 +18,51 @@ {{#form on="save"}} {{* récupérer les infos du matériel *}} {{#load type="equipment" key=$_POST.equipment assign="equipment"}} + {{:assign designation=$equipment.designation}} {{/load}} - {{* TODO vérifier si qté sortie <= dispo *}} - {{:include file="./_calcul_dispo.html" keep="dispo" }} + {{* déterminer la quantité disponible de ce matériel à la date donnée *}} + {{:assign var="dispo" value=0}} + {{#load + type="movement" + where="$$.equipment = :eqpmt_key AND $$.date <= :date" + :eqpmt_key=$equipment.key + :date=$_POST.date|parse_date + assign="movement" + }} + {{if $movement.direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature item="elem"}} + {{if $movement.inputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'retour'}} + {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{else}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.outputNature item="elem"}} + {{if $movement.outputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'temporaire'}} + {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{/if}} + {{else}} + {{:error message="Erreur : il n'y a aucun mouvement pour le matériel « %s » avant la date du %s."|args:$equipment.designation:$_POST.date}} + {{/load}} - {{* cumuler les entrées et les sorties de ce matériel *}} {{if $_POST.quantite|intval > $dispo}} - {{:error message="Erreur : la quantité indiquée (%s) est supérieure à celle disponible (%d)"|args:$_POST.quantite:$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 *}} + {{:assign mvt_key=""|uuid}} {{:assign var="operation" from="types_sorties.%d|args:$_POST.type_operation}} - {{:save key=$mvt_key validate_schema="/%s/mouvements/movement.schema.json"|args:$module.name @@ -43,25 +74,60 @@ date=$_POST.date|parse_date comment=$_POST.remarques|trim }} - - {{:redirect force="index.html?ok=1&msg=Sortie de « %s » enregistrée"|args:$equipment.designation}} + {{:redirect force="index.html?ok=1&msg=Sortie de « %s » (%d) enregistrée"|args:$designation:$_POST.quantite}} {{else}} {{:form_errors}} {{/form}} -{{* lister les catégories et matériels associés *}} +{{* itérer sur les catégories *}} {{#load type="category" assign="category" order="$$.name"}} - {{:assign nom_cat=$category.name}} + {{:assign nom_cat=$category.name}} - {{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment" order="$$.designation"}} + {{* lister les matériels de la catégorie *}} + {{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment" order="$$.designation"}} + {{:assign designation=$equipment.designation}} - {{* cumuler les entrées et les sorties de ce matériel *}} - {{:include file="./_calcul_dispo.html" keep="dispo" }} + {{* déterminer la quantité disponible de ce matériel, + ie propriété de l'asso et pas en prêt à la date du jour *}} + {{:assign var="dispo" value=0}} + {{#load + type="movement" + where="$$.equipment = :eqpmt_key AND $$.date <= :date" + :eqpmt_key=$equipment.key + :date=$now|date:"Y-m-d" + assign="movement" + }} - {{if $dispo > 0}} - {{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$equipment.designation:$dispo}} - {{/if}} - {{/load}} + {{if $movement.direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature item="elem"}} + {{if $movement.inputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'retour'}} + {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{else}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.outputNature item="elem"}} + {{if $movement.outputNature == $elem.label}} + {{if $elem.type == 'définitif' || $elem.type == 'temporaire'}} + {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} + {{/if}} + {{:break}} + {{/if}} + {{/foreach}} + {{/if}} + {{else}} +

Il n'y a aucun movement dans cette période.

+ {{/load}} + + {{if $dispo > 0}} + {{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$designation:$dispo}} + {{/if}} + + {{/load}} {{/load}} {{* formulaire de sortie de matériel *}} @@ -73,9 +139,9 @@ {{:input type="select" name="type_operation" label="Type" required=true options=$types_sorties}} {{: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=$equipments onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} {{:input type="textarea" name="remarques" label="Remarques" cols="40" rows="3" required=false}}
From 2376a2d648a34f4ac6bfab08237b757151b10619 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Sun, 19 Nov 2023 18:41:34 +0100 Subject: [PATCH 06/10] =?UTF-8?q?Ajout=20description=20aux=20sch=C3=A9mas?= =?UTF-8?q?=20json?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- equipment.schema.json | 1 + mouvements/movement.schema.json | 1 + 2 files changed, 2 insertions(+) diff --git a/equipment.schema.json b/equipment.schema.json index 76b61d0..c6c5758 100644 --- a/equipment.schema.json +++ b/equipment.schema.json @@ -7,6 +7,7 @@ "enum": ["equipment"] }, "category" : { + "description": "Clé de la catégorie", "type": "string" }, "designation": { diff --git a/mouvements/movement.schema.json b/mouvements/movement.schema.json index d56d663..6d2f153 100644 --- a/mouvements/movement.schema.json +++ b/mouvements/movement.schema.json @@ -25,6 +25,7 @@ "minimum": 1 }, "equipment": { + "description": "Clé du matériel", "type": "string" }, "date" : { From 0b356b6617c17d03ef29c31b6f82559fbce55183 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Mon, 20 Nov 2023 11:18:50 +0100 Subject: [PATCH 07/10] =?UTF-8?q?Mutualisation=20calcul=20des=20entr=C3=A9?= =?UTF-8?q?es/sorties=20=C3=A0=20une=20date=20donn=C3=A9e?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- _calcul_dispo.html | 134 +++++++++++++++++++++++ index.html | 8 -- inventaire.html | 111 +------------------ mouvements/sorties/_calcul_dispo.html | 9 -- mouvements/sorties/stock_disponible.html | 106 ++++-------------- 5 files changed, 158 insertions(+), 210 deletions(-) create mode 100644 _calcul_dispo.html delete mode 100644 mouvements/sorties/_calcul_dispo.html diff --git a/_calcul_dispo.html b/_calcul_dispo.html new file mode 100644 index 0000000..5c75b0e --- /dev/null +++ b/_calcul_dispo.html @@ -0,0 +1,134 @@ +{{* + 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}} + {{#select + key + FROM module_data_equipment as cat + WHERE json_extract(cat.document, '$.type') = 'category'}} + {{:assign var="categories." value=$key}} + {{/select}} +{{/if}} + +{{* date *}} +{{if $date === null}} + {{:assign date=$now|date:"Y-m-d"}} +{{/if}} + +{{* :debug date=$date *}} + +{{* 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 'entrée' THEN json_extract(mvt.document, '$.inputNature') + WHEN 'sortie' THEN json_extract(mvt.document, '$.outputNature') + 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}} + + {{* 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 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}} + + {{if $direction === 'entrée'}} + {{* chercher le type d'entrée parmi les types de la config *}} + {{#foreach from=$module.config.inputNature 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 === 'sortie'}} + {{* chercher le type de sortie parmi les types de la config *}} + {{#foreach from=$module.config.outputNature 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/index.html b/index.html index bd59724..46af22c 100644 --- a/index.html +++ b/index.html @@ -3,14 +3,6 @@ {{* barre de navigation *}} {{:include file="/%s/_nav.html"|args:$module.name current="index"}} -{{* liste des catégories *}} -{{#select - key - FROM module_data_equipment as cat - WHERE json_extract(cat.document, '$.type') = 'category'}} - {{:assign var="categories." value=$key}} -{{/select}} - {{:include file="./inventaire.html" print_cat_name=true}} {{:admin_footer}} diff --git a/inventaire.html b/inventaire.html index b025330..bfa0f33 100644 --- a/inventaire.html +++ b/inventaire.html @@ -1,115 +1,7 @@ {{* inventaire des entrées/sorties des matériels des catégories de la variable $categories *}} -{{:assign base_path="/m/%s"|args:$module.name}} - {{* 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 'entrée' THEN json_extract(mvt.document, '$.inputNature') - WHEN 'sortie' THEN json_extract(mvt.document, '$.outputNature') - 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 - ORDER BY - json_extract(cat.document, '$.name'), - json_extract(eqpmt.document, '$.designation'), - json_extract(mvt.document, '$.date'); - !categories='cat_key'|sql_where:'IN':$categories -}} - - {{: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 à 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}} - - {{if $direction === 'entrée'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$module.config.inputNature 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 === 'sortie'}} - {{* chercher le type de sortie parmi les types de la config *}} - {{#foreach from=$module.config.outputNature 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}} +{{:include file="./_calcul_dispo.html" keep="equipments"}} {{* Afficher les résultats *}} {{if $equipments === null}} @@ -152,6 +44,7 @@ + {{:assign base_path="/m/%s"|args:$module.name}} {{* itérer sur les matériels de la catégorie *}} {{#foreach from=$category.eqpmt key="eqpmt_key" item="eqpmt"}} diff --git a/mouvements/sorties/_calcul_dispo.html b/mouvements/sorties/_calcul_dispo.html deleted file mode 100644 index 2591d77..0000000 --- a/mouvements/sorties/_calcul_dispo.html +++ /dev/null @@ -1,9 +0,0 @@ - {{* cumuler les entrées et les sorties de ce matériel *}} - {{:assign var="dispo" value=0}} - {{#load type="movement" where="$$.equipment = :eqpmt_key" :eqpmt_key=$equipment.key assign="movement"}} - {{if $movement.direction === 'entrée'}} - {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} - {{else}} - {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} - {{/if}} - {{/load}} diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 9d970db..6de88f4 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -11,7 +11,7 @@ {{* types de sorties *}} {{#foreach from=$module.config.outputNature item="elem"}} - {{:assign var='types_sorties.' value="%s"|args:$elem.label}} + {{:assign var='types_sorties.' value="%s"|args:$elem.label}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} @@ -19,48 +19,24 @@ {{* 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}} + {{:assign date=$_POST.date|parse_date}} + + {{* Extraire et compiler les infos de la base *}} + {{:include file="/%s/_calcul_dispo.html"|args:$module.name keep="equipments"}} {{* déterminer la quantité disponible de ce matériel à la date donnée *}} - {{:assign var="dispo" value=0}} - {{#load - type="movement" - where="$$.equipment = :eqpmt_key AND $$.date <= :date" - :eqpmt_key=$equipment.key - :date=$_POST.date|parse_date - assign="movement" - }} - {{if $movement.direction === 'entrée'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$module.config.inputNature item="elem"}} - {{if $movement.inputNature == $elem.label}} - {{if $elem.type == 'définitif' || $elem.type == 'retour'}} - {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} - {{/if}} - {{:break}} - {{/if}} - {{/foreach}} - {{else}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$module.config.outputNature item="elem"}} - {{if $movement.outputNature == $elem.label}} - {{if $elem.type == 'définitif' || $elem.type == 'temporaire'}} - {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} - {{/if}} - {{:break}} - {{/if}} - {{/foreach}} - {{/if}} - {{else}} - {{:error message="Erreur : il n'y a aucun mouvement pour le matériel « %s » avant la date du %s."|args:$equipment.designation:$_POST.date}} - {{/load}} + {{: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}} {{* Enregistrer le mouvement *}} - + {{:assign mvt_key=""|uuid}} {{:assign var="operation" from="types_sorties.%d|args:$_POST.type_operation}} {{:save @@ -79,59 +55,21 @@ {{:form_errors}} {{/form}} -{{* itérer sur les catégories *}} -{{#load type="category" assign="category" order="$$.name"}} - {{:assign nom_cat=$category.name}} +{{* Extraire et compiler les infos de la base *}} +{{:include file="/%s/_calcul_dispo.html"|args:$module.name keep="equipments"}} - {{* lister les matériels de la catégorie *}} - {{#load type="equipment" where="$$.category = :key" :key=$category.key assign="equipment" order="$$.designation"}} - {{:assign designation=$equipment.designation}} - - {{* déterminer la quantité disponible de ce matériel, - ie propriété de l'asso et pas en prêt à la date du jour *}} - {{:assign var="dispo" value=0}} - {{#load - type="movement" - where="$$.equipment = :eqpmt_key AND $$.date <= :date" - :eqpmt_key=$equipment.key - :date=$now|date:"Y-m-d" - assign="movement" +{{* 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 }} - - {{if $movement.direction === 'entrée'}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$module.config.inputNature item="elem"}} - {{if $movement.inputNature == $elem.label}} - {{if $elem.type == 'définitif' || $elem.type == 'retour'}} - {{:assign dispo="%d+%d"|math:$dispo:$movement.amount}} - {{/if}} - {{:break}} - {{/if}} - {{/foreach}} - {{else}} - {{* chercher le type d'entrée parmi les types de la config *}} - {{#foreach from=$module.config.outputNature item="elem"}} - {{if $movement.outputNature == $elem.label}} - {{if $elem.type == 'définitif' || $elem.type == 'temporaire'}} - {{:assign dispo="%d-%d"|math:$dispo:$movement.amount}} - {{/if}} - {{:break}} - {{/if}} - {{/foreach}} - {{/if}} - {{else}} -

Il n'y a aucun movement dans cette période.

- {{/load}} - - {{if $dispo > 0}} - {{:assign var="equipments.%s.%s"|args:$nom_cat:$equipment.key value="%s (dispo : %d)"|args:$designation:$dispo}} - {{/if}} - - {{/load}} -{{/load}} + {{/foreach}} +{{/foreach}} {{* formulaire de sortie de matériel *}} -
@@ -142,7 +80,7 @@
Matériel

La quantité disponible est celle à la date du jour

- {{:input type="select_groups" name="equipment" label="Matériel" required=true options=$equipments onchange="fixerValeurMax('f_equipment', 'f_quantite')"}} + {{: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}}
From 4dd8d660a8620abafc542678c26c5169665bfce3 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Mon, 20 Nov 2023 11:40:49 +0100 Subject: [PATCH 08/10] Correction mineure type sortie --- mouvements/sorties/stock_disponible.html | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 6de88f4..736bc63 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -11,7 +11,9 @@ {{* types de sorties *}} {{#foreach from=$module.config.outputNature item="elem"}} - {{:assign var='types_sorties.' value="%s"|args:$elem.label}} + {{if $elem.type != 'retour'}} + {{:assign var='types_sorties.' value="%s"|args:$elem.label}} + {{/if}} {{/foreach}} {{* Traiter l'envoi du formulaire *}} From 56119b985bc98a7ef9949e5504705d77d290fa72 Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Mon, 20 Nov 2023 12:31:39 +0100 Subject: [PATCH 09/10] =?UTF-8?q?Correction=20erreur=20calcul=20quantit?= =?UTF-8?q?=C3=A9=20mat=C3=A9riel=20non=20propri=C3=A9t=C3=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- _calcul_dispo.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_calcul_dispo.html b/_calcul_dispo.html index 5c75b0e..8d38221 100644 --- a/_calcul_dispo.html +++ b/_calcul_dispo.html @@ -122,7 +122,7 @@ 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 nonproprio="%d-%d"|math:$nonproprio:$nombre}} {{:assign var="equipments.%s.eqpmt.%s.nonproprio"|args:$cat_key:$eqpmt_key from=nonproprio}} From 3688cc5ed34e711f706458e403a7eecf34a6051b Mon Sep 17 00:00:00 2001 From: Jean-Christophe Engel Date: Mon, 20 Nov 2023 14:00:00 +0100 Subject: [PATCH 10/10] =?UTF-8?q?Ajout=20sortie=20mat=C3=A9riel=20emprunt?= =?UTF-8?q?=C3=A9=20+=20correction=20erreur?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- _calcul_dispo.html | 2 - mouvements/sorties/emprunte.html | 112 +++++++++++++++++++++++ mouvements/sorties/index.html | 2 +- mouvements/sorties/stock_disponible.html | 3 + 4 files changed, 116 insertions(+), 3 deletions(-) create mode 100644 mouvements/sorties/emprunte.html diff --git a/_calcul_dispo.html b/_calcul_dispo.html index 8d38221..9e015a0 100644 --- a/_calcul_dispo.html +++ b/_calcul_dispo.html @@ -20,8 +20,6 @@ {{:assign date=$now|date:"Y-m-d"}} {{/if}} -{{* :debug date=$date *}} - {{* Extraire et compiler les infos de la base *}} {{#select json_extract(mvt.document, '$.date') as 'date', diff --git a/mouvements/sorties/emprunte.html b/mouvements/sorties/emprunte.html new file mode 100644 index 0000000..b35f787 --- /dev/null +++ b/mouvements/sorties/emprunte.html @@ -0,0 +1,112 @@ +{{#restrict section="config" level="admin" block=true}}{{/restrict}} +{{:admin_header title="Gestion des matériels" current="module_equipment"}} + +{{if $_GET.dialog === null}} + {{* barre de navigation *}} + {{:include file="/%s/_nav.html"|args:$module.name current="sorties"}} +{{else}} +
+

Sortie de matériel

+{{/if}} + +{{* types de sorties *}} +{{#foreach from=$module.config.outputNature item="elem"}} + {{if $elem.type == 'retour'}} + {{:assign var='types_sorties.' 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}} + {{:assign date=$_POST.date|parse_date}} + + {{* Extraire et compiler les infos de la base *}} + {{:include file="/%s/_calcul_dispo.html"|args:$module.name keep="equipments"}} + + {{* 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}} + + {{* Enregistrer le mouvement *}} + + {{:assign mvt_key=""|uuid}} + {{:assign var="operation" from="types_sorties.%d|args:$_POST.type_operation}} + {{:save + key=$mvt_key + validate_schema="/%s/mouvements/movement.schema.json"|args:$module.name + type="movement" + direction="sortie" + outputNature=$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 de « %s » (%d) enregistrée"|args:$designation:$_POST.quantite}} +{{else}} + {{:form_errors}} +{{/form}} + +{{* Extraire et compiler les infos de la base *}} +{{:include file="/%s/_calcul_dispo.html"|args:$module.name keep="equipments"}} + +{{* 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}} + {{: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=$types_sorties}} + {{: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"}} +

+ + + + + +{{:admin_footer}} diff --git a/mouvements/sorties/index.html b/mouvements/sorties/index.html index 2fbe84c..2879923 100644 --- a/mouvements/sorties/index.html +++ b/mouvements/sorties/index.html @@ -12,7 +12,7 @@
Ajouter une sortie pour du {{:linkbutton label="Matériel en stock disponible" shape="plus" href="stock_disponible.html?dialog" target="_dialog"}} - {{:linkbutton label="Matériel emprunté" shape="plus" href="emprunte.html}} + {{:linkbutton label="Matériel emprunté" shape="plus" href="emprunte.html?dialog" target="_dialog"}}
diff --git a/mouvements/sorties/stock_disponible.html b/mouvements/sorties/stock_disponible.html index 736bc63..c8315ee 100644 --- a/mouvements/sorties/stock_disponible.html +++ b/mouvements/sorties/stock_disponible.html @@ -70,6 +70,9 @@ }} {{/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 *}}