diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 627ce29e5..e5979b41b 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -12,7 +12,7 @@ repos: exclude: ^tests/data/ - repo: https://github.com/astral-sh/ruff-pre-commit # Ruff version. - rev: v0.12.5 + rev: v0.12.7 hooks: - id: ruff - id: ruff-format diff --git a/docs/docs/documentation/getting-started/installation/postgres.md b/docs/docs/documentation/getting-started/installation/postgres.md index adb6320bf..9d8d94853 100644 --- a/docs/docs/documentation/getting-started/installation/postgres.md +++ b/docs/docs/documentation/getting-started/installation/postgres.md @@ -1,5 +1,8 @@ # Installing with PostgreSQL +!!! Warning + When upgrading postgresql major versions, manual steps are required [Postgres#37](https://github.com/docker-library/postgres/issues/37). + PostgreSQL might be considered if you need to support many concurrent users. In addition, some features are only enabled on PostgreSQL, such as fuzzy search. **For Environment Variable Configuration, see** [Backend Configuration](./backend-config.md) @@ -38,7 +41,7 @@ services: postgres: container_name: postgres - image: postgres:15 + image: postgres:17 restart: always volumes: - mealie-pgdata:/var/lib/postgresql/data @@ -46,6 +49,7 @@ services: POSTGRES_PASSWORD: mealie POSTGRES_USER: mealie PGUSER: mealie + POSTGRES_DB: mealie healthcheck: test: ["CMD", "pg_isready"] interval: 30s diff --git a/frontend/composables/use-locales/available-locales.ts b/frontend/composables/use-locales/available-locales.ts index 246f9c786..86733b66e 100644 --- a/frontend/composables/use-locales/available-locales.ts +++ b/frontend/composables/use-locales/available-locales.ts @@ -69,7 +69,7 @@ export const LOCALES = [ { name: "Português (Portuguese)", value: "pt-PT", - progress: 37, + progress: 38, dir: "ltr", }, { @@ -81,7 +81,7 @@ export const LOCALES = [ { name: "Polski (Polish)", value: "pl-PL", - progress: 37, + progress: 39, dir: "ltr", }, { @@ -147,7 +147,7 @@ export const LOCALES = [ { name: "עברית (Hebrew)", value: "he-IL", - progress: 67, + progress: 73, dir: "rtl", }, { @@ -159,7 +159,7 @@ export const LOCALES = [ { name: "Français (French)", value: "fr-FR", - progress: 49, + progress: 50, dir: "ltr", }, { @@ -189,7 +189,7 @@ export const LOCALES = [ { name: "Español (Spanish)", value: "es-ES", - progress: 40, + progress: 41, dir: "ltr", }, { @@ -207,25 +207,25 @@ export const LOCALES = [ { name: "Ελληνικά (Greek)", value: "el-GR", - progress: 38, + progress: 39, dir: "ltr", }, { name: "Deutsch (German)", value: "de-DE", - progress: 64, + progress: 65, dir: "ltr", }, { name: "Dansk (Danish)", value: "da-DK", - progress: 38, + progress: 39, dir: "ltr", }, { name: "Čeština (Czech)", value: "cs-CZ", - progress: 39, + progress: 40, dir: "ltr", }, { diff --git a/frontend/lang/messages/de-DE.json b/frontend/lang/messages/de-DE.json index b8ad87fb2..db5c1212e 100644 --- a/frontend/lang/messages/de-DE.json +++ b/frontend/lang/messages/de-DE.json @@ -587,7 +587,7 @@ "api-extras-description": "Rezepte-Extras sind ein Hauptmerkmal der Mealie API. Sie ermöglichen es dir, benutzerdefinierte JSON Key-Value-Paare zu einem Rezept zu erstellen, um Drittanbieter-Anwendungen zu steuern. Du kannst diese dazu verwenden, um Automatisierungen auszulösen oder benutzerdefinierte Nachrichten an bestimmte Geräte zu senden.", "message-key": "Nachrichten-Schlüssel", "parse": "Parsen", - "ingredients-not-parsed-description": "It looks like your ingredients aren't parsed yet. Click the \"{parse}\" button below to parse your ingredients into structured foods.", + "ingredients-not-parsed-description": "Es scheint als ob deine Zutaten noch nicht eingelesen wurden. Klick unten auf \"{parse}\" um deine Zutaten einzulesen.", "attach-images-hint": "Bilder durch Ziehen & Ablegen in den Editor hinzufügen", "drop-image": "Bild hier ablegen", "enable-ingredient-amounts-to-use-this-feature": "Aktiviere Zutatenmengen, um diese Funktion zu nutzen", diff --git a/frontend/lang/messages/es-ES.json b/frontend/lang/messages/es-ES.json index bf81bd4b7..8a372e4ef 100644 --- a/frontend/lang/messages/es-ES.json +++ b/frontend/lang/messages/es-ES.json @@ -587,7 +587,7 @@ "api-extras-description": "Los extras de las recetas son una característica clave de la API de Mealie. Permiten crear pares json clave/valor personalizados dentro de una receta para acceder desde aplicaciones de terceros. Puede utilizar estas claves para almacenar información, para activar la automatización o mensajes personalizados para transmitir al dispositivo deseado.", "message-key": "Clave de mensaje", "parse": "Analizar", - "ingredients-not-parsed-description": "It looks like your ingredients aren't parsed yet. Click the \"{parse}\" button below to parse your ingredients into structured foods.", + "ingredients-not-parsed-description": "Parece que tus ingredientes no han sido analizados aún. Haz clic en el botón \"{parse}\" de abajo para analizarlos y convertirlos en alimentos estructurados.", "attach-images-hint": "Adjuntar imágenes arrastrando y soltando en el editor", "drop-image": "Soltar imagen", "enable-ingredient-amounts-to-use-this-feature": "Habilitar la cantidad de ingredientes para usar esta característica", diff --git a/frontend/lang/messages/fr-FR.json b/frontend/lang/messages/fr-FR.json index 8f2a590b9..da7fe7a8d 100644 --- a/frontend/lang/messages/fr-FR.json +++ b/frontend/lang/messages/fr-FR.json @@ -113,7 +113,7 @@ "get": "Envoyer", "home": "Accueil", "image": "Image", - "image-upload-failed": "Le téléchargement de l’image a échoué", + "image-upload-failed": "Le téléversement de l’image a échoué", "import": "Importer", "json": "JSON", "keyword": "Mot-clé", @@ -207,7 +207,7 @@ "selected-count": "Sélectionné : {count}", "export-all": "Exporter tout", "refresh": "Actualiser", - "upload-file": "Transférer un fichier", + "upload-file": "Téléverser un fichier", "created-on-date": "Créé le {0}", "unsaved-changes": "Vous avez des modifications non enregistrées. Voulez-vous enregistrer avant de partir ? OK pour enregistrer, Annuler pour ignorer les modifications.", "clipboard-copy-failure": "Échec de la copie dans le presse-papiers.", @@ -472,7 +472,7 @@ "comment": "Commentaire", "comments": "Commentaires", "delete-confirmation": "Voulez-vous vraiment supprimer cette recette ?", - "admin-delete-confirmation": "You're about to delete a recipe that isn't yours using admin permissions. Are you sure?", + "admin-delete-confirmation": "Vous êtes sur le point de supprimer une recette qui n'est pas la vôtre en utilisant les permissions d'administrateur. Êtes-vous sûr(e) ?", "delete-recipe": "Supprimer la recette", "description": "Description", "disable-amount": "Désactiver les quantités des ingrédients", @@ -587,7 +587,7 @@ "api-extras-description": "Les suppléments des recettes sont une fonctionnalité clé de l’API Mealie. Ils permettent de créer des paires JSON clé/valeur personnalisées dans une recette, qui peuvent être référencées depuis des applications tierces. Ces clés peuvent être utilisées par exemple pour déclencher des tâches automatisées ou des messages personnalisés à transmettre à l’appareil souhaité.", "message-key": "Clé de message", "parse": "Analyser", - "ingredients-not-parsed-description": "It looks like your ingredients aren't parsed yet. Click the \"{parse}\" button below to parse your ingredients into structured foods.", + "ingredients-not-parsed-description": "Il semble que vos ingrédients ne soient pas encore analysés. Cliquez sur le bouton \"{parse}\" ci-dessous pour analyser vos ingrédients en aliments structurés.", "attach-images-hint": "Ajouter des images en les glissant-déposant dans l'éditeur", "drop-image": "Déposer l'image", "enable-ingredient-amounts-to-use-this-feature": "Activez les quantités d'ingrédients pour utiliser cette fonctionnalité", @@ -664,8 +664,8 @@ "no-unit": "Pas d'unité", "missing-unit": "Créer une unité manquante : {unit}", "missing-food": "Créer un aliment manquant : {food}", - "this-unit-could-not-be-parsed-automatically": "This unit could not be parsed automatically", - "this-food-could-not-be-parsed-automatically": "This food could not be parsed automatically", + "this-unit-could-not-be-parsed-automatically": "Cette unité n'a pas pu être analysée automatiquement", + "this-food-could-not-be-parsed-automatically": "Cet aliment n'a pas pu être analysé automatiquement", "no-food": "Aucun aliment" }, "reset-servings-count": "Réinitialiser le nombre de portions", diff --git a/frontend/lang/messages/no-NO.json b/frontend/lang/messages/no-NO.json index 215e7da8d..86d1f135c 100644 --- a/frontend/lang/messages/no-NO.json +++ b/frontend/lang/messages/no-NO.json @@ -665,7 +665,7 @@ "missing-unit": "Opprett manglende enhet: {unit}", "missing-food": "Opprett manglende mat: {food}", "this-unit-could-not-be-parsed-automatically": "This unit could not be parsed automatically", - "this-food-could-not-be-parsed-automatically": "This food could not be parsed automatically", + "this-food-could-not-be-parsed-automatically": "Denne maten kunne ikke leses automatisk", "no-food": "Ingen matvarer" }, "reset-servings-count": "Nullstill antall porsjoner", diff --git a/frontend/lang/messages/pl-PL.json b/frontend/lang/messages/pl-PL.json index 92e63cb68..3096e2200 100644 --- a/frontend/lang/messages/pl-PL.json +++ b/frontend/lang/messages/pl-PL.json @@ -472,7 +472,7 @@ "comment": "Komentarz", "comments": "Komentarze", "delete-confirmation": "Czy jesteś pewien, że chcesz usunąć ten przepis?", - "admin-delete-confirmation": "You're about to delete a recipe that isn't yours using admin permissions. Are you sure?", + "admin-delete-confirmation": "Zamierzasz usunąć przepis, który nie należy do Ciebie, używając uprawnień administratora. Czy jesteś pewien?", "delete-recipe": "Usuń przepis", "description": "Opis", "disable-amount": "Wyłącz ilości składników", @@ -580,14 +580,14 @@ "made-this": "Ugotowałem to", "how-did-it-turn-out": "Jak się to udało?", "user-made-this": "{user} ugotował(a) to", - "added-to-timeline": "Added to timeline", - "failed-to-add-to-timeline": "Failed to add to timeline", - "failed-to-update-recipe": "Failed to update recipe", - "added-to-timeline-but-failed-to-add-image": "Added to timeline, but failed to add image", + "added-to-timeline": "Dodano do osi czasu", + "failed-to-add-to-timeline": "Nie udało się dodać do osi czasu", + "failed-to-update-recipe": "Nie udało się zaktualizować przepisu", + "added-to-timeline-but-failed-to-add-image": "Dodano do osi czasu, ale nie udało się dodać obrazu", "api-extras-description": "Dodatki w przepisach są kluczową cechą API Mealie. Pozwalają na tworzenie niestandardowych par kluczy/wartości JSON w przepisie do odwoływania się przez zewnętrzne aplikacje. Możesz użyć tych kluczy do wyzwalania automatyzacji lub przekazywania niestandardowych wiadomości do twoich wybranych urządzeń.", "message-key": "Klucz Wiadomości", "parse": "Analizuj", - "ingredients-not-parsed-description": "It looks like your ingredients aren't parsed yet. Click the \"{parse}\" button below to parse your ingredients into structured foods.", + "ingredients-not-parsed-description": "Wygląda na to, że Twoje składniki nie zostały jeszcze przeanalizowane. Kliknij przycisk \"{parse}\" poniżej, aby przetworzyć składniki w ustrukturyzowane jedzenie.", "attach-images-hint": "Dołącz obrazy przeciągając i upuszczając je do edytora", "drop-image": "Upuść zdjęcie", "enable-ingredient-amounts-to-use-this-feature": "Włącz ilości składników, aby użyć tej funkcji", @@ -608,7 +608,7 @@ "create-from-images": "Utwórz przepis z obrazów", "should-translate-description": "Przetłumacz przepis na mój język", "please-wait-image-procesing": "Proszę czekać, obraz jest przetwarzany. To może chwilę potrwać.", - "please-wait-images-processing": "Please wait, the images are processing. This may take some time.", + "please-wait-images-processing": "Proszę czekać, obrazy są przetwarzane. To może chwilę potrwać.", "bulk-url-import": "Import Zbiorczy z URL", "debug-scraper": "Debuguj Scraper", "create-a-recipe-by-providing-the-name-all-recipes-must-have-unique-names": "Utwórz przepis, podając nazwę. Wszystkie przepisy muszą mieć unikalne nazwy.", @@ -664,15 +664,15 @@ "no-unit": "Brak jednostki", "missing-unit": "Utwórz brakującą jednostkę: {unit}", "missing-food": "Utwórz brakującą potrawę: {food}", - "this-unit-could-not-be-parsed-automatically": "This unit could not be parsed automatically", - "this-food-could-not-be-parsed-automatically": "This food could not be parsed automatically", + "this-unit-could-not-be-parsed-automatically": "Nie można przetworzyć tej jednostki automatycznie", + "this-food-could-not-be-parsed-automatically": "Nie można przetworzyć tego jedzenia automatycznie", "no-food": "Brak potrawy" }, "reset-servings-count": "Zresetuj liczbę porcji", "not-linked-ingredients": "Dodatkowe składniki", - "upload-another-image": "Upload another image", - "upload-images": "Upload images", - "upload-more-images": "Upload more images" + "upload-another-image": "Prześlij kolejny obraz", + "upload-images": "Prześlij obraz", + "upload-more-images": "Prześlij więcej obrazów" }, "recipe-finder": { "recipe-finder": "Wyszukiwarka przepisów", diff --git a/frontend/lang/messages/ru-RU.json b/frontend/lang/messages/ru-RU.json index c5a9179d2..3953534a5 100644 --- a/frontend/lang/messages/ru-RU.json +++ b/frontend/lang/messages/ru-RU.json @@ -472,7 +472,7 @@ "comment": "Комментарий", "comments": "Комментарии", "delete-confirmation": "Вы уверены, что хотите удалить этот рецепт?", - "admin-delete-confirmation": "You're about to delete a recipe that isn't yours using admin permissions. Are you sure?", + "admin-delete-confirmation": "Вы собираетесь удалить рецепт созданный не вами используя права администратора. Вы уверены?", "delete-recipe": "Удалить рецепт", "description": "Описание", "disable-amount": "Не показывать кол-во ингредиентов", @@ -580,14 +580,14 @@ "made-this": "Я приготовил это", "how-did-it-turn-out": "Что получилось?", "user-made-this": "{user} приготовил это", - "added-to-timeline": "Added to timeline", - "failed-to-add-to-timeline": "Failed to add to timeline", + "added-to-timeline": "Добавлено в ленту", + "failed-to-add-to-timeline": "Не удалось добавить в ленту", "failed-to-update-recipe": "Не удалось обновить рецепт", - "added-to-timeline-but-failed-to-add-image": "Added to timeline, but failed to add image", + "added-to-timeline-but-failed-to-add-image": "Добавлено в ленту, но не удалось загрузить изображение", "api-extras-description": "Дополнения к рецептам являются ключевым элементом Mealie API. Они позволяют создавать пользовательские пары json ключ/значение в рецепте для ссылания на другие приложения. Вы можете использовать эти ключи, чтобы сохранить нужную информацию, например, для автоматизаций или уведомлений на ваши устройства.", "message-key": "Ключ сообщения", "parse": "Обработать", - "ingredients-not-parsed-description": "It looks like your ingredients aren't parsed yet. Click the \"{parse}\" button below to parse your ingredients into structured foods.", + "ingredients-not-parsed-description": "Похоже, ваши ингредиенты не разобраны. Нажмите кнопку \"{parse}\" чтобы разобрать ваши ингредиенты в структурированный список.", "attach-images-hint": "Прикрепляйте изображения, перетаскивая их в редактор", "drop-image": "Перетащите изображение", "enable-ingredient-amounts-to-use-this-feature": "Включите количество ингредиентов для использования этой функции", @@ -604,8 +604,8 @@ "import-with-zip": "Импорт из .zip", "create-recipe-from-an-image": "Создать рецепт из изображения", "create-recipe-from-an-image-description": "Создайте рецепт, загрузив изображение. Mealie попытается извлечь текст из изображения с помощью ИИ и создать рецепт из него.", - "crop-and-rotate-the-image": "Crop and rotate the image so that only the text is visible, and it's in the correct orientation.", - "create-from-images": "Create from Images", + "crop-and-rotate-the-image": "Обрежьте и поверните изображение так, чтобы виден был только текст в нужной ориентации.", + "create-from-images": "Создать из изображений", "should-translate-description": "Перевести рецепт на мой язык", "please-wait-image-procesing": "Подождите, идет обработка изображения.", "please-wait-images-processing": "Пожалуйста, подождите, изображения обрабатываются. Это может занять некоторое время.", @@ -640,7 +640,7 @@ "recipe-debugger": "Отладчик рецептов", "recipe-debugger-description": "Вставьте сюда URL рецепта, который вы хотите отладить. Рецепт по указанному URL-адресу будет отсканирован и результаты сканирования будут указаны ниже. Если вы не видите никаких возвращенных данных, то сайт, который вы пытаетесь обработать, не поддерживается Mealie или библиотекой сканера.", "use-openai": "Использовать OpenAI", - "recipe-debugger-use-openai-description": "Use OpenAI to parse the results instead of relying on the scraper library. When creating a recipe via URL, this is done automatically if the scraper library fails, but you may test it manually here.", + "recipe-debugger-use-openai-description": "Использовать OpenAI для разбора результатов вместо использования скрейпера. При создании рецепта по URL это делается автоматически, если скрейпер не справляется, но вы можете протестировать его здесь вручную.", "debug": "Отладка", "tree-view": "В виде дерева", "recipe-servings": "Порции", @@ -672,7 +672,7 @@ "not-linked-ingredients": "Дополнительные ингредиенты", "upload-another-image": "Upload another image", "upload-images": "Загрузить изображения", - "upload-more-images": "Upload more images" + "upload-more-images": "Загрузить больше изображений" }, "recipe-finder": { "recipe-finder": "Поиск рецептов", @@ -1313,12 +1313,12 @@ "account-summary-description": "Вот сводка информации о вашей группе.", "group-statistics": "Статистика группы", "group-statistics-description": "Статистика вашей группы дает некоторую информацию о том, как вы используете Mealie.", - "household-statistics": "Household Statistics", + "household-statistics": "Статистика домохозяйства", "household-statistics-description": "Your Household Statistics provide some insight how you're using Mealie.", "storage-capacity": "Емкость хранилища", "storage-capacity-description": "Указанный размер хранилища - это подсчёт размера изображений и приложений рецептов загруженных вами.", "personal": "Личное", - "personal-description": "These are settings that are personal to you. Changes here won't affect other users.", + "personal-description": "Это персональные настройки. Изменения здесь не повлияют на других пользователей.", "user-settings": "Настройки пользователя", "user-settings-description": "Управляйте вашими настройками, меняйте пароль и обновляйте адрес электронной почты.", "api-tokens-description": "Управляйте вашими API-токенами для доступа сторонних приложений.", diff --git a/frontend/lang/messages/sk-SK.json b/frontend/lang/messages/sk-SK.json index 598b48aeb..ee32adf83 100644 --- a/frontend/lang/messages/sk-SK.json +++ b/frontend/lang/messages/sk-SK.json @@ -437,9 +437,9 @@ "upload-individual-zip-file": "Nahrať súbor .zip exportovaný z inej Mealie inštalácie.", "url-form-hint": "Okopírujte a zložte odkaz z vašej obľúbenej webstránky", "view-scraped-data": "Náhľad získaných údajov", - "trim-whitespace-description": "Vymažte medzery a prázdne riadky na začiatku a na konci", - "trim-prefix-description": "Vymažte prvé písmeno z každého riadku", - "split-by-numbered-line-description": "Pokus rozdeliť odsek pomocou výrazu '1)' alebo '1.'", + "trim-whitespace-description": "Vymazať medzery a prázdne riadky na začiatku a na konci", + "trim-prefix-description": "Vymazať prvé písmeno z každého riadku", + "split-by-numbered-line-description": "Pokúsiť sa rozdeliť odsek pomocou vzoru '1)' alebo '1.'", "import-by-url": "Importovať recept z URL", "create-manually": "Vytvoriť recept manuálne", "make-recipe-image": "Nastaviť ako obrázok receptu" @@ -579,10 +579,10 @@ "open-timeline": "Otvoriť časovú os", "made-this": "Toto som uvaril", "how-did-it-turn-out": "Ako to dopadlo?", - "user-made-this": "{user} toto uvaril/-a", - "added-to-timeline": "Added to timeline", - "failed-to-add-to-timeline": "Failed to add to timeline", - "failed-to-update-recipe": "Failed to update recipe", + "user-made-this": "{user} toto uvaril(a)", + "added-to-timeline": "Pridané na časovú os", + "failed-to-add-to-timeline": "Pridanie na časovú os skončilo chybou", + "failed-to-update-recipe": "Recept sa nepodarilo aktualizovať", "added-to-timeline-but-failed-to-add-image": "Added to timeline, but failed to add image", "api-extras-description": "API dolnky receptov sú kľúčovou funkcionalitou Mealie API. Umožňujú používateľom vytvárať vlastné JSON páry kľúč/hodnota v rámci receptu, a využiť v aplikáciách tretích strán. Údaje uložené pod jednotlivými kľúčmi je možné využiť napríklad ako spúšťač automatizovaných procesov, či pri zasielaní vlastných správ do vami zvolených zariadení.", "message-key": "Kľúč správy", @@ -605,7 +605,7 @@ "create-recipe-from-an-image": "Vytvoriť recept z obrázka", "create-recipe-from-an-image-description": "Vytvoriť recept nahraním fotografie jedla. Mealie sa pokúsi previesť obrázok na text pomocou AI a vytvorí k nemu recept.", "crop-and-rotate-the-image": "Orežte a otočte obrázok tak, aby bol viditeľný iba text a aby mal správnu orientáciu.", - "create-from-images": "Create from Images", + "create-from-images": "Vytvoriť z obrázka", "should-translate-description": "Preložiť recept do môjho jazyka", "please-wait-image-procesing": "Čakajte, prosím. Obrázok sa spracováva. Môže to chvíľku trvať.", "please-wait-images-processing": "Please wait, the images are processing. This may take some time.", @@ -614,12 +614,12 @@ "create-a-recipe-by-providing-the-name-all-recipes-must-have-unique-names": "Vytvoriť recept zadaním názvu. Všetky recepty musia mať jedinečné názvy.", "new-recipe-names-must-be-unique": "Názvy nových receptov musia byť jedinečné", "scrape-recipe": "Scrapovať recept", - "scrape-recipe-description": "Stiahne recept zo zadaného url odkazu. Zadajte url stránky, z ktorej chcete stiahnuť recept, a Mealie sa pokúsi recept stiahnuť a vložiť do vašej zbierky.", + "scrape-recipe-description": "Stiahne recept zo zadanej adresy URL. Zadajte URL adresu stránky, z ktorej chcete stiahnuť recept, a Mealie sa pokúsi recept stiahnuť a vložiť do vašej zbierky.", "scrape-recipe-have-a-lot-of-recipes": "Máte množstvo receptov, ktoré by ste chceli naraz zoscrapovať?", "scrape-recipe-suggest-bulk-importer": "Vyskúšajte hromadný importér", "scrape-recipe-have-raw-html-or-json-data": "Máte surové údaje HTML alebo JSON?", "scrape-recipe-you-can-import-from-raw-data-directly": "Môžete importovať priamo nespracované údaje", - "import-original-keywords-as-tags": "Importuj pôvodné kľúčové slová ako tagy", + "import-original-keywords-as-tags": "Importovať pôvodné kľúčové slová ako štítky", "stay-in-edit-mode": "Zostať v režime editovania", "import-from-zip": "Importovať zo Zip-súboru", "import-from-zip-description": "Importovať recept exportovaný z inej Mealie inštalácie.", @@ -632,7 +632,7 @@ "upload-a-png-image-from-a-recipe-book": "Nahraj png-obrázok z kuchárky", "recipe-bulk-importer": "Hromadný importér receptov", "recipe-bulk-importer-description": "Hromadný importér receptov umožňuje importovať veľké množstvo receptov prechádzaním stránok na backende, pričom celá úloha beží na pozadí. Toto je užitočné napríklad pri počiatočnej migrácii na Mealie, alebo ak chcete importovať veľké množstvo receptov naraz.", - "set-categories-and-tags": "Zadaj kategórie a tagy", + "set-categories-and-tags": "Nastavte kategórie a štítky", "bulk-imports": "Hromadné importy", "bulk-import-process-has-started": "Hromadný import bol spustený", "bulk-import-process-has-failed": "Hromadný import zlyhal", @@ -671,8 +671,8 @@ "reset-servings-count": "Resetovať počet porcií", "not-linked-ingredients": "Ďalšie suroviny", "upload-another-image": "Upload another image", - "upload-images": "Upload images", - "upload-more-images": "Upload more images" + "upload-images": "Nahrať obrázky", + "upload-more-images": "Nahrať ďalšie obrázky" }, "recipe-finder": { "recipe-finder": "Hľadač receptov", @@ -720,7 +720,7 @@ "backup-deleted": "Záloha bola odstránená", "restore-success": "Obnovenie bolo úspešné", "restore-fail": "Obnovenie zlyhalo. Ďalšie podrobnosti nájdete v denníkoch servera", - "backup-tag": "Označenie zálohy", + "backup-tag": "Štítok zálohy", "create-heading": "Vytvoriť zálohu", "delete-backup": "Odstrániť zálohu", "error-creating-backup-see-log-file": "Vytvorenie zálohy zlyhalo. Pozrite prosím súbor záznamu", @@ -789,8 +789,8 @@ "theme-saved": "Motív bol uložený", "theme-updated": "Motív bol aktualizovaný", "warning": "Upozornenie", - "light-mode": "Svetlá téma", - "dark-mode": "Tmavá téma" + "light-mode": "Svetlý motív", + "dark-mode": "Tmavý motív" }, "token": { "active-tokens": "Aktívne kľúče", @@ -1115,10 +1115,10 @@ "recipe-columns": "Stĺpce receptu", "data-exports-description": "V tejto sekcii sa nachádzajú odkazy na aktuálne dostupné exporty pripravené na stiahnutie. Platnosť týchto odkazov je však časovo obmedzená, v prípade záujmu na to prosím nezabudnite.", "data-exports": "Export dát", - "tag": "Tag", + "tag": "Štítok", "categorize": "Kategorizovať", "update-settings": "Aktualizovať nastavenia", - "tag-recipes": "Tagovať recepty", + "tag-recipes": "Oštítkovať recepty", "categorize-recipes": "Kategorizovať recepty", "export-recipes": "Exportovať recepty", "delete-recipes": "Odstrániť recepty", diff --git a/frontend/pages/shopping-lists/[id].vue b/frontend/pages/shopping-lists/[id].vue index f7031f8e8..e32f068d3 100644 --- a/frontend/pages/shopping-lists/[id].vue +++ b/frontend/pages/shopping-lists/[id].vue @@ -136,6 +136,30 @@ v-if="!edit" class="py-2" > + +
+ +
+
+ + {{ $t('general.add') }} + +
+ +
- -
- -
-
- - {{ $t('general.add') }} - -
- =3.0.0)", "pyjwt (>=2.0.0,<3)"] [[package]] name = "openai" -version = "1.98.0" +version = "1.99.1" description = "The official Python library for the openai API" optional = false python-versions = ">=3.8" groups = ["main"] files = [ - {file = "openai-1.98.0-py3-none-any.whl", hash = "sha256:b99b794ef92196829120e2df37647722104772d2a74d08305df9ced5f26eae34"}, - {file = "openai-1.98.0.tar.gz", hash = "sha256:3ee0fcc50ae95267fd22bd1ad095ba5402098f3df2162592e68109999f685427"}, + {file = "openai-1.99.1-py3-none-any.whl", hash = "sha256:8eeccc69e0ece1357b51ca0d9fb21324afee09b20c3e5b547d02445ca18a4e03"}, + {file = "openai-1.99.1.tar.gz", hash = "sha256:2c9d8e498c298f51bb94bcac724257a3a6cac6139ccdfc1186c6708f7a93120f"}, ] [package.dependencies]