From b85627da5c285e07ecd7893216aef9ed7a0aca70 Mon Sep 17 00:00:00 2001 From: Ozzie Isaacs Date: Sun, 19 Dec 2021 11:29:54 +0100 Subject: [PATCH 01/45] Fix for adding/deleting visibility restrictions on custom columns/tags --- cps/admin.py | 15 +++++++++++++-- optional-requirements.txt | 2 +- setup.cfg | 4 ++-- 3 files changed, 16 insertions(+), 5 deletions(-) diff --git a/cps/admin.py b/cps/admin.py index 04d9138f..1c228e49 100644 --- a/cps/admin.py +++ b/cps/admin.py @@ -756,7 +756,12 @@ def prepare_tags(user, action, tags_name, id_list): return ",".join(saved_tags_list) -@admi.route("/ajax/addrestriction/", defaults={"user_id": 0}, methods=['POST']) +@admi.route("/ajax/addrestriction/", methods=['POST']) +@login_required +@admin_required +def add_user_0_restriction(res_type): + return add_restriction(res_type, 0) + @admi.route("/ajax/addrestriction//", methods=['POST']) @login_required @admin_required @@ -803,7 +808,13 @@ def add_restriction(res_type, user_id): return "" -@admi.route("/ajax/deleterestriction/", defaults={"user_id": 0}, methods=['POST']) +@admi.route("/ajax/deleterestriction/", methods=['POST']) +@login_required +@admin_required +def delete_user_0_restriction(res_type): + return delete_restriction(res_type, 0) + + @admi.route("/ajax/deleterestriction//", methods=['POST']) @login_required @admin_required diff --git a/optional-requirements.txt b/optional-requirements.txt index 03f58bb5..3fac14ca 100644 --- a/optional-requirements.txt +++ b/optional-requirements.txt @@ -12,7 +12,7 @@ rsa>=3.4.2,<4.8.0 six>=1.10.0,<1.17.0 # Gdrive and Gmail integration -google-api-python-client>=1.7.11,<2.32.0 +google-api-python-client>=1.7.11,<2.34.0 # Gmail google-auth-oauthlib>=0.4.3,<0.5.0 diff --git a/setup.cfg b/setup.cfg index fc74a1ed..87f6055f 100644 --- a/setup.cfg +++ b/setup.cfg @@ -56,7 +56,7 @@ install_requires = [options.extras_require] gdrive = - google-api-python-client>=1.7.11,<2.32.0 + google-api-python-client>=1.7.11,<2.34.0 gevent>20.6.0,<22.0.0 greenlet>=0.4.17,<1.2.0 httplib2>=0.9.2,<0.21.0 @@ -70,7 +70,7 @@ gdrive = six>=1.10.0,<1.17.0 gmail = google-auth-oauthlib>=0.4.3,<0.5.0 - google-api-python-client>=1.7.11,<2.32.0 + google-api-python-client>=1.7.11,<2.34.0 goodreads = goodreads>=0.3.2,<0.4.0 python-Levenshtein>=0.12.0,<0.13.0 From d45085215f231533ae62749f0e74c637b2168faa Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Wed, 22 Dec 2021 19:05:41 +0100 Subject: [PATCH 02/45] Update Translation --- cps/iso_language_names.py | 41 ---- cps/translations/cs/LC_MESSAGES/messages.mo | Bin 39546 -> 39546 bytes cps/translations/cs/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/de/LC_MESSAGES/messages.mo | Bin 53605 -> 56158 bytes cps/translations/de/LC_MESSAGES/messages.po | 212 +++++++++--------- cps/translations/el/LC_MESSAGES/messages.mo | Bin 57741 -> 57741 bytes cps/translations/el/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/es/LC_MESSAGES/messages.mo | Bin 51330 -> 51330 bytes cps/translations/es/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/fi/LC_MESSAGES/messages.mo | Bin 27430 -> 27430 bytes cps/translations/fi/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/fr/LC_MESSAGES/messages.mo | Bin 53669 -> 53669 bytes cps/translations/fr/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/hu/LC_MESSAGES/messages.mo | Bin 25180 -> 25180 bytes cps/translations/hu/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/it/LC_MESSAGES/messages.mo | Bin 56299 -> 56299 bytes cps/translations/it/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/ja/LC_MESSAGES/messages.mo | Bin 19843 -> 19843 bytes cps/translations/ja/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/km/LC_MESSAGES/messages.mo | Bin 24546 -> 24546 bytes cps/translations/km/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/nl/LC_MESSAGES/messages.mo | Bin 50497 -> 50497 bytes cps/translations/nl/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/pl/LC_MESSAGES/messages.mo | Bin 52413 -> 52413 bytes cps/translations/pl/LC_MESSAGES/messages.po | 148 ++++++------ .../pt_BR/LC_MESSAGES/messages.mo | Bin 46930 -> 46930 bytes .../pt_BR/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/ru/LC_MESSAGES/messages.mo | Bin 47969 -> 47969 bytes cps/translations/ru/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/sv/LC_MESSAGES/messages.mo | Bin 48760 -> 48760 bytes cps/translations/sv/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/tr/LC_MESSAGES/messages.mo | Bin 22790 -> 22790 bytes cps/translations/tr/LC_MESSAGES/messages.po | 148 ++++++------ cps/translations/uk/LC_MESSAGES/messages.mo | Bin 18028 -> 18028 bytes cps/translations/uk/LC_MESSAGES/messages.po | 148 ++++++------ .../zh_Hans_CN/LC_MESSAGES/messages.mo | Bin 50104 -> 50104 bytes .../zh_Hans_CN/LC_MESSAGES/messages.po | 148 ++++++------ .../zh_Hant_TW/LC_MESSAGES/messages.mo | Bin 48886 -> 48886 bytes .../zh_Hant_TW/LC_MESSAGES/messages.po | 148 ++++++------ messages.pot | 148 ++++++------ 40 files changed, 1507 insertions(+), 1558 deletions(-) diff --git a/cps/iso_language_names.py b/cps/iso_language_names.py index c6267ffd..11e5e67b 100644 --- a/cps/iso_language_names.py +++ b/cps/iso_language_names.py @@ -55,7 +55,6 @@ LANGUAGE_NAMES = { "bik": "bikolština", "bin": "bini", "bis": "bislamština", - "bit": "berinomo", "bla": "siksika", "bod": "tibetština", "bos": "bosenština", @@ -164,7 +163,6 @@ LANGUAGE_NAMES = { "hil": "hiligayonština", "hin": "hindština", "hit": "chetitština", - "hmj": "Ge", "hmn": "hmongština", "hmo": "hiri motu", "hrv": "chorvatština", @@ -479,7 +477,6 @@ LANGUAGE_NAMES = { "bik": "Bikol", "bin": "Bini", "bis": "Bislama", - "bit": "Berinomo", "bla": "Blackfoot", "bod": "Tibetisch", "bos": "Bosnisch", @@ -588,7 +585,6 @@ LANGUAGE_NAMES = { "hil": "Hiligaynon", "hin": "Hindi", "hit": "Hethitisch", - "hmj": "Ge", "hmn": "Miao-Sprachen", "hmo": "Hiri-Motu", "hrv": "Kroatisch", @@ -898,7 +894,6 @@ LANGUAGE_NAMES = { "bel": "Λευκωρωσικά", "bem": "Bemba (Zambia)", "ben": "Μπενγκάλι", - "bit": "Berinomo", "bho": "Bhojpuri", "bik": "Bikol", "byn": "Bilin", @@ -973,7 +968,6 @@ LANGUAGE_NAMES = { "lug": "Ganda", "gay": "Gayo", "gba": "Gbaya (Central African Republic)", - "hmj": "Ge", "gez": "Geez", "kat": "Γεωργιανά", "deu": "Γερμανικά", @@ -1282,7 +1276,6 @@ LANGUAGE_NAMES = { "bik": "Bicolano", "bin": "Bini", "bis": "Bislama", - "bit": "Berinomo", "bla": "Siksiká", "bod": "Tibetano", "bos": "Bosnio", @@ -1391,7 +1384,6 @@ LANGUAGE_NAMES = { "hil": "Hiligainón", "hin": "Hindi", "hit": "Hitita", - "hmj": "Ge", "hmn": "Hmong", "hmo": "Hiri motu", "hrv": "Croata", @@ -1706,7 +1698,6 @@ LANGUAGE_NAMES = { "bik": "bikol", "bin": "bini", "bis": "bislama", - "bit": "Berinomo", "bla": "mustajalka (siksika)", "bod": "tiibetti", "bos": "bosnia", @@ -1815,7 +1806,6 @@ LANGUAGE_NAMES = { "hil": "hiligaynon", "hin": "hindi", "hit": "heetti", - "hmj": "Ge", "hmn": "hmong", "hmo": "hiri-motu", "hrv": "kroatia", @@ -2130,7 +2120,6 @@ LANGUAGE_NAMES = { "bik": "bikol", "bin": "bini", "bis": "bislama", - "bit": "berinomo", "bla": "pied-noir", "bod": "tibétain", "bos": "bosniaque", @@ -2239,7 +2228,6 @@ LANGUAGE_NAMES = { "hil": "hiligaynon", "hin": "hindi", "hit": "hittite", - "hmj": "ge", "hmn": "hmong", "hmo": "hiri Motu", "hrv": "croate", @@ -2554,7 +2542,6 @@ LANGUAGE_NAMES = { "bik": "bikol", "bin": "bini", "bis": "biszlama", - "bit": "Berinomo", "bla": "szikszika", "bod": "tibeti", "bos": "bosnyák", @@ -2663,7 +2650,6 @@ LANGUAGE_NAMES = { "hil": "hiligajnon", "hin": "hindi", "hit": "hettita", - "hmj": "Ge", "hmn": "hmong", "hmo": "hiri motu", "hrv": "horvát", @@ -2978,7 +2964,6 @@ LANGUAGE_NAMES = { "bik": "bicol", "bin": "Bini", "bis": "bislama", - "bit": "Berinomo", "bla": "Siksika", "bod": "Tibetano", "bos": "Bosniaco", @@ -3087,7 +3072,6 @@ LANGUAGE_NAMES = { "hil": "Hiligayna", "hin": "Hindi", "hit": "hittite", - "hmj": "Ge", "hmn": "Hmong", "hmo": "Hiri motu", "hrv": "Croato", @@ -3402,7 +3386,6 @@ LANGUAGE_NAMES = { "bik": "ビコル語", "bin": "ビニ語", "bis": "ビスラマ語", - "bit": "Berinomo", "bla": "ブラックフット語", "bod": "チベット語", "bos": "ボスニア語", @@ -3511,7 +3494,6 @@ LANGUAGE_NAMES = { "hil": "ヒリジャノン語", "hin": "ヒンディー語", "hit": "ヒッタイト語", - "hmj": "Ge", "hmn": "フモング語", "hmo": "ヒリモトゥ語", "hrv": "クロアチア語", @@ -3826,7 +3808,6 @@ LANGUAGE_NAMES = { "bik": "Bikol", "bin": "Bini", "bis": "Bislama", - "bit": "Berinomo", "bla": "Siksika", "bod": "Tibetan", "bos": "Bosnian", @@ -3935,7 +3916,6 @@ LANGUAGE_NAMES = { "hil": "Hiligaynon", "hin": "Hindi", "hit": "Hittite", - "hmj": "Ge", "hmn": "Hmong", "hmo": "Hiri Motu", "hrv": "Croatian", @@ -4250,7 +4230,6 @@ LANGUAGE_NAMES = { "bik": "Bikol", "bin": "Bini; Edo", "bis": "Bislama", - "bit": "Berinomo", "bla": "Siksika", "bod": "Tibetaans", "bos": "Bosnisch", @@ -4359,7 +4338,6 @@ LANGUAGE_NAMES = { "hil": "Hiligainoons", "hin": "Hindi", "hit": "Hittitisch", - "hmj": "Ge", "hmn": "Hmong", "hmo": "Hiri Motu", "hrv": "Kroatisch", @@ -4674,7 +4652,6 @@ LANGUAGE_NAMES = { "bik": "bikol", "bin": "edo", "bis": "bislama", - "bit": "Berinomo", "bla": "siksika", "bod": "tybetański", "bos": "bośniacki", @@ -4783,7 +4760,6 @@ LANGUAGE_NAMES = { "hil": "hiligajnon", "hin": "hindi", "hit": "hetycki", - "hmj": "Ge", "hmn": "hmong", "hmo": "hiri motu", "hrv": "chorwacki", @@ -5093,7 +5069,6 @@ LANGUAGE_NAMES = { "bel": "Belarusian", "bem": "Bemba (Zambia)", "ben": "Bengali", - "bit": "Berinomo", "bho": "Bhojpuri", "bik": "Bikol", "byn": "Bilin", @@ -5168,7 +5143,6 @@ LANGUAGE_NAMES = { "lug": "Ganda", "gay": "Gayo", "gba": "Gbaya (Central African Republic)", - "hmj": "Ge", "gez": "Geez", "kat": "Georgiano", "deu": "Alemão", @@ -5475,7 +5449,6 @@ LANGUAGE_NAMES = { "bik": "Бикольский", "bin": "Бини", "bis": "Бислама", - "bit": "Berinomo", "bla": "Сиксика", "bod": "Тибетский", "bos": "Боснийский", @@ -5584,7 +5557,6 @@ LANGUAGE_NAMES = { "hil": "Хилигайнон", "hin": "Хинди", "hit": "Хиттит", - "hmj": "Ge", "hmn": "Хмонг", "hmo": "Хири Моту", "hrv": "Хорватский", @@ -5899,7 +5871,6 @@ LANGUAGE_NAMES = { "bik": "Bikol", "bin": "Edo (bini)", "bis": "Bislama", - "bit": "Berinomo", "bla": "Siksika (svartfotindianernas språk)", "bod": "Tibetanska", "bos": "Bosniska", @@ -6008,7 +5979,6 @@ LANGUAGE_NAMES = { "hil": "Hiligaynon", "hin": "Hindi", "hit": "Hettitiska språk", - "hmj": "Ge", "hmn": "Hmong", "hmo": "Hiri Motu", "hrv": "Kroatiska", @@ -6318,7 +6288,6 @@ LANGUAGE_NAMES = { "bel": "Beyaz Rusça", "bem": "Bemba (Zambia)", "ben": "Bengalce", - "bit": "Berinomo", "bho": "Bhojpuri (Hindistan)", "bik": "Bikol (Filipinler)", "byn": "Bilin", @@ -6393,7 +6362,6 @@ LANGUAGE_NAMES = { "lug": "Ganda Dili", "gay": "Gayo (Sumatra)", "gba": "Gbaya (Orta Afrika Cumhuriyeti)", - "hmj": "Ge", "gez": "Geez (Etiyopya)", "kat": "Gürcüce", "deu": "Almanca", @@ -6700,7 +6668,6 @@ LANGUAGE_NAMES = { "bik": "бікольська", "bin": "біні", "bis": "біслама", - "bit": "беріномо", "bla": "сісіка", "bod": "тибетська", "bos": "боснійська", @@ -6809,7 +6776,6 @@ LANGUAGE_NAMES = { "hil": "хілігайнон", "hin": "хінді", "hit": "хетська", - "hmj": "ге", "hmn": "хмонг", "hmo": "хірімоту", "hrv": "хорватська", @@ -7124,7 +7090,6 @@ LANGUAGE_NAMES = { "bik": "比科尔语", "bin": "比尼语", "bis": "比斯拉马语", - "bit": "Berinomo", "bla": "西克西卡语", "bod": "藏语", "bos": "波斯尼亚语", @@ -7233,7 +7198,6 @@ LANGUAGE_NAMES = { "hil": "希利盖农语", "hin": "印地语", "hit": "赫梯语", - "hmj": "亻革家语、重安江苗语", "hmn": "苗语", "hmo": "希里莫图语", "hrv": "克罗地亚语", @@ -7543,7 +7507,6 @@ LANGUAGE_NAMES = { "bel": "白俄羅斯文", "bem": "Bemba (Zambia)", "ben": "Bengali", - "bit": "Berinomo", "bho": "Bhojpuri", "bik": "Bikol", "byn": "Bilin", @@ -7618,7 +7581,6 @@ LANGUAGE_NAMES = { "lug": "Ganda", "gay": "Gayo", "gba": "Gbaya (Central African Republic)", - "hmj": "Ge", "gez": "Geez", "kat": "Georgian", "deu": "德文", @@ -7925,7 +7887,6 @@ LANGUAGE_NAMES = { "bik": "Bikol", "bin": "Bini", "bis": "Bislama", - "bit": "Berinomo", "bla": "Siksika", "bod": "Tibetan", "bos": "Bosnian", @@ -7960,7 +7921,6 @@ LANGUAGE_NAMES = { "cre": "Cree", "crh": "Turkish; Crimean", "csb": "Kashubian", - "csl": "Chinese Sign Language", "cym": "Welsh", "dak": "Dakota", "dan": "Danish", @@ -8035,7 +7995,6 @@ LANGUAGE_NAMES = { "hil": "Hiligaynon", "hin": "Hindi", "hit": "Hittite", - "hmj": "Ge", "hmn": "Hmong", "hmo": "Hiri Motu", "hrv": "Croatian", diff --git a/cps/translations/cs/LC_MESSAGES/messages.mo b/cps/translations/cs/LC_MESSAGES/messages.mo index c77a5c217131a2e988c551ff63cd7155744ce307..3733c6c4e23a2c3ed78a08e9ba5ea3edb538486a 100644 GIT binary patch delta 30 mcmeyhh3VH8rVY;`IE;)G3@xn;%r?J^uwi7h*sLAp?*IVBQwtja delta 30 mcmeyhh3VH8rVY;`I1Eh`49%@f4L84wuwi7h+^ikt?*IVBPzxIX diff --git a/cps/translations/cs/LC_MESSAGES/messages.po b/cps/translations/cs/LC_MESSAGES/messages.po index f835c699..581af829 100644 --- a/cps/translations/cs/LC_MESSAGES/messages.po +++ b/cps/translations/cs/LC_MESSAGES/messages.po @@ -6,7 +6,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2020-06-09 21:11+0100\n" "Last-Translator: Lukas Heroudek \n" "Language: cs_CZ\n" @@ -15,7 +15,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "Uživatel admin" msgid "All" msgstr "Vše" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Uživatel nenalezen" @@ -92,7 +92,7 @@ msgstr "Zobrazit vše" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -100,7 +100,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Nezbývá žádný správce, nelze odebrat roli správce" @@ -144,7 +144,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Konfigurace Calibre-Web aktualizována" @@ -208,279 +208,279 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Zakázat" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Povolit" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json není nakonfigurováno pro webové aplikace" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "Umístění zápisového souboru není platné. Určete prosím platnou polohu" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "Umístění zápisového souboru pro přístup není platné. Určete prosím platnou polohu" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Prosím zadejte LDAP poskytovatele, port, DN a Identifikátor objektu uživatele" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Zadejte platné uživatelské jméno pro obnovení hesla" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "Filtr objektů skupiny LDAP musí mít jeden “%s” formátový identifikátor" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "Filtr objektů skupiny LDAP má nesrovnatelnou závorku" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "Filtr uživatelských objektů LDAP musí mít jeden “%s” formátový identifikátor" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "Filtr uživatelských objektů LDAP má nesrovnatelnou závorku" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "Umístění databáze není platné, opravte prosím cestu" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "Databáze není zapisovatelná" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "Umístění souboru klíčů není platné, zadejte prosím správnou cestu" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "Umístění certifikátu není platné, zadejte prosím správnou cestu" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Nastavení e-mailového serveru aktualizováno" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Konfigurace funkcí" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Vyplňte všechna pole!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "E-mail není z platné domény" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Přidat nového uživatele" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Uživatel '%(user)s' vytvořen" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Byl nalezen existující účet pro tuto e-mailovou adresu nebo přezdívku." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Uživatel '%(nick)s' smazán" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Nezbývá žádný správce, nemůžete jej odstranit" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Upravit uživatele %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Uživatel '%(nick)s' aktualizován" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Neznámá chyba. Opakujte prosím později." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Změnit SMTP nastavení" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Při odesílání zkušebního e-mailu došlo k chybě: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Prvně nastavte svou e-mailovou adresu..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Nastavení e-mailového serveru aktualizováno" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Heslo pro uživatele %(user)s resetováno" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Nejprve nakonfigurujte nastavení pošty SMTP..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Prohlížeč log souborů" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Požadování balíčku aktualizace" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Stahování balíčku aktualizace" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Rozbalování balíčku aktualizace" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Nahrazování souborů" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Databázová připojení jsou uzavřena" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Zastavuji server" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Aktualizace dokončena, klepněte na tlačítko OK a znovu načtěte stránku" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Aktualizace selhala:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP chyba" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Chyba připojení" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Vypršel časový limit při navazování spojení" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Všeobecná chyba" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Aktualizační soubor nemohl být uložen do Temp Dir" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Nepodařilo se vytvořit nejméně jednoho uživatele LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Nepodařilo se vytvořit nejméně jednoho uživatele LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Chyba: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Chyba: Žádná reakce od uživatele LDAP serveru" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Nejméně jeden uživatel LDAP nenalezen v databázi" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1342,7 +1342,7 @@ msgstr "Převedený soubor nebyl nalezen nebo více než jeden soubor ve složce msgid "Ebook-converter failed: %(error)s" msgstr "Převaděč eknih selhal: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2581,7 +2581,7 @@ msgstr "Chyba" msgid "Upload done, processing, please wait..." msgstr "Nahrávání hotovo, zpracovávám, čekejte prosím..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Nastavení" @@ -2732,7 +2732,7 @@ msgstr "Calibre-Web katalog eknih" msgid "epub Reader" msgstr "Čtečka PDF" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Po otevření postranních panelů přeformátujte text." diff --git a/cps/translations/de/LC_MESSAGES/messages.mo b/cps/translations/de/LC_MESSAGES/messages.mo index 6721cea96ee9ae1f50721065e05b4216ed1dbe0e..ae7fbfcfd0a44656a9805698eee5cd981eb806fa 100644 GIT binary patch delta 13959 zcma*sd3==By~pt`MSylwD;JC&`m!U^0U>tIp=qN z=Xaioy`McAf3_w*a<)yv7K{IU-pH~#V@aBN|NPJ1zLuq-r*Qxt!|wPk_QCXi=6h4H z4SmP$uRxpr7UaKH4gctc=iGkF{+89$vLev(nn^=nxDHeC2296WQIYS& zPPiZS+(~3k>nt|IltE@Z9Z9Lx7ZvDGY=@Ju1Q((*TZbd@9~hZIW9VSZnuBX`8or0u zVb39!H63rkTs)24@JG}Rx(>Ch_Bb9@3)iAHuns%oHf)SF*c=aIGX4&AgzpdK{L^TB z!hllr4@|&B4!$iWq554=8R?G7$QZP7I%=T`)c0>io$V%6z%L+WWSv6=n8x-Ca3Zn? zD>9t?>+EV6&;*At507IGevR5uSH5*M4n_rhCw9We+bVC|0USmJ_%3?zZ*G6q zC^Nqob$yqkHXPYZLksRe71s;Mrma(`>TNRGERcpeyW!Xlr=p%;f(j&vlcvD}#n6o{d~ts~Gi#EvSVaMSbDdsGT1}6;sQxq!T-$&U`Vd zDA!_V+>HwG7?K3*3~Js~qSO&&VhZb9188W%38)=kg{)yMK`p!kxoOtZsG|HB_59bU z;*1+_Zb4(z5oBOj9E!^9)u;^yu?yaenfNGnV}0uw4W0d;P!oUQ`VUk10?1p{VA)cx2351;}+g1zw#%)#%mDfVPl6=z@6 zjt8RV9gWJQ50hEnT0>(1Zo&dQii7boHpjs;%~_4Zmh>m10-cAtUOvQO%$+2fe6?4x<+M4E6aBsOs&&TSpGW5qKqPXSbt{ZVM{l zZK$2^c6}Q4+_TsW52NNiKAZfvrtwDx6yZhG1PMf=;!DO9yb7sD%Y&NeDR;aEb*8Ui zD?E#B@vo@jjGJo$PDj=+U8o5>U2~F@=#|r z7Pa%K?)WvR7soQx8Q*|8ScS^O!>A)Wgv!)wsM>fB`IEx>2vs{>7Bpmn`%j|-1J$Sn z@5c7{0H)#r9EQhHXKXDr0kp<`bW>3a6`~fJiK?NiQ5h;m?R+gNu!m4bz7HGj{~;RM z(MfEFr?DfRLlup+$kad=)B?RQ7xQo+UW>}aov00LLelX0YsV)UkUyYak$FXCrwdX2RhW*uaS|RyWu$pAe`et%)Dhf-3g~83 z(QZIpvj<$CbU%Lqm7)6Lh}qG322>P3pw6&aiHW=|YR8$V;u(V4`4qQ*E$aDYsOKtC z8C#E9cr$9=U8veQfU2=t*HaPqflpljhPn+upo%EfF%x890{!0Da3rWIFF-v%3ANx7 z)B*wQgtxf;9oU`zK~#p$xZ{zJY3RXkuotG3n%{t7*n|G{sD;*|GH?$z#+`2eNt{Ce z5KhL#G84!Q)GbcLvnHAP2Qz1T*k1)I57p&&5y+9!9-cPoR$SV~nU+F47o?O_!NejzpdP6jTN( zP;aa%cRY$Znp)Hg=vCKGQAPFxY6074GMSGm-U8J47}UJ8eD3f60tOV>Qq((t4QfaC zqQ3Ar+E|MU_&rnrU!b0ERAB7-q;LWJo*^fDR!8J8t-u+`-1K69-cVIT2h|tKSanb#t z{c`i;G7dFS1=@Ho>I=1~v;7!#War&}=NnAMx}%CSACqtxs+cFZ{b{K0&&SpnSxloF zjSB3E8!-=`!>;&8v@t$tQrH9I=?}q{Sb#d)DXue60nA2a@EV+oC76u+a5UB-&qb`u zG}_lZ?4=Uh;n1Z#g zC$P2d|A!3?{+$lB;~!9wcCIuj%ESKjN1;;b$5vS7e!do!(k-Z3+J?G@zeW|~+t>oX zL>1#tsOQtF$SmtyU1(^+F{l8pbo+kPPFJILz8h5oAD|{ks5aNKIqE2~F$;&_T)Ymo za10fA9k$0;P|yDXBTC6%X{6z0)C(hRg^9eI>nPM2UyFL~I@c=KyHFc=9CcfsLmj~p zR3?t10{F!J{LiTQF0LT|3g8k0I;*6WrWR6Bfn=j@K|U(-MW~5Fs0D6BrF;$QjJIK5 zd>ECf*RdB~Le*H;Rc7b;*pB|#Rpfs-jd|_|8&OsJ5GsH@s7Pa|9oC{!cN}#DZ=-7E zL)3GBMQ!9OxBnw5utqnUfEuGR)DM-JVG$Zi>3nyMi>z-w zLE{=sUT5yD7iZHyf&($-R&%C>sGXLgYGW;q#~rBR`~)-bOH?LX-)3qf6_vRxY=Xm3 zwK5hPe*YJ{9|TdUTZNk7PSk@@)KTomZg>cFwr5ed7~W*f{KG!OOt z8Q2q-qHf9Es0=-dxmdS>{5PlZ7Y0)C686GYcba$pVC+M`6lY=-saoq(_w(;jndozu zxyF<6diqPSH`bw2egX6GA|_$4jV90m5gIC*S*WvgP?7G&0r&#yNdAJlC70dL)9*G5 z=b-|dg393is0Cg_ZR|a_{~5NV|96~#KcUu%jK9a6$y`ik;7-&FX}jC6!CCZ=V+wZM zL`7pRPQ+E%A78>A_;*w$Q={g6l8deAhfw3cLLI?<$a)d0#x$(ssD;j;Qrdg7`5z1l zQB{94YG;pPV|*GF=s{F1yoz1%3sk0BZ81OJy)lP=0qRIfP-njpo9h0*NJFVPirV3u zs7!o{n&@jBgehD3w;7y-i*OgJ7UJ$T3v@v3bUZf0S=a&>qUJA0)k2j!eiPcd|98-6 zihEJ1c@F#HTd3k|bf5VnvLEWXC8+1hF%#FJ-UoZI1JJ(%+=iO?p!@k-sK`G>rSLn{88_W-`l+Z)^gsnV z3N_zc)c49!nO=>$Ew@By45YCKZTv5sj6dOZIBAEuHjm*b`Y)mu_zu&t&BJD)zNiHX zQ5#x-I*LlvbGM<2aF^?|sA7-Q(a=ub#9{a`j=)ZjnE$ugd>lkSiW+|f3ozkP;~2E* zuX245mHIz)mY8?R+NS&YQD$pbS!G3 zYfx{h2c356B>`vh{vaK zDjvX&_yd+;`=?AQZ^U-=*P}AB9aTgJP?@R6Tznrhu<>4VJ$s-6n24D;4|Sv~_L6^9 z|J@8Ixo&SyYH_$iLW%Qyi??lT$rB`V^Rs5AT{F2cn9W`QE?L4Q9c8yP>}4MHN#J+u%y< zjT^8F{@NXX2bKEIQ5(37t#$v?o-=2Wg(|uUn1hQ^3*3q-&bv`BsLePPPr09Ws4+Y3 zhT3_5Ou%8N8W@Gzz|GhlH=}B%7O&9#KSN_W1DU@z_cnmKW?N8a^#{zx9j_j~CvXU!Mg4Z99x?&WL5;7*$UqtgY4pMKsMMq$=4#~XxvAX})(-_CVBdApW5jD{T)EE962jEYr3Hu*20ggbO{Z**c7P;dAw|_GxGJZE| z16$qkXE2riiw)zP|7jXp_;bv|FL4BRec4>6h1j3|O{f6&p^EkeR0`k5#(2*4uhIvG538I>TE-(7tJPA z@ts6{|5HrFuTTMBLT#Y!?@Z>pV8mu%01Ztv8&wN8peDKvm61o>&tFH?$QP&`G(BNb zn}K?MFsgR0M5VaM9bbVuf_tzV?m^v_lP5U;o-{5npf9GJG%4zd>JPytI2EtJ*;t6% zumC^7X_)b_FJKOKI%TfkMAW!*iu@~en;FQ)Q>e(k!9LjjHS^}1 zfQ{*|!hX2M?H|Ba^lMS6KJNBUVKe$4Vsku)`urn{!Lhgkr=yPQ7|z1?QGxb3ZH_vUPh%tlSKw$| zhk6qpbH_iyEc#vFG&`S+HvMW;#_mJa&Tmi?e}t{^94f$XP_^(qDv*@7OfmLCYAs@o zqoI^vgDQ>{n1T;rU)+mIWdYL*4fys4t#DW#A+1j(@^N*!(?HL#1Tx1}-Qee-52L{;xhRPiiA1>`}cE{sXI&KeMKCjuQ^Ej}UtxE~g}V^_YoGr@K3kZW>eArPNdD3)}O(A#V|L z{QQv}D7D9v-Pl`WlH*!T2>2>1{Puj0uhNOVKlYh~=$gV)O^X92+Suet2O70-R)iIz z?Frky=(STaVwa}uXq4r1LUwVW(pS=u`Xa{;I?H{YVyDC|sSGN?Ca&n_Y12~3R70MY zDKScA?1O1L6WSC9s+^!*svQ;w{9*DFtDISt+QJhoF1MFCE2{&+lGu5tCZTn4&|#0H zdwFG%&s!W_wRC9omZhCCf=&fN{o6=5c4pZx;*vs~I|or>&xwt$NQ&<|H&_``cS;}>4%yig$ce|E<1FXA z7|w}JUcM}@TSMsok_1kQujnM5ishVEFt+=K`1t6;r5Q~)Mnx5SIDAK3N<%%d;h>i^ zs^X$Osk>)Su+pO?eqcke~RHF5m0 z*Q+PRMgHSzgh{2>@7QJahkRjgnPbmc&T*D=JH~s%B$ZA2e2(9q)J@==PgBMH3^f=Y&+6 z{vwZmnOzm||LdKyef2dV7W4P9D=X}V0G9HvBqS8}1oRff4wMUJ#0{8OO zWdXl#m0exGt30STX$i$Pui6kXBQpYf-xZGEND8#)ga>|0<($d(e!v_;HRcGZM zZOzo>ztt4AP+t=bY))(D9=cN*U0pwR%Kz~lH>cW;$~ELv{G8^XQ|9q$E>myO=j#vV zjH@i=Jh=*_#Lrc*C%P|)Ri1L)gis(DCb6W{cl7q`aYg^XhhtwKeJZZwI3+a1{wXIn zs)i7p*t(Z@{Krd0=j!45@>0=B=0s~ZcaKdz@mO3pT^z4_g6>(VoO!DRg7v$2??o?c zOOKs98I4by)^K|YgFa7X5m)BtWupu0d&O41ekv~We_f{#&xe_WS3#NMre)me9{&Ro Cv5?RJ delta 11962 zcmYM(33yG{`p5B|nMjaCB9TZA5)wotK_Wt8PKX*Rii(+1(om)5gOVDmD#xs1uCaz5 zMO8~{Rzq9WqPT9&)mF7=-D>;){;d5x|NGqMe%4xN@3r3bu6OP9-g|Yo*UdFv&a1)R z3oZV2*3+`0a6y=Q|NpOmM9WI18;CV93+v(l)bsCPFurg152Azq6->f^ung9#XIc4} zhTU*3HnuFMb%RDa1JOL~gD+qf7N8%lKrdX6m2nf+!q3nj?_zm;hymzT-?A!UMbvX~ zsPPV{=X%=xq3FZ<))*R^Xrk?#s0T~10bYB}c^;!O<3ZZ0 zV>AY0bJX)4F%*7sR;AdDFBdACnMKY?NhYDmM zR>jHo@9)~b@3H%5QAhG4YC}&j4nsK?WvU5k-WI4#7dUCe(~z;a5!>Qv48l;hqX%nY z1m>aw8i4(9g5AG@THq1tnm$GC*wMr+SO7t z1@aFz$BI;zQr!i08=R;kn}MqG5~NJ5RjB#SBlTvJ2pi+Jw_5NksJE(;pq5|^HHb)$WUFc_FE|y>wCymQA zG{GOJ0KCYv`ejf%tc1Ew)llDo1k@3wqP_z;sG8`Eb#W-Fx)-4`c@Xv79n`gZfZ^!V zg8XZz(KK{c4N<9XgWB-`)Pj>y3(Q2NdKK!Zw%h&RQS*2*7=sb0Of^OY(jBYeG}H#y zq2}MzlKd-0hZ#^r-(n5CkE-^NRwl4SjHKTTb%s4rI~jtyz7uUrPyug5)yfB`TW|!G z$uCjsT|v!%zZLn{L}go>g{q<=uZN1T18T=ZP!qk5nqV3#kOipBtw9}$8x`nrR1Ms) ze}9Myz^9D~Fc@{jQBE3~ARe_)W4oV&KJ`|&)J}tQ%nqxfUaW(@*c5AFD@?@UsOz*0b@pel zCjMd@nrr6GwC#z?@L24q`@fim&hR#Nz`s!uwr^(^>WSL%G}MAik!)JWFb)ITn+&C* zHqssyaCfYYFJl>8h~8L={LOz#6EG}i=bwt0S0{#QFV=wY7%b=bM#IhK!{A=RsG%8>-RD{o=Cg_7IvSFx*HzTKG z?MF@I+sTXvp^mTymdD1ZTa|+)N^^$+@C zT4$5;EY!jsumW~RZD5G)bkxGDkW;jF;R~qmt^)6lI;u6O_YZU-|N8KpwFmB?`hQ{y z25}yIEv;6lqANy4ehT$PyMf8*+tsqNF&*^*8;2Ef1!}%+sP~Scp8pSKV~{i7RA(0q zV&Fv##zNE?O~F8%ZI3TO72y`tneM~{+>Oe_HPk#$QJE^=&D2B$@(0v%plYT!Dih9S zG!)?;)Pi4P7+%6qe1PfbM;>*y*{A?IViM+~7Mg)7zIRZyvlx}3wOARCpaQ#sI`aF- zd`{~r4NX|CyZM3zp^By^s%WxNHP9Qiz+kL{g_w#vjg@gcDl;Xh1y`erd7a%q zfvSm9sQG@ydYJkmN1^-Qp9b}2m7;d^0CO>}mq~3AathXX48gBZJGqJavOPuz{%h+f zFsW~j3TyzXm|w-_xE>YIZFFkK<$9Z)XJR7#LX5`cc7Gp6(!Yak(7TVxNPA49UyRDg zr>KAqp^Ekt>Y81${n7sYf2a(3^(Ft>QG8!h6q%?q%tb~1JnHxUsNxxe+WAbozZCWS z7SwYeqKfeZYT<8C#dZT#I}flD{%IT7&uJd0-p`nX;XIIuDx!RQya2Vsmr)B8p{jg5 z>iJ^Sf-6xAY{x2i*zW%amGXzE42AbM&sB5M(1VSzCU(YJI2M(nRj7rIpfd0kYA4t2 z{*RbL|0%Y`)&oo+b1{Pc3RDL6pfYqAwXqARK%Lj@2OgnP?m5uB7=(JE4r;+HyWa+N zwmt3fA*cY0Pzy~!?QkaQx%sG!t+e}_QAf5Hy>$OSr_q>!qnLr#AQNE|)I=@O8}m>* z>Wn@(47I>WRO+3!^H3XEiCSnIY6E-i@dKzp&tRbL|M&I-cd<4<{EE6Rk%P_AJcrfk z4@FJ*7AlZMsD*Z5RXl*ccm?&`4b(!vU>N>|I>O+WOzLAXmG!O0G?cqmJY*>cjK5ZRikFT#2X!I-?&BKxJ;2Jw5`<(4U6N*c^QJ&;QG5=v)5*YDdRW z6Mcscyo)Lp|Dh&;7}WErs6cX2--mv7e-i3eEJV$-4V8g|sCm9a75z^`$-f@(d)Z7F zfyzV@mcb_Ii>Wqvg7NhGqmFJ4*4Fc=_b#FXy@r#2Js3OO zEYty0>36mJGf^3thdx+}{zF)$k(5;a`}D)e6nR9Z?$};iSPe zu%=-k7NgE=f$dU!wlJ1sd>yvK9jGtiU)T%-UNO(L$6)%MQJ?mKs0}Sd9l;6IZM%jl za%YtylbQ|~&A?bp#>J?}PoM(0kJ|YoRKV5dUD2d|uV<;`{?>1Tv6-wJ;64Vjm2^U8smZ!)GZ(J%0^@@E6oAutu4CAC3yRx@|Mm zk@iGA*T?pCsrx^Vh9cj9s`}lilpjE4;0P*!>-O*WP!m2x1@HuQH0541XCH=T=_jD7 zJrxyr0cxJtQ1eejr&2wQhR$>aDn+ZYCZ5D#e1O`q_h@r}gHc6P3pL&kRh&hrg(si_ zoPpZdY}9j0QK{d66>-~W@~;OEFrXbAM)l940{R9O&;?XxJjR%e_}j+gED!#n1RL@D zm#>>z@EdFXmc*m3;Q&;oW}v>Pi_w9*#*+Um8s`~MgrVd3FB4b;U&gnvE&hRdm^I#{ z?k&urUxG^M_oxh9#~OGa>tVe|O2KS?C;B!>QzCl0T|C=O7ehEh{$y7}NlVFUUJsEK-`7G8+_+xme2(9Y6k81qqqj6w%4#2UC8WAGB{{r_Pc zRxUP~Xo^lv)R9IVEJW>WDTd;Dtcf3Eef$CIV#u5P&#st_D%Sa^-#4N%aS`>Udx(88 zV5a#SQ;2@_mtYF6no0guBBI8lYbS(4F=NjF;>K+Ic5jhsD5|Ub3^etoPe$HBx>gs z-ZE94jmq30Y^&!`#dydb{~DF?JE(bmopVj2GInMl9<`J4*c2C{s{9=K<8SDTf1^_D z{kF+m6e=T`n1J1}HcrDb_&x^WZq!B&qXKY#OG7W-My1Sa9+i#h*b5h-Cj1@CW7T&| zmDj}p`i)Q%w?v(7XM4N{I_M8Z1@Ip(gs(26Tx?aJu_#3KNpP~Y-QDSN#1(mTkP??;KDYyxr{qKL5Y3P3XyUYaHs0m-f zL>!4)cqInoUQ|ZDuz!Dq3b4ikb97Bnfptd(T4?J+UDJ;+1i!~9-T(XcK)^zCogAq9 znufX+T~U$0hPu}-Q~-NW3;Y)=q2D5NrctOGO0@eqs0DkVYNil1-wbqCq_K{MCioDQ zx|680y=eDup)&9Y!?65f^L!jCwHX+T%`p`RqXU>GpDK^3HFcU+TnIi9m8T4l? zBmZg~WWa%c*+wllDQ=1b8Gi{w@f421AFu-Uc-Krg6syoL#XS57Tchs^^To`=%Jj#f zGCLo&(NZUkY#JY;uFqrCb@>OiL%&ipVJPYh`=bILgI#eaW~1*)6Hr_9rvCyeW4%xd z6=66QV*^}ik2}Aip=)ywRZPLFOcAA{#&c0sI|3uI1YgH(sEKN>HamL}_53KTgUc`l zk76!9!E)GgjrnWZ5ve_=l}|(0Z7?eG5vVWSX!C$I1#8itk1Dp0P?7#qFp-zQHnh%kJMtz3;Kv9AyNmAB~N$5$gRyR56!qCjXlFJqC1dw_#iS1hpfd zEoKL~s2vYOEm(|EIL{v6idpoJp+0DSTTPLLqvnf7y*C(ru?STQW44n2+B9Y{5RJR+ zAI_mte+#vPr>L{6^u9TYSX8lPV*>U>EifIua4zZtG#}gHN&ENEZDym+CcW_r)&s*Q4(BpQxg$^MR@MnK+uh3$^_YT>P@j2yrUtZyB+f4G2U>EFZ3_{cVJulaVzp~jn`s=pg*;!#)uov5OkhZS)# z`r}5_dv1ID3smMVqcfbwQyQw~(2vYN%_d<0{l4hHLX5z-Q5o5Yb?`i@*gW=`YgHQ+ zNHS_8%~650$FA55Riryn&pqBp{?+jP*nCjJP{k9EN>N*k#7?M*hNDtC2^G)+RO+{( zcKSJLr>8LpZ=&Y;1Iwee-z;1KH6F8{{0GvAXFwA)LiL-YcF+-ZpL<|77NEZQrKnV2 zLrruC_51@&#=lVWC4OQ8Oh=u49xAha?D64FdteIs@WWix4qW#577V4o7q#FSOvG=o z33`8O{zzqGefk4X3opPbxDu7QeW)+r7q(xc0(M@cp(47Dk$4~VLb(Ix&t?>6(N9J_ zHxhOBlTex3gtc)GCg2aY0SC=JZ-mi|cgJ*m9aVEXkoTR|2^!k@cc_T3pmy*lDrH`u znIa5BO_YYJfo`aY3Q-v;wtwG+s*Q7434caq)bn%md=*s9q~f#x|F5n6Ljmf+F<1@X z#u(gzarhgr8O;n&251ao6)C?U?1`6$gw^1qj z1hw#E)O8CxV!miCQD-kUchYqB8XdR>jya%=0Z!f#jnv z4#GM(9CiPfU;?gp($Iuwu_@ld+8BGvyx0--U^i6JO~D2@AG7c%2B7b06L1KscB*0! zHbu?f5w(%Q7>MJrIy&E^p%*q|89a&F$vJf31JscOpE0*13AJEb48*ReBj}HQI2AR| zEW2NVnr|5@BYW}Lkstv%t*bQB_~8NS-X@$i6SYL8u07VkF6fD4Pz#Pj-IgV&v;7Jk zcnfun{k}9Aia}l5KIo65upCZCZ`QYF(@<*Wp;ER6_24dh`~YfaU!!W`66!YGu)Tvi zqMz*F!@e@9b)agiC0cRugNt4*?Dty2D2Hh{UMYHwru$00vL5cH^&5D*DmL_YUuzKW z?+VJ=?+(ol@^odl$Z*YRk?FqMBEZA#-)g%Dm(J*picc1SL2Bnyc^f6@9$2U)W*a8EzYk1mD!zcgt0q1~ef40+A^KPxxr{r~^~ diff --git a/cps/translations/de/LC_MESSAGES/messages.po b/cps/translations/de/LC_MESSAGES/messages.po index 272328a3..10cc56e3 100644 --- a/cps/translations/de/LC_MESSAGES/messages.po +++ b/cps/translations/de/LC_MESSAGES/messages.po @@ -7,8 +7,8 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" -"PO-Revision-Date: 2021-08-01 17:24+0200\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" +"PO-Revision-Date: 2021-12-22 19:05+0100\n" "Last-Translator: Ozzie Isaacs\n" "Language: de\n" "Language-Team: \n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "Benutzer bearbeiten" msgid "All" msgstr "Alle" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Benutzer nicht gefunden" @@ -92,7 +92,7 @@ msgstr "Zeige alle" msgid "Malformed request" msgstr "Ungültige Anfrage" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "Guest Name kann nicht geändert werden" @@ -100,7 +100,7 @@ msgstr "Guest Name kann nicht geändert werden" msgid "Guest can't have this role" msgstr "Guest Benutzer kann diese Rolle nicht haben" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Kein Admin Benutzer verblieben Admin Berechtigung kann nicht entfernt werden" @@ -144,7 +144,7 @@ msgstr "Ungültige Lese Spalte" msgid "Invalid Restricted Column" msgstr "Ungültiger Spaltenname für Einschränkung" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Konfiguration von Calibre-Web wurde aktualisiert" @@ -194,7 +194,7 @@ msgstr "Ort der Calibre Datenbank editieren?" #: cps/admin.py:594 msgid "Are you sure you want delete Calibre-Web's sync database to force a full sync with your Kobo Reader?" -msgstr "" +msgstr "Möchten Sie wirklich die Synchronisationsdatenbank von Calibre-Web löschen, um eine komplette Synchronisation zu erzwingen?" #: cps/admin.py:743 msgid "Tag not found" @@ -204,276 +204,273 @@ msgstr "Tag nicht gefunden" msgid "Invalid Action" msgstr "Ungültige Aktion" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Verbieten" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Erlauben" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" -msgstr "" +msgstr "{} Synchronisationseinträge gelöscht" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json ist nicht für Web Anwendungen konfiguriert" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "Logdatei Pfad ist ungültig, bitte einen gültigen Pfad angeben" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "Zugriffs Logdatei Pfad ist ungültig, bitte einen gültigen Pfad angeben" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Bitte einen LDAP Server, Port, DN und Benutzer Objekt angeben" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "Bitte einen LDAP Service Account und Password eingeben" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "Bitte einen LDAP Service Account eingeben" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP Gruppen Objekt Filter benötigt genau eine \"%s\" Format Kennung" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "LDAP Gruppen Objekt Filter hat ungleiche Anzahl von Klammern" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP Benutzer Objekt Filter benötigt genau eine \"%s\" Format Kennung" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "LDAP Benutzer Objekt Filter hat ungleiche Anzahl von Klammern" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "Der LDAP Member User Filter benötigt genau eine \"%s\" Formatierungsmarkierung" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "LDAP Member User Filter hat eine ungleiche Anzahl von geöffneten und geschlossenen Klammern" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CA-Zertifikat, Zertifikat oder Key Datei ist kein gültiger Pfad" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "Einstellungsdatenbank ist nicht schreibbar" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "DB Pfad ist nicht gültig, bitte einen gültigen Pfad angeben" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "Datenbank ist nicht schreibbar" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "Schlüsseldatei ist ungültig, bitte einen gültigen Pfad angeben" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "Zertifikatsdatei ist ungültig, bitte einen gültigen Pfad angeben" -#: cps/admin.py:1335 -#, fuzzy +#: cps/admin.py:1346 msgid "Database Settings updated" -msgstr "Einstellungen des E-Mail-Servers aktualisiert" +msgstr "Datenbankeinstellung aktualisiert" -#: cps/admin.py:1343 +#: cps/admin.py:1354 msgid "Database Configuration" msgstr "Datenbank-Konfiguration" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Bitte alle Felder ausfüllen!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "E-Mail bezieht sich nicht auf eine gültige Domain" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Neuen Benutzer hinzufügen" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Benutzer '%(user)s' angelegt" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "Es existiert bereits ein Account für diese E-Mailadresse oder diesen Benutzernamen." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Benutzer '%(nick)s' gelöscht" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "Guest Benutzer kann nicht gelöscht werden" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Benutzer kann nicht gelöscht werden, es wäre kein Admin Benutzer übrig" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Benutzer %(nick)s bearbeiten" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Benutzer '%(nick)s' aktualisiert" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Es ist ein unbekannter Fehler aufgetreten. Bitte später erneut versuchen." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "SMTP-Einstellungen ändern" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "Gmail Account Verifikation erfolgreich" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "Test E-Mail an %(email)s wurde zum Senden in die Warteschlange eingereiht, für das Ergebnis bitte Aufgaben überprüfen" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Es trat ein Fehler beim Versenden der Test-E-Mail auf: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Bitte zuerst E-Mail Adresse konfigurieren..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Einstellungen des E-Mail-Servers aktualisiert" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Passwort für Benutzer %(user)s wurde zurückgesetzt" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Bitte zuerst die SMTP-Einstellung konfigurieren ..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Logdatei Anzeige" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Frage Update an" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Lade Update herunter" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Entpacke Update" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Ersetze Dateien" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Schließe Datenbankverbindungen" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Stoppe Server" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Update abgeschlossen, bitte okay drücken und Seite neu laden" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Update fehlgeschlagen:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP Fehler" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Verbindungsfehler" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Timeout beim Verbindungsaufbau" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Allgemeiner Fehler" -#: cps/admin.py:1720 -#, fuzzy +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "Updatedatei konnte nicht in Temporärem Ordner gespeichert werden" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" -msgstr "" +msgstr "Dateien konnten während des Updates nicht ausgetauscht werden" -#: cps/admin.py:1745 -#, fuzzy +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" -msgstr "Mindestens ein LDAP Benutzer konnte nicht erzeugt werden" +msgstr "Mindestens ein LDAP Benutzer konnte nicht extrahiert werden" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Mindestens ein LDAP Benutzer konnte nicht erzeugt werden" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Fehler: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Fehler: Keine Benutzerinformationen von LDAP Server empfangen" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Mindestens ein LDAP Benutzer wurde nicht in der Datenbank gefudnen" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} Benutzer erfolgreich importiert" @@ -513,9 +510,9 @@ msgid "%(seriesindex)s is not a valid number, skipping" msgstr "%(seriesindex)s ist keine gültige Zahl, Eintrag wird ignoriert" #: cps/editbooks.py:490 cps/editbooks.py:954 -#, fuzzy, python-format +#, python-format msgid "'%(langname)s' is not a valid language" -msgstr "%(langname)s ist keine gültige Sprache" +msgstr "'%(langname)s' ist keine gültige Sprache" #: cps/editbooks.py:630 cps/editbooks.py:981 #, python-format @@ -651,9 +648,9 @@ msgid "Send %(format)s to Kindle" msgstr "Sende %(format)s an Kindle" #: cps/helper.py:219 cps/tasks/convert.py:90 -#, fuzzy, python-format +#, python-format msgid "%(book)s send to Kindle" -msgstr "An Kindle senden" +msgstr "%(book)s an Kindle senden" #: cps/helper.py:224 msgid "The requested file could not be read. Maybe wrong permissions?" @@ -728,7 +725,7 @@ msgstr "Nur jpg/jpeg/png/webp/bmp Dateien werden als Coverdatei unterstützt" #: cps/helper.py:651 msgid "Invalid cover file content" -msgstr "" +msgstr "Ungültiger Cover Dateiinhalt" #: cps/helper.py:655 msgid "Only jpg/jpeg files are supported as coverfile" @@ -1016,7 +1013,7 @@ msgstr "Das Buch wurde dem Bücherregal %(sname)s hinzugefügt" #: cps/shelf.py:126 msgid "You are not allowed to add a book to the shelf" -msgstr "" +msgstr "Keine Erlaubnis Bücher zu diesem Bücherregal hinzuzufügen" #: cps/shelf.py:144 #, python-format @@ -1040,7 +1037,7 @@ msgstr "Das Buch wurde aus dem Bücherregal: %(sname)s entfernt" #: cps/shelf.py:218 msgid "Sorry you are not allowed to remove a book from this shelf" -msgstr "" +msgstr "Sie haben keine Berechtigung um Bücher aus diesem Bücherregal zu löschen" #: cps/shelf.py:228 cps/templates/layout.html:140 msgid "Create a Shelf" @@ -1056,7 +1053,7 @@ msgstr "Bücherregal editieren" #: cps/shelf.py:249 msgid "Sorry you are not allowed to create a public shelf" -msgstr "" +msgstr "Sie haben keine Berechtigung um öffentliche Bücherregal zu erzeugen" #: cps/shelf.py:261 #, python-format @@ -1332,7 +1329,7 @@ msgstr "Konvertierte Datei nicht gefunden, oder mehr als eine Datei im Pfad %(fo msgid "Ebook-converter failed: %(error)s" msgstr "Fehler des EBook-Converters: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre fehlgeschlagen mit Fehler: %(error)s" @@ -1755,9 +1752,8 @@ msgid "Keyword" msgstr "Suchbegriff" #: cps/templates/book_edit.html:233 -#, fuzzy msgid "Search keyword" -msgstr " Suchbegriff " +msgstr "Suche Schlüsselbegriff" #: cps/templates/book_edit.html:239 msgid "Click the cover to load metadata to the form" @@ -1865,21 +1861,19 @@ msgid "Enter Publishers" msgstr "Herausgeber eingeben" #: cps/templates/book_table.html:73 -#, fuzzy msgid "Enter comments" -msgstr "Domainnamen eingeben" +msgstr "Kommentare eingeben" #: cps/templates/book_table.html:73 msgid "Comments" -msgstr "" +msgstr "Kommentare" #: cps/templates/book_table.html:77 cps/templates/book_table.html:79 #: cps/templates/book_table.html:81 cps/templates/book_table.html:83 #: cps/templates/book_table.html:87 cps/templates/book_table.html:89 #: cps/templates/book_table.html:91 cps/templates/book_table.html:93 -#, fuzzy msgid "Enter " -msgstr "IDs" +msgstr "Eingeben " #: cps/templates/book_table.html:110 cps/templates/modal_dialogs.html:46 msgid "Are you really sure?" @@ -1955,7 +1949,7 @@ msgstr "Nightly" #: cps/templates/config_edit.html:50 msgid "Trusted Hosts (Comma Separated)" -msgstr "" +msgstr "Trusted Hosts (Komma separiert)" #: cps/templates/config_edit.html:61 msgid "Logfile Configuration" @@ -1979,7 +1973,7 @@ msgstr "Feature-Konfiguration" #: cps/templates/config_edit.html:104 msgid "Convert non-English characters in title and author while saving to disk" -msgstr "" +msgstr "Nicht-englische Zeichen in Titel und Autor beim Speichern auf Festplatte ersetzen" #: cps/templates/config_edit.html:108 msgid "Enable Uploads" @@ -1987,7 +1981,7 @@ msgstr "Hochladen aktivieren" #: cps/templates/config_edit.html:108 msgid "(Please ensure users having also upload rights)" -msgstr "" +msgstr "(Bitte stellen Sie sicher das sie über die Upload Berechtigung verfügen)" #: cps/templates/config_edit.html:112 msgid "Allowed Upload Fileformats" @@ -2274,14 +2268,12 @@ msgid "Allow Editing Public Shelves" msgstr "Editieren öffentlicher Bücherregale erlauben" #: cps/templates/config_view_edit.html:123 -#, fuzzy msgid "Default Language" -msgstr "Sprachen ausschließen" +msgstr "Default Sprache" #: cps/templates/config_view_edit.html:131 -#, fuzzy msgid "Default Visible Language of Books" -msgstr "Zeige nur Bücher mit dieser Sprache" +msgstr "Defaulteinstellung sichtbare Büchersprache" #: cps/templates/config_view_edit.html:147 msgid "Default Visibilities for New Users" @@ -2451,11 +2443,11 @@ msgstr "Benutzer ausloggem" #: cps/templates/index.html:69 msgid "Sort ascending according to download count" -msgstr "" +msgstr "Aufsteigend nach Downloadzahlen sortieren" #: cps/templates/index.html:70 msgid "Sort descending according to download count" -msgstr "" +msgstr "Absteigend nach Downloadzahlen sortieren" #: cps/templates/index.html:76 cps/templates/search.html:33 #: cps/templates/shelf.html:21 @@ -2568,7 +2560,7 @@ msgstr "Fehler" msgid "Upload done, processing, please wait..." msgstr "Hochladen beendet, verarbeite Daten, bitte warten..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Einstellungen" @@ -2717,7 +2709,7 @@ msgstr "Calibre-Web E-Book-Katalog" msgid "epub Reader" msgstr "epub-Leser" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Text umbrechen, wenn Seitenleiste geöffnet ist." @@ -3071,7 +3063,7 @@ msgstr "Erzeugen/Ansehen" #: cps/templates/user_edit.html:70 msgid "Force full kobo sync" -msgstr "" +msgstr "Komplettsynchronisation Kobo erzwingen" #: cps/templates/user_edit.html:88 msgid "Add allowed/Denied Custom Column Values" @@ -3150,9 +3142,8 @@ msgid "Edit Denied Column Values" msgstr "Erlaubte/Verbotene Calibre Spalten bearbeiten" #: cps/templates/user_table.html:142 -#, fuzzy msgid "Denied Column Values" -msgstr "Verbotene Calibre Spalten" +msgstr "Verbotene Spaltennamen" #: cps/templates/user_table.html:144 msgid "Change Password" @@ -3167,7 +3158,6 @@ msgid "Edit Public Shelves" msgstr "Öffentliche Bücherregale bearbeiten" #: cps/templates/user_table.html:152 -#, fuzzy msgid "Sync selected Shelves with Kobo" msgstr "Ausgesuchte Bücherregale mit Kobo synchronisieren" diff --git a/cps/translations/el/LC_MESSAGES/messages.mo b/cps/translations/el/LC_MESSAGES/messages.mo index bbafe7de47247c277900badefb9cde8cbc43c6d7..4068708c27897b675a4e7d1e2ee166871fbc2096 100644 GIT binary patch delta 30 mcmeA@%-nmJdBfy54kIH4LrW_Iv(2;PI2jo&HZP5T(Fg#i)e7wZ delta 30 mcmeA@%-nmJdBfy54nq?KLvt%r!_BkfI2jo&H!qEU(Fg#i(hBVW diff --git a/cps/translations/el/LC_MESSAGES/messages.po b/cps/translations/el/LC_MESSAGES/messages.po index c4389f7a..2afe1a0a 100644 --- a/cps/translations/el/LC_MESSAGES/messages.po +++ b/cps/translations/el/LC_MESSAGES/messages.po @@ -6,7 +6,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: Depountis Georgios\n" "Language: el\n" @@ -15,7 +15,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "Χρήστης Διαχειριστής" msgid "All" msgstr "Όλα" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Δεν βρέθηκε χρήστης" @@ -92,7 +92,7 @@ msgstr "Προβολή Όλων" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -100,7 +100,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Δεν έχει απομείνει χρήστης διαχειριστής, δεν μπορεί να αφαιρεθεί ο ρόλος διαχειριστή" @@ -144,7 +144,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Ενημερώθηκε η διαμόρφωση Calibre-Web" @@ -208,279 +208,279 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Απόρριψη" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Επιτρέπεται" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json Δεν Έχει Διαμορφωθεί Για Διαδικτυακή Εφαρμογή" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "Το Φύλλο Καταγραφής Τοποθεσίας δεν είναι Έγκυρο, Παρακαλούμε Συμπλήρωσε Τη Σωστή Πορεία" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "Η Πρόσβαση Φύλλου Καταγραφης Τοποθεσίας δεν είναι έγκυρη, Παρακαλούμε Συμπλήρωσε Τη Σωστή Πορεία" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Παρακαλούμε Συμπλήρωσε ένα Πάροχο LDAP, Θύρα, DN και Αντικείμενο Αναγνώρισης Χρήστη" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Παρακαλούμε συμπλήρωσε ένα έγκυρο όνομα χρήστη για επαναφορά του κωδικού" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "Το Αντικείμενο Φίλτρου Ομάδας LDAP Πρέπει να Έχει Μια \"%s\" Αναγνώριση Μορφής" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "Το Αντικείμενο Φίλτρου Ομάδας LDAP Έχει Παρενθέσεις Που Δεν Ταιριάζουν" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "Το Αντικείμενο Φίλτρου Χρήστη LDAP πρέπει να Έχει Μια \"%s\" Αναγνώριση Μορφής" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "Το Αντικείμενο Φίλτρου Χρήστη LDAP Έχει Παρενθέσεις Που Δεν Ταιριάζουν" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "Οι ρυθμίσεις DB δεν μπορούν να Γραφτούν" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "Η Τοποθεσία DB δεν είναι Έγκυρη, Παρακαλούμε Συμπληρώστε Τη Σωστή Πορεία" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "Η DB δεν μπορεί να Γραφτεί" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "Το Αρχειο Κλειδί Τοποθεσίας δεν είναι Έγκυρο, Παρακαλούμε Συμπληρώστε Τη Σωστή Πορεία" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "Η Τοποθεσία Certfile δεν είναι Έγκυρη, Παρακαλούμε Συμπληρώστε Τη Σωστή Πορεία" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Ενημερώθηκαν οι ρυθμίσεις E-mail διακομιστή" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Διαμόρφωση Λειτουργίας" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Παρακαλούμε συμπλήρωσε όλα τα πεδία!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "Το E-mail δεν είναι από έγκυρο domain" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Προσθήκη νέου χρήστη" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Χρήστης/ες '%(user)s' δημιουργήθηκαν" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Βρέθηκε ένας ήδη υπάρχον λογαριασμός για αυτή τη διεύθυνση e-mail ή όνομα χρήστη." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Χρήστης/ες '%(nick)s' διαγράφηκαν" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Δεν έχει απομείνει χρήστης διαχειριστής, δεν μπορεί να διαγραφεί ο χρήστης" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Επεξεργασία χρήστη %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Χρήστης/ες '%(nick)s' ενημερώθηκαν" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Προέκυψε ένα άγνωστο σφάλμα. Παρακαλούμε δοκίμασε ξανά αργότερα." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Επεξεργασία Ρυθμίσεων E-mail Διακομιστή" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Παρουσιάστηκε σφάλμα κατά την αποστολή του δοκιμαστικού e-mail:% (res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Παρακαλούμε ρύθμισε πρώτα τη διεύθυνση e-mail σου..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Ενημερώθηκαν οι ρυθμίσεις E-mail διακομιστή" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Κωδικός για επαναφορά %(user) χρήστη/ών" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Παρακαλούμε διαμόρφωσε πρώτα τις ρυθμίσεις ταχυδρομείου SMTP..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Προβολέας αρχείου φύλλου καταγραφής" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Αίτημα πακέτου ενημέρωσης" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Κατεβάζει πακέτο ενημέρωσης" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Ανοίγει πακέτο ενημέρωσης" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Αντικατάσταση αρχείων" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Οι συνδέσεις βάσης δεδομένων είναι κλειστές" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Σταματάει το διακομιστή" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Η ενημέρωση τελειώσε, παρακαλούμε πιέστε το εντάξει και φορτώστε ξανά τη σελίδα" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Η ενημέρωση απέτυχε:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP Σφάλμα" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Σφάλμα σύνδεσης" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Τελείωσε ο χρόνος κατά την προσπάθεια δημιουργίας σύνδεσης" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Γενικό σφάλμα" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Το Αρχείο Ενημέρωσης Δεν Μπόρεσε Να Αποθηκευτεί σε" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Αποτυχία Δημιουργίας Τουλάχιστον Ενός Χρήστη LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Αποτυχία Δημιουργίας Τουλάχιστον Ενός Χρήστη LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Σφάλμα: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Σφάλμα: Δεν επιστράφηκε χρήστης σε απάντηση του διακομιστή LDAP" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Τουλάχιστον Ένας Χρήστης LDAP Δεν Βρέθηκε Στη Βάση Δεδομένων" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1342,7 +1342,7 @@ msgstr "Το τροποποιημένο αρχείο δεν βρέθηκε ή υ msgid "Ebook-converter failed: %(error)s" msgstr "Ο μετατροπέας Ebook απέτυχε: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Το Calibre απέτυχε με σφάλμα: %(error)s" @@ -2581,7 +2581,7 @@ msgstr "Σφάλμα" msgid "Upload done, processing, please wait..." msgstr "Το ανέβασμα έγινε, γίνεται επεξεργασία, παρακαλούμε περίμενε..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Ρυθμίσεις" @@ -2732,7 +2732,7 @@ msgstr "Calibre-Web Κατάλογος eBook" msgid "epub Reader" msgstr "PDF πρόγραμμα ανάγνωσης" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Επανάληψη ροής κειμένου όταν οι μπάρες στο πλάι είναι ανοιχτές." diff --git a/cps/translations/es/LC_MESSAGES/messages.mo b/cps/translations/es/LC_MESSAGES/messages.mo index a476236c2e4db4569fabd707fd52271759f95fda..aaa84a38823366c0be19402b88b798683e733d90 100644 GIT binary patch delta 30 mcmZpg$lNrMdBf>^4kIH4LrW_Iv(1^4nq?KLvt%r!_AlT6&M*UH-9PU3kLwDkqY<# diff --git a/cps/translations/es/LC_MESSAGES/messages.po b/cps/translations/es/LC_MESSAGES/messages.po index 4254df10..3047167f 100644 --- a/cps/translations/es/LC_MESSAGES/messages.po +++ b/cps/translations/es/LC_MESSAGES/messages.po @@ -9,7 +9,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2020-05-25 17:22+0200\n" "Last-Translator: minakmostoles \n" "Language: es\n" @@ -18,7 +18,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -79,7 +79,7 @@ msgstr "Editar usuarios" msgid "All" msgstr "Todo" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Usuario no encontrado" @@ -96,7 +96,7 @@ msgstr "Mostrar todo" msgid "Malformed request" msgstr "Petición mal formulada" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "El nombre de invitado no se puede cambiar" @@ -104,7 +104,7 @@ msgstr "El nombre de invitado no se puede cambiar" msgid "Guest can't have this role" msgstr "El invitado no puede tener ese rol" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "No queda ningún usuario administrador, no se puede eliminar al usuario" @@ -148,7 +148,7 @@ msgstr "Columna de lectura no válida" msgid "Invalid Restricted Column" msgstr "Columna restringida no válida" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Configuración de Calibre-Web actualizada" @@ -212,279 +212,279 @@ msgstr "Etiqueta no encontrada" msgid "Invalid Action" msgstr "Acción no válida" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Denegar" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Permitir" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json no está configurado para la aplicación web" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "La ruta del Logfile no es válida. Por favor, Introduce la ruta correcta" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "La ruta del Access Logfile no es válida. Por favor, Introduce la ruta correcta" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Por favor, Introduce un proveedor LDAP, puerto, DN y el User Object Identifier" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Por favor, introduce una cuenta de servicio LDAP y su contraseña" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "Por favor, introduce una cuenta de servicio LDAP" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP Group Object Filter necesita tener un identificador de formato \"%s\"" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "El LDAP Group Object Filter tiene un paréntesis diferente" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP Group Object Filter necesita tener un identificador de formato \"%s\"" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "El LDAP Group Object Filter tiene un paréntesis diferente" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "El filtro de usuarios LDAP necesita tener un identificador de formato \"%s\"" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "El filtro de LDAP \"Member User\" tiene paréntesis no coincidentes" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "Ubicaciones del certificado de la CA del LDAP, del certificado o de la clave no válidos. Por favor introduce la ruta correcta" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "La base de datos de configuración no es modificable" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "La ruta de la base de datos no es válida. Por favor, Introduce la ruta correcta" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "La base de datos no es modificable" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "La ruta del Keyfile no es válida, por favor, Introduce la ruta correcta" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "La ruta de Certfile no es válida, por favor, Introduce la ruta correcta" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Actualizados los ajustes del servidor de correo electrónico" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Configuración de la base de datos" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "¡Por favor, rellena todos los campos!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "El correo electrónico no tiene un dominio válido" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Añadir un nuevo usuario" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Usuario '%(user)s' creado" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Encontrada una cuenta existente para este correo electrónico o nombre de usuario." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Usuario '%(nick)s' eliminado" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "No puedes borrar al Usuario Invitado" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "No queda ningún usuario administrador, no se puede borrar al usuario" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Editar Usuario %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Usuario '%(nick)s' actualizado" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Ha ocurrido un error desconocido. Por favor vuelva a intentarlo más tarde." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Cambiar parámetros de correo" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "Verificación de cuenta de Gmail exitosa" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "Puesto en cola un correo electrónico de prueba enviado a %(email)s, por favor, comprueba el resultado en Tareas" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Ocurrió un error enviando el correo electrónico de prueba: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Por favor, configure su correo electrónico primero..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Actualizados los ajustes del servidor de correo electrónico" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Contraseña para el usuario %(user)s reinicializada" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Configura primero los parámetros del servidor SMTP..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Visor del fichero de log" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Solicitando paquete de actualización" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Descargando paquete de actualización" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Descomprimiendo paquete de actualización" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Remplazando archivos" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Los conexiones con la base datos están cerradas" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Parando el servidor" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Actualización finalizada. Por favor, pulse OK y recargue la página" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Falló la actualización:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "Error HTTP" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Error de conexión" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Tiempo agotado mientras se trataba de establecer la conexión" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Error general" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "La actualización del archivo no pudo guardarse en el directorio temporal (Temp Dir)" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Error al crear al menos un usuario LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Error al crear al menos un usuario LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Error: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Error: el servidor LDAP no ha devuelto ningún usuario" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Al menos, un usuario LDAP no se ha encontrado en la base de datos" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} Usuario importado con éxito" @@ -1346,7 +1346,7 @@ msgstr "Archivo convertido no encontrado, o más de un archivo en el directorio msgid "Ebook-converter failed: %(error)s" msgstr "Falló Ebook-converter: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre falló con el error: %(error)s" @@ -2585,7 +2585,7 @@ msgstr "Error" msgid "Upload done, processing, please wait..." msgstr "Carga hecha, procesando, por favor espere ..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Ajustes" @@ -2736,7 +2736,7 @@ msgstr "Catálogo de ebooks de Calibre-Web" msgid "epub Reader" msgstr "Lector PDF" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Redimensionar el texto cuando las barras laterales están abiertas." diff --git a/cps/translations/fi/LC_MESSAGES/messages.mo b/cps/translations/fi/LC_MESSAGES/messages.mo index a6a8eea22ae2015996cf9171da50daf962aad316..6493ba4325f76fbee08206f00e39284f80e0ea76 100644 GIT binary patch delta 30 mcmZ2>jd9sE#tkL*97aY8hL%jd9sE#tkL*9EK(ehUQkLhMQ~br5G74H&1uy*8%{j3kmrE diff --git a/cps/translations/fi/LC_MESSAGES/messages.po b/cps/translations/fi/LC_MESSAGES/messages.po index 5fe3845e..ae6cbd12 100644 --- a/cps/translations/fi/LC_MESSAGES/messages.po +++ b/cps/translations/fi/LC_MESSAGES/messages.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2020-01-12 13:56+0100\n" "Last-Translator: Samuli Valavuo \n" "Language: fi\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -76,7 +76,7 @@ msgstr "Pääkäyttäjä" msgid "All" msgstr "Kaikki" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -93,7 +93,7 @@ msgstr "Näytä kaikki" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -101,7 +101,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -145,7 +145,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web asetukset päivitetty" @@ -209,276 +209,276 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Sähköpostipalvelimen tiedot päivitetty" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Ominaisuuksien asetukset" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Ole hyvä ja täytä kaikki kentät!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "Sähköpostiosoite ei ole toimivasta domainista" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Lisää uusi käyttäjä" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Käyttäjä '%(user)s' lisätty" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Tälle sähköpostiosoitteelle tai tunnukselle löytyi jo tili." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Käyttäjä '%(nick)s' poistettu" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Pääkäyttäjiä ei jää jäljelle, käyttäjää ei voi poistaa" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Muokkaa käyttäjää %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Käyttäjä '%(nick)s' päivitetty" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Tapahtui tuntematon virhe. Yritä myöhemmin uudelleen." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Muuta SMTP asetuksia" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Testisähköpostin lähetyksessä tapahtui virhe: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "" -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Sähköpostipalvelimen tiedot päivitetty" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Käyttäjän %(user)s salasana palautettu" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Ole hyvä ja aseta SMTP postiasetukset ensin..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Lokitiedoston katselin" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Haetaan päivitystiedostoa" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Ladataan päivitystiedostoa" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Puretaan päivitystiedostoa" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Korvataan tiedostoja" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Tietokantayhteydet on katkaistu" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Sammutetaan palvelin" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Päivitys valmistui, ole hyvä ja paina OK ja lataa sivu uudelleen" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Päivitys epäonnistui:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP virhe" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Yhteysvirhe" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Aikakatkaisu yhteyttä luotaessa" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Yleinen virhe" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1340,7 +1340,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "E-kirjan muunnos epäonnistui: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2577,7 +2577,7 @@ msgstr "Virhe" msgid "Upload done, processing, please wait..." msgstr "Lataus tehty, prosessoidaan, ole hyvä ja odota..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Asetukset" @@ -2728,7 +2728,7 @@ msgstr "Calibre-Web e-kirjaluettelo" msgid "epub Reader" msgstr "PDF lukija" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Uudelleenjärjestä teksti kun sivut on auki." diff --git a/cps/translations/fr/LC_MESSAGES/messages.mo b/cps/translations/fr/LC_MESSAGES/messages.mo index 1c4e6de1da68267433118f1c0b12870ff2029506..ed7751543b7f4b78e543f112eedb1f6a3dcadf29 100644 GIT binary patch delta 30 mcmZ3wn0e`9<_-1v97aY8hL%\n" "Language: fr\n" @@ -31,7 +31,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -91,7 +91,7 @@ msgstr "Utilisateur admin" msgid "All" msgstr "Tout" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "L'utilisateur n'a pas été trouvé" @@ -108,7 +108,7 @@ msgstr "Montrer tout" msgid "Malformed request" msgstr "Demande malformée" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "Le nom de l’invité ne peut pas être modifié" @@ -116,7 +116,7 @@ msgstr "Le nom de l’invité ne peut pas être modifié" msgid "Guest can't have this role" msgstr "L’invité ne peut pas avoir ce rôle" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Aucun utilisateur admin restant, impossible de supprimer le rôle admin" @@ -160,7 +160,7 @@ msgstr "Colonne de lecture non valide" msgid "Invalid Restricted Column" msgstr "Colonne restreinte non valide" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Configuration de Calibre-Web mise à jour" @@ -224,279 +224,279 @@ msgstr "Étiquette introuvable" msgid "Invalid Action" msgstr "Action invalide" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Refuser" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Autoriser" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json n'est pas configuré pour l'application Web" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "L'emplacement du fichier logfile est incorrect, veuillez saisir un chemin valide" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "L'emplacement du fichier Access Logfile est incorrect, veuillez saisir un chemin valide" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Veuillez saisir un fournisseur LDAP, Port, DN et l'identifiant objet de l'utilisateur" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Veuillez entrer un nom d'utilisateur valide pour réinitialiser le mot de passe" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "Veuillez entrer un compte de service LDAP" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "Le filtre objet du groupe LDAP a besoin d'un identifiant de format \"%s\"" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "Le filtre objet du groupe LDAP a une parenthèse non gérée" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "Le filtre objet de l'utilisateur LDAP a besoin d'un identifiant de format \"%s\"" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "Le filtre objet de l'utilisateur LDAP a une parenthèse non gérée" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "Le filtre utilisateur des membres LDAP doit avoir un identificateur de format \"%s\\ »" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "Le filtre utilisateur de membre LDAP a des parenthèses non appariées" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CACertificat, certificat ou emplacement de clé non valide, veuillez entrer le chemin correct" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "Les paramètres de la base de données ne sont pas accessibles en écriture" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "L'emplacement de la base de données est incorrect, veuillez saisir un chemin valide" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "La base de données n'est pas accessible en écriture" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "L'emplacement du fichier Keyfile est incorrect, veuillez saisir un chemin valide" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "L'emplacement du fichier Certfile est incorrect, veuillez saisir un chemin valide" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Les paramètres du serveur de courriels ont été mis à jour" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Configuration des options" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Veuillez compléter tous les champs !" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "Cette adresse de courriel n’appartient pas à un domaine valide" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Ajouter un nouvel utilisateur" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Utilisateur '%(user)s' créé" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Un compte existant a été trouvé pour cette adresse de courriel ou pour ce surnom." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Utilisateur '%(nick)s' supprimé" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "Impossible de supprimer l’utilisateur Invité" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Aucun utilisateur admin restant, impossible de supprimer l’utilisateur" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Éditer l'utilisateur %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Utilisateur '%(nick)s' mis à jour" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Une erreur inconnue est survenue. Veuillez réessayer plus tard." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Modifier les paramètres du serveur de courriels" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "La vérification du compte Gmail réussie" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "Teste les courriels en file d’attente pour l’envoi à %(email)s, veuillez vérifier le résultat des tâches" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Il y a eu une erreur pendant l’envoi du courriel de test : %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Veuillez d'abord configurer votre adresse de courriel..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Les paramètres du serveur de courriels ont été mis à jour" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Le mot de passe de l’utilisateur %(user)s a été réinitialisé" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Veuillez configurer les paramètres SMTP au préalable..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Visualiseur de fichier journal" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Demande de mise à jour" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Téléchargement de la mise à jour" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Décompression de la mise à jour" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Remplacement des fichiers" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Les connexions à la base de données ont été fermées" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Arrêt du serveur" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Mise à jour terminée, merci d’appuyer sur okay et de rafraîchir la page" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "La mise à jour a échoué :" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "Erreur HTTP" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Erreur de connexion" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Délai d'attente dépassé lors de l'établissement de connexion" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Erreur générale" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Le fichier de mise à jour ne peut pas être sauvegardé dans le répertoire temporaire" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Impossible de créer au moins un utilisateur LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Impossible de créer au moins un utilisateur LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Erreur : %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Erreur : Aucun utilisateur renvoyé dans la réponse LDAP du serveur" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Au moins un utilisateur LDAP n'a pas été trouvé dans la base de données" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} utilisateur importé avec succès" @@ -1358,7 +1358,7 @@ msgstr "Fichier converti non trouvé ou plus d'un fichier dans le chemin %(folde msgid "Ebook-converter failed: %(error)s" msgstr "La commande ebook-convert a échouée : %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre a échoué avec l’erreur : %(error)s" @@ -2597,7 +2597,7 @@ msgstr "Erreur" msgid "Upload done, processing, please wait..." msgstr "Téléversement terminé, traitement en cours, veuillez patienter…." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Paramètres" @@ -2748,7 +2748,7 @@ msgstr "Catalogue de livres électroniques Calibre-Web" msgid "epub Reader" msgstr "Lecteur PDF" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Mettre à jour la mise en page du texte quand les bandeaux latéraux sont ouverts." diff --git a/cps/translations/hu/LC_MESSAGES/messages.mo b/cps/translations/hu/LC_MESSAGES/messages.mo index 58ac79655713c9103519382572063fdfce35a686..58121e6b00bb63d7a8f3f1d9dd7e93db98673cd5 100644 GIT binary patch delta 29 lcmca}gz?T1#tj?HIE;)G3@xn;%qH(J`_5>wd4u^HEdaFV3y=T+ delta 29 lcmca}gz?T1#tj?HI1Eh`49%@f4JYp~`_5>&d4u^HEdaFT3y=T+ diff --git a/cps/translations/hu/LC_MESSAGES/messages.po b/cps/translations/hu/LC_MESSAGES/messages.po index 7e6b1ed7..6012214d 100644 --- a/cps/translations/hu/LC_MESSAGES/messages.po +++ b/cps/translations/hu/LC_MESSAGES/messages.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PROJECT VERSION\n" "Report-Msgid-Bugs-To: EMAIL@ADDRESS\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2019-04-06 23:36+0200\n" "Last-Translator: \n" "Language: hu\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -76,7 +76,7 @@ msgstr "Rendszergazda felhasználó" msgid "All" msgstr "" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -93,7 +93,7 @@ msgstr "Mindent mutass" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -101,7 +101,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -145,7 +145,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "A Calibre-Web konfigurációja frissítve." @@ -209,276 +209,276 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Az e-mail kiszolgáló beállításai frissítve." -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Funkciók beállítása" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Az összes mezőt ki kell tölteni!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "Az e-mail tartománya nem érvényes." -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Új felhasználó hozzáadása" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "A következő felhasználó létrehozva: %(user)s" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Már létezik felhasználó ehhez az e-mail címhez vagy felhasználói névhez." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "A felhasználó törölve: %(nick)s" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr " A felhasználó szerkesztése: %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "A felhasználó frissítve: %(nick)s" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Ismeretlen hiba történt. Próbáld újra később!" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "SMTP beállítások változtatása" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Hiba történt a teszt levél küldése során: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "" -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Az e-mail kiszolgáló beállításai frissítve." -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "A(z) %(user)s felhasználó jelszavának alaphelyzetbe állítása" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Először be kell állítani az SMTP levelező beállításokat..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Frissítési csomag kérése" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Frissítési csomag letöltése" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Frissítési csomag kitömörítése" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Fájlok cserélése" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Adatbázis kapcsolatok lezárva" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Szerver leállítása" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "A frissítés települt, kattints az OK-ra és újra tölt az oldal" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "A frissítés nem sikerült:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP hiba" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Kapcsolódási hiba" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Időtúllépés a kapcsolódás során" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Általános hiba" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1340,7 +1340,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "Az e-könyv átalakítás nem sikerült: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2577,7 +2577,7 @@ msgstr "Hiba" msgid "Upload done, processing, please wait..." msgstr "Feltöltés kész, feldolgozás alatt, kérlek várj..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Beállítások" @@ -2727,7 +2727,7 @@ msgstr "Calibre-Web e-könyv katalógus" msgid "epub Reader" msgstr "" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Szöveg újratördelése amikor az oldalsávok nyitva vannak" diff --git a/cps/translations/it/LC_MESSAGES/messages.mo b/cps/translations/it/LC_MESSAGES/messages.mo index f7ef8e8940133c1e4fabd9a8f7639243a319058f..f53f178d6988a9708ba6127dbcc2aac6247f86a9 100644 GIT binary patch delta 30 mcmaF8o%!{4<_$g-97aY8hL%\n" "Language: it\n" @@ -15,7 +15,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -74,7 +74,7 @@ msgstr "Modifica gli utenti" msgid "All" msgstr "Tutti" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Utente non trovato" @@ -91,7 +91,7 @@ msgstr "tutte le lingue presenti" msgid "Malformed request" msgstr "Richiesta non formulata correttamente" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "Il nome dell'utente Guest (ospite) non può essere modificato" @@ -99,7 +99,7 @@ msgstr "Il nome dell'utente Guest (ospite) non può essere modificato" msgid "Guest can't have this role" msgstr "L'utente Guest (ospite) non può avere questo ruolo" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Non rimarrebbe nessun utente amministratore, non posso rimuovere il ruolo di amministratore" @@ -143,7 +143,7 @@ msgstr "Colonna di lettura non valida" msgid "Invalid Restricted Column" msgstr "Colonna con restrizioni non valida" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "La configurazione di Calibre-Web è stata aggiornata" @@ -204,273 +204,273 @@ msgstr "Etichetta non trovata" msgid "Invalid Action" msgstr "Azione non valida" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Nega" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Permetti" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json non è configurato per Web Application" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "La posizione del Logfile non è valida, per favore indica il percorso corretto" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "La posizione dell'Access Logfile non è valida, per favore indica il percorso corretto" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Per favore digita un Provider LDAP, porta, DN e User Object Identifier" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "Per favore digita nome di utente e password del servizio LDAP" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "Per favore indica un account di servizio LDAP" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP Group Object Filter deve avere un \"%s\" Format Identifier" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "LDAP Group Object Filter contiene una parentesi senza la corrispettiva" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP User Object Filter deve avere un \"%s\" Format Identifier" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "LDAP User Object Filter contiene una parentesi senza la corrispettiva" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP Member User Filter deve avere un \"%s\" Format Identifier" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "LDAP Member User Filter contiene una parentesi senza la corrispettiva" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CACertificate, il certificato o la posizione della chiave non sono corretti, per favore indica il percorso corretto" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "I parametri del DB non sono scrivibili" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "La posizione del DB non è valida, per favore indica il percorso corretto" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "Il DB non è scrivibile" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "La posizione del Keyfile non è valida, per favore indica il percorso corretto" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "La posizione del Certfile non è valida, per favore indica il percorso corretto" -#: cps/admin.py:1335 +#: cps/admin.py:1346 msgid "Database Settings updated" msgstr "Configurazione del Database aggiornata" -#: cps/admin.py:1343 +#: cps/admin.py:1354 msgid "Database Configuration" msgstr "Configurazione del Database" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Per favore compila tutti i campi!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "L'e-mail non proviene da un dominio valido" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Aggiungi un nuovo utente" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "L'utente '%(user)s' è stato creato" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "Trovato un account esistente con questo e-mail o nome di utente" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "L'utente '%(nick)s' è stato eliminato" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "Non posso eliminare l'utente Guest (ospite)" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Non rimarrebbe nessun utente amministratore, non posso eliminare l'utente" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Modifica l'utente %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "L'utente '%(nick)s' è stato aggiornato" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Si è verificato un errore sconosciuto: per favore riprova." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Modifica le impostazioni del server e-mail" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "L'account Gmail è stato verificato con successo" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "L'e-mail di test è stato accodato con successo per essere spedito a %(email)s, per favore verifica tramite il pulsante 'Compito' il risultato" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Si è verificato un errore nell'invio dell'e-mail di test: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Per favore prima configura il tuo indirizzo e-mail..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Configurazione del server e-mail aggiornata" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "La password dell'utente %(user)s è stata resettata" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Configura dapprima le impostazioni del server SMTP..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Visualizzatore del Logfile" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Richiedo il pacchetto di aggiornamento" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Scarico il pacchetto di aggiornamento" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Decomprimo il pacchetto di aggiornamento" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Sostituisco i file" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Le connessioni al database sono chiuse" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Arresto il server" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Aggiornamento completato, per favore premi ok e ricarica la pagina" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Aggiornamento non riuscito:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "Errore HTTP" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Errore di connessione" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Tempo scaduto nello stabilire la connessione" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Errore generale" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "Il file di aggiornamento non può essere salvato nella cartella temporanea" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "Durante l'aggiornamento non è stato possibile sostituire alcuni file" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "Fallita l'estrazione di almeno un utente LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Fallita la creazione di almeno un utente LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Errore: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Errore: nessun utente restituito in risposta dal server LDAP" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Almeno un utente LDAP non è stato trovato nel database" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} utente importato con successo" @@ -1330,7 +1330,7 @@ msgstr "Non ho trovato il file convertito o ci sono più di un file nella cartel msgid "Ebook-converter failed: %(error)s" msgstr "Errore nel convertitore: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Si è verificato un errore con Calibre: %(error)s" @@ -2562,7 +2562,7 @@ msgstr "Errore" msgid "Upload done, processing, please wait..." msgstr "Caricamento riuscito, sto elaborando, per favore aspetta..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Configurazione" @@ -2711,7 +2711,7 @@ msgstr "Catalogo Calibre-Web" msgid "epub Reader" msgstr "Lettore epub" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Adatta il testo quando le barre laterali sono aperte." diff --git a/cps/translations/ja/LC_MESSAGES/messages.mo b/cps/translations/ja/LC_MESSAGES/messages.mo index afb7b8da638e2cdebe0aa2c13ad21330f93b5b73..e0ea3ef77ac4ddc2c8a45f3da5fe51e014946399 100644 GIT binary patch delta 30 mcmZpk&DcDfaYLCFhmnzjp{139+2%SeX+}ni&9k&$DgpqJy9rkS delta 30 mcmZpk&DcDfaYLCFhoOmrp}Cc*;pRFmX+}oN&9k&$DgpqJxCvJP diff --git a/cps/translations/ja/LC_MESSAGES/messages.po b/cps/translations/ja/LC_MESSAGES/messages.po index c8bfd79e..805e925b 100644 --- a/cps/translations/ja/LC_MESSAGES/messages.po +++ b/cps/translations/ja/LC_MESSAGES/messages.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2018-02-07 02:20-0500\n" "Last-Translator: white \n" "Language: ja\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "" msgid "All" msgstr "" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -92,7 +92,7 @@ msgstr "" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -100,7 +100,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -144,7 +144,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web の設定を更新しました" @@ -204,276 +204,276 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "メールサーバの設定を更新しました" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "機能設定" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "全ての項目を入力してください" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "このメールは有効なドメインからのものではありません" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "新規ユーザ追加" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "ユーザ '%(user)s' を作成しました" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "このメールアドレスかニックネームで登録されたアカウントが見つかりました" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "ユーザ '%(nick)s' を削除しました" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "%(nick)s を編集" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "ユーザ '%(nick)s' を更新しました" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "不明なエラーが発生しました。あとで再試行してください。" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "SMTP設定を変更" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "テストメールを %(res)s に送信中にエラーが発生しました" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "" -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "メールサーバの設定を更新しました" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "%(user)s 用のパスワードをリセット" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "初めにSMTPメールの設定をしてください" -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "更新データを要求中" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "更新データをダウンロード中" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "更新データを展開中" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "ファイルを置換中" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "データベースの接続を切断完了" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "サーバ停止中" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "アップデート完了、OKを押してページをリロードしてください" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "アップデート失敗:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTPエラー" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "接続エラー" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "接続を確立中にタイムアウトしました" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "エラー発生" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1335,7 +1335,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "Ebook-converter が失敗しました: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2571,7 +2571,7 @@ msgstr "エラー" msgid "Upload done, processing, please wait..." msgstr "アップロード完了。現在処理中ですのでお待ち下さい..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "設定" @@ -2721,7 +2721,7 @@ msgstr "" msgid "epub Reader" msgstr "" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "" diff --git a/cps/translations/km/LC_MESSAGES/messages.mo b/cps/translations/km/LC_MESSAGES/messages.mo index ffd09157b05df02247331d69602fb202cd19cf90..59d510d611b0a5f7af96521f3ae1abd8d591b1fb 100644 GIT binary patch delta 29 lcmaE~pYhRt#tjEmIE;)G3@xn;%qE{y`OIjsd9SLf6#%ph3lIPR delta 29 lcmaE~pYhRt#tjEmI1Eh`49%@f4JV&e`OIj!d9SLf6#%pf3lIPR diff --git a/cps/translations/km/LC_MESSAGES/messages.po b/cps/translations/km/LC_MESSAGES/messages.po index e867d38c..196ea2a9 100644 --- a/cps/translations/km/LC_MESSAGES/messages.po +++ b/cps/translations/km/LC_MESSAGES/messages.po @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2018-08-27 17:06+0700\n" "Last-Translator: \n" "Language: km_KH\n" @@ -17,7 +17,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -77,7 +77,7 @@ msgstr "អ្នកប្រើប្រាស់រដ្ឋបាល" msgid "All" msgstr "" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -94,7 +94,7 @@ msgstr "បង្ហាញទាំងអស់" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -102,7 +102,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -146,7 +146,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "" @@ -210,275 +210,275 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "ទំនាក់ទំនងទៅមូលដ្ឋានទិន្នន័យត្រូវបានផ្តាច់" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "ការកំណត់មុខងារ" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "សូមបំពេញចន្លោះទាំងអស់!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "បន្ថែមអ្នកប្រើប្រាស់ថ្មី" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "បានបង្កើតអ្នកប្រើប្រាស់ ‘%(user)s’" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "អ្នកប្រើប្រាស់ ‘%(nick)s’ ត្រូវបានលុប" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "កែប្រែអ្នកប្រើប្រាស់ %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "អ្នកប្រើប្រាស់ ‘%(nick)s’ ត្រូវបានកែប្រែ" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "ប្តូរការកំណត់ SMTP" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "" -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "សូមកំណត់អ៊ីមែល SMTP ជាមុនសិន" -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "កំពុងស្នើសុំឯកសារបច្ចុប្បន្នភាព" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "កំពុងទាញយកឯកសារបច្ចុប្បន្នភាព" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "កំពុងពន្លាឯកសារបច្ចុប្បន្នភាព" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "ទំនាក់ទំនងទៅមូលដ្ឋានទិន្នន័យត្រូវបានផ្តាច់" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "ការធ្វើបច្ចុប្បន្នភាពបានបញ្ចប់ សូមចុច okay រួចបើកទំព័រជាថ្មី" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1339,7 +1339,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "Ebook-converter បានបរាជ័យ៖ %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2575,7 +2575,7 @@ msgstr "" msgid "Upload done, processing, please wait..." msgstr "" -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "ការកំណត់" @@ -2725,7 +2725,7 @@ msgstr "" msgid "epub Reader" msgstr "" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "សេរេអត្ថបទនៅពេលបើកផ្ទាំងចំហៀង។" diff --git a/cps/translations/nl/LC_MESSAGES/messages.mo b/cps/translations/nl/LC_MESSAGES/messages.mo index 46b0374b19e4d7f4baf22424e3b5e1decea01fb2..d7e7c45ee39325b7c028cb75a234a08734bb2334 100644 GIT binary patch delta 30 mcmX@u#eA@fdBf8}4kIH4LrW_Iv(0Y{4H+3NHp>?)1pxrEKMHOD delta 30 mcmX@u#eA@fdBf8}4nq?KLvt%r!_99C4H+3NH_I0*1pxrEJPK|A diff --git a/cps/translations/nl/LC_MESSAGES/messages.po b/cps/translations/nl/LC_MESSAGES/messages.po index 88594080..fc45d08a 100644 --- a/cps/translations/nl/LC_MESSAGES/messages.po +++ b/cps/translations/nl/LC_MESSAGES/messages.po @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web (GPLV3)\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/Calibre-Web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2020-12-12 08:20+0100\n" "Last-Translator: Marcel Maas \n" "Language: nl\n" @@ -17,7 +17,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -77,7 +77,7 @@ msgstr "Systeembeheerder" msgid "All" msgstr "Alles" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Gebruiker niet gevonden" @@ -94,7 +94,7 @@ msgstr "Alle talen" msgid "Malformed request" msgstr "Misvormd verzoek" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "Gast naam kan niet worden veranderd" @@ -102,7 +102,7 @@ msgstr "Gast naam kan niet worden veranderd" msgid "Guest can't have this role" msgstr "Gast kan deze rol niet hebben" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Kan systeembeheerder rol niet verwijderen van de laatste systeembeheerder" @@ -146,7 +146,7 @@ msgstr "Ongeldige gelezen kolom" msgid "Invalid Restricted Column" msgstr "Ongeldige beperkte kolom" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web-configuratie bijgewerkt" @@ -210,278 +210,278 @@ msgstr "Tag niet gevonden" msgid "Invalid Action" msgstr "Ongeldige actie" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Weigeren" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Toestaan" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json is niet geconfigureerd voor webapplicatie" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "De locatie van het logbestand is onjuist, voer een geldige locatie in" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "De locatie vam het toegangslog is onjuist, voer een geldige locatie in" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Voer alsjeblieft een LDAP Provider, Port, DN en User Object Identifier in" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "Voer een geldig LDAP Service Account en wachtwoord in" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "Voer een LDAP Service Account in" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP Groep Object Filter Moet Een \"%s\" Formaat Identificiatie hebben" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "LDAP Groep Object Filter heeft een niet-gebalanceerd haakje" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP Gebruiker Object Filter moet \"%s\" Formaat Identificatie hebben" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "LDAP Gebruiker Filter heeft een niet-gebalanceerd haakje" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP Lid Gebruiker Filter moet een \"%s\" Formaat Identificatie hebben" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "LDAP Lid Gebruiker Filter heeft een niet-gebalanceerd haakje" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CACertficaat, Certificaat of Sleutel Locatie is ongeldig. Voer alsjeblieft een geldig pad in." -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "DB-instellingen niet opgeslagen" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "Database niet gevonden, voer de juiste locatie in" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "Kan niet schrijven naar database" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "SSL-sleutellocatie is niet geldig, voer een geldig pad in" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "SSL-certificaatlocatie is niet geldig, voer een geldig pad in" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "E-mailserver-instellingen bijgewerkt" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Databaseconfiguratie" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Vul alle velden in!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "Het e-mailadres bevat geen geldige domeinnaam" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Gebruiker toevoegen" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Gebruiker '%(user)s' aangemaakt" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Bestaand account met dit e-mailadres of deze gebruikersnaam aangetroffen." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Gebruiker '%(nick)s' verwijderd" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "Kan Gast gebruiker niet verwijderen" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Kan laatste systeembeheerder niet verwijderen" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Gebruiker '%(nick)s' bewerken" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Gebruiker '%(nick)s' bijgewerkt" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Onbekende fout opgetreden. Probeer het later nog eens." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "SMTP-instellingen bewerken" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "Gmail Account succesvol geverifieerd" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "Test E-Mail wordt verzonden naar %(email)s, controleer de taken voor het resultaat" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Fout opgetreden bij het versturen van de test-e-mail: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Gelieve eerst je e-mail adres configureren..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "E-mailserver-instellingen bijgewerkt" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Wachtwoord voor gebruiker %(user)s is hersteld" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Stel eerst SMTP-mail in..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Logbestand lezer" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Update opvragen" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Update downloaden" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Update uitpakken" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Update toepassen" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Databaseverbindingen zijn gesloten" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Bezig met stoppen van Calibre-Web" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Update voltooid, klik op 'Oké' en vernieuw de pagina" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Update mislukt:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP-fout" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Verbindingsfout" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Time-out tijdens maken van verbinding" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Algemene fout" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Geüpload bestand kon niet opgeslagen worden in de tijdelijke map" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Mislukt om minstens een LDAP gebruiker aan te maken" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Het is niet gelukt tenminste een LDAP gebruiker aan te maken" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Fout: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Fout: No user returned in response of LDAP server" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Minstens een LDAP Gebruiker is niet gevonden in de Database" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} Gebruiker succesvol geïmporteerd" @@ -1343,7 +1343,7 @@ msgstr "Omgezette bestand is niet gevonden of meer dan een bestand in map %(fold msgid "Ebook-converter failed: %(error)s" msgstr "E-boek-conversie mislukt: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre mislukt met foutmelding: %(error)s" @@ -2582,7 +2582,7 @@ msgstr "Fout" msgid "Upload done, processing, please wait..." msgstr "Uploaden voltooid, bezig met verwerken..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Instellingen" @@ -2733,7 +2733,7 @@ msgstr "Calibre-Web - e-boekcatalogus" msgid "epub Reader" msgstr "PDF lezer" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Tekstindeling automatisch aanpassen als het zijpaneel geopend is." diff --git a/cps/translations/pl/LC_MESSAGES/messages.mo b/cps/translations/pl/LC_MESSAGES/messages.mo index 26286b36a7d211d76960cbb277672f98a950231f..3c1424b46a39204b6817d00519046c223aca62ed 100644 GIT binary patch delta 30 mcmdlxlX>q<<_&X-IE;)G3@xn;%r-A6N@HZS*vwtBDFOhkxC*QQ delta 30 mcmdlxlX>q<<_&X-I1Eh`49%@f4L2_-N@HZS+{|6FDFOhkwF;~N diff --git a/cps/translations/pl/LC_MESSAGES/messages.po b/cps/translations/pl/LC_MESSAGES/messages.po index 85da79f1..c7dfbcf7 100644 --- a/cps/translations/pl/LC_MESSAGES/messages.po +++ b/cps/translations/pl/LC_MESSAGES/messages.po @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre Web - polski (POT: 2021-06-12 08:52)\n" "Report-Msgid-Bugs-To: EMAIL@ADDRESS\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2021-06-12 15:35+0200\n" "Last-Translator: Radosław Kierznowski \n" "Language: pl\n" @@ -17,7 +17,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -78,7 +78,7 @@ msgstr "Edytuj użytkowników" msgid "All" msgstr "Wszystko" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Nie znaleziono użytkownika" @@ -95,7 +95,7 @@ msgstr "Pokaż wszystkie" msgid "Malformed request" msgstr "Nieprawidłowo sformułowane żądanie" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "Nazwa gościa nie może być zmieniona" @@ -103,7 +103,7 @@ msgstr "Nazwa gościa nie może być zmieniona" msgid "Guest can't have this role" msgstr "Gość nie może pełnić tej roli" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Nie można odebrać praw administratora. Brak na serwerze innego konta z prawami administratora" @@ -149,7 +149,7 @@ msgstr "Nieprawidłowa kolumna odczytu" msgid "Invalid Restricted Column" msgstr "Nieprawidłowa kolumna z ograniczeniami" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Konfiguracja Calibre-Web została zaktualizowana" @@ -210,279 +210,279 @@ msgstr "Nie znaleziono znacznika" msgid "Invalid Action" msgstr "Nieprawidłowe działanie" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Zabroń" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Zezwalaj" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json nie został skonfigurowany dla aplikacji webowej" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "Lokalizacja pliku dziennika jest nieprawidłowa, wprowadź poprawną ścieżkę" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "Lokalizacja pliku dziennika dostępu jest nieprawidłowa, wprowadź poprawną ścieżkę" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Wprowadź dostawcę LDAP, port, nazwę wyróżniającą i identyfikator obiektu użytkownika" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "Proszę wprowadzić konto i hasło usługi LDAP" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "Proszę wprowadzić konto usługi LDAP" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "Filtr obiektów grupy LDAP musi mieć jeden identyfikator formatu \"% s\"" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "Filtr obiektów grupy LDAP ma niedopasowany nawias" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "Filtr obiektów użytkownika LDAP musi mieć jeden identyfikator formatu \"% s\"" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "Filtr obiektów użytkownika LDAP ma niedopasowany nawias" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "Filtr użytkownika członka LDAP musi mieć jedno \"%s\" identyfikator formatu" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "Filtr użytkownika członka LDAP ma niedopasowane nawiasy" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "Główny urząd certyfikatu LDAP, Certyfikat lub Lokalizacja Klucza nie jest prawidłowa, Proszę wprowadzić poprawną ścieżkę" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "Ustawienia Bazy Danych nie są zapisywalne" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "Lokalizacja bazy danych jest nieprawidłowa, wprowadź poprawną ścieżkę" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "Baza danych nie jest zapisywalna" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "Lokalizacja pliku klucza jest nieprawidłowa, wprowadź poprawną ścieżkę" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "Lokalizacja pliku certyfikatu jest nieprawidłowa, wprowadź poprawną ścieżkę" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Zaktualizowano ustawienia serwera poczty e-mail" -#: cps/admin.py:1343 +#: cps/admin.py:1354 msgid "Database Configuration" msgstr "Konfiguracja bazy danych" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Proszę wypełnić wszystkie pola!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "E-mail nie pochodzi z prawidłowej domeny" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Dodaj nowego użytkownika" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Użytkownik '%(user)s' został utworzony" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "Znaleziono istniejące konto dla tego adresu e-mail lub nazwy." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Użytkownik '%(nick)s' został usunięty" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 #, fuzzy msgid "Can't delete Guest User" msgstr "Nie można usunąć użytkownika gościa" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Nie można usunąć użytkownika. Brak na serwerze innego konta z prawami administratora" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Edytuj użytkownika %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Użytkownik '%(nick)s' został zaktualizowany" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Wystąpił nieznany błąd. Spróbuj ponownie później." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Zmień ustawienia SMTP" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "Weryfikacja konta Gmail przebiegła pomyślnie" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, fuzzy, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "Testowy e-mail czeka w kolejce do wysłania do %(email)s, sprawdź zadania, aby uzyskać wynik" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Wystąpił błąd podczas wysyłania e-maila testowego: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Najpierw skonfiguruj swój adres e-mail..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Zaktualizowano ustawienia serwera poczty e-mail" # ??? -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Zrestartowano hasło użytkownika %(user)s" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Proszę najpierw skonfigurować ustawienia SMTP poczty e-mail..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Przeglądanie dziennika" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Żądanie o pakiet aktualizacji" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Pobieranie pakietu aktualizacji" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Rozpakowywanie pakietu aktualizacji" # ??? -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Zastępowanie plików" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Połączenia z bazą danych zostały zakończone" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Zatrzymywanie serwera" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Aktualizacja zakończona, proszę nacisnąć OK i odświeżyć stronę" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Aktualizacja nieudana:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "Błąd HTTP" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Błąd połączenia" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Przekroczono limit czasu podczas nawiązywania połączenia" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Błąd ogólny" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Plik aktualizacji nie mógł zostać zapisany w katalogu tymczasowym" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Błąd przy tworzeniu przynajmniej jednego użytkownika LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Błąd przy tworzeniu przynajmniej jednego użytkownika LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Błąd: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Błąd. LDAP nie zwrócił żadnego użytkownika" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Przynajmniej jeden użytkownik LDAP nie został znaleziony w bazie danych" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} Użytkownik pomyślnie zaimportowany" @@ -1347,7 +1347,7 @@ msgstr "Konwertowany plik nie został znaleziony, lub więcej niż jeden plik w msgid "Ebook-converter failed: %(error)s" msgstr "Konwertowanie nie powiodło się: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, fuzzy, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre nie powiodło się z błędem: %(error)s" @@ -2597,7 +2597,7 @@ msgstr "Błąd" msgid "Upload done, processing, please wait..." msgstr "Wysyłanie zakończone, przetwarzanie, proszę czekać…" -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Ustawienia" @@ -2749,7 +2749,7 @@ msgstr "Katalog e-booków Calibre-Web" msgid "epub Reader" msgstr "Czytnik PDF" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Przepływ tekstu, gdy paski boczne są otwarte." diff --git a/cps/translations/pt_BR/LC_MESSAGES/messages.mo b/cps/translations/pt_BR/LC_MESSAGES/messages.mo index 23b5a33f2199bd120ac7e3f66b1b9acd46b499ad..c6efe3c2bd789c787432ed2b1b4d82a3f36684a4 100644 GIT binary patch delta 30 mcmccgj_J}nrVTY|97aY8hL%\n" "Language: br\n" @@ -13,7 +13,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -73,7 +73,7 @@ msgstr "Usuário Admin" msgid "All" msgstr "Todos" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Usuário não encontrado" @@ -91,7 +91,7 @@ msgstr "Mostrar tudo" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -99,7 +99,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Nenhum usuário administrador restante, não pode remover a função de administrador" @@ -143,7 +143,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Configuração do Calibre-Web atualizada" @@ -207,279 +207,279 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Negar" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Permita" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json não está configurado para aplicativo da web" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "A localização do arquivo de log não é válida, digite o caminho correto" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "A localização do arquivo de log de acesso não é válida, digite o caminho correto" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Digite um provedor LDAP, porta, DN e identificador de objeto do usuário" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Por favor, digite um nome de usuário válido para redefinir a senha" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "O filtro de objeto de grupo LDAP precisa ter um identificador de formato \"%s\"" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "Filtro de objeto de grupo LDAP tem parênteses incomparáveis" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "O filtro de objeto de usuário LDAP precisa ter um identificador de formato \"%s\"" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "Filtro de objeto de usuário LDAP tem parênteses incomparáveis" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "O filtro de usuário membro do LDAP precisa ter um identificador de formato \"%s\"" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "Filtro de usuário de membro LDAP tem parênteses incomparáveis" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CACertificate, Certificados ou chave de localização não é válida, Insira o caminho correto" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "O banco de dados de configurações não é gravável" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "A localização do banco de dados não é válida, digite o caminho correto" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "DB não é gravável" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "A localização do arquivo-chave não é válida, por favor insira o caminho correto" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "A localização do arquivo de certificação não é válida, digite o caminho correto" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "Atualização das configurações do servidor de e-mail" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Configuração das Características" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Por favor, preencha todos os campos!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "O e-mail não é de um domínio válido" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Adicionar novo usuário" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Usuário '%(user)s' criado" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Encontrei uma conta existente para este endereço de e-mail ou apelido." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Usuário '%(nick)s' excluído" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Nenhum usuário administrador restante, não é possível excluir o usuário" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Editar usuário %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Usuário '%(nick)s' atualizado" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Ocorreu um erro desconhecido. Por favor, tente novamente mais tarde." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Editar configurações do servidor de e-mail" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Ocorreu um erro ao enviar o e-mail de teste: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Por favor, configure seu endereço de e-mail primeiro..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "Atualização das configurações do servidor de e-mail" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Senha para redefinição do usuário %(user)s" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Por favor, configure primeiro as configurações de correio SMTP..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "visualizador de arquivo de registro" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Solicitação de pacote de atualização" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Download do pacote de atualização" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Descompactação de pacote de atualização" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Substituição de arquivos" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "As ligações à base de dados estão fechadas" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Parar servidor" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Atualização concluída, pressione okay e recarregue a página" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Atualização falhou:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "Erro HTTP" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Erro de conexão" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Tempo limite durante o estabelecimento da conexão" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Erro geral" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Arquivo de atualização não pôde ser salvo no diretório temporário" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Falha na criação no mínimo de um usuário LDAP" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Falha na criação no mínimo de um usuário LDAP" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Erro: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Erro: Nenhum usuário retornado em resposta do servidor LDAP" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "No mínimo um usuário LDAP não encontrado no banco de dados" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} Usuário Importado com Sucesso" @@ -1341,7 +1341,7 @@ msgstr "Arquivo convertido não encontrado ou mais de um arquivo na pasta %(fold msgid "Ebook-converter failed: %(error)s" msgstr "Conversor de ebook falhou: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre falhou com erro: %(error)s" @@ -2580,7 +2580,7 @@ msgstr "Erro" msgid "Upload done, processing, please wait..." msgstr "Upload feito, processando, por favor aguarde ..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Configurações" @@ -2731,7 +2731,7 @@ msgstr "Catálogo de e-books Calibre-Web" msgid "epub Reader" msgstr "leitor de PDF" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Refluxo de texto quando as barras laterais estão abertas." diff --git a/cps/translations/ru/LC_MESSAGES/messages.mo b/cps/translations/ru/LC_MESSAGES/messages.mo index 255a7fd7f9e20aaaf25b6b77c4df1b9b9b2b189f..69d9e91fa593d79d7386beda5873cec19f1012b2 100644 GIT binary patch delta 30 mcmaF(jp^YxrVY|T97aY8hL%\n" "Language: sv\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "Redigera användare" msgid "All" msgstr "Alla" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "Användaren hittades inte" @@ -92,7 +92,7 @@ msgstr "Visa alla" msgid "Malformed request" msgstr "Felaktig begäran" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "Gästnamn kan inte ändras" @@ -100,7 +100,7 @@ msgstr "Gästnamn kan inte ändras" msgid "Guest can't have this role" msgstr "Gäst kan inte ha den här rollen" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "Ingen administratörsanvändare kvar, kan inte ta bort administratörsrollen" @@ -145,7 +145,7 @@ msgstr "Ogiltig roll" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web konfiguration uppdaterad" @@ -207,279 +207,279 @@ msgstr "Taggen hittades inte" msgid "Invalid Action" msgstr "Ogiltig åtgärd" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "Förneka" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "Tillåt" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json är inte konfigurerad för webbapplikation" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "Loggfilens plats är inte giltig, vänligen ange rätt sökväg" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "Åtkomstloggplatsens plats är inte giltig, vänligen ange rätt sökväg" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "Vänligen ange en LDAP-leverantör, port, DN och användarobjektidentifierare" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Ange giltigt användarnamn för att återställa lösenordet" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP-gruppobjektfilter måste ha en \"%s\"-formatidentifierare" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "LDAP-gruppobjektfilter har omatchande parentes" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP-användarobjektfilter måste ha en \"%s\"-formatidentifierare" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "LDAP-användarobjektfilter har omatchad parentes" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "Användarfilter för LDAP-medlemmar måste ha en \"%s\"-formatidentifierare" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "Användarfilter för LDAP-medlemmar har omatchad parentes" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP-certifikat, certifikat eller nyckelplats är inte giltigt, vänligen ange rätt sökväg" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "Inställningar för DB är inte skrivbara" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "DB-plats är inte giltig, vänligen ange rätt sökväg" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "DB är inte skrivbar" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "Keyfile-platsen är inte giltig, vänligen ange rätt sökväg" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "Certfile-platsen är inte giltig, vänligen ange rätt sökväg" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "E-postserverinställningar uppdaterade" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Funktion konfiguration" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Fyll i alla fält!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "E-posten är inte från giltig domän" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Lägg till ny användare" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Användaren '%(user)s' skapad" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "Hittade ett befintligt konto för den här e-postadressen eller namnet." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Användaren '%(nick)s' borttagen" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "Det går inte att ta bort gästanvändaren" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Ingen adminstratörsanvändare kvar, kan inte ta bort användaren" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Redigera användaren %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Användaren '%(nick)s' uppdaterad" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Ett okänt fel uppstod. Försök igen senare." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Ändra SMTP-inställningar" -#: cps/admin.py:1551 +#: cps/admin.py:1562 #, fuzzy msgid "Gmail Account Verification Successful" msgstr "Verifiering av G-mail-kontot lyckades" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "Testa e-post i kö för att skicka till %(email)s, vänligen kontrollera Uppgifter för resultat" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Det gick inte att skicka Testmeddelandet: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Vänligen konfigurera din e-postadress först..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "E-postserverinställningar uppdaterade" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "Lösenord för användaren %(user)s återställd" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Konfigurera SMTP-postinställningarna först..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Visaren för loggfil" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Begär uppdateringspaketet" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Hämtar uppdateringspaketet" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Packar upp uppdateringspaketet" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Ersätta filer" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Databasanslutningarna är stängda" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Stoppar server" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Uppdatering klar, tryck på okej och uppdatera sidan" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Uppdateringen misslyckades:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP-fel" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Anslutningsfel" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Tiden ute när du etablerade anslutning" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Allmänt fel" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "Uppdateringsfilen kunde inte sparas i Temp Dir" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 #, fuzzy msgid "Failed to extract at least One LDAP User" msgstr "Det gick inte att skapa minst en LDAP-användare" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "Det gick inte att skapa minst en LDAP-användare" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "Fel: %(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "Fel: Ingen användare återges som svar på LDAP-servern" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "Minst en LDAP-användare hittades inte i databasen" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} användare har importerats" @@ -1340,7 +1340,7 @@ msgstr "Konverterad fil hittades inte eller mer än en fil i mappen %(folder)s" msgid "Ebook-converter failed: %(error)s" msgstr "E-bokkonverteraren misslyckades: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "calibre misslyckades med fel: %(error)s" @@ -2580,7 +2580,7 @@ msgstr "Fel" msgid "Upload done, processing, please wait..." msgstr "Uppladdning klar, bearbetning, vänligen vänta ..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Inställningar" @@ -2730,7 +2730,7 @@ msgstr "Calibre-Web e-bokkatalog" msgid "epub Reader" msgstr "PDF-läsare" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Fyll i texten igen när sidofält är öppna." diff --git a/cps/translations/tr/LC_MESSAGES/messages.mo b/cps/translations/tr/LC_MESSAGES/messages.mo index fbad469794a36a215097b28241ad531de6c4e936..4354ea9aa3eb72cd7758b46d267bb21923274341 100644 GIT binary patch delta 30 mcmZqM#Mripal=hx4kIH4LrW_Iv&|2U1sNGFHh(q|RsjH|842hB delta 30 mcmZqM#Mripal=hx4nq?KLvt%r!_5zk1sNGFH-9z}RsjH|776G8 diff --git a/cps/translations/tr/LC_MESSAGES/messages.po b/cps/translations/tr/LC_MESSAGES/messages.po index 8a049549..9d6781da 100644 --- a/cps/translations/tr/LC_MESSAGES/messages.po +++ b/cps/translations/tr/LC_MESSAGES/messages.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: EMAIL@ADDRESS\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2020-04-23 22:47+0300\n" "Last-Translator: iz \n" "Language: tr\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "" msgid "All" msgstr "Tümü" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -92,7 +92,7 @@ msgstr "" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -100,7 +100,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -144,7 +144,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web yapılandırması güncellendi" @@ -204,278 +204,278 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 #, fuzzy msgid "Please Enter a LDAP Service Account and Password" msgstr "Şifrenizi sıfırlayabilmek için lütfen geçerli bir kullanıcı adı giriniz" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "E-posta sunucusu ayarları güncellendi" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Özellik Yapılandırması" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Lütfen tüm alanları doldurun!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "E-posta izin verilen bir servisten değil" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Yeni kullanıcı ekle" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "'%(user)s' kullanıcısı oluşturuldu" -#: cps/admin.py:1390 +#: cps/admin.py:1401 #, fuzzy msgid "Found an existing account for this e-mail address or name." msgstr "Bu e-posta adresi veya kullanıcı adı için zaten bir hesap var." -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Kullanıcı '%(nick)s' silindi" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "Başka yönetici kullanıcı olmadığından silinemedi" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "%(nick)s kullanıcısını düzenle" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "'%(nick)s' kullanıcısı güncellendi" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "Bilinmeyen bir hata oluştu. Lütfen daha sonra tekrar deneyiniz." -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "Deneme e-postası gönderilirken bir hata oluştu: %(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "Lütfen önce e-posta adresinizi ayarlayın..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "E-posta sunucusu ayarları güncellendi" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "%(user)s kullanıcısının şifresi sıfırlandı" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Lütfen önce SMTP e-posta ayarlarını ayarlayın..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "Log dosyası görüntüleyici" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Güncelleme paketi isteniyor" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Güncelleme paketi indiriliyor" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Güncelleme paketi ayıklanıyor" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "Dosyalar değiştiriliyor" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "Veritabanı bağlantıları kapalı" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "Sunucu durduruyor" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Güncelleme tamamlandı, sayfayı yenilemek için lütfen Tamam'a tıklayınız" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "Güncelleme başarısız:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP Hatası" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "Bağlantı hatası" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "Bağlantı kurulmaya çalışırken zaman aşımına uğradı" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "Genel hata" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "%(filename)s dosyası geçici dizine kaydedilemedi" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1337,7 +1337,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "eKitap-Dönüştürücü hatası: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2574,7 +2574,7 @@ msgstr "Hata" msgid "Upload done, processing, please wait..." msgstr "Yükleme tamamlandı, işleniyor, lütfen bekleyin..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Ayarlar" @@ -2725,7 +2725,7 @@ msgstr "" msgid "epub Reader" msgstr "PDF Okuyucu" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Kenar çubukları açıkken metni kaydır" diff --git a/cps/translations/uk/LC_MESSAGES/messages.mo b/cps/translations/uk/LC_MESSAGES/messages.mo index c62a20741224bb4b7ac0506a67af57add25127da..62855c0847be892c5299e2aba81e4e5efcd1c2ee 100644 GIT binary patch delta 30 mcmaFU!}z9$al-<64kIH4LrW_Iv&}2yQyCd8HuEXQsR970Q3-Yc delta 30 mcmaFU!}z9$al-<64nq?KLvt%r!_6z?QyCd8H}fgRsR970P6>7Z diff --git a/cps/translations/uk/LC_MESSAGES/messages.po b/cps/translations/uk/LC_MESSAGES/messages.po index 4e8801da..9a4907fd 100644 --- a/cps/translations/uk/LC_MESSAGES/messages.po +++ b/cps/translations/uk/LC_MESSAGES/messages.po @@ -6,7 +6,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-web\n" "Report-Msgid-Bugs-To: https://github.com/janeczku/calibre-web\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2017-04-30 00:47+0300\n" "Last-Translator: ABIS Team \n" "Language: uk\n" @@ -15,7 +15,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "Керування сервером" msgid "All" msgstr "" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -92,7 +92,7 @@ msgstr "Показати всі" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -100,7 +100,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -144,7 +144,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "" @@ -208,275 +208,275 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "З'єднання з базою даних закрите" -#: cps/admin.py:1343 +#: cps/admin.py:1354 #, fuzzy msgid "Database Configuration" msgstr "Особливі налаштування" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "Будь-ласка, заповніть всі поля!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "Додати користувача" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "Користувач '%(user)s' додан" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "Користувача '%(nick)s' видалено" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "Змінити користувача %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "Користувача '%(nick)s' оновлено" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "Змінити налаштування SMTP" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "" -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "Будь-ласка, спочатку сконфігуруйте параметри SMTP" -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "Перевірка оновлень" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "Завантаження оновлень" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "Розпакування оновлення" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "З'єднання з базою даних закрите" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "Оновлення встановлені, натисніть ok і перезавантажте сторінку" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1337,7 +1337,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2573,7 +2573,7 @@ msgstr "" msgid "Upload done, processing, please wait..." msgstr "" -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "Налаштування" @@ -2723,7 +2723,7 @@ msgstr "" msgid "epub Reader" msgstr "" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "Переформатувати текст, коли відкриті бічні панелі." diff --git a/cps/translations/zh_Hans_CN/LC_MESSAGES/messages.mo b/cps/translations/zh_Hans_CN/LC_MESSAGES/messages.mo index f7b864c06419b6c1b50a7fa22e8effca884a8167..3bbd44758668b5cf44be2dc9deef7cb3aab922ba 100644 GIT binary patch delta 30 lcmdnd&b*_Yd4pCphmnzjp{139*=D0^bw);u%~3UR?f{t`310vJ delta 30 lcmdnd&b*_Yd4pCphoOmrp}Cc*;bx<1bw)\n" "Language: zh_CN\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "管理用户" msgid "All" msgstr "全部" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "找不到用户" @@ -92,7 +92,7 @@ msgstr "显示全部" msgid "Malformed request" msgstr "格式错误的请求" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "访客名称无法更改" @@ -100,7 +100,7 @@ msgstr "访客名称无法更改" msgid "Guest can't have this role" msgstr "游客无法拥有此角色" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "理员账户不存在,无法删除管理员角色" @@ -144,7 +144,7 @@ msgstr "无效的阅读列" msgid "Invalid Restricted Column" msgstr "无效的限制列" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web配置已更新" @@ -204,273 +204,273 @@ msgstr "标签未找到" msgid "Invalid Action" msgstr "无效的动作" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "拒绝" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "允许" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json 未为 Web 应用程序配置" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "日志文件路径无效,请输入正确的路径" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "访问日志路径无效,请输入正确的路径" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "请输入LDAP主机、端口、DN和用户对象标识符" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "请输入一个LDAP服务账号和密码 " -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "请输入一个LDAP服务账号" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP组对象过滤器需要一个具有“%s”格式标识符" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "LDAP组对象过滤器的括号不匹配" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP用户对象过滤器需要一个具有“%s”格式标识符" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "LDAP用户对象过滤器的括号不匹配" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP成员用户过滤器需要有一个“%s”格式标识符" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "LDAP成员用户过滤器中有不匹配的括号" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CA证书、证书或密钥位置无效,请输入正确的路径" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "设置数据库不可写入" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "数据库路径无效,请输入正确的路径" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "数据库不可写入" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "密钥文件路径无效,请输入正确的路径" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "证书文件路径无效,请输入正确的路径" -#: cps/admin.py:1335 +#: cps/admin.py:1346 msgid "Database Settings updated" msgstr "数据库设置已更新" -#: cps/admin.py:1343 +#: cps/admin.py:1354 msgid "Database Configuration" msgstr "数据库配置" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "请填写所有字段!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "邮箱不在有效域中" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "添加新用户" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "用户“%(user)s”已创建" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "使用此邮箱或用户名的账号已经存在。" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "用户“%(nick)s”已删除" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "无法删除游客用户" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "管理员账户不存在,无法删除用户" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "编辑用户 %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "用户“%(nick)s”已更新" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "发生一个未知错误,请稍后再试。" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "编辑邮件服务器设置" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "G-Mail账号校验成功" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "发送给%(email)s的测试邮件已进入队列。请检查任务结果" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "发送测试邮件时出错:%(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "请先配置您的邮箱地址..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "邮件服务器设置已更新" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "用户 %(user)s 的密码已重置" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "请先配置SMTP邮箱设置..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "日志文件查看器" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "正在请求更新包" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "正在下载更新包" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "正在解压更新包" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "正在替换文件" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "数据库连接已关闭" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "正在停止服务器" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "更新完成,请点击确定并刷新页面" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "更新失败:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP错误" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "连接错误" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "建立连接超时" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "一般错误" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "更新文件无法保存在临时目录中" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "更新期间无法替换文件" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "未能提取至少一个LDAP用户" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "未能创建至少一个LDAP用户" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "错误:%(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "错误:在LDAP服务器的响应中没有返回用户" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "数据库中没有找到至少一个LDAP用户" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} 用户被成功导入" @@ -1329,7 +1329,7 @@ msgstr "找不到转换后的文件或文件夹%(folder)s中有多个文件" msgid "Ebook-converter failed: %(error)s" msgstr "电子书转换器失败: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre 运行失败,错误信息:%(error)s" @@ -2560,7 +2560,7 @@ msgstr "错误" msgid "Upload done, processing, please wait..." msgstr "上传完成,正在处理,请稍候..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "设置" @@ -2709,7 +2709,7 @@ msgstr "Caliebre-Web电子书路径" msgid "epub Reader" msgstr "epub阅读器" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "打开侧栏时重排文本。" diff --git a/cps/translations/zh_Hant_TW/LC_MESSAGES/messages.mo b/cps/translations/zh_Hant_TW/LC_MESSAGES/messages.mo index 4a8c7cdda6dae1399802544661279fbb51224ac3..9f2dd7d88e9ed3c4c7bdc7ea6e0295deccf4b713 100644 GIT binary patch delta 30 mcmezNm+9MIrVa1PIgE@H3@xn;%r<{3S7&6j*eq9h!xaG8kqmwS delta 30 mcmezNm+9MIrVa1PISfq{49%@f4L5%)S7&6j+$>jl!xaG8jtqVP diff --git a/cps/translations/zh_Hant_TW/LC_MESSAGES/messages.po b/cps/translations/zh_Hant_TW/LC_MESSAGES/messages.po index a7c87e24..d9cbf08b 100644 --- a/cps/translations/zh_Hant_TW/LC_MESSAGES/messages.po +++ b/cps/translations/zh_Hant_TW/LC_MESSAGES/messages.po @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: Calibre-Web\n" "Report-Msgid-Bugs-To: EMAIL@ADDRESS\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: 2020-09-27 22:18+0800\n" "Last-Translator: xlivevil \n" "Language: zh_TW\n" @@ -16,7 +16,7 @@ msgstr "" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -75,7 +75,7 @@ msgstr "管理用戶" msgid "All" msgstr "全部" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "找不到用戶" @@ -92,7 +92,7 @@ msgstr "顯示全部" msgid "Malformed request" msgstr "格式錯誤的請求" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "訪客名稱無法更改" @@ -100,7 +100,7 @@ msgstr "訪客名稱無法更改" msgid "Guest can't have this role" msgstr "遊客無法擁有此角色" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "管理員賬戶不存在,無法刪除管理員角色" @@ -144,7 +144,7 @@ msgstr "無效的閱讀列" msgid "Invalid Restricted Column" msgstr "無效的限制列" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "Calibre-Web配置已更新" @@ -204,275 +204,275 @@ msgstr "標籤未找到" msgid "Invalid Action" msgstr "無效的動作" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "拒絕" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "允許" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "client_secrets.json 未為 Web 應用程序配置" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "日誌文件路徑無效,請輸入正確的路徑" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "訪問日誌路徑無效,請輸入正確的路徑" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "請輸入LDAP主機、端口、DN和用戶對象標識符" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "請輸入一個LDAP服務賬號和密碼 " -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "請輸入一個LDAP服務賬號" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "LDAP群組對象過濾器需要一個具有“%s”格式標識符號" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "LDAP群組對象過濾器的括號不匹配" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP用戶對象過濾器需要一個具有“%s”格式標識符" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "LDAP用戶對象過濾器的括號不匹配" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "LDAP成員用戶過濾器需要有一個“%s”格式標識符號" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "LDAP成員用戶過濾器中有不匹配的括號" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "LDAP CA證書、證書或密鑰位置無效,請輸入正確的路徑" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "設置數據庫不可寫入" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "數據庫路徑無效,請輸入正確的路徑" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "數據庫不可寫入" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "密鑰文件路徑無效,請輸入正確的路徑" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "證書文件路徑無效,請輸入正確的路徑" -#: cps/admin.py:1335 +#: cps/admin.py:1346 #, fuzzy msgid "Database Settings updated" msgstr "郵件服務器設置已更新" -#: cps/admin.py:1343 +#: cps/admin.py:1354 msgid "Database Configuration" msgstr "數據庫配置" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "請填寫所有欄位!" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "郵箱不在有效網域中" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "添加新用戶" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "用戶“%(user)s”已創建" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "使用此郵箱或用戶名的賬號已經存在。" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "用戶“%(nick)s”已刪除" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "無法刪除訪客用戶" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "管理員賬戶不存在,無法刪除用戶" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "編輯用戶 %(nick)s" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "用戶“%(nick)s”已更新" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "發生一個未知錯誤,請稍後再試。" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "編輯郵件服務器設置" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "G-Mail賬號驗證成功" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "發送給%(email)s的測試郵件已進入隊列。請檢查任務結果" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "發送測試郵件時出錯:%(res)s" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "請先配置您的郵箱地址..." -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "郵件服務器設置已更新" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "用戶 %(user)s 的密碼已重置" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "請先配置SMTP郵箱設置..." -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "日誌文件查看器" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "正在請求更新包" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "正在下載更新包" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "正在解壓更新包" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "正在替換文件" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "數據庫連接已關閉" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "正在停止服務器" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "更新完成,請點擊確定並刷新頁面" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "更新失敗:" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "HTTP錯誤" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "連接錯誤" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "建立連接超時" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "一般錯誤" -#: cps/admin.py:1720 +#: cps/admin.py:1731 #, fuzzy msgid "Update file could not be saved in temp dir" msgstr "更新文件無法保存在臨時目錄中" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "更新時檔案無法替換變更" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "未能提取至少一個LDAP用戶" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "未能創建至少一個LDAP用戶" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "錯誤:%(ldaperror)s" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "錯誤:在LDAP服務器的響應中沒有返回用戶" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "數據庫中沒有找到至少一個LDAP用戶" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "{} 用戶被成功導入" @@ -1331,7 +1331,7 @@ msgstr "找不到轉換後的文件或文件夾%(folder)s中有多個文件" msgid "Ebook-converter failed: %(error)s" msgstr "電子書轉換器失敗: %(error)s" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "Calibre 運行失敗,錯誤信息:%(error)s" @@ -2567,7 +2567,7 @@ msgstr "錯誤" msgid "Upload done, processing, please wait..." msgstr "上傳完成,正在處理中,請稍候..." -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "設置" @@ -2716,7 +2716,7 @@ msgstr "Caliebre-Web電子書路徑" msgid "epub Reader" msgstr "epub閱讀器" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "打開側欄時重排文本。" diff --git a/messages.pot b/messages.pot index 5588247f..15027461 100644 --- a/messages.pot +++ b/messages.pot @@ -8,14 +8,14 @@ msgid "" msgstr "" "Project-Id-Version: PROJECT VERSION\n" "Report-Msgid-Bugs-To: EMAIL@ADDRESS\n" -"POT-Creation-Date: 2021-12-14 17:51+0100\n" +"POT-Creation-Date: 2021-12-22 19:06+0100\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=utf-8\n" "Content-Transfer-Encoding: 8bit\n" -"Generated-By: Babel 2.9.0\n" +"Generated-By: Babel 2.8.0\n" #: cps/about.py:34 cps/about.py:49 cps/about.py:65 cps/converter.py:31 msgid "not installed" @@ -74,7 +74,7 @@ msgstr "" msgid "All" msgstr "" -#: cps/admin.py:343 cps/admin.py:1595 +#: cps/admin.py:343 cps/admin.py:1606 msgid "User not found" msgstr "" @@ -91,7 +91,7 @@ msgstr "" msgid "Malformed request" msgstr "" -#: cps/admin.py:418 cps/admin.py:1473 +#: cps/admin.py:418 cps/admin.py:1484 msgid "Guest Name can't be changed" msgstr "" @@ -99,7 +99,7 @@ msgstr "" msgid "Guest can't have this role" msgstr "" -#: cps/admin.py:442 cps/admin.py:1431 +#: cps/admin.py:442 cps/admin.py:1442 msgid "No admin user remaining, can't remove admin role" msgstr "" @@ -143,7 +143,7 @@ msgstr "" msgid "Invalid Restricted Column" msgstr "" -#: cps/admin.py:560 cps/admin.py:1312 +#: cps/admin.py:560 cps/admin.py:1323 msgid "Calibre-Web configuration updated" msgstr "" @@ -203,273 +203,273 @@ msgstr "" msgid "Invalid Action" msgstr "" -#: cps/admin.py:860 cps/admin.py:866 cps/admin.py:876 cps/admin.py:886 +#: cps/admin.py:871 cps/admin.py:877 cps/admin.py:887 cps/admin.py:897 #: cps/templates/modal_dialogs.html:29 cps/templates/user_table.html:41 #: cps/templates/user_table.html:58 msgid "Deny" msgstr "" -#: cps/admin.py:862 cps/admin.py:868 cps/admin.py:878 cps/admin.py:888 +#: cps/admin.py:873 cps/admin.py:879 cps/admin.py:889 cps/admin.py:899 #: cps/templates/modal_dialogs.html:28 cps/templates/user_table.html:44 #: cps/templates/user_table.html:61 msgid "Allow" msgstr "" -#: cps/admin.py:902 +#: cps/admin.py:913 msgid "{} sync entries deleted" msgstr "" -#: cps/admin.py:1025 +#: cps/admin.py:1036 msgid "client_secrets.json Is Not Configured For Web Application" msgstr "" -#: cps/admin.py:1070 +#: cps/admin.py:1081 msgid "Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1076 +#: cps/admin.py:1087 msgid "Access Logfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1106 +#: cps/admin.py:1117 msgid "Please Enter a LDAP Provider, Port, DN and User Object Identifier" msgstr "" -#: cps/admin.py:1112 +#: cps/admin.py:1123 msgid "Please Enter a LDAP Service Account and Password" msgstr "" -#: cps/admin.py:1115 +#: cps/admin.py:1126 msgid "Please Enter a LDAP Service Account" msgstr "" -#: cps/admin.py:1120 +#: cps/admin.py:1131 #, python-format msgid "LDAP Group Object Filter Needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1122 +#: cps/admin.py:1133 msgid "LDAP Group Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1126 +#: cps/admin.py:1137 #, python-format msgid "LDAP User Object Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1128 +#: cps/admin.py:1139 msgid "LDAP User Object Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1135 +#: cps/admin.py:1146 #, python-format msgid "LDAP Member User Filter needs to Have One \"%s\" Format Identifier" msgstr "" -#: cps/admin.py:1137 +#: cps/admin.py:1148 msgid "LDAP Member User Filter Has Unmatched Parenthesis" msgstr "" -#: cps/admin.py:1144 +#: cps/admin.py:1155 msgid "LDAP CACertificate, Certificate or Key Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1186 cps/admin.py:1297 cps/admin.py:1394 cps/admin.py:1501 -#: cps/admin.py:1570 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 +#: cps/admin.py:1197 cps/admin.py:1308 cps/admin.py:1405 cps/admin.py:1512 +#: cps/admin.py:1581 cps/shelf.py:100 cps/shelf.py:160 cps/shelf.py:203 #: cps/shelf.py:274 cps/shelf.py:335 cps/shelf.py:370 cps/shelf.py:445 msgid "Settings DB is not Writeable" msgstr "" -#: cps/admin.py:1197 +#: cps/admin.py:1208 msgid "DB Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1212 +#: cps/admin.py:1223 msgid "DB is not Writeable" msgstr "" -#: cps/admin.py:1224 +#: cps/admin.py:1235 msgid "Keyfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1228 +#: cps/admin.py:1239 msgid "Certfile Location is not Valid, Please Enter Correct Path" msgstr "" -#: cps/admin.py:1335 +#: cps/admin.py:1346 msgid "Database Settings updated" msgstr "" -#: cps/admin.py:1343 +#: cps/admin.py:1354 msgid "Database Configuration" msgstr "" -#: cps/admin.py:1359 cps/web.py:1478 +#: cps/admin.py:1370 cps/web.py:1478 msgid "Please fill out all fields!" msgstr "" -#: cps/admin.py:1367 +#: cps/admin.py:1378 msgid "E-mail is not from valid domain" msgstr "" -#: cps/admin.py:1373 cps/admin.py:1523 +#: cps/admin.py:1384 cps/admin.py:1534 msgid "Add new user" msgstr "" -#: cps/admin.py:1384 +#: cps/admin.py:1395 #, python-format msgid "User '%(user)s' created" msgstr "" -#: cps/admin.py:1390 +#: cps/admin.py:1401 msgid "Found an existing account for this e-mail address or name." msgstr "" -#: cps/admin.py:1410 +#: cps/admin.py:1421 #, python-format msgid "User '%(nick)s' deleted" msgstr "" -#: cps/admin.py:1412 cps/admin.py:1413 +#: cps/admin.py:1423 cps/admin.py:1424 msgid "Can't delete Guest User" msgstr "" -#: cps/admin.py:1416 +#: cps/admin.py:1427 msgid "No admin user remaining, can't delete user" msgstr "" -#: cps/admin.py:1489 cps/admin.py:1614 +#: cps/admin.py:1500 cps/admin.py:1625 #, python-format msgid "Edit User %(nick)s" msgstr "" -#: cps/admin.py:1493 +#: cps/admin.py:1504 #, python-format msgid "User '%(nick)s' updated" msgstr "" -#: cps/admin.py:1497 cps/admin.py:1629 cps/web.py:1503 cps/web.py:1563 +#: cps/admin.py:1508 cps/admin.py:1640 cps/web.py:1503 cps/web.py:1563 msgid "An unknown error occurred. Please try again later." msgstr "" -#: cps/admin.py:1532 cps/templates/admin.html:98 +#: cps/admin.py:1543 cps/templates/admin.html:98 msgid "Edit E-mail Server Settings" msgstr "" -#: cps/admin.py:1551 +#: cps/admin.py:1562 msgid "Gmail Account Verification Successful" msgstr "" -#: cps/admin.py:1577 +#: cps/admin.py:1588 #, python-format msgid "Test e-mail queued for sending to %(email)s, please check Tasks for result" msgstr "" -#: cps/admin.py:1580 +#: cps/admin.py:1591 #, python-format msgid "There was an error sending the Test e-mail: %(res)s" msgstr "" -#: cps/admin.py:1582 +#: cps/admin.py:1593 msgid "Please configure your e-mail address first..." msgstr "" -#: cps/admin.py:1584 +#: cps/admin.py:1595 msgid "E-mail server settings updated" msgstr "" -#: cps/admin.py:1626 +#: cps/admin.py:1637 #, python-format msgid "Password for user %(user)s reset" msgstr "" -#: cps/admin.py:1632 cps/web.py:1443 +#: cps/admin.py:1643 cps/web.py:1443 msgid "Please configure the SMTP mail settings first..." msgstr "" -#: cps/admin.py:1643 +#: cps/admin.py:1654 msgid "Logfile viewer" msgstr "" -#: cps/admin.py:1709 +#: cps/admin.py:1720 msgid "Requesting update package" msgstr "" -#: cps/admin.py:1710 +#: cps/admin.py:1721 msgid "Downloading update package" msgstr "" -#: cps/admin.py:1711 +#: cps/admin.py:1722 msgid "Unzipping update package" msgstr "" -#: cps/admin.py:1712 +#: cps/admin.py:1723 msgid "Replacing files" msgstr "" -#: cps/admin.py:1713 +#: cps/admin.py:1724 msgid "Database connections are closed" msgstr "" -#: cps/admin.py:1714 +#: cps/admin.py:1725 msgid "Stopping server" msgstr "" -#: cps/admin.py:1715 +#: cps/admin.py:1726 msgid "Update finished, please press okay and reload page" msgstr "" -#: cps/admin.py:1716 cps/admin.py:1717 cps/admin.py:1718 cps/admin.py:1719 -#: cps/admin.py:1720 cps/admin.py:1721 +#: cps/admin.py:1727 cps/admin.py:1728 cps/admin.py:1729 cps/admin.py:1730 +#: cps/admin.py:1731 cps/admin.py:1732 msgid "Update failed:" msgstr "" -#: cps/admin.py:1716 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 +#: cps/admin.py:1727 cps/updater.py:385 cps/updater.py:595 cps/updater.py:597 msgid "HTTP Error" msgstr "" -#: cps/admin.py:1717 cps/updater.py:387 cps/updater.py:599 +#: cps/admin.py:1728 cps/updater.py:387 cps/updater.py:599 msgid "Connection error" msgstr "" -#: cps/admin.py:1718 cps/updater.py:389 cps/updater.py:601 +#: cps/admin.py:1729 cps/updater.py:389 cps/updater.py:601 msgid "Timeout while establishing connection" msgstr "" -#: cps/admin.py:1719 cps/updater.py:391 cps/updater.py:603 +#: cps/admin.py:1730 cps/updater.py:391 cps/updater.py:603 msgid "General error" msgstr "" -#: cps/admin.py:1720 +#: cps/admin.py:1731 msgid "Update file could not be saved in temp dir" msgstr "" -#: cps/admin.py:1721 +#: cps/admin.py:1732 msgid "Files could not be replaced during update" msgstr "" -#: cps/admin.py:1745 +#: cps/admin.py:1756 msgid "Failed to extract at least One LDAP User" msgstr "" -#: cps/admin.py:1790 +#: cps/admin.py:1801 msgid "Failed to Create at Least One LDAP User" msgstr "" -#: cps/admin.py:1803 +#: cps/admin.py:1814 #, python-format msgid "Error: %(ldaperror)s" msgstr "" -#: cps/admin.py:1807 +#: cps/admin.py:1818 msgid "Error: No user returned in response of LDAP server" msgstr "" -#: cps/admin.py:1840 +#: cps/admin.py:1851 msgid "At Least One LDAP User Not Found in Database" msgstr "" -#: cps/admin.py:1842 +#: cps/admin.py:1853 msgid "{} User Successfully Imported" msgstr "" @@ -1328,7 +1328,7 @@ msgstr "" msgid "Ebook-converter failed: %(error)s" msgstr "" -#: cps/tasks/convert.py:241 +#: cps/tasks/convert.py:245 #, python-format msgid "Calibre failed with error: %(error)s" msgstr "" @@ -2559,7 +2559,7 @@ msgstr "" msgid "Upload done, processing, please wait..." msgstr "" -#: cps/templates/layout.html:76 cps/templates/read.html:71 +#: cps/templates/layout.html:76 cps/templates/read.html:72 #: cps/templates/readcbr.html:84 cps/templates/readcbr.html:108 msgid "Settings" msgstr "" @@ -2708,7 +2708,7 @@ msgstr "" msgid "epub Reader" msgstr "" -#: cps/templates/read.html:74 +#: cps/templates/read.html:75 msgid "Reflow text when sidebars are open." msgstr "" From bdedec90dd8df032cbc666a26618f17bcde3b6ea Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Thu, 23 Dec 2021 11:13:08 +0100 Subject: [PATCH 03/45] Catch more Gdrive errors (#2233) --- cps/gdrive.py | 2 +- cps/gdriveutils.py | 7 +++++++ cps/helper.py | 4 ++-- 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/cps/gdrive.py b/cps/gdrive.py index 6ca73ca9..e782cb9e 100644 --- a/cps/gdrive.py +++ b/cps/gdrive.py @@ -109,7 +109,7 @@ def revoke_watch_gdrive(): try: gdriveutils.stopChannel(gdriveutils.Gdrive.Instance().drive, last_watch_response['id'], last_watch_response['resourceId']) - except HttpError: + except (HttpError, AttributeError): pass config.config_google_drive_watch_changes_response = {} config.save() diff --git a/cps/gdriveutils.py b/cps/gdriveutils.py index 878c1f9f..c4445944 100644 --- a/cps/gdriveutils.py +++ b/cps/gdriveutils.py @@ -56,11 +56,13 @@ try: from pydrive2.auth import GoogleAuth from pydrive2.drive import GoogleDrive from pydrive2.auth import RefreshError + from pydrive2.files import ApiRequestError except ImportError as err: try: from pydrive.auth import GoogleAuth from pydrive.drive import GoogleDrive from pydrive.auth import RefreshError + from pydrive.files import ApiRequestError except ImportError as err: importError = err gdrive_support = False @@ -322,6 +324,11 @@ def getFolderId(path, drive): log.error("gdrive.db DB is not Writeable") log.debug('Database error: %s', ex) session.rollback() + except ApiRequestError as ex: + log.error('{} {}'.format(ex.error['message'], path)) + session.rollback() + except RefreshError as ex: + log.error(ex) return currentFolderId diff --git a/cps/helper.py b/cps/helper.py index e4305550..b8499a12 100644 --- a/cps/helper.py +++ b/cps/helper.py @@ -673,9 +673,9 @@ def save_cover(img, book_path): def do_download_file(book, book_format, client, data, headers): if config.config_use_google_drive: - startTime = time.time() + #startTime = time.time() df = gd.getFileFromEbooksFolder(book.path, data.name + "." + book_format) - log.debug('%s', time.time() - startTime) + #log.debug('%s', time.time() - startTime) if df: return gd.do_gdrive_download(df, headers) else: From ec73558b035e866442732074b717f00b729ae514 Mon Sep 17 00:00:00 2001 From: Ozzie Isaacs Date: Thu, 23 Dec 2021 19:14:21 +0100 Subject: [PATCH 04/45] Bugfix advanced search for language Update results from testrun --- cps/db.py | 17 +- test/Calibre-Web TestSummary_Linux.html | 740 ++++++++++-------------- 2 files changed, 313 insertions(+), 444 deletions(-) diff --git a/cps/db.py b/cps/db.py index 4b0a7ac7..9c5b5657 100644 --- a/cps/db.py +++ b/cps/db.py @@ -796,23 +796,24 @@ class CalibreDB(): def speaking_language(self, languages=None, return_all_languages=False, with_count=False, reverse_order=False): from . import get_locale - if not languages: - if with_count: + if with_count: + if not languages: languages = self.session.query(Languages, func.count('books_languages_link.book'))\ .join(books_languages_link).join(Books)\ .filter(self.common_filters(return_all_languages=return_all_languages)) \ .group_by(text('books_languages_link.lang_code')).all() - for lang in languages: - lang[0].name = isoLanguages.get_language_name(get_locale(), lang[0].lang_code) - return sorted(languages, key=lambda x: x[0].name, reverse=reverse_order) - else: + for lang in languages: + lang[0].name = isoLanguages.get_language_name(get_locale(), lang[0].lang_code) + return sorted(languages, key=lambda x: x[0].name, reverse=reverse_order) + else: + if not languages: languages = self.session.query(Languages) \ .join(books_languages_link) \ .join(Books) \ .filter(self.common_filters(return_all_languages=return_all_languages)) \ .group_by(text('books_languages_link.lang_code')).all() - for lang in languages: - lang.name = isoLanguages.get_language_name(get_locale(), lang.lang_code) + for lang in languages: + lang.name = isoLanguages.get_language_name(get_locale(), lang.lang_code) return sorted(languages, key=lambda x: x.name, reverse=reverse_order) diff --git a/test/Calibre-Web TestSummary_Linux.html b/test/Calibre-Web TestSummary_Linux.html index 3c54e88b..d291d368 100644 --- a/test/Calibre-Web TestSummary_Linux.html +++ b/test/Calibre-Web TestSummary_Linux.html @@ -37,20 +37,20 @@
-

Start Time: 2021-12-05 19:18:28

+

Start Time: 2021-12-22 20:24:40

-

Stop Time: 2021-12-05 22:58:48

+

Stop Time: 2021-12-23 00:00:41

-

Duration: 3h 0 min

+

Duration: 2h 57 min

@@ -705,11 +705,11 @@ - + TestEditAdditionalBooks 16 - 14 - 0 + 13 + 1 0 2 @@ -844,11 +844,31 @@ - +
TestEditAdditionalBooks - test_writeonly_path
- PASS + +
+ FAIL +
+ + + + @@ -881,11 +901,11 @@ - + TestEditBooks 35 - 34 - 0 + 32 + 2 0 1 @@ -904,11 +924,31 @@ - +
TestEditBooks - test_edit_author
- PASS + +
+ FAIL +
+ + + + @@ -1057,11 +1097,31 @@ - +
TestEditBooks - test_edit_title
- PASS + +
+ FAIL +
+ + + + @@ -1405,11 +1465,11 @@ - + TestEditBooksOnGdrive 20 - 20 - 0 + 18 + 2 0 0 @@ -1428,11 +1488,31 @@ - +
TestEditBooksOnGdrive - test_edit_author
- PASS + +
+ FAIL +
+ + + + @@ -1554,11 +1634,31 @@ - +
TestEditBooksOnGdrive - test_edit_title
- PASS + +
+ FAIL +
+ + + + @@ -1858,11 +1958,11 @@ - + TestKoboSync 11 - 2 - 9 + 11 + 0 0 0 @@ -1872,35 +1972,11 @@ - +
TestKoboSync - test_book_download
- -
- FAIL -
- - - - + PASS @@ -1914,134 +1990,38 @@ AssertionError: {'Benefits': {}} != {} - +
TestKoboSync - test_kobo_sync_selected_shelfs
- -
- FAIL -
- - - - + PASS - +
TestKoboSync - test_kobo_upload_book
- -
- FAIL -
- - - - + PASS - +
TestKoboSync - test_shelves_add_remove_books
- -
- FAIL -
- - - - + PASS - +
TestKoboSync - test_sync_changed_book
- -
- FAIL -
- - - - + PASS @@ -2055,144 +2035,48 @@ AssertionError: {'Benefits': {}} != {} - +
TestKoboSync - test_sync_reading_state
- -
- FAIL -
- - - - + PASS - +
TestKoboSync - test_sync_shelf
- -
- FAIL -
- - - - + PASS - +
TestKoboSync - test_sync_unchanged
- -
- FAIL -
- - - - + PASS - +
TestKoboSync - test_sync_upload
- -
- FAIL -
- - - - + PASS - + TestKoboSyncBig 5 - 1 - 4 + 5 + 0 0 0 @@ -2211,134 +2095,38 @@ AssertionError: {'Benefits': {}} != {} - +
TestKoboSyncBig - test_kobo_sync_selected_shelfs
- -
- FAIL -
- - - - + PASS - +
TestKoboSyncBig - test_sync_changed_book
- -
- FAIL -
- - - - + PASS - +
TestKoboSyncBig - test_sync_reading_state
- -
- FAIL -
- - - - + PASS - +
TestKoboSyncBig - test_sync_shelf
- -
- FAIL -
- - - - + PASS @@ -4377,11 +4165,11 @@ AssertionError: 0 != 1 - + TestCalibreHelper 16 - 16 - 0 + 11 + 5 0 0 @@ -4454,29 +4242,95 @@ AssertionError: 0 != 1 - +
TestCalibreHelper - test_check_chinese_Characters
- PASS + +
+ FAIL +
+ + + + - +
TestCalibreHelper - test_check_deg_eur_replacement
- PASS + +
+ FAIL +
+ + + + - +
TestCalibreHelper - test_check_doubleS
- PASS + +
+ FAIL +
+ + + + @@ -4490,20 +4344,64 @@ AssertionError: 0 != 1 - +
TestCalibreHelper - test_check_high23
- PASS + +
+ FAIL +
+ + + + - +
TestCalibreHelper - test_check_umlauts
- PASS + +
+ FAIL +
+ + + + @@ -4538,8 +4436,8 @@ AssertionError: 0 != 1 Total 378 - 358 - 14 + 361 + 11 0 6   @@ -4581,7 +4479,7 @@ AssertionError: 0 != 1 Babel - 2.9.0 + 2.9.1 Basic @@ -4593,13 +4491,13 @@ AssertionError: 0 != 1 Flask - 1.1.2 + 2.0.2 Basic Flask-Babel - 1.0.0 + 2.0.0 Basic @@ -4627,12 +4525,6 @@ AssertionError: 0 != 1 Basic - - httplib2 - 0.14.0 - Basic - - iso-639 0.4.5 @@ -4641,25 +4533,13 @@ AssertionError: 0 != 1 Jinja2 - 2.11.2 + 3.0.3 Basic lxml - 4.6.3 - Basic - - - - natsort - 7.1.0 - Basic - - - - pyasn1 - 0.4.8 + 4.6.5 Basic @@ -4671,31 +4551,19 @@ AssertionError: 0 != 1 pytz - 2019.3 - Basic - - - - PyYAML - 5.3.1 + 2021.3 Basic requests - 2.22.0 - Basic - - - - six - 1.14.0 + 2.24.0 Basic SQLAlchemy - 1.4.27 + 1.4.28 Basic @@ -4707,7 +4575,7 @@ AssertionError: 0 != 1 Unidecode - 1.1.1 + 1.2.0 Basic @@ -4719,13 +4587,13 @@ AssertionError: 0 != 1 Werkzeug - 1.0.1 + 2.0.2 Basic google-api-python-client - 2.32.0 + 2.33.0 TestCliGdrivedb @@ -4749,13 +4617,13 @@ AssertionError: 0 != 1 PyYAML - 5.3.1 + 6.0 TestCliGdrivedb google-api-python-client - 2.32.0 + 2.33.0 TestEbookConvertCalibreGDrive @@ -4779,13 +4647,13 @@ AssertionError: 0 != 1 PyYAML - 5.3.1 + 6.0 TestEbookConvertCalibreGDrive google-api-python-client - 2.32.0 + 2.33.0 TestEbookConvertGDriveKepubify @@ -4809,7 +4677,7 @@ AssertionError: 0 != 1 PyYAML - 5.3.1 + 6.0 TestEbookConvertGDriveKepubify @@ -4827,7 +4695,7 @@ AssertionError: 0 != 1 google-api-python-client - 2.32.0 + 2.33.0 TestEditBooksOnGdrive @@ -4851,13 +4719,13 @@ AssertionError: 0 != 1 PyYAML - 5.3.1 + 6.0 TestEditBooksOnGdrive google-api-python-client - 2.32.0 + 2.33.0 TestSetupGdrive @@ -4881,7 +4749,7 @@ AssertionError: 0 != 1 PyYAML - 5.3.1 + 6.0 TestSetupGdrive @@ -4899,13 +4767,13 @@ AssertionError: 0 != 1 jsonschema - 4.2.1 + 4.3.2 TestKoboSync jsonschema - 4.2.1 + 4.3.2 TestKoboSyncBig @@ -4917,7 +4785,7 @@ AssertionError: 0 != 1 jsonschema - 4.2.1 + 4.3.2 TestLdapLogin @@ -4935,7 +4803,7 @@ AssertionError: 0 != 1 SQLAlchemy-Utils - 0.37.9 + 0.38.1 TestOAuthLogin @@ -4947,7 +4815,7 @@ AssertionError: 0 != 1 From 222929e7413f97c4b81b093d1f21a8586d5c605d Mon Sep 17 00:00:00 2001 From: cbartondock Date: Thu, 23 Dec 2021 18:05:20 -0500 Subject: [PATCH 05/45] Fixed extra s in scholar metadata --- cps/metadata_provider/scholar.py | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/cps/metadata_provider/scholar.py b/cps/metadata_provider/scholar.py index 6e13c768..9aa0ab87 100644 --- a/cps/metadata_provider/scholar.py +++ b/cps/metadata_provider/scholar.py @@ -19,20 +19,23 @@ from scholarly import scholarly from cps.services.Metadata import Metadata - +import pprint +pp = pprint.PrettyPrinter(indent=4) class scholar(Metadata): __name__ = "Google Scholar" __id__ = "googlescholar" - def search(self, query, generic_cover=""): + def search(self, query, generic_cover=None): val = list() if self.active: scholar_gen = scholarly.search_pubs(' '.join(query.split('+'))) i = 0 for publication in scholar_gen: + print(f"PUBLICATION {i + 1}") + pp.pprint(publication) v = dict() - v['id'] = "1234" # publication['bib'].get('title') + v['id'] = publication['url_scholarbib'].split(':')[1] v['title'] = publication['bib'].get('title') v['authors'] = publication['bib'].get('author', []) v['description'] = publication['bib'].get('abstract', "") @@ -41,8 +44,8 @@ class scholar(Metadata): v['publishedDate'] = publication['bib'].get('pub_year')+"-01-01" else: v['publishedDate'] = "" - v['tags'] = "" - v['ratings'] = 0 + v['tags'] = [] + v['rating'] = 0 v['series'] = "" v['cover'] = generic_cover v['url'] = publication.get('pub_url') or publication.get('eprint_url') or "", @@ -55,6 +58,7 @@ class scholar(Metadata): i += 1 if (i >= 10): break + pp.pprint(val) return val From 4edd1914b4d2b90a826b199167ca55e34258b7c4 Mon Sep 17 00:00:00 2001 From: cbartondock Date: Thu, 23 Dec 2021 23:16:41 -0500 Subject: [PATCH 06/45] Fixed google scholar issues --- cps/metadata_provider/scholar.py | 7 +------ cps/search_metadata.py | 4 ++-- cps/static/js/get_meta.js | 4 +--- 3 files changed, 4 insertions(+), 11 deletions(-) diff --git a/cps/metadata_provider/scholar.py b/cps/metadata_provider/scholar.py index 9aa0ab87..5ff078b9 100644 --- a/cps/metadata_provider/scholar.py +++ b/cps/metadata_provider/scholar.py @@ -19,21 +19,17 @@ from scholarly import scholarly from cps.services.Metadata import Metadata -import pprint -pp = pprint.PrettyPrinter(indent=4) class scholar(Metadata): __name__ = "Google Scholar" __id__ = "googlescholar" - def search(self, query, generic_cover=None): + def search(self, query, generic_cover=""): val = list() if self.active: scholar_gen = scholarly.search_pubs(' '.join(query.split('+'))) i = 0 for publication in scholar_gen: - print(f"PUBLICATION {i + 1}") - pp.pprint(publication) v = dict() v['id'] = publication['url_scholarbib'].split(':')[1] v['title'] = publication['bib'].get('title') @@ -58,7 +54,6 @@ class scholar(Metadata): i += 1 if (i >= 10): break - pp.pprint(val) return val diff --git a/cps/search_metadata.py b/cps/search_metadata.py index e837fe21..b88f222f 100644 --- a/cps/search_metadata.py +++ b/cps/search_metadata.py @@ -103,9 +103,9 @@ def metadata_search(): data = list() active = current_user.view_settings.get('metadata', {}) if query: - static_cover = url_for('static', filename='generic_cover.jpg') + generic_cover = "" with concurrent.futures.ThreadPoolExecutor(max_workers=5) as executor: - meta = {executor.submit(c.search, query, static_cover): c for c in cl if active.get(c.__id__, True)} + meta = {executor.submit(c.search, query, generic_cover): c for c in cl if active.get(c.__id__, True)} for future in concurrent.futures.as_completed(meta): data.extend(future.result()) return Response(json.dumps(data), mimetype='application/json') diff --git a/cps/static/js/get_meta.js b/cps/static/js/get_meta.js index 51ab740d..2ad4d53b 100644 --- a/cps/static/js/get_meta.js +++ b/cps/static/js/get_meta.js @@ -40,7 +40,7 @@ $(function () { $("#book_title").val(book.title); $("#tags").val(uniqueTags.join(", ")); $("#rating").data("rating").setValue(Math.round(book.rating)); - if(book.cover !== null){ + if(book.cover){ $(".cover img").attr("src", book.cover); $("#cover_url").val(book.cover); } @@ -128,9 +128,7 @@ $(function () { e.preventDefault(); keyword = $("#keyword").val(); $('.pill').each(function(){ - // console.log($(this).data('control')); $(this).data("initial", $(this).prop('checked')); - // console.log($(this).data('initial')); }); doSearch(keyword); }); From 785726deee13b4d56f6c3503dd57c1e3eb7d6f30 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Sat, 25 Dec 2021 10:09:11 +0100 Subject: [PATCH 07/45] Migrated some routes to POST - delete shelf, import ldap users - delete_kobo token, kobo force full sync - shutdown, reconnect, shutdown --- cps/admin.py | 10 +++++----- cps/editbooks.py | 17 ++++++----------- cps/kobo_auth.py | 8 ++------ cps/shelf.py | 9 +++++---- cps/static/js/main.js | 29 ++++++++++++++++++----------- cps/templates/shelf.html | 22 ++++------------------ cps/web.py | 5 +++-- 7 files changed, 43 insertions(+), 57 deletions(-) diff --git a/cps/admin.py b/cps/admin.py index 1c228e49..29f5fb20 100644 --- a/cps/admin.py +++ b/cps/admin.py @@ -129,11 +129,11 @@ def admin_forbidden(): abort(403) -@admi.route("/shutdown") +@admi.route("/shutdown", methods=["POST"]) @login_required @admin_required def shutdown(): - task = int(request.args.get("parameter").strip()) + task = request.get_json().get('parameter', -1) showtext = {} if task in (0, 1): # valid commandos received # close all database connections @@ -906,7 +906,7 @@ def list_restriction(res_type, user_id): response.headers["Content-Type"] = "application/json; charset=utf-8" return response -@admi.route("/ajax/fullsync") +@admi.route("/ajax/fullsync", methods=["POST"]) @login_required def ajax_fullsync(): count = ub.session.query(ub.KoboSyncedBooks).filter(current_user.id == ub.KoboSyncedBooks.user_id).delete() @@ -1626,7 +1626,7 @@ def edit_user(user_id): page="edituser") -@admi.route("/admin/resetpassword/") +@admi.route("/admin/resetpassword/", methods=["POST"]) @login_required @admin_required def reset_user_password(user_id): @@ -1802,7 +1802,7 @@ def ldap_import_create_user(user, user_data): return 0, message -@admi.route('/import_ldap_users') +@admi.route('/import_ldap_users', methods=["POST"]) @login_required @admin_required def import_ldap_users(): diff --git a/cps/editbooks.py b/cps/editbooks.py index 21dc3ba0..b6fdc164 100644 --- a/cps/editbooks.py +++ b/cps/editbooks.py @@ -26,6 +26,8 @@ import json from shutil import copyfile from uuid import uuid4 from markupsafe import escape +from functools import wraps + try: from lxml.html.clean import clean_html except ImportError: @@ -51,13 +53,6 @@ from .tasks.upload import TaskUpload from .render_template import render_title_template from .usermanagement import login_required_if_no_ano -try: - from functools import wraps -except ImportError: - pass # We're not using Python 3 - - - editbook = Blueprint('editbook', __name__) log = logger.create() @@ -237,14 +232,14 @@ def modify_identifiers(input_identifiers, db_identifiers, db_session): changed = True return changed, error -@editbook.route("/ajax/delete/") +@editbook.route("/ajax/delete/", methods=["POST"]) @login_required def delete_book_from_details(book_id): return Response(delete_book_from_table(book_id, "", True), mimetype='application/json') -@editbook.route("/delete/", defaults={'book_format': ""}) -@editbook.route("/delete//") +@editbook.route("/delete/", defaults={'book_format': ""}, methods=["POST"]) +@editbook.route("/delete//", methods=["POST"]) @login_required def delete_book_ajax(book_id, book_format): return delete_book_from_table(book_id, book_format, False) @@ -1014,7 +1009,7 @@ def move_coverfile(meta, db_book): category="error") -@editbook.route("/upload", methods=["GET", "POST"]) +@editbook.route("/upload", methods=["POST"]) @login_required_if_no_ano @upload_required def upload(): diff --git a/cps/kobo_auth.py b/cps/kobo_auth.py index a51095c8..8d46b26a 100644 --- a/cps/kobo_auth.py +++ b/cps/kobo_auth.py @@ -62,6 +62,7 @@ particular calls to non-Kobo specific endpoints such as the CalibreWeb book down from binascii import hexlify from datetime import datetime from os import urandom +from functools import wraps from flask import g, Blueprint, url_for, abort, request from flask_login import login_user, current_user, login_required @@ -70,11 +71,6 @@ from flask_babel import gettext as _ from . import logger, config, calibre_db, db, helper, ub, lm from .render_template import render_title_template -try: - from functools import wraps -except ImportError: - pass # We're not using Python 3 - log = logger.create() @@ -167,7 +163,7 @@ def generate_auth_token(user_id): ) -@kobo_auth.route("/deleteauthtoken/") +@kobo_auth.route("/deleteauthtoken/", methods=["POST"]) @login_required def delete_auth_token(user_id): # Invalidate any prevously generated Kobo Auth token for this user. diff --git a/cps/shelf.py b/cps/shelf.py index 5f6a66bf..19c2d68e 100644 --- a/cps/shelf.py +++ b/cps/shelf.py @@ -56,7 +56,7 @@ def check_shelf_view_permissions(cur_shelf): return True -@shelf.route("/shelf/add//") +@shelf.route("/shelf/add//", methods=["POST"]) @login_required def add_to_shelf(shelf_id, book_id): xhr = request.headers.get('X-Requested-With') == 'XMLHttpRequest' @@ -112,7 +112,7 @@ def add_to_shelf(shelf_id, book_id): return "", 204 -@shelf.route("/shelf/massadd/") +@shelf.route("/shelf/massadd/", methods=["POST"]) @login_required def search_to_shelf(shelf_id): shelf = ub.session.query(ub.Shelf).filter(ub.Shelf.id == shelf_id).first() @@ -164,7 +164,7 @@ def search_to_shelf(shelf_id): return redirect(url_for('web.index')) -@shelf.route("/shelf/remove//") +@shelf.route("/shelf/remove//", methods=["POST"]) @login_required def remove_from_shelf(shelf_id, book_id): xhr = request.headers.get('X-Requested-With') == 'XMLHttpRequest' @@ -323,12 +323,13 @@ def delete_shelf_helper(cur_shelf): ub.session_commit("successfully deleted Shelf {}".format(cur_shelf.name)) -@shelf.route("/shelf/delete/") +@shelf.route("/shelf/delete/", methods=["POST"]) @login_required def delete_shelf(shelf_id): cur_shelf = ub.session.query(ub.Shelf).filter(ub.Shelf.id == shelf_id).first() try: delete_shelf_helper(cur_shelf) + flash(_("Shelf successfully deleted"), category="success") except InvalidRequestError: ub.session.rollback() log.error("Settings DB is not Writeable") diff --git a/cps/static/js/main.js b/cps/static/js/main.js index 585d2296..6cef22f8 100644 --- a/cps/static/js/main.js +++ b/cps/static/js/main.js @@ -179,7 +179,7 @@ $("#delete_confirm").click(function() { if (ajaxResponse) { path = getPath() + "/ajax/delete/" + deleteId; $.ajax({ - method:"get", + method:"post", url: path, timeout: 900, success:function(data) { @@ -376,9 +376,11 @@ $(function() { $("#restart").click(function() { $.ajax({ + method:"post", + contentType: "application/json; charset=utf-8", dataType: "json", - url: window.location.pathname + "/../../shutdown", - data: {"parameter":0}, + url: getPath() + "/shutdown", + data: JSON.stringify({"parameter":0}), success: function success() { $("#spinner").show(); setTimeout(restartTimer, 3000); @@ -387,9 +389,11 @@ $(function() { }); $("#shutdown").click(function() { $.ajax({ + method:"post", + contentType: "application/json; charset=utf-8", dataType: "json", - url: window.location.pathname + "/../../shutdown", - data: {"parameter":1}, + url: getPath() + "/shutdown", + data: JSON.stringify({"parameter":1}), success: function success(data) { return alert(data.text); } @@ -447,9 +451,11 @@ $(function() { $("#DialogContent").html(""); $("#spinner2").show(); $.ajax({ + method:"post", + contentType: "application/json; charset=utf-8", dataType: "json", url: getPath() + "/shutdown", - data: {"parameter":2}, + data: JSON.stringify({"parameter":2}), success: function success(data) { $("#spinner2").hide(); $("#DialogContent").html(data.text); @@ -527,7 +533,7 @@ $(function() { $(this).data('value'), function (value) { $.ajax({ - method: "get", + method: "post", url: getPath() + "/kobo_auth/deleteauthtoken/" + value, }); $("#config_delete_kobo_token").hide(); @@ -574,7 +580,7 @@ $(function() { function(value){ path = getPath() + "/ajax/fullsync" $.ajax({ - method:"get", + method:"post", url: path, timeout: 900, success:function(data) { @@ -638,7 +644,7 @@ $(function() { else { $("#InvalidDialog").modal('show'); } - } else { + } else { changeDbSettings(); } } @@ -685,7 +691,7 @@ $(function() { "GeneralDeleteModal", $(this).data('value'), function(value){ - window.location.href = window.location.pathname + "/../../shelf/delete/" + value + $("#delete_shelf").closest("form").submit() } ); @@ -734,7 +740,8 @@ $(function() { $("#DialogContent").html(""); $("#spinner2").show(); $.ajax({ - method:"get", + method:"post", + contentType: "application/json; charset=utf-8", dataType: "json", url: getPath() + "/import_ldap_users", success: function success(data) { diff --git a/cps/templates/shelf.html b/cps/templates/shelf.html index 4f74a4da..5bb9317e 100644 --- a/cps/templates/shelf.html +++ b/cps/templates/shelf.html @@ -2,14 +2,16 @@ {% block body %}

{{title}}

+
{% if g.user.role_download() %} {{ _('Download') }} {% endif %} {% if g.user.is_authenticated %} {% if (g.user.role_edit_shelfs() and shelf.is_public ) or not shelf.is_public %} - -
{{ _('Delete this Shelf') }}
+ +
{{ _('Delete this Shelf') }}
{{ _('Edit Shelf Properties') }} +
{% if entries.__len__() %} {{ _('Arrange books manually') }} @@ -84,22 +86,6 @@ {% endfor %}
- - {% endblock %} {% block modal %} {{ delete_confirm_modal() }} diff --git a/cps/web.py b/cps/web.py index f203783b..81c37711 100644 --- a/cps/web.py +++ b/cps/web.py @@ -1055,7 +1055,8 @@ def get_tasks_status(): return render_title_template('tasks.html', entries=answer, title=_(u"Tasks"), page="tasks") -@app.route("/reconnect") +# method is available without login and not protected by CSRF to make it easy reachable +@app.route("/reconnect", methods=['GET']) def reconnect(): calibre_db.reconnect_db(config, ub.app_DB_path) return json.dumps({}) @@ -1435,7 +1436,7 @@ def download_link(book_id, book_format, anyname): return get_download_link(book_id, book_format, client) -@web.route('/send///') +@web.route('/send///', methods=["POST"]) @login_required @download_required def send_to_kindle(book_id, book_format, convert): From 573c9f9fb495f4408d31c8a272702a099fb463d4 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Sat, 25 Dec 2021 10:35:08 +0100 Subject: [PATCH 08/45] Improved logging (right stacklevel on mail exceptions) Updated jsonschema requirements --- cps/logger.py | 13 ++++--------- cps/tasks/mail.py | 12 ++++++------ optional-requirements.txt | 2 +- setup.cfg | 2 +- 4 files changed, 12 insertions(+), 17 deletions(-) diff --git a/cps/logger.py b/cps/logger.py index 5847188b..053d0bd3 100644 --- a/cps/logger.py +++ b/cps/logger.py @@ -42,20 +42,15 @@ logging.addLevelName(logging.CRITICAL, "CRIT") class _Logger(logging.Logger): - def debug_or_exception(self, message, *args, **kwargs): + def debug_or_exception(self, message, stacklevel=2, *args, **kwargs): if sys.version_info > (3, 7): if is_debug_enabled(): - self.exception(message, stacklevel=2, *args, **kwargs) + self.exception(message, stacklevel=stacklevel, *args, **kwargs) else: - self.error(message, stacklevel=2, *args, **kwargs) - elif sys.version_info > (3, 0): - if is_debug_enabled(): - self.exception(message, stack_info=True, *args, **kwargs) - else: - self.error(message, *args, **kwargs) + self.error(message, stacklevel=stacklevel, *args, **kwargs) else: if is_debug_enabled(): - self.exception(message, *args, **kwargs) + self.exception(message, stack_info=True, *args, **kwargs) else: self.error(message, *args, **kwargs) diff --git a/cps/tasks/mail.py b/cps/tasks/mail.py index 05b2175f..03526c8b 100644 --- a/cps/tasks/mail.py +++ b/cps/tasks/mail.py @@ -158,10 +158,10 @@ class TaskEmail(CalibreTask): else: self.send_gmail_email(msg) except MemoryError as e: - log.debug_or_exception(e) + log.debug_or_exception(e, stacklevel=3) self._handleError(u'MemoryError sending e-mail: {}'.format(str(e))) except (smtplib.SMTPException, smtplib.SMTPAuthenticationError) as e: - log.debug_or_exception(e) + log.debug_or_exception(e, stacklevel=3) if hasattr(e, "smtp_error"): text = e.smtp_error.decode('utf-8').replace("\n", '. ') elif hasattr(e, "message"): @@ -171,11 +171,11 @@ class TaskEmail(CalibreTask): else: text = '' self._handleError(u'Smtplib Error sending e-mail: {}'.format(text)) - except socket.error as e: - log.debug_or_exception(e) + except (socket.error) as e: + log.debug_or_exception(e, stacklevel=3) self._handleError(u'Socket Error sending e-mail: {}'.format(e.strerror)) except Exception as ex: - log.debug_or_exception(ex) + log.debug_or_exception(ex, stacklevel=3) self._handleError(u'Error sending e-mail: {}'.format(ex)) def send_standard_email(self, msg): @@ -248,7 +248,7 @@ class TaskEmail(CalibreTask): data = file_.read() file_.close() except IOError as e: - log.debug_or_exception(e) + log.debug_or_exception(e, stacklevel=3) log.error(u'The requested file could not be read. Maybe wrong permissions?') return None # Set mimetype diff --git a/optional-requirements.txt b/optional-requirements.txt index 3fac14ca..c0009c94 100644 --- a/optional-requirements.txt +++ b/optional-requirements.txt @@ -38,4 +38,4 @@ natsort>=2.2.0,<8.1.0 comicapi>=2.2.0,<2.3.0 #Kobo integration -jsonschema>=3.2.0,<4.3.0 +jsonschema>=3.2.0,<4.4.0 diff --git a/setup.cfg b/setup.cfg index 87f6055f..95f3502d 100644 --- a/setup.cfg +++ b/setup.cfg @@ -87,7 +87,7 @@ comics = natsort>=2.2.0,<8.1.0 comicapi>= 2.2.0,<2.3.0 kobo = - jsonschema>=3.2.0,<4.3.0 + jsonschema>=3.2.0,<4.4.0 From f39dc100b458e86d195a007619da7292af7033e1 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Sat, 25 Dec 2021 21:39:58 +0100 Subject: [PATCH 09/45] Migrated some routes to POST - shelf massadd - resetpassword - delete shelf - send to kindle --- cps/static/js/details.js | 2 +- cps/static/js/main.js | 36 +++++++++++++++++++++++++++++++++--- cps/templates/detail.html | 6 +++--- cps/templates/search.html | 2 +- cps/templates/shelf.html | 4 ++-- cps/templates/user_edit.html | 2 +- 6 files changed, 41 insertions(+), 11 deletions(-) diff --git a/cps/static/js/details.js b/cps/static/js/details.js index 9caf9470..3a7def32 100644 --- a/cps/static/js/details.js +++ b/cps/static/js/details.js @@ -62,7 +62,7 @@ $("#archived_cb").on("change", function() { $("#shelf-actions").on("click", "[data-shelf-action]", function (e) { e.preventDefault(); - $.get(this.href) + $.post(this.href) .done(function() { var $this = $(this); switch ($this.data("shelf-action")) { diff --git a/cps/static/js/main.js b/cps/static/js/main.js index 6cef22f8..e8da76ef 100644 --- a/cps/static/js/main.js +++ b/cps/static/js/main.js @@ -20,6 +20,20 @@ function getPath() { return jsFileLocation.substr(0, jsFileLocation.search("/static/js/libs/jquery.min.js")); // the js folder path } +function postButton(event, action){ + event.preventDefault(); + var newForm = jQuery('
', { + "action": action, + 'target': "_top", + 'method': "post" + }).append(jQuery('', { + 'name': 'csrf_token', + 'value': $("input[name=\'csrf_token\']").val(), + 'type': 'hidden' + })).appendTo('body'); + newForm.submit(); +} + function elementSorter(a, b) { a = +a.slice(0, -2); b = +b.slice(0, -2); @@ -71,6 +85,22 @@ $(document).on("change", "select[data-controlall]", function() { } }); +/*$(document).on("click", "#sendbtn", function (event) { + postButton(event, $(this).data('action')); +}); + +$(document).on("click", ".sendbutton", function (event) { + // $(".sendbutton").on("click", "body", function(event) { + postButton(event, $(this).data('action')); +});*/ + +$(document).on("click", ".postAction", function (event) { + // $(".sendbutton").on("click", "body", function(event) { + postButton(event, $(this).data('action')); +}); + + + // Syntax has to be bind not on, otherwise problems with firefox $(".container-fluid").bind("dragenter dragover", function () { if($("#btn-upload").length && !$('body').hasClass('shelforder')) { @@ -685,13 +715,14 @@ $(function() { }); }); - $("#delete_shelf").click(function() { + $("#delete_shelf").click(function(event) { confirmDialog( $(this).attr('id'), "GeneralDeleteModal", $(this).data('value'), function(value){ - $("#delete_shelf").closest("form").submit() + postButton(event, $("#delete_shelf").data("action")); + // $("#delete_shelf").closest("form").submit() } ); @@ -775,4 +806,3 @@ $(function() { }); }); }); - diff --git a/cps/templates/detail.html b/cps/templates/detail.html index 0ecaf903..1fd5f09a 100644 --- a/cps/templates/detail.html +++ b/cps/templates/detail.html @@ -38,16 +38,16 @@ {% endif %} {% if g.user.kindle_mail and kindle_list %} {% if kindle_list.__len__() == 1 %} - {{kindle_list[0]['text']}} +
{{kindle_list[0]['text']}}
{% else %}
-
diff --git a/cps/templates/search.html b/cps/templates/search.html index 627beaf8..32339803 100644 --- a/cps/templates/search.html +++ b/cps/templates/search.html @@ -17,7 +17,7 @@ diff --git a/cps/templates/shelf.html b/cps/templates/shelf.html index 5bb9317e..adfead60 100644 --- a/cps/templates/shelf.html +++ b/cps/templates/shelf.html @@ -2,14 +2,14 @@ {% block body %}

{{title}}

- + {% if g.user.role_download() %} {{ _('Download') }} {% endif %} {% if g.user.is_authenticated %} {% if (g.user.role_edit_shelfs() and shelf.is_public ) or not shelf.is_public %} -
{{ _('Delete this Shelf') }}
+
{{ _('Delete this Shelf') }}
{{ _('Edit Shelf Properties') }} {% if entries.__len__() %} diff --git a/cps/templates/user_edit.html b/cps/templates/user_edit.html index e6fbdb74..de7a4fb3 100644 --- a/cps/templates/user_edit.html +++ b/cps/templates/user_edit.html @@ -17,7 +17,7 @@
{% if ( g.user and g.user.role_passwd() or g.user.role_admin() ) and not content.role_anonymous() %} {% if g.user and g.user.role_admin() and not new_user and not profile and ( mail_configured and content.email if content.email != None ) %} - {{_('Reset user Password')}} + {{_('Reset user Password')}} {% endif %}
From 47f5e2ffb4253b57271e76444e465da425752239 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Sun, 26 Dec 2021 10:31:04 +0100 Subject: [PATCH 10/45] Remove python2 urllib imports Fix for "javascript:" script links in identifier --- cps/db.py | 3 +++ cps/helper.py | 5 +---- cps/kobo.py | 6 +----- cps/redirect.py | 6 ++---- cps/services/SyncToken.py | 7 ++----- 5 files changed, 9 insertions(+), 18 deletions(-) diff --git a/cps/db.py b/cps/db.py index 9c5b5657..470ecc1c 100644 --- a/cps/db.py +++ b/cps/db.py @@ -23,6 +23,7 @@ import re import ast import json from datetime import datetime +from urllib.parse import quote from sqlalchemy import create_engine from sqlalchemy import Table, Column, ForeignKey, CheckConstraint @@ -166,6 +167,8 @@ class Identifiers(Base): return u"https://portal.issn.org/resource/ISSN/{0}".format(self.val) elif format_type == "isfdb": return u"http://www.isfdb.org/cgi-bin/pl.cgi?{0}".format(self.val) + elif self.val.lower().startswith("javascript:"): + return quote(self.val) else: return u"{0}".format(self.val) diff --git a/cps/helper.py b/cps/helper.py index b8499a12..e8a0b738 100644 --- a/cps/helper.py +++ b/cps/helper.py @@ -38,11 +38,8 @@ from sqlalchemy.sql.expression import true, false, and_, text, func from werkzeug.datastructures import Headers from werkzeug.security import generate_password_hash from markupsafe import escape +from urllib.parse import quote -try: - from urllib.parse import quote -except ImportError: - from urllib import quote try: import unidecode diff --git a/cps/kobo.py b/cps/kobo.py index e0395855..b5ff000e 100644 --- a/cps/kobo.py +++ b/cps/kobo.py @@ -23,11 +23,7 @@ import os import uuid from time import gmtime, strftime import json - -try: - from urllib import unquote -except ImportError: - from urllib.parse import unquote +from urllib.parse import unquote from flask import ( Blueprint, diff --git a/cps/redirect.py b/cps/redirect.py index d491b353..8bd68109 100644 --- a/cps/redirect.py +++ b/cps/redirect.py @@ -27,10 +27,8 @@ # http://flask.pocoo.org/snippets/62/ -try: - from urllib.parse import urlparse, urljoin -except ImportError: - from urlparse import urlparse, urljoin +from urllib.parse import urlparse, urljoin + from flask import request, url_for, redirect diff --git a/cps/services/SyncToken.py b/cps/services/SyncToken.py index 85ed5032..2e23efe2 100644 --- a/cps/services/SyncToken.py +++ b/cps/services/SyncToken.py @@ -21,11 +21,8 @@ import sys from base64 import b64decode, b64encode from jsonschema import validate, exceptions, __version__ from datetime import datetime -try: - # pylint: disable=unused-import - from urllib import unquote -except ImportError: - from urllib.parse import unquote + +from urllib.parse import unquote from flask import json from .. import logger From 3e0d8763c377d2146462811e3e4ccf13f0d312ce Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Sun, 26 Dec 2021 10:46:43 +0100 Subject: [PATCH 11/45] Prevent 2 public shelfs with same names due to changing public property --- cps/shelf.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/cps/shelf.py b/cps/shelf.py index 19c2d68e..b1fbdd04 100644 --- a/cps/shelf.py +++ b/cps/shelf.py @@ -248,12 +248,13 @@ def create_edit_shelf(shelf, page_title, page, shelf_id=False): if not current_user.role_edit_shelfs() and to_save.get("is_public") == "on": flash(_(u"Sorry you are not allowed to create a public shelf"), category="error") return redirect(url_for('web.index')) - shelf.is_public = 1 if to_save.get("is_public") else 0 + is_public = 1 if to_save.get("is_public") else 0 if config.config_kobo_sync: shelf.kobo_sync = True if to_save.get("kobo_sync") else False shelf_title = to_save.get("title", "") - if check_shelf_is_unique(shelf, shelf_title, shelf_id): + if check_shelf_is_unique(shelf, shelf_title, is_public, shelf_id): shelf.name = shelf_title + shelf.is_public = is_public if not shelf_id: shelf.user_id = int(current_user.id) ub.session.add(shelf) @@ -284,12 +285,12 @@ def create_edit_shelf(shelf, page_title, page, shelf_id=False): sync_only_selected_shelves=sync_only_selected_shelves) -def check_shelf_is_unique(shelf, title, shelf_id=False): +def check_shelf_is_unique(shelf, title, is_public, shelf_id=False): if shelf_id: ident = ub.Shelf.id != shelf_id else: ident = true() - if shelf.is_public == 1: + if is_public == 1: is_shelf_name_unique = ub.session.query(ub.Shelf) \ .filter((ub.Shelf.name == title) & (ub.Shelf.is_public == 1)) \ .filter(ident) \ From f22e4d996c0f647b506cd42c60407a9ee8c78818 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Mon, 27 Dec 2021 09:31:32 +0100 Subject: [PATCH 12/45] Proxy kobo library sync at the end of local sync --- cps/kobo.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cps/kobo.py b/cps/kobo.py index b5ff000e..c74a3230 100644 --- a/cps/kobo.py +++ b/cps/kobo.py @@ -321,7 +321,7 @@ def HandleSyncRequest(): def generate_sync_response(sync_token, sync_results, set_cont=False): extra_headers = {} - if config.config_kobo_proxy: + if config.config_kobo_proxy and not set_cont: # Merge in sync results from the official Kobo store. try: store_response = make_request_to_kobo_store(sync_token) From 0548fbb685569851ec5a37b3650c5b6c54ee4447 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Mon, 27 Dec 2021 09:37:52 +0100 Subject: [PATCH 13/45] Bugfix post commands without updater --- cps/templates/admin.html | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/cps/templates/admin.html b/cps/templates/admin.html index 9728cb6d..6cd7815e 100644 --- a/cps/templates/admin.html +++ b/cps/templates/admin.html @@ -188,9 +188,8 @@ - - {% if feature_support['updater'] %} + {% if feature_support['updater'] %}
{{_('Check for Update')}}
From ae1f515446e7ee1f31700df42b810a0ce1061cf5 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Mon, 27 Dec 2021 20:02:42 +0100 Subject: [PATCH 14/45] Bugfix uncheck all ekements in books list and user list Improved testability for books list --- cps/static/js/table.js | 30 +++++++++++++++--------------- cps/templates/book_table.html | 4 ++-- 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/cps/static/js/table.js b/cps/static/js/table.js index e98f6a8b..112ca957 100644 --- a/cps/static/js/table.js +++ b/cps/static/js/table.js @@ -47,15 +47,15 @@ $(function() { var rows = rowsAfter; if (e.type === "uncheck-all") { - rows = rowsBefore; + selections = []; + } else { + var ids = $.map(!$.isArray(rows) ? [rows] : rows, function (row) { + return row.id; + }); + + var func = $.inArray(e.type, ["check", "check-all"]) > -1 ? "union" : "difference"; + selections = window._[func](selections, ids); } - - var ids = $.map(!$.isArray(rows) ? [rows] : rows, function (row) { - return row.id; - }); - - var func = $.inArray(e.type, ["check", "check-all"]) > -1 ? "union" : "difference"; - selections = window._[func](selections, ids); if (selections.length >= 2) { $("#merge_books").removeClass("disabled"); $("#merge_books").attr("aria-disabled", false); @@ -540,14 +540,14 @@ $(function() { var rows = rowsAfter; if (e.type === "uncheck-all") { - rows = rowsBefore; + selections = []; + } else { + var ids = $.map(!$.isArray(rows) ? [rows] : rows, function (row) { + return row.id; + }); + var func = $.inArray(e.type, ["check", "check-all"]) > -1 ? "union" : "difference"; + selections = window._[func](selections, ids); } - - var ids = $.map(!$.isArray(rows) ? [rows] : rows, function (row) { - return row.id; - }); - var func = $.inArray(e.type, ["check", "check-all"]) > -1 ? "union" : "difference"; - selections = window._[func](selections, ids); handle_header_buttons(); }); }); diff --git a/cps/templates/book_table.html b/cps/templates/book_table.html index fb0cfed8..eb5c1bff 100644 --- a/cps/templates/book_table.html +++ b/cps/templates/book_table.html @@ -120,8 +120,8 @@
From c095ee3c144765ed559861caef2d0b045f704329 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Tue, 28 Dec 2021 11:31:32 +0100 Subject: [PATCH 15/45] Fix #2243 (whitespaces are trimmed also for normal search) --- cps/web.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cps/web.py b/cps/web.py index 81c37711..e139848e 100644 --- a/cps/web.py +++ b/cps/web.py @@ -1069,7 +1069,7 @@ def reconnect(): def search(): term = request.args.get("query") if term: - return redirect(url_for('web.books_list', data="search", sort_param='stored', query=term)) + return redirect(url_for('web.books_list', data="search", sort_param='stored', query=term.strip())) else: return render_title_template('search.html', searchterm="", From a90177afa0bd1846cf7cbb92b93b770aff065082 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Tue, 28 Dec 2021 20:17:51 +0100 Subject: [PATCH 16/45] Better version output in about page (exe file, pyPi, git commit string removed if empty) --- cps/about.py | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/cps/about.py b/cps/about.py index ba5a99af..7e839520 100644 --- a/cps/about.py +++ b/cps/about.py @@ -74,13 +74,22 @@ opt = dep_check.load_dependencys(True) for i in (req + opt): ret[i[1]] = i[0] +if constants.NIGHTLY_VERSION[0] == "$Format:%H$": + calibre_web_version = constants.STABLE_VERSION['version'] +else: + calibre_web_version = (constants.STABLE_VERSION['version'] + ' - ' + + constants.NIGHTLY_VERSION[0].replace('%','%%') + ' - ' + + constants.NIGHTLY_VERSION[1].replace('%','%%')) +if getattr(sys, 'frozen', False): + calibre_web_version += " - Exe-Version" +elif constants.HOME_CONFIG: + calibre_web_version += " - pyPi" + if not ret: _VERSIONS = OrderedDict( Platform = '{0[0]} {0[2]} {0[3]} {0[4]} {0[5]}'.format(platform.uname()), Python=sys.version, - Calibre_Web=constants.STABLE_VERSION['version'] + ' - ' - + constants.NIGHTLY_VERSION[0].replace('%','%%') + ' - ' - + constants.NIGHTLY_VERSION[1].replace('%','%%'), + Calibre_Web=calibre_web_version, WebServer=server.VERSION, Flask=flask.__version__, Flask_Login=flask_loginVersion, @@ -110,9 +119,7 @@ else: _VERSIONS = OrderedDict( Platform = '{0[0]} {0[2]} {0[3]} {0[4]} {0[5]}'.format(platform.uname()), Python = sys.version, - Calibre_Web = constants.STABLE_VERSION['version'] + ' - ' - + constants.NIGHTLY_VERSION[0].replace('%', '%%') + ' - ' - + constants.NIGHTLY_VERSION[1].replace('%', '%%'), + Calibre_Web=calibre_web_version, Werkzeug = werkzeug.__version__, Jinja2=jinja2.__version__, pySqlite = sqlite3.version, From c1030dfd1340ff65f9b4ea2d20a8c048b7db2e14 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Thu, 30 Dec 2021 14:44:35 +0100 Subject: [PATCH 17/45] Update dependency scholary --- optional-requirements.txt | 2 +- setup.cfg | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/optional-requirements.txt b/optional-requirements.txt index c0009c94..b90951aa 100644 --- a/optional-requirements.txt +++ b/optional-requirements.txt @@ -31,7 +31,7 @@ SQLAlchemy-Utils>=0.33.5,<0.38.0 # extracting metadata rarfile>=2.7 -scholarly>=1.2.0, <1.5 +scholarly>=1.2.0, <1.6 # other natsort>=2.2.0,<8.1.0 diff --git a/setup.cfg b/setup.cfg index 95f3502d..a81102b8 100644 --- a/setup.cfg +++ b/setup.cfg @@ -82,7 +82,7 @@ oauth = SQLAlchemy-Utils>=0.33.5,<0.38.0 metadata = rarfile>=2.7 - scholarly>=1.2.0,<1.5 + scholarly>=1.2.0,<1.6 comics = natsort>=2.2.0,<8.1.0 comicapi>= 2.2.0,<2.3.0 From bbadfa22511c2ae8fb4cdcaa326ccc1be66a07f4 Mon Sep 17 00:00:00 2001 From: Ozzieisaacs Date: Tue, 4 Jan 2022 21:11:52 +0100 Subject: [PATCH 18/45] bugfixes load metadata --- cps/metadata_provider/scholar.py | 2 +- cps/templates/book_edit.html | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/cps/metadata_provider/scholar.py b/cps/metadata_provider/scholar.py index 5ff078b9..df387831 100644 --- a/cps/metadata_provider/scholar.py +++ b/cps/metadata_provider/scholar.py @@ -43,7 +43,7 @@ class scholar(Metadata): v['tags'] = [] v['rating'] = 0 v['series'] = "" - v['cover'] = generic_cover + v['cover'] = "" v['url'] = publication.get('pub_url') or publication.get('eprint_url') or "", v['source'] = { "id": self.__id__, diff --git a/cps/templates/book_edit.html b/cps/templates/book_edit.html index cac3219c..9d2ac14e 100644 --- a/cps/templates/book_edit.html +++ b/cps/templates/book_edit.html @@ -226,7 +226,7 @@