Add utility scripts
This commit is contained in:
parent
3c6579e7a3
commit
69327d9edf
33
scripts/product_definitions.csv
Normal file
33
scripts/product_definitions.csv
Normal file
@ -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
|
|
47
scripts/provision.py
Executable file
47
scripts/provision.py
Executable file
@ -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()
|
66
scripts/renew_lineup.py
Executable file
66
scripts/renew_lineup.py
Executable file
@ -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 = '<tspan style="font-weight:bold">'
|
||||||
|
ALLERGEN_END_STYLE = '</tspan>'
|
||||||
|
|
||||||
|
|
||||||
|
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()
|
14
scripts/subber.py
Normal file
14
scripts/subber.py
Normal file
@ -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))
|
Loading…
Reference in New Issue
Block a user