From 69327d9edf1b73741cf9670edee30dbd85124a06 Mon Sep 17 00:00:00 2001 From: Paul Mathieu Date: Tue, 5 Aug 2025 22:24:57 +0200 Subject: [PATCH] Add utility scripts --- scripts/product_definitions.csv | 33 +++++++++++++++++ scripts/provision.py | 47 +++++++++++++++++++++++ scripts/renew_lineup.py | 66 +++++++++++++++++++++++++++++++++ scripts/subber.py | 14 +++++++ 4 files changed, 160 insertions(+) create mode 100644 scripts/product_definitions.csv create mode 100755 scripts/provision.py create mode 100755 scripts/renew_lineup.py create mode 100644 scripts/subber.py diff --git a/scripts/product_definitions.csv b/scripts/product_definitions.csv new file mode 100644 index 0000000..7e03359 --- /dev/null +++ b/scripts/product_definitions.csv @@ -0,0 +1,33 @@ +aromate;Herbes de Provence;Thym*, Sarriette*, Origan*;Le classique des herbes aromatiques pour donner une touche méditerranéenne à vos plats.;6307a6;Aromate - Herbes de Provence - Thym Sarriette Origan.svg;True +aromate;Origan;Origan*;La fameuse herbe à pizza, mais qui peut aussi assaisonner vos soupes, plats mijotés, poissons ou charcuteries.;4800b9;Aromate - Origan.svg;True +aromate;Sarriette;Sarriette des montagnes*;Le pèbre d'aï s'utilise en cuisine dans les pommes de terre, champignons, ragoûts de légumes, riz...;00d40e;Aromate - Sarriette.svg;True +aromate;Sauge;Sauge officinale*;La plante qui sauve peut être utilisée en cuisine, dans vos viandes en sauce, légumes, vinaigrettes...;d00676;Aromate - Sauge.svg;True +aromate;Thym;Thym*;Le roi des aromates, à utiliser en branche ou effeuillé, pour agrémenter vos grillades, plats en sauce, poêlées...;0048ff;Aromate - Thym.svg;True +confiture;Confiture d'Abricot;Abricot*, Sucre de canne*;;ff5d00;Confiture - Abricot.svg;True +confiture;Confiture d'Abricot;Abricot, Sucre de canne*;;ff5d00;Confiture - Abricot - Non Bio.svg;False +confiture;Confiture d'Abricot Lavande;Abricot, Lavande*, Sucre de canne*;;9683ec;Confiture - Abricot Lavande - Non Bio.svg;False +confiture;Gelée Extra de Groseille;Groseille*, Sucre de canne*;;ec001a;Gelée Extra - Groseille.svg;True +confiture;Gelée Extra de Cassis;Cassis*, Sucre de canne*;;9b00ff;Gelée Extra - Cassis.svg;True +confiture;Marmelade d'Orange Amère; Oranges amères, Sucre de canne*, eau;;ff5d00;Marmelade - Orange Amère - Non Bio.svg;False +pesto;Pesto de Livèche;Huile d'olive*, Livèche* (34%), *amandes*, jus de citron*, ail*, sel;;119200;Pesto - Livèche.svg;True +pesto;Pesto d'Ail des Ours;Huile d'olive*, Ail des ours* (34%), *Amandes*, Jus de citron*, Sel;;196b00;Pesto - Ail des Ours.svg;True +sirop;Lavande;Sucre* (55%), Infusion de lavande* (42%), Jus de citron* (3%);;4200ff;Sirop - Lavande.svg;True +sirop;Thym;Sucre* (55%), Infusion de thym* (42%), Jus de citron* (3%);;0048ff;Sirop - Thym.svg;True +sirop;Mélisse;Sucre* (55%), Infusion de mélisse* (42%), Jus de citron* (3%);;d00676;Sirop - Mélisse.svg;True +sirop;Menthe Verte;Sucre* (55%), Infusion de menthe verte* (42%), Jus de citron* (3%);;007e49;Sirop - Menthe Verte.svg;True +sirop;Menthe et Mélisse;Sucre* (55%), Infusion de menthe verte* et mélisse* (42%), Jus de citron* (3%);;fabf12;Sirop - Menthe et Mélisse.svg;True +sirop;Sureau;Sucre* (55%), Infusion de sureau* (42%), Jus de citron* (3%);;8aa700;Sirop - Sureau.svg;True +sirop;Romarin;Sucre* (55%), Infusion de romarin* (42%), Jus de citron* (3%);;007d87;Sirop - Romarin.svg;True +tisane;J'ai Bien Mangé...; Thym*, Sauge*, Romarin*, Soucis*;;0c7c00;Tisane - Digestion - Thym Sauge Romarin Soucis.svg;True +tisane;Nuit Étoilée;Agastache*, Mélisse*, Aubépine*;;5b7aff;Tisane - Nuit Étoilée - Agastache Mélisse Aubépine.svg;True +tisane;Nuit Étoilée;Mélisse*, Lavande*, Aubépine*;;5b7aff;Tisane - Nuit Étoilée - Mélisse Lavande Aubépine.svg;True +tisane;Réconfort de la Gorge; Origan*, Agastache*, Thym*, Bleuet*;;00a07b;Tisane - Réconfort de la Gorge - Origan Agastache Thym Bleuet.svg;True +tisane;Équilibre Féminin;Achillée millefeuille*, Lavande vraie*, Cynorhodon*;;64139f;Tisane - Équilibre Féminin - Achillée millefeuille Lavande vraie Cynorhodon.svg;True +tisane;Équilibre Féminin;Achillée millefeuille*, Lavande vraie*, Ortie piquante*;;64139f;Tisane - Équilibre Féminin - Achillée millefeuille Lavande vraie Ortie piquante.svg;True +tisane;Équilibre Féminin;Achillée millefeuille*, Lavande vraie*, Pétales de Cynorhodon*;;64139f;Tisane - Équilibre Féminin - Achillée millefeuille Lavande vraie Pétales de Cynorhodon.svg;True +tisane;Équilibre Féminin;Achillée millefeuille*, Lavande vraie*, Sauge officinale*, Ortie piquante*;;64139f;Tisane - Équilibre Féminin - Achillée millefeuille Lavande vraie Sauge officinale Ortie piquante.svg;True +tisane;Joie de Vivre;Basilic sacré*, Sarriette des montagnes*, Lavande vraie*;;ff6d00;Tisane - Joie de Vivre - Basilic Sacré Sarriette des Montagnes Lavande Vraie.svg;True +sel;Grillades - Viande et Légumes;Sel de Camargue, Thym*, Origan*, Sarriette*, Mélisse*, Souci*;;c80003;Sel - Grillades.svg;True +sel;Herbes de Provence;Sel de Camargue, Thym*, Origan*, Sarriette*, Romarin*;;6307a6;Sel - Herbes de Provence.svg;True +sel;Poisson et Viande Blanche;Sel de Camargue, Thym*, Sauge*, Agastache*, Bleuet*;;5b7aff;Sel - Poisson et Viande Blanche.svg;True +chocolat;Menthe Poivrée;"Chocolat de couverture noir* (pâte de cacao*, sucre de canne*, beurre de cacao*; peut contenir : *lait), *crème entière* (crème de lait à 30% de matière grasse*, stabilisants : carraghénanes), menthe poivrée*";;007e49;Chocolat - Menthe Poivrée.svg;True diff --git a/scripts/provision.py b/scripts/provision.py new file mode 100755 index 0000000..a4aeb4a --- /dev/null +++ b/scripts/provision.py @@ -0,0 +1,47 @@ +#!/usr/bin/env python3 + +import csv +import dataclasses +import requests + +backend = 'http://localhost:8000' +products_file = './product_definitions.csv' + + +@dataclasses.dataclass +class Tikette: + category: str + designation: str + ingredients: str + description: str + color: str + svg: str + ab: str + + def newtikette_payload(self, katzids): + return { + 'title': self.svg.split('.')[0], + 'category_id': katzids[self.category], + 'designation': self.designation, + 'ingredients': self.ingredients, + 'description': self.description, + 'color': self.color, + 'ab': 'inline' if self.ab else 'none', + } + + +def get_tikettes(): + with open('./product_definitions.csv') as f: + return [Tikette(*x) for x in csv.reader(f, delimiter=';')] + + +def populate_database(): + katz = requests.get(backend + '/categories', json=True).json()['tikats'] + katzids = {x['name'].lower(): x['id'] for x in katz} + + for tk in get_tikettes(): + requests.post(backend + '/newtikette', json=tk.newtikette_payload(katzids)) + + +if __name__ == "__main__": + populate_database() diff --git a/scripts/renew_lineup.py b/scripts/renew_lineup.py new file mode 100755 index 0000000..249c209 --- /dev/null +++ b/scripts/renew_lineup.py @@ -0,0 +1,66 @@ +#!/usr/bin/env python3 + +import argparse +from string import Template +import sys +import os +import csv +from subber import Subber + +TEMPLATES_DIR = os.path.join(os.path.dirname(__file__), "..", "templates") +OUT_DIR = "." +DEFAULT_CSV = 'product_definitions.csv' + +JAM_DESIGNATION_FONTSIZE_DEFAULT = 42.6667 +JAM_DESIGNATION_FONTSIZE_SMALL = 36 + + +templates = { + 'aromate': f"{TEMPLATES_DIR}/Aromate.svg", + 'chocolat': f"{TEMPLATES_DIR}/Chocolat.svg", + 'confiture': f"{TEMPLATES_DIR}/Confiture.svg", + 'pesto': f"{TEMPLATES_DIR}/Pesto.svg", + 'sirop': f"{TEMPLATES_DIR}/Sirop.svg", + 'tisane': f"{TEMPLATES_DIR}/Tisane.svg", + 'sel': f"{TEMPLATES_DIR}/Sel.svg", +} + +ALLERGEN_BEGIN_STYLE = '' +ALLERGEN_END_STYLE = '' + + +def parse_args(): + parser = argparse.ArgumentParser(description='Renew whole lineup from template and list of subs') + parser.add_argument('--list', default=DEFAULT_CSV, help='Lineup file') + + return parser.parse_args() + + +def main(): + args = parse_args() + + with open(args.list) as csvfile: + reader = csv.reader(csvfile, delimiter=';', quotechar='"') + for row in reader: + template = templates[row[0]] + outfile = f"{OUT_DIR}/{row[5]}" + with open(outfile, 'w') as out: + # TODO Fix bold formatting with allergen and parenthesis + ingredients = [e.strip() for e in row[2].split(',')] + ingredients = [e if not e.startswith('*') else ALLERGEN_BEGIN_STYLE + e[1:] + ALLERGEN_END_STYLE for e in ingredients] + ingredients_sub = ", ".join(ingredients) + AB_logo_visibility = 'inline' if row[6] == 'True' else 'none' + subs = { + 'designation': row[1].strip(), + 'ingredients': ingredients_sub, + 'description': row[3].strip(), + 'color': row[4], + 'AB': AB_logo_visibility, + 'designation_fontsize': JAM_DESIGNATION_FONTSIZE_DEFAULT, + } + s = Subber(subs) + s.sub(template, out) + + +if __name__ == "__main__": + main() diff --git a/scripts/subber.py b/scripts/subber.py new file mode 100644 index 0000000..f185789 --- /dev/null +++ b/scripts/subber.py @@ -0,0 +1,14 @@ +from string import Template + + +class Subber(): + + def __init__(self, subs): + self.subs = subs + + def sub(self, infile, outfile): + with open(infile) as template: + lines = template.readlines() + data = ''.join(lines) + + outfile.write(Template(data).safe_substitute(self.subs))