cookbookapp importer
This commit is contained in:
parent
aeb5682176
commit
94e357f4f6
@ -130,13 +130,14 @@ class ImportExportBase(forms.Form):
|
|||||||
REZKONV = 'REZKONV'
|
REZKONV = 'REZKONV'
|
||||||
OPENEATS = 'OPENEATS'
|
OPENEATS = 'OPENEATS'
|
||||||
PLANTOEAT = 'PLANTOEAT'
|
PLANTOEAT = 'PLANTOEAT'
|
||||||
|
COOKBOOKAPP = 'COOKBOOKAPP'
|
||||||
|
|
||||||
type = forms.ChoiceField(choices=(
|
type = forms.ChoiceField(choices=(
|
||||||
(DEFAULT, _('Default')), (PAPRIKA, 'Paprika'), (NEXTCLOUD, 'Nextcloud Cookbook'),
|
(DEFAULT, _('Default')), (PAPRIKA, 'Paprika'), (NEXTCLOUD, 'Nextcloud Cookbook'),
|
||||||
(MEALIE, 'Mealie'), (CHOWDOWN, 'Chowdown'), (SAFRON, 'Safron'), (CHEFTAP, 'ChefTap'),
|
(MEALIE, 'Mealie'), (CHOWDOWN, 'Chowdown'), (SAFRON, 'Safron'), (CHEFTAP, 'ChefTap'),
|
||||||
(PEPPERPLATE, 'Pepperplate'), (RECETTETEK, 'RecetteTek'), (RECIPESAGE, 'Recipe Sage'), (DOMESTICA, 'Domestica'),
|
(PEPPERPLATE, 'Pepperplate'), (RECETTETEK, 'RecetteTek'), (RECIPESAGE, 'Recipe Sage'), (DOMESTICA, 'Domestica'),
|
||||||
(MEALMASTER, 'MealMaster'), (REZKONV, 'RezKonv'), (OPENEATS, 'Openeats'), (RECIPEKEEPER, 'Recipe Keeper'),
|
(MEALMASTER, 'MealMaster'), (REZKONV, 'RezKonv'), (OPENEATS, 'Openeats'), (RECIPEKEEPER, 'Recipe Keeper'),
|
||||||
(PLANTOEAT, 'Plantoeat'),
|
(PLANTOEAT, 'Plantoeat'), (COOKBOOKAPP, 'CookBookApp'),
|
||||||
))
|
))
|
||||||
|
|
||||||
|
|
||||||
|
66
cookbook/integration/cookbookapp.py
Normal file
66
cookbook/integration/cookbookapp.py
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
import base64
|
||||||
|
import gzip
|
||||||
|
import json
|
||||||
|
import re
|
||||||
|
from io import BytesIO
|
||||||
|
|
||||||
|
import yaml
|
||||||
|
|
||||||
|
from cookbook.helper.ingredient_parser import parse, get_food, get_unit
|
||||||
|
from cookbook.integration.integration import Integration
|
||||||
|
from cookbook.models import Recipe, Step, Ingredient, Keyword
|
||||||
|
from gettext import gettext as _
|
||||||
|
|
||||||
|
|
||||||
|
class CookBookApp(Integration):
|
||||||
|
|
||||||
|
def import_file_name_filter(self, zip_info_object):
|
||||||
|
return zip_info_object.filename.endswith('.yml')
|
||||||
|
|
||||||
|
def get_recipe_from_file(self, file):
|
||||||
|
recipe_yml = yaml.safe_load(file.getvalue().decode("utf-8"))
|
||||||
|
|
||||||
|
recipe = Recipe.objects.create(
|
||||||
|
name=recipe_yml['name'].strip(),
|
||||||
|
created_by=self.request.user, internal=True,
|
||||||
|
space=self.request.space)
|
||||||
|
|
||||||
|
try:
|
||||||
|
recipe.servings = re.findall('([0-9])+', recipe_yml['recipeYield'])[0]
|
||||||
|
except Exception as e:
|
||||||
|
pass
|
||||||
|
|
||||||
|
try:
|
||||||
|
recipe.working_time = recipe_yml['prep_time'].replace(' minutes', '')
|
||||||
|
recipe.waiting_time = recipe_yml['cook_time'].replace(' minutes', '')
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
|
||||||
|
if recipe_yml['on_favorites']:
|
||||||
|
recipe.keywords.add(Keyword.objects.get_or_create(name=_('Favorites'), space=self.request.space))
|
||||||
|
|
||||||
|
step = Step.objects.create(instruction=recipe_yml['directions'], space=self.request.space, )
|
||||||
|
|
||||||
|
if 'notes' in recipe_yml and recipe_yml['notes'].strip() != '':
|
||||||
|
step.instruction = step.instruction + '\n\n' + recipe_yml['notes']
|
||||||
|
|
||||||
|
if 'nutritional_info' in recipe_yml:
|
||||||
|
step.instruction = step.instruction + '\n\n' + recipe_yml['nutritional_info']
|
||||||
|
|
||||||
|
if 'source' in recipe_yml and recipe_yml['source'].strip() != '':
|
||||||
|
step.instruction = step.instruction + '\n\n' + recipe_yml['source']
|
||||||
|
|
||||||
|
step.save()
|
||||||
|
recipe.steps.add(step)
|
||||||
|
|
||||||
|
for ingredient in recipe_yml['ingredients'].split('\n'):
|
||||||
|
if ingredient.strip() != '':
|
||||||
|
amount, unit, ingredient, note = parse(ingredient)
|
||||||
|
f = get_food(ingredient, self.request.space)
|
||||||
|
u = get_unit(unit, self.request.space)
|
||||||
|
step.ingredients.add(Ingredient.objects.create(
|
||||||
|
food=f, unit=u, amount=amount, note=note, space=self.request.space,
|
||||||
|
))
|
||||||
|
|
||||||
|
recipe.save()
|
||||||
|
return recipe
|
@ -70,21 +70,22 @@
|
|||||||
<select class="form-control" v-model="recipe_app">
|
<select class="form-control" v-model="recipe_app">
|
||||||
<option value="DEFAULT">Tandoor</option>
|
<option value="DEFAULT">Tandoor</option>
|
||||||
|
|
||||||
<option value="PAPRIKA">Paprika</option>
|
|
||||||
<option value="NEXTCLOUD">Nextcloud Cookbook</option>
|
|
||||||
<option value="MEALIE">Mealie</option>
|
|
||||||
<option value="CHOWDOWN">Chowdown</option>
|
|
||||||
<option value="SAFRON">Safron</option>
|
|
||||||
<option value="OPENEATS">Openeats</option>
|
|
||||||
<option value="CHEFTAP">Cheftap</option>
|
<option value="CHEFTAP">Cheftap</option>
|
||||||
<option value="PEPPERPLATE">Pepperplate</option>
|
<option value="CHOWDOWN">Chowdown</option>
|
||||||
<option value="RECIPESAGE">Recipesage</option>
|
<option value="COOKBOOKAPP">CookBookApp</option>
|
||||||
<option value="RECIPEKEEPER">Recipekeeper</option>
|
|
||||||
<option value="DOMESTICA">Domestica</option>
|
<option value="DOMESTICA">Domestica</option>
|
||||||
|
<option value="MEALIE">Mealie</option>
|
||||||
<option value="MEALMASTER">Mealmaster</option>
|
<option value="MEALMASTER">Mealmaster</option>
|
||||||
<option value="REZKONV">Rezkonv</option>
|
<option value="NEXTCLOUD">Nextcloud Cookbook</option>
|
||||||
<option value="RECETTETEK">RecetteTek</option>
|
<option value="OPENEATS">Openeats</option>
|
||||||
|
<option value="PAPRIKA">Paprika</option>
|
||||||
|
<option value="PEPPERPLATE">Pepperplate</option>
|
||||||
<option value="PLANTOEAT">Plantoeat</option>
|
<option value="PLANTOEAT">Plantoeat</option>
|
||||||
|
<option value="RECETTETEK">RecetteTek</option>
|
||||||
|
<option value="RECIPEKEEPER">Recipekeeper</option>
|
||||||
|
<option value="RECIPESAGE">Recipesage</option>
|
||||||
|
<option value="REZKONV">Rezkonv</option>
|
||||||
|
<option value="SAFRON">Safron</option>
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<b-form-checkbox v-model="import_duplicates" name="check-button" switch style="margin-top: 1vh">
|
<b-form-checkbox v-model="import_duplicates" name="check-button" switch style="margin-top: 1vh">
|
||||||
|
@ -10,7 +10,8 @@ from django.utils.translation import gettext as _
|
|||||||
|
|
||||||
from cookbook.forms import ExportForm, ImportForm, ImportExportBase
|
from cookbook.forms import ExportForm, ImportForm, ImportExportBase
|
||||||
from cookbook.helper.permission_helper import group_required
|
from cookbook.helper.permission_helper import group_required
|
||||||
from cookbook.integration.Pepperplate import Pepperplate
|
from cookbook.integration.cookbookapp import CookBookApp
|
||||||
|
from cookbook.integration.pepperplate import Pepperplate
|
||||||
from cookbook.integration.cheftap import ChefTap
|
from cookbook.integration.cheftap import ChefTap
|
||||||
from cookbook.integration.chowdown import Chowdown
|
from cookbook.integration.chowdown import Chowdown
|
||||||
from cookbook.integration.default import Default
|
from cookbook.integration.default import Default
|
||||||
@ -62,6 +63,8 @@ def get_integration(request, export_type):
|
|||||||
return OpenEats(request, export_type)
|
return OpenEats(request, export_type)
|
||||||
if export_type == ImportExportBase.PLANTOEAT:
|
if export_type == ImportExportBase.PLANTOEAT:
|
||||||
return Plantoeat(request, export_type)
|
return Plantoeat(request, export_type)
|
||||||
|
if export_type == ImportExportBase.COOKBOOKAPP:
|
||||||
|
return CookBookApp(request, export_type)
|
||||||
|
|
||||||
|
|
||||||
@group_required('user')
|
@group_required('user')
|
||||||
|
@ -36,6 +36,7 @@ Overview of the capabilities of the different integrations.
|
|||||||
| RezKonv | ✔️ | ❌ | ❌ |
|
| RezKonv | ✔️ | ❌ | ❌ |
|
||||||
| OpenEats | ✔️ | ❌ | ⌚ |
|
| OpenEats | ✔️ | ❌ | ⌚ |
|
||||||
| Plantoeat | ✔️ | ❌ | ✔ |
|
| Plantoeat | ✔️ | ❌ | ✔ |
|
||||||
|
| CookBookApp | ✔️ | ⌚ | ❌ |
|
||||||
|
|
||||||
✔ = implemented, ❌ = not implemented and not possible/planned, ⌚ = not yet implemented
|
✔ = implemented, ❌ = not implemented and not possible/planned, ⌚ = not yet implemented
|
||||||
|
|
||||||
@ -209,3 +210,11 @@ Store the outputted json string in a `.json` file and simply import it using the
|
|||||||
]
|
]
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Plantoeat
|
||||||
|
|
||||||
|
Plan to eat allow to export a text file containing all your recipes. Simply upload that text file to Tandoor to import all recipes
|
||||||
|
|
||||||
|
## CookBookApp
|
||||||
|
|
||||||
|
CookBookApp can export .zip files containing .yml files. Upload the entire ZIP to Tandoor to import all conluded recipes.
|
Loading…
Reference in New Issue
Block a user