Compare commits

...

228 Commits

Author SHA1 Message Date
github-actions f413f5c692 chore: version v2.6.0 2026-03-18 20:37:39 +00:00
Weblate (bot) 52307ed09f chore(web): update translations (#26192)
Translate-URL: https://hosted.weblate.org/projects/immich/immich/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/af/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ar/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/be/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/bg/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/bn/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ca/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/cs/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/da/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/de/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/de_CH/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/el/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/eo/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/es/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/et/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/eu/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/fi/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/fr/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ga/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/gl/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/gsw/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/gu/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/he/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/hi/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/hu/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/id/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/it/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ja/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/km/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/kn/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ko/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/lt/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/lv/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ml/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ms/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/nb_NO/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/nl/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/pl/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/pt/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/pt_BR/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ro/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/ru/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/sk/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/sl/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/sr_Cyrl/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/sr_Latn/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/sv/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/te/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/th/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/tr/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/uk/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/vi/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/yue_Hant/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/zh_Hans/
Translate-URL: https://hosted.weblate.org/projects/immich/immich/zh_Hant/
Translation: Immich/immich

Co-authored-by: -J- <heyj0e@tuta.io>
Co-authored-by: Abdullah Atsa <abdullahatsauban@gmail.com>
Co-authored-by: Adam Havránek <adamhavra@seznam.cz>
Co-authored-by: Ahmed Hamdy <ahmedhamdy19375@gmail.com>
Co-authored-by: Ahmed Khaleel Shihab <ahmed91shihab@gmail.com>
Co-authored-by: Aindriú Mac Giolla Eoin <aindriu80@gmail.com>
Co-authored-by: Aleksa Milošević <akimaki15@gmail.com>
Co-authored-by: Anton Palmqvist <apq@users.noreply.hosted.weblate.org>
Co-authored-by: Antón Gómez López <antongomez03@gmail.com>
Co-authored-by: Arif Budiman <arifpedia@gmail.com>
Co-authored-by: Balázs R <nvi9@outlook.hu>
Co-authored-by: Baptiste Mille-Mathias <baptiste.millemathias@alcmeon.com>
Co-authored-by: Berkay Görgülü <berthanas@gmail.com>
Co-authored-by: Bora Atıcı <boratici.acc@gmail.com>
Co-authored-by: CHUNG, Jin-ho <doctorjinho@gmail.com>
Co-authored-by: Cesare Capo <cescapo@icloud.com>
Co-authored-by: Chintan Prajapati <chintan9@student.fdu.edu>
Co-authored-by: Denis Pacquier <denis.pacquier@gmail.com>
Co-authored-by: DevServs <bonov@mail.ru>
Co-authored-by: Dusan Hlavaty <dhlavaty@gmail.com>
Co-authored-by: Dymitr <zasvab@gmail.com>
Co-authored-by: Dániel Gál <galdaniel.school@gmail.com>
Co-authored-by: Emanuel Santos Martins <santosmartinsemanuel@gmail.com>
Co-authored-by: Emanuele La Mura <acedit.wcry@gmail.com>
Co-authored-by: Farkas Rábai <farkasrabai@gmail.com>
Co-authored-by: Fjuro <fjuro@users.noreply.hosted.weblate.org>
Co-authored-by: Floruit <1964993179@qq.com>
Co-authored-by: Frank Paul Silye <frankps@gmail.com>
Co-authored-by: Gabriel <jellyfin.sensitize624@passmail.net>
Co-authored-by: Gideon Wentink <gjwentink@gmail.com>
Co-authored-by: Goran Aničin <anicin.goran@gmail.com>
Co-authored-by: HackingAll <hacking.all.YT@gmail.com>
Co-authored-by: Happy <59247878+happy2452354@users.noreply.github.com>
Co-authored-by: Haru Ijima <haruijimakun@gmail.com>
Co-authored-by: Hosted Weblate user 85894 <reo7s@users.noreply.hosted.weblate.org>
Co-authored-by: Hurricane_32 <rodrigorimo@hotmail.com>
Co-authored-by: IMPERA <rickbrouwer2005premium@gmail.com>
Co-authored-by: Ian.Su <stu92116stu92116@hotmail.com.tw>
Co-authored-by: Immich <weblate@immich.app>
Co-authored-by: Indrek Haav <indrek.haav@hotmail.com>
Co-authored-by: IsakBH <isak@brunhenriksen.net>
Co-authored-by: Ismail <binhelati@gmail.com>
Co-authored-by: Ivan Dimitrov <idimitrov08@gmail.com>
Co-authored-by: Jannik Norden <development.jnorden@outlook.com>
Co-authored-by: Jeppe Nellemann <jepnel@proton.me>
Co-authored-by: Joseph <josephlegrand33+hosted.weblate.org@gmail.com>
Co-authored-by: Jozef Gaal <preklady@mayday.sk>
Co-authored-by: Junghyuk Kwon <kwon@junghy.uk>
Co-authored-by: KW Lam <kwlam281@gmail.com>
Co-authored-by: Kaushal Patel <kaushalpatel1982@gmail.com>
Co-authored-by: Kim Hokyeong <manmen.mi1375@gmail.com>
Co-authored-by: Krzysztof <doom.zg@gmail.com>
Co-authored-by: Leo Bottaro <github@leobottaro.com>
Co-authored-by: Leon S <leonnis16@gmail.com>
Co-authored-by: Liviu Roman <contact@liviuroman.com>
Co-authored-by: Londoneye02 <jcdelcaz@gmail.com>
Co-authored-by: Luca Beyer <trickobert@gmail.com>
Co-authored-by: Lukas Konsin <lukaskonsin@proton.me>
Co-authored-by: Madipodo <madipo@posteo.de>
Co-authored-by: Marc Casillas <mcasillassu@gmail.com>
Co-authored-by: MarcSerraPeralta <marcserraperalta@gmail.com>
Co-authored-by: Marian Wolf <marian.wolf2008@gmail.com>
Co-authored-by: Matjaž T. <matjaz@moj-svet.si>
Co-authored-by: Mayukh Roy <mayukhroy2020@gmail.com>
Co-authored-by: Mees Frensel <meesfrensel@gmail.com>
Co-authored-by: Meet Bhingradiya <meetbhingradiya36@gmail.com>
Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com>
Co-authored-by: MrZapp-LM <paul.lutz@lichtermacher.at>
Co-authored-by: Muhammad Ivan Aldorino <ivanaldorino@gmail.com>
Co-authored-by: Mykola Vaskevych <22372199@studentmail.ul.ie>
Co-authored-by: Mārtiņš Bruņenieks <martinsb@gmail.com>
Co-authored-by: Olaf Nielsen <solluh@mail.de>
Co-authored-by: PPNplus <ppnplus@protonmail.com>
Co-authored-by: PaCoalt <pschwarzwaelder@yahoo.com>
Co-authored-by: Petri Hämäläinen <petri.hamalainen@mailbox.org>
Co-authored-by: Philip Goto <philip.goto@gmail.com>
Co-authored-by: Philipp Frauenfelder <philipp.frauenfelder@gmail.com>
Co-authored-by: PhillyMay <mein.alias@outlook.com>
Co-authored-by: Phyruos <phyruos@gmail.com>
Co-authored-by: Predrag Milićević <predragmilicevic@gmail.com>
Co-authored-by: Psycho <unhomen@gmail.com>
Co-authored-by: Ramon \"9Tails\" Canales <emaildoramon@gmail.com>
Co-authored-by: Rebelder <bas+github@bbelder.eu>
Co-authored-by: Reo7s <biz@reo-ang.net>
Co-authored-by: Roger Veciana Rovira <rveciana@gmail.com>
Co-authored-by: Roman Fedorchuk <roma.fedorchuk@gmail.com>
Co-authored-by: Ruben Silva <ruben02b@gmail.com>
Co-authored-by: Shadi Alrashoodi <shadifaisal91@gmail.com>
Co-authored-by: Shashibhushan Singh <shashibhushansingh11@gmail.com>
Co-authored-by: Shawn <xiaxinx@gmail.com>
Co-authored-by: Shihfu Juan <xlion@xlion.tw>
Co-authored-by: Skanda <skillwiz94@gmail.com>
Co-authored-by: Sylvain Pichon <service@spichon.fr>
Co-authored-by: TA <tobi@warsnich.de>
Co-authored-by: TV Box <realceday.tvbox@gmail.com>
Co-authored-by: Thomas Grimstad <solmester@gmail.com>
Co-authored-by: Thomas Vente <thomas.vente@gmail.com>
Co-authored-by: Tim Morley <weblate.3919org@timsk.org>
Co-authored-by: TobnacTobi <Tobias.Schrull@gmx.de>
Co-authored-by: Toivo Schmale <thetoicraft@gmail.com>
Co-authored-by: Tomo Tomov <tomotomov92@gmail.com>
Co-authored-by: Ugnius <kaugnius@gmail.com>
Co-authored-by: Ulices <hasecilu@tuta.io>
Co-authored-by: Ulpi Antor <weblate.residual441@passmail.net>
Co-authored-by: Unn Krigul <unn@arter.studio>
Co-authored-by: User 123456789 <user123456789@users.noreply.hosted.weblate.org>
Co-authored-by: Vallabh Sharma <srivallabhsharma@gmail.com>
Co-authored-by: Vegard Fladby <vegard@fladby.org>
Co-authored-by: Viesturs <viesturs.sprogis@outlook.com>
Co-authored-by: Vivek M <vivekmalhotra004@gmail.com>
Co-authored-by: Vixepti <contact@vixepti.fr>
Co-authored-by: Xo <xocodokie@users.noreply.hosted.weblate.org>
Co-authored-by: Zawaer <zawarudo123pro@gmail.com>
Co-authored-by: anton garcias <isaga.percompartir@gmail.com>
Co-authored-by: ashraf0484 <t.sashraf@gmail.com>
Co-authored-by: bittin1ddc447d824349b2 <bittin@reimu.nl>
Co-authored-by: chamdim <chamdim@protonmail.com>
Co-authored-by: dimitrijeforesta <dimitrije.foresta@gmail.com>
Co-authored-by: eav5jhl0 <eav5jhl0@users.noreply.hosted.weblate.org>
Co-authored-by: jellebuitenhuis <github@jellebuitenhuis.nl>
Co-authored-by: kylo32 <kylo32@gmail.com>
Co-authored-by: l m <virtuamoo@gmail.com>
Co-authored-by: millallo <millallo@tiscali.it>
Co-authored-by: muziqaz <muziqaz@users.noreply.hosted.weblate.org>
Co-authored-by: mycodeco <victorschiellerup@gmail.com>
Co-authored-by: nachtpfoetchen <nachtpfoetchen@posteo.de>
Co-authored-by: pyccl <changcongliang@163.com>
Co-authored-by: stesoma <soma.steltzer@gmail.com>
Co-authored-by: techmoocher 🦊 <ndvphuc276@gmail.com>
Co-authored-by: timmy61109 <qazzxcasdqwewsxedc@gmail.com>
Co-authored-by: waclaw66 <waclaw66@seznam.cz>
Co-authored-by: 안세훈 <on9686@gmail.com>
2026-03-18 20:27:17 +00:00
Jason Rasmussen 77020e742a fix: validate accept header before returning html (#27019) 2026-03-18 14:15:48 -04:00
Jason Rasmussen 38b135ff36 fix: bounding box return type (#27014) 2026-03-18 11:58:40 -04:00
Jason Rasmussen cda4a2a5fc fix: filter after searching by asset id (#26994)
* fix: filter after searching by asset id

* Update web/src/lib/modals/SearchFilterModal.svelte

Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com>

---------

Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com>
2026-03-18 13:32:54 +00:00
Min Idzelis 88002cf7fe fix(web): allow images to be downloaded again(long-press or right click) (#26992) 2026-03-18 12:40:36 +01:00
Andreas Heinz 694ea151f5 fix(web): escape handling for tagging and adding a face in asset viewer (#26870) 2026-03-18 12:39:25 +01:00
Jason Rasmussen b092c8b601 fix: healthcheck (#26989) 2026-03-17 17:54:39 -04:00
Jason Rasmussen 48e6e17829 feat: primary notifications (#26988) 2026-03-17 17:54:11 -04:00
Jason Rasmussen 0519833d75 refactor: prefer tv (#26993) 2026-03-17 17:53:48 -04:00
Thomas 34caed3b2b fix(server): flaky metadata tests (#26964) 2026-03-17 18:06:22 +01:00
Thomas 677cb660f5 fix(mobile): reflect asset deletions instantly (#26835)
Sometimes the current asset won't update when deleted, or it won't
refresh until an event (like showing details) happens.
2026-03-17 06:43:14 -05:00
Michel Heusschen 9b0b2bfcf2 fix(web): jump to primary stacked asset from memory (#26978) 2026-03-17 06:39:39 -05:00
Preslav Penchev ac6938a629 fix(web): allow pasting PIN code from clipboard or password manager (#26944)
* fix(web): allow pasting PIN code from clipboard or password manager

The keydown handler was blocking Ctrl+V/Cmd+V since it called
preventDefault() on all non-numeric keys. Also adds an onpaste
handler to distribute pasted digits across the individual inputs.

* refactor: handle paste in handleInput, remove maxlength

* cleanup + fix digit focus

---------

Co-authored-by: Preslav Penchev <preslav.penchev@acronis.com>
Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com>
2026-03-17 06:38:06 -05:00
Thomas 16749ff8ba fix(server): sync files to disk (#26881)
Ensure that all files are flushed after they've been written.

At current, files are not explicitly flushed to disk, which can cause
data corruption. In extreme circumstances, it's possible that uploaded
files may not ever be persisted at all.
2026-03-17 06:33:43 -05:00
renovate[bot] bba4a00eb1 chore(deps): update github-actions (#26967)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-17 10:40:22 +01:00
Mees Frensel 9dafc8e8e9 fix(web): make link fit album card (#26958) 2026-03-16 19:17:55 +01:00
Michel Heusschen 4e44fb9cf7 fix(web): prevent search page error on missing album filter (#26948) 2026-03-16 19:15:20 +01:00
Yaros 82db581cc5 feat(mobile): open in browser (#26369)
* feat(mobile): open in browser

* chore: open in browser instead of webview

* chore: allow archived asset

* fix: moved openinbrowser above unstack

* feat: deeplink into favorites, trash & archived

* fix: use remoteId (for tests to succeed)

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-16 18:06:51 +00:00
Mert b66c97b785 fix(mobile): use shared auth for background_downloader (#26911)
shared client for background_downloader on ios
2026-03-13 22:23:07 -05:00
Mert ff936f901d fix(mobile): duplicate server urls returned (#26864)
remove server url

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-13 22:09:42 -05:00
Min Idzelis 48fe111daa feat(web): improve OCR overlay text fitting, reactivity, and accessibility (#26678)
- Precise font sizing using canvas measureText instead of character-count heuristic
- Fix overlay repositioning on viewport resize by computing metrics from reactive state instead of DOM reads
- Fix animation delay on resize by using transition-colors instead of transition-all
- Add keyboard accessibility: OCR boxes are focusable via Tab with reading-order sort
- Show text on focus (same styling as hover) with proper ARIA attributes
2026-03-13 22:04:55 -05:00
bo0tzz 0581b49750 fix: ignore optional headers in pr template check (#26910) 2026-03-13 22:55:00 +00:00
rthrth-svg 2c6d4f3fe1 fix(web): copy yearMonth in MonthGroup to avoid shared object reference with asset (#26890)
Co-authored-by: Min Idzelis <min123@gmail.com>
2026-03-13 22:27:08 +01:00
Belnadifia 55513cd59f feat(server): support IDPs that only send the userinfo in the ID token (#26717)
Co-authored-by: irouply <irouply@secom.fr>
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
2026-03-13 22:14:45 +01:00
bo0tzz 10fa928abe feat: require pull requests to follow template (#26902)
* feat: require pull requests to follow template

* fix: persist-credentials: false
2026-03-13 09:43:00 -05:00
Nathaniel Hourt e322d44f95 fix: SMTP over TLS (#26893)
Final step on #22833

PReq #22833 is about adding support for SMTP-over-TLS rather than just STARTTLS when sending emails. That PReq adds almost everything; it just forgot to actually pass the flag to Nodemailer at the end.

This adds that last line of code and makes it work correctly (for me, anyways!).

Co-authored-by: Nathaniel <I@nathaniel.land>
2026-03-13 09:41:50 -05:00
Michel Heusschen c2a279e49e fix(web): keep header fixed on individual shared links (#26892) 2026-03-13 09:40:04 -05:00
Mert 226b9390db fix(mobile): video auth (#26887)
* fix video auth

* update commit
2026-03-13 09:38:21 -05:00
Michel Heusschen 754f072ef9 fix(web): disable drag and drop for internal items (#26897) 2026-03-13 09:37:51 -05:00
luis15pt c91d8745b4 fix: use correct original URL for 360 video panorama playback (#26831)
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-12 21:27:44 +01:00
Brandon Wees f3b7cd6198 refactor: move encoded video to asset files table (#26863)
* refactor: move encoded video to asset files table

* chore: update
2026-03-12 16:15:21 -04:00
Jason Rasmussen 990aff441b fix: add to shared link (#26886) 2026-03-12 16:10:55 -04:00
Daniel Dietzler 001d7d083f refactor: small test factories (#26862) 2026-03-12 14:48:49 -04:00
Michel Heusschen 3fd24e2083 fix(server): restrict individual shared link asset removal to owners (#26868)
* fix(server): restrict individual shared link asset removal to owners

* make open-api
2026-03-12 14:48:00 -04:00
Jason Rasmussen 6bb8f4fcc4 refactor: clean class (#26885) 2026-03-12 14:47:35 -04:00
Jason Rasmussen d4605b21d9 refactor: external links (#26880) 2026-03-12 14:55:33 +00:00
Jason Rasmussen 3bd37ebbfb refactor: clean class (#26879) 2026-03-12 09:53:46 -05:00
Min Idzelis 5c3777ab46 fix(web): fix zoom touch event handling (#26866)
fix(web): fix zoom touch event handling and add clarifying comments

- Suppress Safari's synthetic dblclick on double-tap which conflicts with zoom-image's touchstart-based zoom
- Add comment explaining pointer-events-none on zoom transform wrapper
- Add comments for touchAction and overflow style overrides
2026-03-12 09:37:29 -05:00
Alex 6c531e0a5a chore: add shadow to video play/pause icon shadow (#26836) 2026-03-11 14:15:31 -05:00
Thomas 471c27cd33 chore(mobile): remove background from asset viewer back button (#26851)
We recently changed the asset viewer to use a gradient. The circle
button looks out of place now.
2026-03-11 14:15:18 -05:00
bo0tzz 4773788a88 chore: more unused release workflow cleanup (#26817) 2026-03-11 20:04:26 +01:00
renovate[bot] d49d995611 chore(deps): update dependency exiftool-vendored to v35.13.1 (#26813)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-11 20:03:19 +01:00
Snowknight26 0ac3d6a83a fix(web): face selection box position resetting on browser resize (#26766) 2026-03-11 19:38:08 +01:00
Mees Frensel 9996ee12d0 refactor(web): crop area tool (#26843) 2026-03-11 18:58:26 +01:00
Brendan Ngo 0a79dd1228 fix(server): extract make/model from sony video files (#26833)
Co-authored-by: Your Name <brendan.ngo@okendo.io>
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
2026-03-11 17:29:37 +00:00
Mees Frensel e45308b949 fix(web): exclude emoji from translation string (#26852) 2026-03-11 13:22:59 -04:00
Mert c403e03a42 fix(mobile): logout on upgrade (#26827)
* use cookiejar

* cookie duping hook

* remove old pref

* handle network switching on logout

* remove bootstrapCookies

* dead code

* fix cast

* use constants

* use new event name

* update api
2026-03-11 12:07:27 -05:00
Luis Nachtigall e7db3b220d feat(mobile): show animated images in asset viewer (#26614)
* Add support for showing animated images in AssetViewer with AnimatedImageStreamCompleter

* Add GIF overlay to thumbnail tile for animated assets

* formatting

* require isAnimated parameter in image providers for better asset handling

* feat: refactor AnimatedImageStreamCompleter to use streams for codec loading and initial image handling

* formatting

* add isAnimatedImage property to BaseAsset

* remove ApiService.getRequestHeaders() usage
2026-03-11 12:07:06 -05:00
bo0tzz 28d5c169c0 chore: use pokedex-large runner for rocm (#26823) 2026-03-11 11:15:48 -05:00
renovate[bot] 0f2fe656db fix(deps): update typescript-projects (#26812)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-11 16:40:41 +01:00
Daniel Dietzler 34ce68095d chore: upgrade to kysely 0.28.11 (#26744) 2026-03-11 16:17:31 +01:00
Min Idzelis 8764a1894b feat: adaptive progressive image loading for photo viewer (#26636)
* feat(web): adaptive progressive image loading for photo viewer

Replace ImageManager with a new AdaptiveImageLoader that progressively
loads images through quality tiers (thumbnail → preview → original).

New components and utilities:
- AdaptiveImage: layered image renderer with thumbhash, thumbnail,
  preview, and original layers with visibility managed by load state
- AdaptiveImageLoader: state machine driving the quality progression
  with per-quality callbacks and error handling
- ImageLayer/Image: low-level image elements with load/error lifecycle
- PreloadManager: preloads adjacent assets for instant navigation
- AlphaBackground/DelayedLoadingSpinner: loading state UI

Zoom is handled via a derived CSS transform applied to the content
wrapper in AdaptiveImage, with the zoom library (zoomTarget: null)
only tracking state without manipulating the DOM directly.

Also adds scaleToCover to container-utils and getAssetUrls to utils.

* fix: don't partially render images in firefox

* add passive loading indicator to asset-viewer

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-11 09:48:46 -05:00
Michel Heusschen 27f69b39b2 fix(server): use correct day ordering in timeline buckets (#26821)
* fix(web): sort timeline day groups received from server

* fix(server): use correct day ordering in timeline buckets
2026-03-11 08:49:35 -04:00
Michel Heusschen 9fc6fbc373 fix(web): restore asset update events in asset viewer (#26845) 2026-03-11 08:46:29 -04:00
Thomas 9fc32b6f7a feat(mobile): use material design 3 slider (#26829)
* feat(mobile): use material design 3 slider

The new slider is easier to use, and looks more modern.

* chore: add shadow to button and text for better visibility

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-11 01:58:01 +00:00
Thomas 4571940a4e fix(mobile): wrap backup error message text (#26834)
Refs: #25022
2026-03-10 20:40:01 -05:00
Thomas 1ceb6d2e21 fix(mobile): use tabular figures in backup page (#26830)
The numbers in the backup page are not monospace, and so changes cause
the layout to shift. Using tabular figures (monospace) will prevent
that.

Refs: #25021
2026-03-10 20:12:33 -05:00
Andreas Heinz 1a4c5d73ac feat(web): add shortcut "p" to open/close the face tag box (#26826) 2026-03-10 23:53:38 +01:00
renovate[bot] 22b43bf4d9 chore(deps): update dependency @types/node to ^24.11.0 (#26808)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-10 16:46:21 +00:00
Michel Heusschen 45eff1c663 fix(web): prevent unrelated assets from appearing in tag view (#26816) 2026-03-10 17:43:30 +01:00
renovate[bot] 56b8e1b8a9 chore(deps): update docker.io/valkey/valkey:9 docker digest to 3eeb097 (#26807)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-10 17:34:20 +01:00
Thomas f79c8cf1c1 feat(mobile): consolidate video controls (#26673)
Videos have recently been changed to support zooming, but this can make
the controls in the centre of the screen unergonomic as they will either
stay in the centre when dismissing, or stick to the video when zooming.
Neither is great. We should align the behaviour with other apps which
has the play/pause toggle at the bottom of the screen with the seeker
bar instead.

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-10 10:55:31 -05:00
Min Idzelis 8e50d25f45 feat(web): animate zoom toggle with cubicOut easing (#26731) 2026-03-10 10:42:02 -05:00
Michel Heusschen 8222781d1f fix(web): correct tag rounding in search options (#26814) 2026-03-10 15:25:13 +00:00
bo0tzz 08c4594cde chore: remove release-pr workflow (#26742)
It's not being used right now; can always add it back :P
2026-03-09 16:53:13 -04:00
Daniel Dietzler d325231df2 chore: refactor test factories (#26804) 2026-03-09 20:47:03 +00:00
Daniil Suvorov f2726606e0 fix(web): context menu overflow (#26760) 2026-03-09 19:47:54 +01:00
Andreas Heinz 0edbca24e4 fix(web): recalculate face bounding boxes (#26737)
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
2026-03-09 18:44:47 +00:00
Snowknight26 4791d9c0c3 fix(web): show the correct cursor at crop bounds when editing an asset (#26748) 2026-03-09 19:39:01 +01:00
Michel Heusschen a47b232235 fix(web): refresh recent albums sidebar after album changes (#26757) 2026-03-09 17:11:32 +01:00
Luis Nachtigall df0c86920d fix(mobile): restrict trashed asset migration to Android platform (#26726)
* fix(migration): restrict trashed asset migration to Android platform

* playbackStyle migration add different log depending on platform
2026-03-09 09:56:27 -05:00
Min Idzelis 422111d26e test(e2e): fix flakiness: optimize resetDatabase with TRUNCATE and fix selectDay selector scoping (#26776)
fix(e2e): optimize resetDatabase with TRUNCATE and fix selectDay selector scoping
2026-03-08 01:38:15 -06:00
Min Idzelis 7a83baaf27 feat: responsive video duration in thumbnail (#26770) 2026-03-08 01:37:41 -06:00
Aleksander Pejcic aaf34fa7d4 feat(ml): enable openvino for cpu (#22948)
* Enable OpenVINO CPU acceleration in Immich

* Remove unnecessary debug log

* Removing checking for device_ids for openvino since cpu will always be available

* Find OpenVINOExecutionProvider index instead of assuming index 0

* Fix openvino tests

* Fix failing test mock. OpenVINO expects provider options, but cuda provide doesn't so use that for mocked tests.

* Support empty provider options in OrtSessions in which case ONNXRuntime will use its own defaults

* Use OpenVINOExecutionProvider for test_sets_provider_options_kwarg

* fix mock

* simplify

* unused variable

---------

Co-authored-by: Aleksander <pejcic@adobe.com>
Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com>
2026-03-07 18:40:43 +00:00
Sergey Katsubo 4a384bca86 fix(server): opus handling as accepted audio codec in transcode policy (#26736)
* Fix opus handling as accepted audio codec in transcode policy

Fix the issue when opus is among accepted audio codecs in transcode policy
(which is default) but it still triggers transcoding because the codec name
from ffprobe (opus) does not match `libopus` literal in Immich.

Make a distinction between a codec name and encoder:
- codec name: switch to `opus` as the audio codec name. This matches what ffprobe
returns for a media file with opus audio.
- encoder: continue using the `libopus` encoder in ffmpeg.

* Add unit tests for accepted audio codecs and for libopus encoder

* Add db migration for ffmpeg.targetAudioCodec opus

* backward compatibility

* tweak

* noisy logs

* full mapping

* make check happy

* mark deprecated

* update api

* indexOf

---------

Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com>
2026-03-07 13:08:42 -05:00
Thomas dd72ec2621 fix(mobile): correct local asset dimensions (#26677)
* fix(mobile): correct local asset dimensions

We are constraining the size of videos so that they play nicely with
hero animations, and don't stretch in weird ways. This however caused a
regression as we are not account for local assets on Android which have
un-oriented dimensions.

* post-orientation width and height in local sync

* migration

* no need to handle it in asset viewer

---------

Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com>
Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-07 13:07:34 -05:00
Luis Nachtigall e73686bd76 feat(android): enhance playback style detection using MIME type, reducing glide exposure (#26747)
* feat(android): enhance playback style detection using MIME type

* feat(android): improve playback style detection for GIF and WebP formats

* fix(android): make playback style detection faster

* refactor(android): simplify XMP reading logic for API 29 and below

* update playback style detection documentation

* use DefaultImageHeaderParser instead of all available ones for webp playbackStyle type detection
2026-03-07 10:41:26 -05:00
Snowknight26 6e9a425592 fix(web): asset viewer showing wrong viewer type when hovering on stack thumbnails (#26741) 2026-03-06 21:17:11 +01:00
Thomas 6012d22d98 fix(mobile): incorrect asset dimensions in search (#26725)
Search results use a different provider than the main timeline, and they
appear appear to have diverged a bit. This means that assets can
sometimes look wrong or different in search compared to the main
timeline or albums.
2026-03-05 21:58:58 -06:00
Min Idzelis abfcffb423 feat(web): toggle zoom on double-click in photo viewer (#26732) 2026-03-05 21:58:09 -06:00
Min Idzelis ec7246b86f refactor(web): add --font-sans CSS variable for primary font (#26730) 2026-03-06 03:00:37 +00:00
Brandon Wees 9597f8c37f feat(mobile): SyncAssetEditV1 (#26518)
* feat(mobile): SyncAssetEditV1

* fix: websocket handling

* fix: server version requirement

* fix: revert pubspec changes
2026-03-05 13:03:59 -06:00
Alex 7b0deb1fd3 fix: playback style migration (#26718) 2026-03-05 12:51:58 -06:00
Thomas 5ab05e57fa fix(mobile): inconsistent asset details background (#26634)
The background of the photo view does not extend below the height of the
viewport, and so the asset details fade in over black with the photo
view, and the standard surface colour scheme of the scaffold for the
rest. This leads to a janky animation. We can't change the background of
the scaffold to black, as it in turn makes the iOS bouncing scroll
physics cut off incorrectly. The best fix is to remove background
decoration from the photo view, and defer to the parent to colour the
background.

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-05 17:45:21 +00:00
Marvin M ba3f114625 chore: always use Package Imports (#26630)
* chore: always_use_package_imports

* fix: lint

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-05 11:18:01 -06:00
Mees Frensel 9b642633c1 fix(server): clarify transcoding bitrate policy (#26711) 2026-03-05 12:13:29 -05:00
Mert a05c8c6087 feat(mobile): use shared native client (#25942)
* use shared client in dart

fix android

* websocket integration

platform-side headers

update comment

consistent platform check

tweak websocket handling

support streaming

* redundant logging

* fix proguard

* formatting

* handle onProgress

* support videos on ios

* inline return

* improved ios impl

* cleanup

* sync stopForegroundBackup

* voidify

* future already completed

* stream request on android

* outdated ios ws code

* use `choosePrivateKeyAlias`

* return result

* formatting

* update tests

* redundant check

* handle custom headers

* move completer outside of state

* persist auth

* dispose old socket

* use group id for cookies

* redundant headers

* cache global ref

* handle network switching

* handle basic auth

* apply custom headers immediately

* video player update

* fix

* persist url

* potential logout fix

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-05 11:04:45 -06:00
Mert 35a521c6ec fix(ml): batch size setting (#26524) 2026-03-05 12:01:47 -05:00
Snowknight26 09fabb36b6 fix(web): video stealing focus when it plays again when looping (#26704) 2026-03-05 15:41:27 +00:00
Daniel Dietzler c259fee309 chore: cleanup vscode settings (#26709) 2026-03-05 08:12:59 -05:00
renovate[bot] 78ba9cbc63 chore(deps): update dependency multer to v2.1.1 [security] (#26705)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-05 10:59:51 +01:00
Michel Heusschen 33d75462c9 fix(web): combobox dropdown positioning in modals (#26707) 2026-03-05 10:58:26 +01:00
Mees Frensel e9451f10d6 chore(web): small cleanup of timeline month (#26708) 2026-03-05 09:53:20 +00:00
Min Idzelis 480b7e8d65 chore: configure ESLint flat config and auto-fix on save in VSCode settings (#26679) 2026-03-04 14:55:02 -05:00
Thomas 228ac63ab9 feat(mobile): keep search results visible (#26498)
Search results are replaced with a spinner when loading the next page,
which is quite jarring. Search results now remain visible when loading
the next page with a spinner at the bottom. The next page also loads
sooner, which makes it feel a lot smoother.

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-04 11:27:11 -06:00
Thomas 7e9da945f6 chore(mobile): simplify asset page scroll (#26635)
In order to scroll smoothly without interfering with the gesture
detector on the photo view, we have an offstate scroll view which we
defer all drags to, and then forward scroll offsets to the real scroll
controller. This works well, but it can be simpler. Instead, we can
create a custom scroll controller on a scroll view with never scrollable
physics, and then forward drag events to that, bypassing the need for a
proxy scroll controller.

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-03-04 10:28:55 -06:00
Thomas dd03c9c0a9 fix(mobile): add safe area for asset details (#26675) 2026-03-04 09:47:51 -06:00
Mees Frensel 16e4a2b92a fix(docs): we usually don't assign issues (#26691)
Update CONTRIBUTING.md
2026-03-04 09:43:19 -06:00
Andreas Heinz 5caa7e1902 feat(web): bounding box for faces when hovering over the face in photo view (#26667)
* feat(web): when hovering over a face already deteced, display the bounding box also shown when hovering over the person in the details-pane.

* prevent lint error

* fix unused var
2026-03-04 15:27:26 +00:00
Snowknight26 8279e1078a fix(web): download toast showing wrong filename for motion assets (#26689) 2026-03-04 16:22:48 +01:00
Timon 011ecbb43d refactor(web): remove replaceAsset action (#26444) 2026-03-04 09:05:44 -06:00
Min Idzelis 2725c96cb1 chore: add recommended VSCode workspace extensions (#26682) 2026-03-04 09:29:15 -05:00
Daniel Dietzler 3c476b1987 chore: vitest 4 for web, cli, and e2e (#26668) 2026-03-04 14:19:13 +00:00
Snowknight26 5989c9b4aa fix(web): inconsistent asset nav bar state after visiting shared link (#26674) 2026-03-04 08:25:29 -05:00
Min Idzelis 13c4260a1f fix: resolve medium test asset paths relative to file location (#26683) 2026-03-04 08:23:58 -05:00
Min Idzelis 54bc9ddd69 chore: add vitest project names and fix server config root paths (#26684)
Add `name` to all vitest configs matching CI job buckets (server:unit,
server:medium, cli:unit, web:unit, e2e:server, e2e:maintenance) so they
appear as filterable @tags in the Vitest VSCode extension.

Fix `root` in server vitest configs to use an absolute path derived from
`import.meta.url` instead of `'./'`, which resolved relative to the config
file directory (`server/test/`) rather than `server/`, causing test
discovery to fail in the Vitest VSCode extension.
2026-03-04 08:20:43 -05:00
Paul Makles f94e0fbc39 fix(maintenance mode): wait for valid server config on restart (#26456)
Signed-off-by: izzy <me@insrt.uk>
2026-03-04 11:16:21 +00:00
Nicolò Maria Semprini 5532f669eb feat: improve HEIC, HEIF and JPEG XL browser support detection (#26122)
feat: improve heic, heif and jxl browser support detection
2026-03-03 22:41:51 -05:00
Min Idzelis e4c24bdec8 chore: enable prettier caching and quiet output (#26681) 2026-03-04 03:34:48 +00:00
Savely Krasovsky 56f14162f6 chore: bump base images manually (#26670) 2026-03-04 00:54:55 +00:00
renovate[bot] 8abbbc49cf chore(deps): update dependency opentofu to v1.11.5 (#26655)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-03 16:53:01 +00:00
Thomas 4eb08eee18 fix(mobile): video state (#26574)
Consolidate video state into a single asset-scoped provider, and reduce
dependency on global state generally. Overall this should fix a few
timing issues and race conditions with videos specifically, and make
future changes in this area easier.
2026-03-03 10:28:07 -06:00
Mees Frensel 0560f98c2d chore(web): clarify locale settings description (#25562) 2026-03-03 12:52:17 +01:00
Brandon Annin 49ad411d50 fix(docs): add ocr to job flow diagram (#26505) 2026-03-03 12:43:59 +01:00
renovate[bot] 2478cc40f4 chore(deps): update dependency terragrunt to v0.99.4 (#26658)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-03 11:42:11 +00:00
Joe Babbitt 44eeb1e088 fix: implement existing withStacked on searchAssetBuilder (#26607)
Co-authored-by: Joe <code@joebabbitt.com>
2026-03-03 11:41:29 +00:00
Min Idzelis a868ae3ad0 perf: move album fetching into detail panel (#26632) 2026-03-03 12:25:03 +01:00
renovate[bot] acac0d4f37 chore(deps): update github-actions (#26656)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: bo0tzz <git@bo0tzz.me>
2026-03-03 11:14:12 +00:00
Michel Heusschen 8c40a28fef fix(server): clean up edited thumbnail when deleting asset (#26664) 2026-03-03 12:08:07 +01:00
renovate[bot] b2081eda1e fix(deps): update typescript-projects (#26657)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
2026-03-03 12:06:22 +01:00
renovate[bot] 9670c853c6 chore(deps): update docker.io/valkey/valkey:9 docker digest to 2bce660 (#26652)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-03 12:02:04 +01:00
renovate[bot] cc2dacb308 chore(deps): update prom/prometheus docker digest to 4a61322 (#26653)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-03 11:23:13 +01:00
renovate[bot] 15fc6b18f3 chore(deps): update dependency @types/node to ^24.10.14 (#26654)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-03 09:22:58 +00:00
Mees Frensel a284e38890 fix(web): timeline and asset viewer RTL support (#26513) 2026-03-03 09:01:54 +01:00
Thomas 05010c3a84 fix(mobile): asset viewer hero animation (#26545)
The image in the photo view has no height, and is therefore entirely
unconstrained. This causes the image to take up the full height of the
viewport during the hero animation, which can make look out of sync. In
some other cases, it can stretch or resize the image to fill the entire
viewport.
2026-03-02 22:26:53 -06:00
Min Idzelis 4da3d68a67 refactor: use keyed each for face bounding boxes (#26648) 2026-03-02 22:16:13 -06:00
Min Idzelis 20c639e52a refactor: extract shared ContentMetrics for overlay position calculations (#26310) 2026-03-02 21:49:56 -06:00
Luis Nachtigall 6deb97d5bc fix(mobile): android detect supported version for special format column (#26633)
* fix(android): detect supported version for special format column

* fix(android): remove unnecessary suppression for new API in special format check

* fix(android): change visibility of hasSpecialFormatColumn method to private
2026-03-02 17:06:35 -05:00
Snowknight26 b282d83e95 fix(web): show shared link download button when logged in (#26629) 2026-03-02 22:00:23 +01:00
Jason Rasmussen 5bc08f8654 refactor: queue names (#26650) 2026-03-02 15:46:26 -05:00
shenlong f54924d46a refactor: simplify video zooming (#26527)
fix: simplify video zooming

# Conflicts:
#	mobile/lib/presentation/widgets/asset_viewer/asset_page.widget.dart
#	mobile/lib/presentation/widgets/asset_viewer/video_viewer.widget.dart

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-03-02 17:53:49 +00:00
Michel Heusschen dffe4d1d5c refactor(web): remove resize observer action (#26647) 2026-03-02 14:45:34 +00:00
Min Idzelis 7f47cdd645 feat: enhance face-editor positioning (#26303)
feat: enhance face-editor positioning - less overlap

test: timeline with actual video
2026-03-02 09:44:59 -05:00
Min Idzelis 625b30c50a test: stack editor e2e tests (#26526)
* feat: add responsive layout to broken asset

* test: stack editor e2e tests
2026-03-02 09:43:56 -05:00
Min Idzelis 8619d14eca feat: add responsive layout to broken asset (#26384) 2026-03-02 09:27:40 -05:00
Min Idzelis 062546c168 refactor: rename image cancel method (#26381) 2026-03-02 09:23:20 -05:00
Michel Heusschen ea668d6b22 refactor(web): convert memory observer to an attachment (#26646) 2026-03-02 09:20:13 -05:00
Michel Heusschen f06af2c600 refactor(web): dedupe isAllUserOwned logic (#26645) 2026-03-02 09:18:32 -05:00
Snowknight26 9dd2633e0c chore(web): deduplicate storage template examples (#26462) 2026-03-02 12:52:02 +01:00
Mees Frensel 13a514c189 fix(web): small thumbnail issues (#26643) 2026-03-02 12:50:33 +01:00
Mees Frensel b0c9120bb6 chore: update PWA support (#26491) 2026-03-02 11:35:53 +00:00
Yaros bc4265416d fix(web): top bar z index on search page (#26582) 2026-03-02 11:33:00 +01:00
shenlong d4434f2276 fix: reset db from splash screen (#26617)
Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-03-01 15:23:26 -06:00
Luis Nachtigall f4e156494f feat(mobile): add playbackStyle to local asset entity and related database schema (#26596)
* feat: add playbackStyle to local asset entity and related database schema

* implement conversion function for playbackStyle in local sync service

* implement conversion function for playbackStyle in local sync service

* refactor: remove deducedPlaybackStyle from TrashedLocalAssetEntityData

* add playbackStyle column to trashed local asset entity

* make playbackStyle non-nullable across the mobile codebase

* Streamline playbackStyle backfill:
- only backfill local assets playbackStyle in flutter/dart code
- only update trashed local assets in db migration

* bump target database version to 23 and update migration logic for playbackStyle

* set playback_style to 0 in merged_asset.drift as its a getter in base asset

* run make pigeon

* Populate playbackStyle for trashed assets during native migration
2026-03-01 14:50:21 -05:00
Min Idzelis 84abad564e fix(server): deduplicate shared links in getAll query (#26395) 2026-03-01 14:41:15 -05:00
renovate[bot] 02d356f5dd chore(deps): update dependency multer to v2.1.0 [security] (#26613)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-01 11:34:11 +01:00
renovate[bot] e963eedd26 chore(deps): update dependency @sveltejs/kit to v2.53.3 [security] (#26612)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-01 11:33:51 +01:00
renovate[bot] 3da4acfe67 chore(deps): update dependency svelte to v5.53.5 [security] (#26611)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-03-01 11:22:54 +01:00
Yaros e06cedb626 fix: hide download action for local/merged assets (#26461)
* fix: hide download action for local/merged assets

* chore: use onlyRemote

* chore: rename hasLocal to onlyLocal
2026-03-01 11:16:45 +05:30
Luis Nachtigall ac5ef6a56d feat(mobile): add support for encoded image requests in local/remote image APIs (#26584)
* feat(mobile): add support for encoded image requests in local and remote image APIs

* fix(mobile): handle memory cleanup for cancelled image requests

* refactor(mobile): simplify memory management and response handling for encoded image requests

* fix(mobile): correct formatting in cancellation check for image requests

* Apply suggestion from @mertalev

Co-authored-by: Mert <101130780+mertalev@users.noreply.github.com>

* refactor(mobile): rename 'encoded' parameter to 'preferEncoded' for clarity in image request APIs

* fix(mobile): ensure proper resource cleanup for cancelled image requests

* refactor(mobile): streamline codec handling by removing unnecessary descriptor disposal in loadCodec request

---------

Co-authored-by: Mert <101130780+mertalev@users.noreply.github.com>
2026-02-28 11:43:58 -05:00
Luis Nachtigall d6c724b13b feat(mobile): add playbackStyle to native sync API (#26541)
* feat(mobile): add playbackStyle to native sync API

Adds a `playbackStyle` field to `PlatformAsset` in the pigeon sync API so
native platforms can communicate the asset's playback style (image, video,
animated, livePhoto) to Flutter during sync.

- Add `playbackStyleValue` computed property to `PHAsset` extension (iOS)
- Populate `playbackStyle` in `toPlatformAsset()` and the full-sync path
- Update generated Dart/Kotlin/Swift files

* fix(tests): add playbackStyle to local asset test cases

* fix(tests): update playbackStyle to use integer values in local sync tests

* feat(mobile): extend playbackStyle enum to include videoLooping

* Update PHAssetExtensions.swift

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* fix(playback): simplify playbackStyleValue implementation by removing iOS version check

* feat(android): implement proper playbackStyle detection

* add PlatformAssetPlaybackStyle enum

* linting

---------

Co-authored-by: Mert <101130780+mertalev@users.noreply.github.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2026-02-28 03:08:51 +00:00
Hao Xi aa87d1b9a3 fix: tune up the performance of the getByDayOfYear query. (#26495) 2026-02-27 16:51:19 -05:00
Savely Krasovsky dc4da4b3d6 feat: update onnxruntime-openvino to 1.24.1 and intel drivers (#26565)
feat: update onnxruntime-openvino to 1.24.1 and intel drivers to the latest version
2026-02-27 16:35:29 -05:00
Marius 7dbd08a747 feat(mobile): add confirmation dialog to permanent delete action (#26442) 2026-02-27 15:49:57 +00:00
Thomas 1d89190f96 fix(mobile): don't cut off top corners of app bar (#26550)
It's not visible normally, but in screenshots and when casting, the top
corners of the app bar are cut off. This should fix that.
2026-02-27 17:39:58 +05:30
Thomas c2d8400899 fix(mobile): prevent video player from being recreated unnecessarily (#26553)
The changes in #25952 inadvertently removed an optimisation which
prevents the video player from being recreated when the tree changed.
This happens surprisingly often, namely when the hero animation
finishes. The widget is particularly expensive, so recreating it 2-3 in
a short period not only feels sluggish, but also causes the video to
hitch and restart.

The solution is to bring the global key back for the native video
player. Unlike before, we are using a custom global key which compares
the values of hero tags directly. This means we don't need to maintain a
map of hero tags to global keys in the state, and also means we don't
have to pass the global key down multiple layers.

This also fixes #25981.
2026-02-27 17:39:38 +05:30
Mees Frensel a100a4025e fix(web): handle delete shortcut on shared link page as remove (#26552) 2026-02-27 12:50:06 +01:00
Nikhil Alapati 334fc250d3 fix(server): Live Photo migration bug when album is in template (#25329)
Co-authored-by: Nikhil Alapati <nikhilalapati@meta.com>
2026-02-27 12:46:55 +01:00
Michel Heusschen 28ca5f59fe fix(web): map timeline asset count (#26564) 2026-02-27 12:28:53 +01:00
Thomas 789d82632a fix(mobile): race condition showing details (#26559)
Asset details are prematurely hidden when a drag ends if the simulation
shows that it will close given its current velocity. It makes for a much
more responsible feeling UI. However, this behaviour conflicts with the
logic which determines whether details are showing based on the current
offset. The result is that the details are hidden, then immediately
shown again, and then hidden once it passes the min snap distance
threshold.

This can be fixed by only evaluating the position based logic when a
drag is active, and then inferring upcoming state with a simulation.
2026-02-27 12:12:24 +05:30
Daniel Dietzler 9f9569c152 fix: schema check (#26543) 2026-02-26 13:27:50 -05:00
Jason Rasmussen fae05270a3 feat: doc links (#26519) 2026-02-26 12:14:17 -05:00
Michel Heusschen 771816f601 feat(web): map timeline sidepanel (#26532)
* feat(web): map timeline panel

* update openapi

* remove #key

* add index on lat/lng
2026-02-26 12:03:23 -05:00
Daniel Dietzler e25ec4ec17 chore: migrate migration scripts to sql tools (#26537) 2026-02-26 17:59:52 +01:00
Kishor Prins dd9046508d feat: ROCm 7.2 and MIGraphX support (#26178) 2026-02-26 16:52:26 +00:00
shenlong 177d1c9a30 feat: splash screen error page (#26460)
* feat: splash screen error page

* Update mobile/lib/pages/common/splash_screen.page.dart

Co-authored-by: Alex <alex.tran1502@gmail.com>

* add clear data action

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-02-26 16:47:28 +00:00
Noel S ded8d4e2b4 fix(mobile): set correct initial system-ui mode in asset viewer (#26500)
* fix: set correct initial system-ui mode on asset open

* move to function and add details visibility to initial state logic

* switch to ref.read
2026-02-26 10:10:46 -06:00
Mees Frensel e454c3566b refactor: star rating (#26357)
* refactor: star rating

* transform rating 0 to null in controller dto

* migrate rating 0 to null

* deprecate rating -1

* rating type annotation

* update Rating type
2026-02-26 14:54:20 +01:00
Luis Nachtigall 4c79c3c902 feat(mobile): Prevent premature image cache eviction when higher image loading is enabled (#26208)
* feat(mobile): enhance image loading with error handling and eviction options

* pull request suggestions: remove log and remove useless local implementation
2026-02-25 17:31:37 -05:00
Alex 3bed1b6131 fix: consider DAR when extracting video dimension (#25293)
* feat: consider DAR when extracting video dimension

* move to probe

* comment

---------

Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com>
2026-02-25 21:58:53 +00:00
Brandon Wees 3c9fb651d0 feat(server): SyncAssetEditV1 (#26446)
* feat: SyncAssetEditV1

* fix: audit table import

* fix: sql tools table fetch

* fix: medium tests (wip)

* fix: circ dependency

* chore: finalize tests

* chore: codegen/lint

* fix: code review
2026-02-25 18:12:41 +00:00
Mees Frensel 55e625a2ac fix(web): error page i18n (#26517) 2026-02-25 18:35:25 +01:00
Daniel Dietzler ca6c486a80 refactor: person stubs (#26512) 2026-02-25 08:56:00 -05:00
socksprox d94d9600a7 fix(mobile): birthday picker shows limited months when no date exists (#26407)
* ScrollDatePicker defaults maximumDate to DateTime.now(). When no birthday exists, the picker starts at today (Feb 2026) with max also Feb 2026 — so only Jan–Feb are available for the current year.

Fix applied: Added maximumDate: DateTime(DateTime.now().year, 12, 31) at person_edit_birthday_modal.widget.dart:93, allowing all 12 months to be selected while still preventing future-year birthdays.

* fix(mobile): initialize birthday picker to past date to prevent future birthdays

When no birthday exists, initialize to 30 years ago instead of today.
This allows all 12 months to be selectable while keeping maximumDate
as DateTime.now() to prevent future birthday selection.

Fixes issue where only current months were available due to maxDate constraint.

---------

Co-authored-by: socksprox <info@shadowfly.net>
2026-02-25 07:58:02 +05:30
Mees Frensel 11e5c42bc9 fix(web): toast warning when trying to upload unsupported file type (#26492) 2026-02-24 15:58:40 -05:00
shenlong 33c6cf8325 test: backup repository (#26494)
test: backup repository tests

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-24 15:50:02 -05:00
renovate[bot] dd97395f3a chore(deps): update dependency gunicorn to v25 (#26486)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-02-24 16:14:04 +00:00
renovate[bot] 7ae268e287 fix(deps): update dependency exiftool-vendored to v35 (#26488)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
2026-02-24 14:40:57 +01:00
Jason Rasmussen f07e2b58f0 refactor: prefer buffer (#26469)
* refactor: prefer buffer

* Update server/src/schema/tables/session.table.ts

Co-authored-by: Daniel Dietzler <36593685+danieldietzler@users.noreply.github.com>

---------

Co-authored-by: Daniel Dietzler <36593685+danieldietzler@users.noreply.github.com>
2026-02-24 13:26:36 +00:00
shenlong 4b8f90aa55 refactor: remote album repository test to use context (#26481)
* refactor: remote album repository test to use context

* refactor: medium repo context (#26482)

* refactor: medium repo context

* store userId in closure

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-24 13:25:07 +00:00
Daniel Dietzler 55ee9f76da chore: eslint 10 (#26490) 2026-02-24 08:24:18 -05:00
Michel Heusschen 30f6d4439e fix(web): prevent null folder tree on concurrent load (#26489) 2026-02-24 08:23:07 -05:00
renovate[bot] f62d98a0d1 chore(deps): update dependency eslint-plugin-unicorn to v63 (#26484)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-02-24 12:34:12 +01:00
renovate[bot] db3d580761 chore(deps): update dependency globals to v17 (#26485)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-02-24 12:18:01 +01:00
renovate[bot] 0bc38fefe6 fix(deps): update typescript-projects (#26483)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
2026-02-24 11:15:26 +00:00
renovate[bot] acc4219849 chore(deps): update actions/checkout action to v6.0.2 (#26477)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2026-02-24 10:09:34 +01:00
shenlong 5234e21241 fix: retain asset when either asset is a favorite (#26473)
Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-23 16:52:34 -05:00
shenlong 17b327bfcd refactor: medium repository context (#26472)
refactor: repository test context

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-23 21:34:21 +00:00
Min Idzelis d14d0a9b9b feat: add isTransparent to db (#26413) 2026-02-23 21:33:52 +00:00
Mees Frensel bf47147fbb fix(server): accept showAt and hideAt for creating memories (#26429)
* fix(server): accept showAt and hideAt for creating memories

* fix history
2026-02-23 21:26:34 +00:00
aviv926 9ea0a69a72 feat(docs): Adding information about parameter c= (#26430)
* Adding information about parameter c=

* Apply suggestions from code review

Co-authored-by: bo0tzz <git@bo0tzz.me>

---------

Co-authored-by: Jason Rasmussen <jason@rasm.me>
Co-authored-by: bo0tzz <git@bo0tzz.me>
2026-02-23 21:21:06 +00:00
shenlong 00f43ffc25 chore: add Option type (#26467)
Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-23 16:20:25 -05:00
Jonathan Jogenfors 96dc4a77a0 fix: always show library scan button (#26428)
* fix: always show library scan button

* chore: clean up

---------

Co-authored-by: Jason Rasmussen <jason@rasm.me>
2026-02-23 21:18:23 +00:00
shenlong db7158b967 refactor: ImmichHtmlText to ImmichFormattedText (#26466)
Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-23 16:05:00 -05:00
Brandon Wees e5722c525b feat: getAssetEdits respond with edit IDs (#26445)
* feat: getAssetEdits respond with edit IDs

* chore: cleanup typings for edit API

* chore: cleanup types with jason

* fix: openapi sync

* fix: factory
2026-02-23 20:57:57 +00:00
shenlong f616de5af8 chore(mobile): nudge users to switch to the new timeline (#26458)
* nudge users to switch to the new timeline

* remove timeline switch setting from new timeline

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-23 13:42:32 -06:00
shenlong 4f39663d27 fix: simplify timeline rebuild on orientation (#26408)
* revert: current fix

# Conflicts:
#	mobile/lib/presentation/widgets/timeline/timeline.widget.dart

* fix: simpler fix

* rebase

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
2026-02-23 13:30:09 -05:00
Thomas 367025a3a8 chore(mobile): simplify showing details toggle (#26403)
Keeping track of the last scroll offset and guarding on scroll direction
is not necessary. The dead zone with kTouchSlop is more than sufficient,
and much simpler.

Co-authored-by: shenlong <139912620+shenlong-tanwen@users.noreply.github.com>
2026-02-23 23:49:35 +05:30
Min Idzelis 60dafecdc9 refactor: thumbnail components (#26379) 2026-02-23 11:56:20 -05:00
Yaros 16c1c3c780 fix(mobile): join local on archived timeline (#26387) 2026-02-23 20:21:32 +05:30
Brandon Wees e633bc3f24 fix: missing deletedAt and isVisible columns on mobile (#26414)
* feat: SyncAssetV2

* feat: mobile sync handling

* feat: request correct sync object based on server version

* fix: mobile queries

* chore: sync sql

* fix: test

* chore: switch to mapper

* fix: sql sync
2026-02-23 09:50:54 -05:00
Daniel Dietzler a07d7b0c82 chore: migrate to sql-tools library (#26400)
Co-authored-by: Jason Rasmussen <jason@rasm.me>
2026-02-23 09:50:16 -05:00
Yaros a469d350be feat(mobile): prompt when deleting from trash (#26392)
* feat(mobile): prompt when deleting from trash

* refactor: use existing strings

* chore: use type-safe translations

* chore: remove old translation function
2026-02-23 14:45:05 +00:00
Yaros ccab4c88bb perf(mobile): optimized album sorting (#25179)
* perf(mobile): optimized album sorting

* refactor: add index & sql query

* fix: migration

* refactor: enum, ordering & list

* test: update album service tests

* chore: fix enums

broken during merging main

* chore: remove unnecessary tests

* test: add tests for getSortedAlbumIds

* test: added back stubs in service test
2026-02-23 20:13:45 +05:30
Min Idzelis 430638e129 feat: warn when losing transparency during thumbnail generation (#26243)
* feat: preserve alpha

* refactor: use isTransparent naming and separate getImageMetadata

* warn instead of preserve
2026-02-23 08:16:28 -05:00
Thomas caebe5166a chore(mobile): remove redundant assignment (#26404)
The view controller is already assigned during page build. Reassigning
it for every drag doesn't really make any sense.
2026-02-23 12:48:25 +00:00
Michel Heusschen 1bd28c3e78 fix(web): prevent state_unsafe_mutation error on people page (#26438) 2026-02-23 13:24:51 +01:00
Matthew Momjian 31a55aaa73 fix(web): storage template example (#26424) 2026-02-23 10:34:56 +00:00
Thomas 8b2e1509ff chore(mobile): simplify pop logic (#26410)
We have all the information we need to decide on whether we should pop
or not at the end of a drag. There's no need to track that separately,
and update the value constantly.
2026-02-23 14:49:15 +05:30
Lauritz Tieste d0cb97f994 feat(mobile): Add slug support for shared links (#26441)
* feat(mobile): add slug support for shared links

* fix(mobile): ensure slug retains existing value when unchanged
2026-02-23 14:31:42 +05:30
Timon f0cf3311d5 feat(mobile): Allow users to set profile picture from asset viewer (#25517)
* init

* fix

* styling

* temporary workaround for 500 error

**Root cause:**
The autogenerated Dart OpenAPI client (`UsersApi.createProfileImage()`) had two issues:
1. It set `Content-Type: multipart/form-data` without a boundary, which overrode the correct header that Dart's `MultipartRequest` would set (`multipart/form-data; boundary=...`).
2. It added the file to both `mp.fields` and `mp.files`, creating a duplicate text field.

**Result:**
Multer on the server failed to parse the multipart body, so `@UploadedFile()` was `undefined` → accessing `file.path` in `UserService.createProfileImage()` threw → **500 Internal Server Error**.

**Workaround:**
Bypass the autogenerated method in `UserApiRepository.createProfileImage()` and send the multipart request directly using the same `ApiClient` (basePath + auth), ensuring:
- No manual `Content-Type` header (let `MultipartRequest` set it with boundary)
- File only in `mp.files`, not `mp.fields`
- Proper filename fallback

* Revert "temporary workaround for 500 error"

This reverts commit 8436cd402632ca7be9272a1c72fdaf0763dcefb6.

* generate route for ProfilePictureCropPage

* add route import

* simplify

* try this

* Revert "try this"

This reverts commit fcf37d2801055c49010ddb4fd271feb900ee645a.

* try patching

* Reapply "temporary workaround for 500 error"

This reverts commit faeed810c21e4c9f0839dfff1f34aa6183469e56.

* Revert "Reapply "temporary workaround for 500 error""

This reverts commit a14a0b76d14975af98ef91748576a79cef959635.

* fix upload

* Refactor image conversion logic by introducing a new utility function. Replace inline image-to-Uint8List conversion with the new utility in EditImagePage, DriftEditImagePage, and ProfilePictureCropPage.

* use toast over snack

* format

* Revert "try patching"

This reverts commit 68a616522a1eee88c4a9755a314c0017e6450c0f.

* Enhance toast notification in ProfilePictureCropPage to include success type for better user feedback.

* Revert "simplify"

This reverts commit 8e85057a40.

* format

* add tests

* refactor to use statefulwidget

* format

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-02-22 06:02:33 +00:00
Timon 3ce0654cab feat(mobile): Allow users to set album cover from mobile app (#25515)
* set album cover from asset

* add to correct kebab group

* add to album selection

* add to legacy control bottom bar

* add tests

* format

* analyze

* Revert "add to legacy control bottom bar"

This reverts commit 9d68e12a08.

* remove unnecessary event emission

* lint

* fix tests

* fix: button order and remove unncessary check

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-02-22 05:53:39 +00:00
Noel S f0e2fced57 feat(mobile): video zooming in asset viewer (#22036)
* wip

* Functional implementation, still need to bug test.

* Fixed flickering bugs

* Fixed bug with drag actions interfering with zoom panning. Fixed video being zoomable when bottom sheet is shown. Code cleanup.

* Add comments and simplify video controls

* Clearer variable name

* Fix bug where the redundant onTapDown would interfere with zooming gestures

* Fix zoom not working the second time when viewing a video.

* fix video of live photo retaining pan from photo portion

* code cleanup and simplified widget stack

---------

Co-authored-by: Alex <alex.tran1502@gmail.com>
2026-02-21 23:37:36 -06:00
Alex Balgavy 8ba20cbd44 feat: tap to see next/previous image (#20286)
* feat(mobile): tap behavior for next/previous image

This change enables switching to the next/previous photo in the photo
viewer by tapping the left/right quarter of the screen.

* Avoid animation on first/last image

* Add changes to asset_viewer.page

* Add setting for tap navigation, disable by default

Not everyone wants to have tapping for next/previous image enabled, so
this commit adds a settings toggle. Since it might be confusing behavior
for new users, it is disabled by default.

* chore: refactor

* fix: lint

---------

Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2026-02-22 05:28:17 +00:00
Mert 1d25267f22 fix(mobile): buffer width/height referenced after recycling (#26415)
recycle after getters
2026-02-21 09:41:44 -06:00
Michel Heusschen a4d95b7aba fix(web): prevent side panel overlap during transition (#26398) 2026-02-21 09:14:53 -06:00
Min Idzelis 25d0bdc9f5 chore: replace remaining usages of npm with pnpm (#26411) 2026-02-21 08:44:33 -05:00
Michel Heusschen 905b9bd560 fix(web): album description auto height (#26420) 2026-02-21 08:43:23 -05:00
Michel Heusschen 672743f543 fix(web): escape handling on album page (#26419) 2026-02-21 08:42:31 -05:00
Michel Heusschen 27c45b5ddb fix(web): restore close action for asset viewer (#26418) 2026-02-21 10:31:30 +00:00
Peter Ombodi 82c6302549 feat(mobile): timeline - add persistentBottomBar flag (#25634)
* feat(mobile): timeline - add selectable all-assets control

* feature(mobile): introduce bottomWidgetBuilder in Timeline
remove redundant code

* fix(mobile): remove redundant code

* refactor(mobile): refactor new code in Timeline

* fix(mobile): fix format

* refactor(mobile): replace unsupported Dart syntax for analyzer compatibility

* refactor(mobile): remove Timeline.bottomSheet and migrate to bottomWidgetBuilder

* refactor(mobile): restore Timeline.bottomSheet and remove bottomWidgetBuilder
add withPersistentBottomBar param to Timeline class

* refactor(mobile): refactor var name

---------

Co-authored-by: Peter Ombodi <peter.ombodi@gmail.com>
2026-02-20 23:51:26 +05:30
Min Idzelis aae64b5e2f test: thumbnail selector (#26383)
* test: face ordering issue/flakiness

* test: thumbnail selector
2026-02-20 15:04:17 +00:00
Benjamin Nguyen 18bf96b4b2 fix(mobile): handle userPreferencesProvider error state during sync (#26332)
fix drift_search_page render bug
2026-02-20 08:57:28 -06:00
Timon 84f2956941 fix(cli): delete sidecar files after upload if requested (#26353)
* fix(cli): delete sidecar files after upload if requested

Introduced a new function, findSidecar, to locate XMP sidecar files based on specified naming conventions. Updated the deleteFiles function to delete associated sidecar files when the main asset file is deleted. Added unit tests for findSidecar to ensure correct functionality.

* lint and format

* fix test

* chore: clean up

---------

Co-authored-by: Jason Rasmussen <jason@rasm.me>
2026-02-20 14:54:08 +00:00
Min Idzelis 6044b41648 fix: align devcontainers with standard development containers (#26321) 2026-02-20 09:37:07 -05:00
Min Idzelis b4e16efdf4 test: face ordering issue/flakiness (#26382) 2026-02-20 09:23:40 -05:00
Min Idzelis 19da655390 fix: exiftool-vendored.exe (#26393) 2026-02-20 09:16:42 -05:00
1029 changed files with 54907 additions and 24360 deletions
+3 -24
View File
@@ -2,6 +2,7 @@
"name": "Immich - Backend, Frontend and ML", "name": "Immich - Backend, Frontend and ML",
"service": "immich-server", "service": "immich-server",
"runServices": [ "runServices": [
"immich-init",
"immich-server", "immich-server",
"redis", "redis",
"database", "database",
@@ -31,29 +32,8 @@
"tasks": { "tasks": {
"version": "2.0.0", "version": "2.0.0",
"tasks": [ "tasks": [
{
"label": "Fix Permissions, Install Dependencies",
"type": "shell",
"command": "[ -f /immich-devcontainer/container-start.sh ] && /immich-devcontainer/container-start.sh || exit 0",
"isBackground": true,
"presentation": {
"echo": true,
"reveal": "always",
"focus": false,
"panel": "dedicated",
"showReuseMessage": true,
"clear": false,
"group": "Devcontainer tasks",
"close": true
},
"runOptions": {
"runOn": "default"
},
"problemMatcher": []
},
{ {
"label": "Immich API Server (Nest)", "label": "Immich API Server (Nest)",
"dependsOn": ["Fix Permissions, Install Dependencies"],
"type": "shell", "type": "shell",
"command": "[ -f /immich-devcontainer/container-start-backend.sh ] && /immich-devcontainer/container-start-backend.sh || exit 0", "command": "[ -f /immich-devcontainer/container-start-backend.sh ] && /immich-devcontainer/container-start-backend.sh || exit 0",
"isBackground": true, "isBackground": true,
@@ -74,7 +54,6 @@
}, },
{ {
"label": "Immich Web Server (Vite)", "label": "Immich Web Server (Vite)",
"dependsOn": ["Fix Permissions, Install Dependencies"],
"type": "shell", "type": "shell",
"command": "[ -f /immich-devcontainer/container-start-frontend.sh ] && /immich-devcontainer/container-start-frontend.sh || exit 0", "command": "[ -f /immich-devcontainer/container-start-frontend.sh ] && /immich-devcontainer/container-start-frontend.sh || exit 0",
"isBackground": true, "isBackground": true,
@@ -130,8 +109,8 @@
} }
}, },
"overrideCommand": true, "overrideCommand": true,
"workspaceFolder": "/workspaces/immich", "workspaceFolder": "/usr/src/app",
"remoteUser": "node", "remoteUser": "root",
"userEnvProbe": "loginInteractiveShell", "userEnvProbe": "loginInteractiveShell",
"remoteEnv": { "remoteEnv": {
// The location where your uploaded files are stored // The location where your uploaded files are stored
@@ -1,23 +1,17 @@
services: services:
immich-app-base:
image: busybox
immich-server: immich-server:
extends:
service: immich-app-base
profiles: !reset []
image: immich-server-dev:latest
build: build:
target: dev-container-mobile target: dev-container-mobile
environment: environment:
- IMMICH_SERVER_URL=http://127.0.0.1:2283/ - IMMICH_SERVER_URL=http://127.0.0.1:2283/
volumes: !override # bind mount host to /workspaces/immich volumes:
- ..:/workspaces/immich
- ${UPLOAD_LOCATION:-upload-devcontainer-volume}${UPLOAD_LOCATION:+/photos}:/data - ${UPLOAD_LOCATION:-upload-devcontainer-volume}${UPLOAD_LOCATION:+/photos}:/data
- pnpm-store:/usr/src/app/.pnpm-store
- server-node_modules:/usr/src/app/server/node_modules
- web-node_modules:/usr/src/app/web/node_modules
- github-node_modules:/usr/src/app/.github/node_modules
- cli-node_modules:/usr/src/app/cli/node_modules
- docs-node_modules:/usr/src/app/docs/node_modules
- e2e-node_modules:/usr/src/app/e2e/node_modules
- sdk-node_modules:/usr/src/app/open-api/typescript-sdk/node_modules
- app-node_modules:/usr/src/app/node_modules
- sveltekit:/usr/src/app/web/.svelte-kit
- coverage:/usr/src/app/web/coverage
- /etc/localtime:/etc/localtime:ro - /etc/localtime:/etc/localtime:ro
immich-web: immich-web:
env_file: !reset [] env_file: !reset []
+2 -1
View File
@@ -2,6 +2,7 @@
"name": "Immich - Mobile", "name": "Immich - Mobile",
"service": "immich-server", "service": "immich-server",
"runServices": [ "runServices": [
"immich-init",
"immich-server", "immich-server",
"redis", "redis",
"database", "database",
@@ -35,7 +36,7 @@
}, },
"forwardPorts": [], "forwardPorts": [],
"overrideCommand": true, "overrideCommand": true,
"workspaceFolder": "/workspaces/immich", "workspaceFolder": "/usr/src/app",
"remoteUser": "node", "remoteUser": "node",
"userEnvProbe": "loginInteractiveShell", "userEnvProbe": "loginInteractiveShell",
"remoteEnv": { "remoteEnv": {
+1 -50
View File
@@ -2,11 +2,6 @@
export IMMICH_PORT="${DEV_SERVER_PORT:-2283}" export IMMICH_PORT="${DEV_SERVER_PORT:-2283}"
export DEV_PORT="${DEV_PORT:-3000}" export DEV_PORT="${DEV_PORT:-3000}"
# search for immich directory inside workspace.
# /workspaces/immich is the bind mount, but other directories can be mounted if runing
# Devcontainer: Clone [repository|pull request] in container volumne
WORKSPACES_DIR="/workspaces"
IMMICH_DIR="$WORKSPACES_DIR/immich"
IMMICH_DEVCONTAINER_LOG="$HOME/immich-devcontainer.log" IMMICH_DEVCONTAINER_LOG="$HOME/immich-devcontainer.log"
log() { log() {
@@ -30,52 +25,8 @@ run_cmd() {
return "${PIPESTATUS[0]}" return "${PIPESTATUS[0]}"
} }
# Find directories excluding /workspaces/immich export IMMICH_WORKSPACE="/usr/src/app"
mapfile -t other_dirs < <(find "$WORKSPACES_DIR" -mindepth 1 -maxdepth 1 -type d ! -path "$IMMICH_DIR" ! -name ".*")
if [ ${#other_dirs[@]} -gt 1 ]; then
log "Error: More than one directory found in $WORKSPACES_DIR other than $IMMICH_DIR."
exit 1
elif [ ${#other_dirs[@]} -eq 1 ]; then
export IMMICH_WORKSPACE="${other_dirs[0]}"
else
export IMMICH_WORKSPACE="$IMMICH_DIR"
fi
log "Found immich workspace in $IMMICH_WORKSPACE" log "Found immich workspace in $IMMICH_WORKSPACE"
log "" log ""
fix_permissions() {
log "Fixing permissions for ${IMMICH_WORKSPACE}"
# Change ownership for directories that exist
for dir in "${IMMICH_WORKSPACE}/.vscode" \
"${IMMICH_WORKSPACE}/server/upload" \
"${IMMICH_WORKSPACE}/.pnpm-store" \
"${IMMICH_WORKSPACE}/.github/node_modules" \
"${IMMICH_WORKSPACE}/cli/node_modules" \
"${IMMICH_WORKSPACE}/e2e/node_modules" \
"${IMMICH_WORKSPACE}/open-api/typescript-sdk/node_modules" \
"${IMMICH_WORKSPACE}/server/node_modules" \
"${IMMICH_WORKSPACE}/server/dist" \
"${IMMICH_WORKSPACE}/web/node_modules" \
"${IMMICH_WORKSPACE}/web/dist"; do
if [ -d "$dir" ]; then
run_cmd sudo chown node -R "$dir"
fi
done
log ""
}
install_dependencies() {
log "Installing dependencies"
(
cd "${IMMICH_WORKSPACE}" || exit 1
export CI=1 FROZEN=1 OFFLINE=1
run_cmd make setup-web-dev setup-server-dev
)
log ""
}
@@ -1,26 +1,21 @@
services: services:
immich-app-base:
image: busybox
immich-server: immich-server:
extends:
service: immich-app-base
profiles: !reset []
image: immich-server-dev:latest
build: build:
target: dev-container-server target: dev-container-server
env_file: !reset [] env_file: !reset []
hostname: immich-dev hostname: immich-dev
environment: environment:
- IMMICH_SERVER_URL=http://127.0.0.1:2283/ - IMMICH_SERVER_URL=http://127.0.0.1:2283/
volumes: !override volumes:
- ..:/workspaces/immich
- ${UPLOAD_LOCATION:-upload-devcontainer-volume}${UPLOAD_LOCATION:+/photos}:/data - ${UPLOAD_LOCATION:-upload-devcontainer-volume}${UPLOAD_LOCATION:+/photos}:/data
- /etc/localtime:/etc/localtime:ro - /etc/localtime:/etc/localtime:ro
- pnpm-store:/usr/src/app/.pnpm-store - pnpm_store_server:/buildcache/pnpm-store
- server-node_modules:/usr/src/app/server/node_modules
- web-node_modules:/usr/src/app/web/node_modules
- github-node_modules:/usr/src/app/.github/node_modules
- cli-node_modules:/usr/src/app/cli/node_modules
- docs-node_modules:/usr/src/app/docs/node_modules
- e2e-node_modules:/usr/src/app/e2e/node_modules
- sdk-node_modules:/usr/src/app/open-api/typescript-sdk/node_modules
- app-node_modules:/usr/src/app/node_modules
- sveltekit:/usr/src/app/web/.svelte-kit
- coverage:/usr/src/app/web/coverage
- ../plugins:/build/corePlugin - ../plugins:/build/corePlugin
immich-web: immich-web:
env_file: !reset [] env_file: !reset []
-17
View File
@@ -1,17 +0,0 @@
#!/bin/bash
# shellcheck source=common.sh
# shellcheck disable=SC1091
source /immich-devcontainer/container-common.sh
log "Setting up Immich dev container..."
fix_permissions
log "Setup complete, please wait while backend and frontend services automatically start"
log
log "If necessary, the services may be manually started using"
log
log "$ /immich-devcontainer/container-start-backend.sh"
log "$ /immich-devcontainer/container-start-frontend.sh"
log
log "From different terminal windows, as these scripts automatically restart the server"
log "on error, and will continuously run in a loop"
+2 -2
View File
@@ -1,7 +1,7 @@
{ {
"scripts": { "scripts": {
"format": "prettier --check .", "format": "prettier --cache --check .",
"format:fix": "prettier --write ." "format:fix": "prettier --cache --write --list-different ."
}, },
"devDependencies": { "devDependencies": {
"prettier": "^3.7.4" "prettier": "^3.7.4"
+2 -3
View File
@@ -19,13 +19,12 @@ jobs:
contents: read contents: read
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with: with:
persist-credentials: false persist-credentials: false
- name: Check for breaking API changes - name: Check for breaking API changes
# sha is pinning to a commit instead of a tag since the action does not tag versions uses: oasdiff/oasdiff-action/breaking@748daafaf3aac877a36307f842a48d55db938ac8 # v0.0.31
uses: oasdiff/oasdiff-action/breaking@ccb863950ce437a50f8f1a40d2a1112117e06ce4
with: with:
base: https://raw.githubusercontent.com/${{ github.repository }}/main/open-api/immich-openapi-specs.json base: https://raw.githubusercontent.com/${{ github.repository }}/main/open-api/immich-openapi-specs.json
revision: open-api/immich-openapi-specs.json revision: open-api/immich-openapi-specs.json
+80
View File
@@ -0,0 +1,80 @@
name: Check PR Template
on:
pull_request_target: # zizmor: ignore[dangerous-triggers]
types: [opened, edited]
permissions: {}
jobs:
parse:
runs-on: ubuntu-latest
if: ${{ github.event.pull_request.head.repo.fork == true }}
permissions:
contents: read
outputs:
uses_template: ${{ steps.check.outputs.uses_template }}
steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
sparse-checkout: .github/pull_request_template.md
sparse-checkout-cone-mode: false
persist-credentials: false
- name: Check required sections
id: check
env:
BODY: ${{ github.event.pull_request.body }}
run: |
OK=true
while IFS= read -r header; do
printf '%s\n' "$BODY" | grep -qF "$header" || OK=false
done < <(sed '/<!--/,/-->/d' .github/pull_request_template.md | grep "^## ")
echo "uses_template=$OK" >> "$GITHUB_OUTPUT"
act:
runs-on: ubuntu-latest
needs: parse
permissions:
pull-requests: write
steps:
- name: Close PR
if: ${{ needs.parse.outputs.uses_template == 'false' && github.event.pull_request.state != 'closed' }}
env:
GH_TOKEN: ${{ github.token }}
NODE_ID: ${{ github.event.pull_request.node_id }}
run: |
gh api graphql \
-f prId="$NODE_ID" \
-f body="This PR has been automatically closed as the description doesn't follow our template. After you edit it to match the template, the PR will automatically be reopened." \
-f query='
mutation CommentAndClosePR($prId: ID!, $body: String!) {
addComment(input: {
subjectId: $prId,
body: $body
}) {
__typename
}
closePullRequest(input: {
pullRequestId: $prId
}) {
__typename
}
}'
- name: Reopen PR (sections now present, PR closed)
if: ${{ needs.parse.outputs.uses_template == 'true' && github.event.pull_request.state == 'closed' }}
env:
GH_TOKEN: ${{ github.token }}
NODE_ID: ${{ github.event.pull_request.node_id }}
run: |
gh api graphql \
-f prId="$NODE_ID" \
-f query='
mutation ReopenPR($prId: ID!) {
reopenPullRequest(input: {
pullRequestId: $prId
}) {
__typename
}
}'
+2 -2
View File
@@ -42,10 +42,10 @@ jobs:
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './cli/.nvmrc' node-version-file: './cli/.nvmrc'
registry-url: 'https://registry.npmjs.org' registry-url: 'https://registry.npmjs.org'
+3 -3
View File
@@ -57,7 +57,7 @@ jobs:
# Initializes the CodeQL tools for scanning. # Initializes the CodeQL tools for scanning.
- name: Initialize CodeQL - name: Initialize CodeQL
uses: github/codeql-action/init@9e907b5e64f6b83e7804b09294d44122997950d6 # v4.32.3 uses: github/codeql-action/init@0d579ffd059c29b07949a3cce3983f0780820c98 # v4.32.6
with: with:
languages: ${{ matrix.language }} languages: ${{ matrix.language }}
# If you wish to specify custom queries, you can do so here or in a config file. # If you wish to specify custom queries, you can do so here or in a config file.
@@ -70,7 +70,7 @@ jobs:
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java). # Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
# If this step fails, then you should remove it and run the build manually (see below) # If this step fails, then you should remove it and run the build manually (see below)
- name: Autobuild - name: Autobuild
uses: github/codeql-action/autobuild@9e907b5e64f6b83e7804b09294d44122997950d6 # v4.32.3 uses: github/codeql-action/autobuild@0d579ffd059c29b07949a3cce3983f0780820c98 # v4.32.6
# ️ Command-line programs to run using the OS shell. # ️ Command-line programs to run using the OS shell.
# 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun # 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun
@@ -83,6 +83,6 @@ jobs:
# ./location_of_script_within_repo/buildscript.sh # ./location_of_script_within_repo/buildscript.sh
- name: Perform CodeQL Analysis - name: Perform CodeQL Analysis
uses: github/codeql-action/analyze@9e907b5e64f6b83e7804b09294d44122997950d6 # v4.32.3 uses: github/codeql-action/analyze@0d579ffd059c29b07949a3cce3983f0780820c98 # v4.32.6
with: with:
category: '/language:${{matrix.language}}' category: '/language:${{matrix.language}}'
+1 -1
View File
@@ -131,7 +131,7 @@ jobs:
- device: rocm - device: rocm
suffixes: '-rocm' suffixes: '-rocm'
platforms: linux/amd64 platforms: linux/amd64
runner-mapping: '{"linux/amd64": "pokedex-giant"}' runner-mapping: '{"linux/amd64": "pokedex-large"}'
uses: immich-app/devtools/.github/workflows/multi-runner-build.yml@bd49ed7a5a6022149f79b6564df48177476a822b # multi-runner-build-workflow-v2.2.1 uses: immich-app/devtools/.github/workflows/multi-runner-build.yml@bd49ed7a5a6022149f79b6564df48177476a822b # multi-runner-build-workflow-v2.2.1
permissions: permissions:
contents: read contents: read
+2 -2
View File
@@ -67,10 +67,10 @@ jobs:
fetch-depth: 0 fetch-depth: 0
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './docs/.nvmrc' node-version-file: './docs/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
+2 -2
View File
@@ -29,10 +29,10 @@ jobs:
persist-credentials: true persist-credentials: true
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './server/.nvmrc' node-version-file: './server/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
+3 -3
View File
@@ -63,13 +63,13 @@ jobs:
ref: main ref: main
- name: Install uv - name: Install uv
uses: astral-sh/setup-uv@eac588ad8def6316056a12d4907a9d4d84ff7a3b # v7.3.0 uses: astral-sh/setup-uv@6ee6290f1cbc4156c0bdd66691b2c144ef8df19a # v7.4.0
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './server/.nvmrc' node-version-file: './server/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
-170
View File
@@ -1,170 +0,0 @@
name: Manage release PR
on:
workflow_dispatch:
push:
branches:
- main
concurrency:
group: ${{ github.workflow }}
cancel-in-progress: true
permissions: {}
jobs:
bump:
runs-on: ubuntu-latest
steps:
- name: Generate a token
id: generate-token
uses: actions/create-github-app-token@29824e69f54612133e76f7eaac726eef6c875baf # v2.2.1
with:
app-id: ${{ secrets.PUSH_O_MATIC_APP_ID }}
private-key: ${{ secrets.PUSH_O_MATIC_APP_KEY }}
- name: Checkout
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
token: ${{ steps.generate-token.outputs.token }}
persist-credentials: true
ref: main
- name: Install uv
uses: astral-sh/setup-uv@eac588ad8def6316056a12d4907a9d4d84ff7a3b # v7.3.0
- name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0
- name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0
with:
node-version-file: './server/.nvmrc'
cache: 'pnpm'
cache-dependency-path: '**/pnpm-lock.yaml'
- name: Determine release type
id: bump-type
uses: ietf-tools/semver-action@c90370b2958652d71c06a3484129a4d423a6d8a8 # v1.11.0
with:
token: ${{ steps.generate-token.outputs.token }}
- name: Bump versions
env:
TYPE: ${{ steps.bump-type.outputs.bump }}
run: |
if [ "$TYPE" == "none" ]; then
exit 1 # TODO: Is there a cleaner way to abort the workflow?
fi
misc/release/pump-version.sh -s $TYPE -m true
- name: Manage Outline release document
id: outline
uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8.0.0
env:
OUTLINE_API_KEY: ${{ secrets.OUTLINE_API_KEY }}
NEXT_VERSION: ${{ steps.bump-type.outputs.next }}
with:
github-token: ${{ steps.generate-token.outputs.token }}
script: |
const fs = require('fs');
const outlineKey = process.env.OUTLINE_API_KEY;
const parentDocumentId = 'da856355-0844-43df-bd71-f8edce5382d9'
const collectionId = 'e2910656-714c-4871-8721-447d9353bd73';
const baseUrl = 'https://outline.immich.cloud';
const listResponse = await fetch(`${baseUrl}/api/documents.list`, {
method: 'POST',
headers: {
'Authorization': `Bearer ${outlineKey}`,
'Content-Type': 'application/json'
},
body: JSON.stringify({ parentDocumentId })
});
if (!listResponse.ok) {
throw new Error(`Outline list failed: ${listResponse.statusText}`);
}
const listData = await listResponse.json();
const allDocuments = listData.data || [];
const document = allDocuments.find(doc => doc.title === 'next');
let documentId;
let documentUrl;
let documentText;
if (!document) {
// Create new document
console.log('No existing document found. Creating new one...');
const notesTmpl = fs.readFileSync('misc/release/notes.tmpl', 'utf8');
const createResponse = await fetch(`${baseUrl}/api/documents.create`, {
method: 'POST',
headers: {
'Authorization': `Bearer ${outlineKey}`,
'Content-Type': 'application/json'
},
body: JSON.stringify({
title: 'next',
text: notesTmpl,
collectionId: collectionId,
parentDocumentId: parentDocumentId,
publish: true
})
});
if (!createResponse.ok) {
throw new Error(`Failed to create document: ${createResponse.statusText}`);
}
const createData = await createResponse.json();
documentId = createData.data.id;
const urlId = createData.data.urlId;
documentUrl = `${baseUrl}/doc/next-${urlId}`;
documentText = createData.data.text || '';
console.log(`Created new document: ${documentUrl}`);
} else {
documentId = document.id;
const docPath = document.url;
documentUrl = `${baseUrl}${docPath}`;
documentText = document.text || '';
console.log(`Found existing document: ${documentUrl}`);
}
// Generate GitHub release notes
console.log('Generating GitHub release notes...');
const releaseNotesResponse = await github.rest.repos.generateReleaseNotes({
owner: context.repo.owner,
repo: context.repo.repo,
tag_name: `${process.env.NEXT_VERSION}`,
});
// Combine the content
const changelog = `
# ${process.env.NEXT_VERSION}
${documentText}
${releaseNotesResponse.data.body}
---
`
const existingChangelog = fs.existsSync('CHANGELOG.md') ? fs.readFileSync('CHANGELOG.md', 'utf8') : '';
fs.writeFileSync('CHANGELOG.md', changelog + existingChangelog, 'utf8');
core.setOutput('document_url', documentUrl);
- name: Create PR
id: create-pr
uses: peter-evans/create-pull-request@c0f553fe549906ede9cf27b5156039d195d2ece0 # v8.1.0
with:
token: ${{ steps.generate-token.outputs.token }}
commit-message: 'chore: release ${{ steps.bump-type.outputs.next }}'
title: 'chore: release ${{ steps.bump-type.outputs.next }}'
body: 'Release notes: ${{ steps.outline.outputs.document_url }}'
labels: 'changelog:skip'
branch: 'release/next'
draft: true
-149
View File
@@ -1,149 +0,0 @@
name: release.yml
on:
pull_request:
types: [closed]
paths:
- CHANGELOG.md
jobs:
# Maybe double check PR source branch?
merge_translations:
uses: ./.github/workflows/merge-translations.yml
permissions:
pull-requests: write
secrets:
PUSH_O_MATIC_APP_ID: ${{ secrets.PUSH_O_MATIC_APP_ID }}
PUSH_O_MATIC_APP_KEY: ${{ secrets.PUSH_O_MATIC_APP_KEY }}
WEBLATE_TOKEN: ${{ secrets.WEBLATE_TOKEN }}
build_mobile:
uses: ./.github/workflows/build-mobile.yml
needs: merge_translations
permissions:
contents: read
secrets:
KEY_JKS: ${{ secrets.KEY_JKS }}
ALIAS: ${{ secrets.ALIAS }}
ANDROID_KEY_PASSWORD: ${{ secrets.ANDROID_KEY_PASSWORD }}
ANDROID_STORE_PASSWORD: ${{ secrets.ANDROID_STORE_PASSWORD }}
# iOS secrets
APP_STORE_CONNECT_API_KEY_ID: ${{ secrets.APP_STORE_CONNECT_API_KEY_ID }}
APP_STORE_CONNECT_API_KEY_ISSUER_ID: ${{ secrets.APP_STORE_CONNECT_API_KEY_ISSUER_ID }}
APP_STORE_CONNECT_API_KEY: ${{ secrets.APP_STORE_CONNECT_API_KEY }}
IOS_CERTIFICATE_P12: ${{ secrets.IOS_CERTIFICATE_P12 }}
IOS_CERTIFICATE_PASSWORD: ${{ secrets.IOS_CERTIFICATE_PASSWORD }}
IOS_PROVISIONING_PROFILE: ${{ secrets.IOS_PROVISIONING_PROFILE }}
IOS_PROVISIONING_PROFILE_SHARE_EXTENSION: ${{ secrets.IOS_PROVISIONING_PROFILE_SHARE_EXTENSION }}misc/release/notes.tmpl
IOS_PROVISIONING_PROFILE_WIDGET_EXTENSION: ${{ secrets.IOS_PROVISIONING_PROFILE_WIDGET_EXTENSION }}
IOS_DEVELOPMENT_PROVISIONING_PROFILE: ${{ secrets.IOS_DEVELOPMENT_PROVISIONING_PROFILE }}
IOS_DEVELOPMENT_PROVISIONING_PROFILE_SHARE_EXTENSION: ${{ secrets.IOS_DEVELOPMENT_PROVISIONING_PROFILE_SHARE_EXTENSION }}
IOS_DEVELOPMENT_PROVISIONING_PROFILE_WIDGET_EXTENSION: ${{ secrets.IOS_DEVELOPMENT_PROVISIONING_PROFILE_WIDGET_EXTENSION }}
FASTLANE_TEAM_ID: ${{ secrets.FASTLANE_TEAM_ID }}
with:
ref: main
environment: production
prepare_release:
runs-on: ubuntu-latest
needs: build_mobile
permissions:
actions: read # To download the app artifact
steps:
- name: Generate a token
id: generate-token
uses: actions/create-github-app-token@29824e69f54612133e76f7eaac726eef6c875baf # v2.2.1
with:
app-id: ${{ secrets.PUSH_O_MATIC_APP_ID }}
private-key: ${{ secrets.PUSH_O_MATIC_APP_KEY }}
- name: Checkout
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with:
token: ${{ steps.generate-token.outputs.token }}
persist-credentials: false
ref: main
- name: Extract changelog
id: changelog
run: |
CHANGELOG_PATH=$RUNNER_TEMP/changelog.md
sed -n '1,/^---$/p' CHANGELOG.md | head -n -1 > $CHANGELOG_PATH
echo "path=$CHANGELOG_PATH" >> $GITHUB_OUTPUT
VERSION=$(sed -n 's/^# //p' $CHANGELOG_PATH)
echo "version=$VERSION" >> $GITHUB_OUTPUT
- name: Download APK
uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 # v7.0.0
with:
name: release-apk-signed
github-token: ${{ steps.generate-token.outputs.token }}
- name: Create draft release
uses: softprops/action-gh-release@a06a81a03ee405af7f2048a818ed3f03bbf83c7b # v2.5.0
with:
tag_name: ${{ steps.version.outputs.result }}
token: ${{ steps.generate-token.outputs.token }}
body_path: ${{ steps.changelog.outputs.path }}
draft: true
files: |
docker/docker-compose.yml
docker/docker-compose.rootless.yml
docker/example.env
docker/hwaccel.ml.yml
docker/hwaccel.transcoding.yml
docker/prometheus.yml
*.apk
- name: Rename Outline document
uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8.0.0
continue-on-error: true
env:
OUTLINE_API_KEY: ${{ secrets.OUTLINE_API_KEY }}
VERSION: ${{ steps.changelog.outputs.version }}
with:
github-token: ${{ steps.generate-token.outputs.token }}
script: |
const outlineKey = process.env.OUTLINE_API_KEY;
const version = process.env.VERSION;
const parentDocumentId = 'da856355-0844-43df-bd71-f8edce5382d9';
const baseUrl = 'https://outline.immich.cloud';
const listResponse = await fetch(`${baseUrl}/api/documents.list`, {
method: 'POST',
headers: {
'Authorization': `Bearer ${outlineKey}`,
'Content-Type': 'application/json'
},
body: JSON.stringify({ parentDocumentId })
});
if (!listResponse.ok) {
throw new Error(`Outline list failed: ${listResponse.statusText}`);
}
const listData = await listResponse.json();
const allDocuments = listData.data || [];
const document = allDocuments.find(doc => doc.title === 'next');
if (document) {
console.log(`Found document 'next', renaming to '${version}'...`);
const updateResponse = await fetch(`${baseUrl}/api/documents.update`, {
method: 'POST',
headers: {
'Authorization': `Bearer ${outlineKey}`,
'Content-Type': 'application/json'
},
body: JSON.stringify({
id: document.id,
title: version
})
});
if (!updateResponse.ok) {
throw new Error(`Failed to rename document: ${updateResponse.statusText}`);
}
} else {
console.log('No document titled "next" found to rename');
}
+2 -2
View File
@@ -30,10 +30,10 @@ jobs:
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
# Setup .npmrc file to publish to npm # Setup .npmrc file to publish to npm
- uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 - uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './open-api/typescript-sdk/.nvmrc' node-version-file: './open-api/typescript-sdk/.nvmrc'
registry-url: 'https://registry.npmjs.org' registry-url: 'https://registry.npmjs.org'
+28 -28
View File
@@ -75,9 +75,9 @@ jobs:
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './server/.nvmrc' node-version-file: './server/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -119,9 +119,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './cli/.nvmrc' node-version-file: './cli/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -166,9 +166,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './cli/.nvmrc' node-version-file: './cli/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -208,9 +208,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './web/.nvmrc' node-version-file: './web/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -252,9 +252,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './web/.nvmrc' node-version-file: './web/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -290,9 +290,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './web/.nvmrc' node-version-file: './web/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -338,9 +338,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './e2e/.nvmrc' node-version-file: './e2e/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -385,9 +385,9 @@ jobs:
submodules: 'recursive' submodules: 'recursive'
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './server/.nvmrc' node-version-file: './server/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -424,9 +424,9 @@ jobs:
submodules: 'recursive' submodules: 'recursive'
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './e2e/.nvmrc' node-version-file: './e2e/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -496,9 +496,9 @@ jobs:
submodules: 'recursive' submodules: 'recursive'
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './e2e/.nvmrc' node-version-file: './e2e/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -511,7 +511,7 @@ jobs:
run: pnpm install --frozen-lockfile run: pnpm install --frozen-lockfile
if: ${{ !cancelled() }} if: ${{ !cancelled() }}
- name: Install Playwright Browsers - name: Install Playwright Browsers
run: npx playwright install chromium --only-shell run: pnpm exec playwright install chromium --only-shell
if: ${{ !cancelled() }} if: ${{ !cancelled() }}
- name: Docker build - name: Docker build
run: docker compose up -d --build --renew-anon-volumes --force-recreate --remove-orphans --wait --wait-timeout 300 run: docker compose up -d --build --renew-anon-volumes --force-recreate --remove-orphans --wait --wait-timeout 300
@@ -620,7 +620,7 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Install uv - name: Install uv
uses: astral-sh/setup-uv@eac588ad8def6316056a12d4907a9d4d84ff7a3b # v7.3.0 uses: astral-sh/setup-uv@6ee6290f1cbc4156c0bdd66691b2c144ef8df19a # v7.4.0
with: with:
python-version: 3.11 python-version: 3.11
- name: Install dependencies - name: Install dependencies
@@ -661,9 +661,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './.github/.nvmrc' node-version-file: './.github/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -712,9 +712,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './server/.nvmrc' node-version-file: './server/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
@@ -774,9 +774,9 @@ jobs:
persist-credentials: false persist-credentials: false
token: ${{ steps.token.outputs.token }} token: ${{ steps.token.outputs.token }}
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 uses: pnpm/action-setup@b906affcce14559ad1aafd4ab0e942779e9f58b1 # v4.3.0
- name: Setup Node - name: Setup Node
uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 uses: actions/setup-node@53b83947a5a98c8d113130e565377fae1a50d02f # v6.3.0
with: with:
node-version-file: './server/.nvmrc' node-version-file: './server/.nvmrc'
cache: 'pnpm' cache: 'pnpm'
+11 -5
View File
@@ -4,12 +4,18 @@ module.exports = {
if (!pkg.name) { if (!pkg.name) {
return pkg; return pkg;
} }
// make exiftool-vendored.pl a regular dependency since Docker prod
// images build with --no-optional to reduce image size
if (pkg.name === "exiftool-vendored") { if (pkg.name === "exiftool-vendored") {
if (pkg.optionalDependencies["exiftool-vendored.pl"]) { const binaryPackage =
// make exiftool-vendored.pl a regular dependency process.platform === "win32"
pkg.dependencies["exiftool-vendored.pl"] = ? "exiftool-vendored.exe"
pkg.optionalDependencies["exiftool-vendored.pl"]; : "exiftool-vendored.pl";
delete pkg.optionalDependencies["exiftool-vendored.pl"];
if (pkg.optionalDependencies[binaryPackage]) {
pkg.dependencies[binaryPackage] =
pkg.optionalDependencies[binaryPackage];
delete pkg.optionalDependencies[binaryPackage];
} }
} }
return pkg; return pkg;
+8 -1
View File
@@ -5,6 +5,13 @@
"dbaeumer.vscode-eslint", "dbaeumer.vscode-eslint",
"dart-code.flutter", "dart-code.flutter",
"dart-code.dart-code", "dart-code.dart-code",
"dcmdev.dcm-vscode-extension" "dcmdev.dcm-vscode-extension",
"bradlc.vscode-tailwindcss",
"ms-playwright.playwright",
"vitest.explorer",
"editorconfig.editorconfig",
"foxundermoon.shell-format",
"timonwong.shellcheck",
"bluebrown.yamlfmt"
] ]
} }
+35 -13
View File
@@ -1,8 +1,7 @@
{ {
"[css]": { "[css]": {
"editor.defaultFormatter": "esbenp.prettier-vscode", "editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true, "editor.formatOnSave": true
"editor.tabSize": 2
}, },
"[dart]": { "[dart]": {
"editor.defaultFormatter": "Dart-Code.dart-code", "editor.defaultFormatter": "Dart-Code.dart-code",
@@ -19,18 +18,15 @@
"source.removeUnusedImports": "explicit" "source.removeUnusedImports": "explicit"
}, },
"editor.defaultFormatter": "esbenp.prettier-vscode", "editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true, "editor.formatOnSave": true
"editor.tabSize": 2
}, },
"[json]": { "[json]": {
"editor.defaultFormatter": "esbenp.prettier-vscode", "editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true, "editor.formatOnSave": true
"editor.tabSize": 2
}, },
"[jsonc]": { "[jsonc]": {
"editor.defaultFormatter": "esbenp.prettier-vscode", "editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true, "editor.formatOnSave": true
"editor.tabSize": 2
}, },
"[svelte]": { "[svelte]": {
"editor.codeActionsOnSave": { "editor.codeActionsOnSave": {
@@ -38,8 +34,7 @@
"source.removeUnusedImports": "explicit" "source.removeUnusedImports": "explicit"
}, },
"editor.defaultFormatter": "svelte.svelte-vscode", "editor.defaultFormatter": "svelte.svelte-vscode",
"editor.formatOnSave": true, "editor.formatOnSave": true
"editor.tabSize": 2
}, },
"[typescript]": { "[typescript]": {
"editor.codeActionsOnSave": { "editor.codeActionsOnSave": {
@@ -47,18 +42,45 @@
"source.removeUnusedImports": "explicit" "source.removeUnusedImports": "explicit"
}, },
"editor.defaultFormatter": "esbenp.prettier-vscode", "editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true, "editor.formatOnSave": true
"editor.tabSize": 2
}, },
"cSpell.words": ["immich"], "cSpell.words": ["immich"],
"css.lint.unknownAtRules": "ignore",
"editor.bracketPairColorization.enabled": true,
"editor.formatOnSave": true, "editor.formatOnSave": true,
"eslint.useFlatConfig": true,
"eslint.validate": ["javascript", "typescript", "svelte"], "eslint.validate": ["javascript", "typescript", "svelte"],
"eslint.workingDirectories": [
{ "directory": "cli", "changeProcessCWD": true },
{ "directory": "e2e", "changeProcessCWD": true },
{ "directory": "server", "changeProcessCWD": true },
{ "directory": "web", "changeProcessCWD": true }
],
"files.watcherExclude": {
"**/.jj/**": true,
"**/.git/**": true,
"**/node_modules/**": true,
"**/build/**": true,
"**/dist/**": true,
"**/.svelte-kit/**": true
},
"explorer.fileNesting.enabled": true, "explorer.fileNesting.enabled": true,
"explorer.fileNesting.patterns": { "explorer.fileNesting.patterns": {
"*.dart": "${capture}.g.dart,${capture}.gr.dart,${capture}.drift.dart", "*.dart": "${capture}.g.dart,${capture}.gr.dart,${capture}.drift.dart",
"*.ts": "${capture}.spec.ts,${capture}.mock.ts", "*.ts": "${capture}.spec.ts,${capture}.mock.ts",
"package.json": "package-lock.json, yarn.lock, pnpm-lock.yaml, bun.lockb, bun.lock, pnpm-workspace.yaml, .pnpmfile.cjs" "package.json": "package-lock.json, yarn.lock, pnpm-lock.yaml, bun.lockb, bun.lock, pnpm-workspace.yaml, .pnpmfile.cjs"
}, },
"search.exclude": {
"**/node_modules": true,
"**/build": true,
"**/dist": true,
"**/.svelte-kit": true,
"**/open-api/typescript-sdk/src": true
},
"svelte.enable-ts-plugin": true, "svelte.enable-ts-plugin": true,
"typescript.preferences.importModuleSpecifier": "non-relative" "tailwindCSS.experimental.configFile": {
"web/src/app.css": "web/src/**"
},
"js/ts.preferences.importModuleSpecifier": "non-relative",
"vitest.maximumConfigs": 10
} }
+2
View File
@@ -15,6 +15,8 @@ Please try to keep pull requests as focused as possible. A PR should do exactly
If you are looking for something to work on, there are discussions and issues with a `good-first-issue` label on them. These are always a good starting point. If none of them sound interesting or fit your skill set, feel free to reach out on our Discord. We're happy to help you find something to work on! If you are looking for something to work on, there are discussions and issues with a `good-first-issue` label on them. These are always a good starting point. If none of them sound interesting or fit your skill set, feel free to reach out on our Discord. We're happy to help you find something to work on!
We usually do not assign issues to new contributors, since it happens often that a PR is never even opened. Again, reach out on Discord if you fear putting a lot of time into fixing an issue, but ending up with a duplicate PR.
## Use of generative AI ## Use of generative AI
We ask you not to open PRs generated with an LLM. We find that code generated like this tends to need a large amount of back-and-forth, which is a very inefficient use of our time. If we want LLM-generated code, it's much faster for us to use an LLM ourselves than to go through an intermediary via a pull request. We ask you not to open PRs generated with an LLM. We find that code generated like this tends to need a large amount of back-and-forth, which is a very inefficient use of our time. If we want LLM-generated code, it's much faster for us to use an LLM ourselves than to go through an intermediary via a pull request.
+1 -1
View File
@@ -52,7 +52,7 @@ attach-server:
docker exec -it docker_immich-server_1 sh docker exec -it docker_immich-server_1 sh
renovate: renovate:
LOG_LEVEL=debug npx renovate --platform=local --repository-cache=reset LOG_LEVEL=debug pnpm exec renovate --platform=local --repository-cache=reset
# Directories that need to be created for volumes or build output # Directories that need to be created for volumes or build output
VOLUME_DIRS = \ VOLUME_DIRS = \
+12 -12
View File
@@ -1,6 +1,6 @@
{ {
"name": "@immich/cli", "name": "@immich/cli",
"version": "2.5.6", "version": "2.6.0",
"description": "Command Line Interface (CLI) for Immich", "description": "Command Line Interface (CLI) for Immich",
"type": "module", "type": "module",
"exports": "./dist/index.js", "exports": "./dist/index.js",
@@ -13,23 +13,23 @@
"cli" "cli"
], ],
"devDependencies": { "devDependencies": {
"@eslint/js": "^9.8.0", "@eslint/js": "^10.0.0",
"@immich/sdk": "workspace:*", "@immich/sdk": "workspace:*",
"@types/byte-size": "^8.1.0", "@types/byte-size": "^8.1.0",
"@types/cli-progress": "^3.11.0", "@types/cli-progress": "^3.11.0",
"@types/lodash-es": "^4.17.12", "@types/lodash-es": "^4.17.12",
"@types/micromatch": "^4.0.9", "@types/micromatch": "^4.0.9",
"@types/mock-fs": "^4.13.1", "@types/mock-fs": "^4.13.1",
"@types/node": "^24.10.13", "@types/node": "^24.11.0",
"@vitest/coverage-v8": "^3.0.0", "@vitest/coverage-v8": "^4.0.0",
"byte-size": "^9.0.0", "byte-size": "^9.0.0",
"cli-progress": "^3.12.0", "cli-progress": "^3.12.0",
"commander": "^12.0.0", "commander": "^12.0.0",
"eslint": "^9.14.0", "eslint": "^10.0.0",
"eslint-config-prettier": "^10.1.8", "eslint-config-prettier": "^10.1.8",
"eslint-plugin-prettier": "^5.1.3", "eslint-plugin-prettier": "^5.1.3",
"eslint-plugin-unicorn": "^62.0.0", "eslint-plugin-unicorn": "^63.0.0",
"globals": "^16.0.0", "globals": "^17.0.0",
"mock-fs": "^5.2.0", "mock-fs": "^5.2.0",
"prettier": "^3.7.4", "prettier": "^3.7.4",
"prettier-plugin-organize-imports": "^4.0.0", "prettier-plugin-organize-imports": "^4.0.0",
@@ -37,7 +37,7 @@
"typescript-eslint": "^8.28.0", "typescript-eslint": "^8.28.0",
"vite": "^7.0.0", "vite": "^7.0.0",
"vite-tsconfig-paths": "^6.0.0", "vite-tsconfig-paths": "^6.0.0",
"vitest": "^3.0.0", "vitest": "^4.0.0",
"vitest-fetch-mock": "^0.4.0", "vitest-fetch-mock": "^0.4.0",
"yaml": "^2.3.1" "yaml": "^2.3.1"
}, },
@@ -45,12 +45,12 @@
"build": "vite build", "build": "vite build",
"build:dev": "vite build --sourcemap true", "build:dev": "vite build --sourcemap true",
"lint": "eslint \"src/**/*.ts\" --max-warnings 0", "lint": "eslint \"src/**/*.ts\" --max-warnings 0",
"lint:fix": "npm run lint -- --fix", "lint:fix": "pnpm run lint --fix",
"prepack": "npm run build", "prepack": "pnpm run build",
"test": "vitest", "test": "vitest",
"test:cov": "vitest --coverage", "test:cov": "vitest --coverage",
"format": "prettier --check .", "format": "prettier --cache --check .",
"format:fix": "prettier --write .", "format:fix": "prettier --cache --write --list-different .",
"check": "tsc --noEmit" "check": "tsc --noEmit"
}, },
"repository": { "repository": {
+136 -37
View File
@@ -1,13 +1,21 @@
import * as fs from 'node:fs'; import fs from 'node:fs';
import * as os from 'node:os'; import os from 'node:os';
import * as path from 'node:path'; import path from 'node:path';
import { setTimeout as sleep } from 'node:timers/promises'; import { setTimeout as sleep } from 'node:timers/promises';
import { describe, expect, it, MockedFunction, vi } from 'vitest'; import { describe, expect, it, MockedFunction, vi } from 'vitest';
import { Action, checkBulkUpload, defaults, getSupportedMediaTypes, Reason } from '@immich/sdk'; import { Action, checkBulkUpload, defaults, getSupportedMediaTypes, Reason } from '@immich/sdk';
import createFetchMock from 'vitest-fetch-mock'; import createFetchMock from 'vitest-fetch-mock';
import { checkForDuplicates, getAlbumName, startWatch, uploadFiles, UploadOptionsDto } from 'src/commands/asset'; import {
checkForDuplicates,
deleteFiles,
findSidecar,
getAlbumName,
startWatch,
uploadFiles,
UploadOptionsDto,
} from 'src/commands/asset';
vi.mock('@immich/sdk'); vi.mock('@immich/sdk');
@@ -50,7 +58,7 @@ describe('uploadFiles', () => {
}); });
it('returns new assets when upload file is successful', async () => { it('returns new assets when upload file is successful', async () => {
fetchMocker.doMockIf(new RegExp(`${baseUrl}/assets$`), () => { fetchMocker.doMockIf(new RegExp(`${baseUrl}/assets$`), function () {
return { return {
status: 200, status: 200,
body: JSON.stringify({ id: 'fc5621b1-86f6-44a1-9905-403e607df9f5', status: 'created' }), body: JSON.stringify({ id: 'fc5621b1-86f6-44a1-9905-403e607df9f5', status: 'created' }),
@@ -67,7 +75,7 @@ describe('uploadFiles', () => {
it('returns new assets when upload file retry is successful', async () => { it('returns new assets when upload file retry is successful', async () => {
let counter = 0; let counter = 0;
fetchMocker.doMockIf(new RegExp(`${baseUrl}/assets$`), () => { fetchMocker.doMockIf(new RegExp(`${baseUrl}/assets$`), function () {
counter++; counter++;
if (counter < retry) { if (counter < retry) {
throw new Error('Network error'); throw new Error('Network error');
@@ -88,7 +96,7 @@ describe('uploadFiles', () => {
}); });
it('returns new assets when upload file retry is failed', async () => { it('returns new assets when upload file retry is failed', async () => {
fetchMocker.doMockIf(new RegExp(`${baseUrl}/assets$`), () => { fetchMocker.doMockIf(new RegExp(`${baseUrl}/assets$`), function () {
throw new Error('Network error'); throw new Error('Network error');
}); });
@@ -228,16 +236,19 @@ describe('startWatch', () => {
await sleep(100); // to debounce the watcher from considering the test file as a existing file await sleep(100); // to debounce the watcher from considering the test file as a existing file
await fs.promises.writeFile(testFilePath, 'testjpg'); await fs.promises.writeFile(testFilePath, 'testjpg');
await vi.waitUntil(() => checkBulkUploadMocked.mock.calls.length > 0, 3000); await vi.waitFor(
expect(checkBulkUpload).toHaveBeenCalledWith({ () =>
assetBulkUploadCheckDto: { expect(checkBulkUpload).toHaveBeenCalledWith({
assets: [ assetBulkUploadCheckDto: {
expect.objectContaining({ assets: [
id: testFilePath, expect.objectContaining({
}), id: testFilePath,
], }),
}, ],
}); },
}),
{ timeout: 5000 },
);
}); });
it('should filter out unsupported files', async () => { it('should filter out unsupported files', async () => {
@@ -249,16 +260,19 @@ describe('startWatch', () => {
await fs.promises.writeFile(testFilePath, 'testjpg'); await fs.promises.writeFile(testFilePath, 'testjpg');
await fs.promises.writeFile(unsupportedFilePath, 'testtxt'); await fs.promises.writeFile(unsupportedFilePath, 'testtxt');
await vi.waitUntil(() => checkBulkUploadMocked.mock.calls.length > 0, 3000); await vi.waitFor(
expect(checkBulkUpload).toHaveBeenCalledWith({ () =>
assetBulkUploadCheckDto: { expect(checkBulkUpload).toHaveBeenCalledWith({
assets: expect.arrayContaining([ assetBulkUploadCheckDto: {
expect.objectContaining({ assets: expect.arrayContaining([
id: testFilePath, expect.objectContaining({
}), id: testFilePath,
]), }),
}, ]),
}); },
}),
{ timeout: 5000 },
);
expect(checkBulkUpload).not.toHaveBeenCalledWith({ expect(checkBulkUpload).not.toHaveBeenCalledWith({
assetBulkUploadCheckDto: { assetBulkUploadCheckDto: {
@@ -283,16 +297,19 @@ describe('startWatch', () => {
await fs.promises.writeFile(testFilePath, 'testjpg'); await fs.promises.writeFile(testFilePath, 'testjpg');
await fs.promises.writeFile(ignoredFilePath, 'ignoredjpg'); await fs.promises.writeFile(ignoredFilePath, 'ignoredjpg');
await vi.waitUntil(() => checkBulkUploadMocked.mock.calls.length > 0, 3000); await vi.waitFor(
expect(checkBulkUpload).toHaveBeenCalledWith({ () =>
assetBulkUploadCheckDto: { expect(checkBulkUpload).toHaveBeenCalledWith({
assets: expect.arrayContaining([ assetBulkUploadCheckDto: {
expect.objectContaining({ assets: expect.arrayContaining([
id: testFilePath, expect.objectContaining({
}), id: testFilePath,
]), }),
}, ]),
}); },
}),
{ timeout: 5000 },
);
expect(checkBulkUpload).not.toHaveBeenCalledWith({ expect(checkBulkUpload).not.toHaveBeenCalledWith({
assetBulkUploadCheckDto: { assetBulkUploadCheckDto: {
@@ -309,3 +326,85 @@ describe('startWatch', () => {
await fs.promises.rm(testFolder, { recursive: true, force: true }); await fs.promises.rm(testFolder, { recursive: true, force: true });
}); });
}); });
describe('findSidecar', () => {
let testDir: string;
let testFilePath: string;
beforeEach(() => {
testDir = fs.mkdtempSync(path.join(os.tmpdir(), 'test-sidecar-'));
testFilePath = path.join(testDir, 'test.jpg');
fs.writeFileSync(testFilePath, 'test');
});
afterEach(() => {
fs.rmSync(testDir, { recursive: true, force: true });
});
it('should find sidecar file with photo.xmp naming convention', () => {
const sidecarPath = path.join(testDir, 'test.xmp');
fs.writeFileSync(sidecarPath, 'xmp data');
const result = findSidecar(testFilePath);
expect(result).toBe(sidecarPath);
});
it('should find sidecar file with photo.ext.xmp naming convention', () => {
const sidecarPath = path.join(testDir, 'test.jpg.xmp');
fs.writeFileSync(sidecarPath, 'xmp data');
const result = findSidecar(testFilePath);
expect(result).toBe(sidecarPath);
});
it('should prefer photo.ext.xmp over photo.xmp when both exist', () => {
const sidecarPath1 = path.join(testDir, 'test.xmp');
const sidecarPath2 = path.join(testDir, 'test.jpg.xmp');
fs.writeFileSync(sidecarPath1, 'xmp data 1');
fs.writeFileSync(sidecarPath2, 'xmp data 2');
const result = findSidecar(testFilePath);
// Should return the first one found (photo.xmp) based on the order in the code
expect(result).toBe(sidecarPath1);
});
it('should return undefined when no sidecar file exists', () => {
const result = findSidecar(testFilePath);
expect(result).toBeUndefined();
});
});
describe('deleteFiles', () => {
let testDir: string;
let testFilePath: string;
beforeEach(() => {
testDir = fs.mkdtempSync(path.join(os.tmpdir(), 'test-delete-'));
testFilePath = path.join(testDir, 'test.jpg');
fs.writeFileSync(testFilePath, 'test');
});
afterEach(() => {
fs.rmSync(testDir, { recursive: true, force: true });
});
it('should delete asset and sidecar file when main file is deleted', async () => {
const sidecarPath = path.join(testDir, 'test.xmp');
fs.writeFileSync(sidecarPath, 'xmp data');
await deleteFiles([{ id: 'test-id', filepath: testFilePath }], [], { delete: true, concurrency: 1 });
expect(fs.existsSync(testFilePath)).toBe(false);
expect(fs.existsSync(sidecarPath)).toBe(false);
});
it('should not delete sidecar file when delete option is false', async () => {
const sidecarPath = path.join(testDir, 'test.xmp');
fs.writeFileSync(sidecarPath, 'xmp data');
await deleteFiles([{ id: 'test-id', filepath: testFilePath }], [], { delete: false, concurrency: 1 });
expect(fs.existsSync(testFilePath)).toBe(true);
expect(fs.existsSync(sidecarPath)).toBe(true);
});
});
+32 -22
View File
@@ -17,7 +17,7 @@ import { Matcher, watch as watchFs } from 'chokidar';
import { MultiBar, Presets, SingleBar } from 'cli-progress'; import { MultiBar, Presets, SingleBar } from 'cli-progress';
import { chunk } from 'lodash-es'; import { chunk } from 'lodash-es';
import micromatch from 'micromatch'; import micromatch from 'micromatch';
import { Stats, createReadStream } from 'node:fs'; import { Stats, createReadStream, existsSync } from 'node:fs';
import { stat, unlink } from 'node:fs/promises'; import { stat, unlink } from 'node:fs/promises';
import path, { basename } from 'node:path'; import path, { basename } from 'node:path';
import { Queue } from 'src/queue'; import { Queue } from 'src/queue';
@@ -403,23 +403,6 @@ export const uploadFiles = async (
const uploadFile = async (input: string, stats: Stats): Promise<AssetMediaResponseDto> => { const uploadFile = async (input: string, stats: Stats): Promise<AssetMediaResponseDto> => {
const { baseUrl, headers } = defaults; const { baseUrl, headers } = defaults;
const assetPath = path.parse(input);
const noExtension = path.join(assetPath.dir, assetPath.name);
const sidecarsFiles = await Promise.all(
// XMP sidecars can come in two filename formats. For a photo named photo.ext, the filenames are photo.ext.xmp and photo.xmp
[`${noExtension}.xmp`, `${input}.xmp`].map(async (sidecarPath) => {
try {
const stats = await stat(sidecarPath);
return new UploadFile(sidecarPath, stats.size);
} catch {
return false;
}
}),
);
const sidecarData = sidecarsFiles.find((file): file is UploadFile => file !== false);
const formData = new FormData(); const formData = new FormData();
formData.append('deviceAssetId', `${basename(input)}-${stats.size}`.replaceAll(/\s+/g, '')); formData.append('deviceAssetId', `${basename(input)}-${stats.size}`.replaceAll(/\s+/g, ''));
formData.append('deviceId', 'CLI'); formData.append('deviceId', 'CLI');
@@ -429,8 +412,15 @@ const uploadFile = async (input: string, stats: Stats): Promise<AssetMediaRespon
formData.append('isFavorite', 'false'); formData.append('isFavorite', 'false');
formData.append('assetData', new UploadFile(input, stats.size)); formData.append('assetData', new UploadFile(input, stats.size));
if (sidecarData) { const sidecarPath = findSidecar(input);
formData.append('sidecarData', sidecarData); if (sidecarPath) {
try {
const stats = await stat(sidecarPath);
const sidecarData = new UploadFile(sidecarPath, stats.size);
formData.append('sidecarData', sidecarData);
} catch {
// noop
}
} }
const response = await fetch(`${baseUrl}/assets`, { const response = await fetch(`${baseUrl}/assets`, {
@@ -446,7 +436,19 @@ const uploadFile = async (input: string, stats: Stats): Promise<AssetMediaRespon
return response.json(); return response.json();
}; };
const deleteFiles = async (uploaded: Asset[], duplicates: Asset[], options: UploadOptionsDto): Promise<void> => { export const findSidecar = (filepath: string): string | undefined => {
const assetPath = path.parse(filepath);
const noExtension = path.join(assetPath.dir, assetPath.name);
// XMP sidecars can come in two filename formats. For a photo named photo.ext, the filenames are photo.ext.xmp and photo.xmp
for (const sidecarPath of [`${noExtension}.xmp`, `${filepath}.xmp`]) {
if (existsSync(sidecarPath)) {
return sidecarPath;
}
}
};
export const deleteFiles = async (uploaded: Asset[], duplicates: Asset[], options: UploadOptionsDto): Promise<void> => {
let fileCount = 0; let fileCount = 0;
if (options.delete) { if (options.delete) {
fileCount += uploaded.length; fileCount += uploaded.length;
@@ -474,7 +476,15 @@ const deleteFiles = async (uploaded: Asset[], duplicates: Asset[], options: Uplo
const chunkDelete = async (files: Asset[]) => { const chunkDelete = async (files: Asset[]) => {
for (const assetBatch of chunk(files, options.concurrency)) { for (const assetBatch of chunk(files, options.concurrency)) {
await Promise.all(assetBatch.map((input: Asset) => unlink(input.filepath))); await Promise.all(
assetBatch.map(async (input: Asset) => {
await unlink(input.filepath);
const sidecarPath = findSidecar(input.filepath);
if (sidecarPath) {
await unlink(sidecarPath);
}
}),
);
deletionProgress.update(assetBatch.length); deletionProgress.update(assetBatch.length);
} }
}; };
+1 -1
View File
@@ -81,7 +81,7 @@ export const connect = async (url: string, key: string) => {
const [error] = await withError(getMyUser()); const [error] = await withError(getMyUser());
if (isHttpError(error)) { if (isHttpError(error)) {
logError(error, 'Failed to connect to server'); logError(error, `Failed to connect to server ${url}`);
process.exit(1); process.exit(1);
} }
+6 -2
View File
@@ -1,4 +1,4 @@
import { defineConfig } from 'vite'; import { defineConfig, UserConfig } from 'vite';
import tsconfigPaths from 'vite-tsconfig-paths'; import tsconfigPaths from 'vite-tsconfig-paths';
export default defineConfig({ export default defineConfig({
@@ -17,4 +17,8 @@ export default defineConfig({
noExternal: /^(?!node:).*$/, noExternal: /^(?!node:).*$/,
}, },
plugins: [tsconfigPaths()], plugins: [tsconfigPaths()],
}); test: {
name: 'cli:unit',
globals: true,
},
} as UserConfig);
-7
View File
@@ -1,7 +0,0 @@
import { defineConfig } from 'vitest/config';
export default defineConfig({
test: {
globals: true,
},
});
+2 -2
View File
@@ -1,6 +1,6 @@
[tools] [tools]
terragrunt = "0.98.0" terragrunt = "0.99.4"
opentofu = "1.11.4" opentofu = "1.11.5"
[tasks."tg:fmt"] [tasks."tg:fmt"]
run = "terragrunt hclfmt" run = "terragrunt hclfmt"
+1 -1
View File
@@ -155,7 +155,7 @@ services:
redis: redis:
container_name: immich_redis container_name: immich_redis
image: docker.io/valkey/valkey:9@sha256:930b41430fb727f533c5982fe509b6f04233e26d0f7354e04de4b0d5c706e44e image: docker.io/valkey/valkey:9@sha256:3eeb09785cd61ec8e3be35f8804c8892080f3ca21934d628abc24ee4ed1698f6
healthcheck: healthcheck:
test: redis-cli ping || exit 1 test: redis-cli ping || exit 1
+2 -2
View File
@@ -56,7 +56,7 @@ services:
redis: redis:
container_name: immich_redis container_name: immich_redis
image: docker.io/valkey/valkey:9@sha256:930b41430fb727f533c5982fe509b6f04233e26d0f7354e04de4b0d5c706e44e image: docker.io/valkey/valkey:9@sha256:3eeb09785cd61ec8e3be35f8804c8892080f3ca21934d628abc24ee4ed1698f6
healthcheck: healthcheck:
test: redis-cli ping || exit 1 test: redis-cli ping || exit 1
restart: always restart: always
@@ -85,7 +85,7 @@ services:
container_name: immich_prometheus container_name: immich_prometheus
ports: ports:
- 9090:9090 - 9090:9090
image: prom/prometheus@sha256:1f0f50f06acaceb0f5670d2c8a658a599affe7b0d8e78b898c1035653849a702 image: prom/prometheus@sha256:4a61322ac1103a0e3aea2a61ef1718422a48fa046441f299d71e660a3bc71ae9
volumes: volumes:
- ./prometheus.yml:/etc/prometheus/prometheus.yml - ./prometheus.yml:/etc/prometheus/prometheus.yml
- prometheus-data:/prometheus - prometheus-data:/prometheus
+1 -1
View File
@@ -61,7 +61,7 @@ services:
redis: redis:
container_name: immich_redis container_name: immich_redis
image: docker.io/valkey/valkey:9@sha256:930b41430fb727f533c5982fe509b6f04233e26d0f7354e04de4b0d5c706e44e image: docker.io/valkey/valkey:9@sha256:3eeb09785cd61ec8e3be35f8804c8892080f3ca21934d628abc24ee4ed1698f6
user: '1000:1000' user: '1000:1000'
security_opt: security_opt:
- no-new-privileges:true - no-new-privileges:true
+1 -1
View File
@@ -49,7 +49,7 @@ services:
redis: redis:
container_name: immich_redis container_name: immich_redis
image: docker.io/valkey/valkey:9@sha256:930b41430fb727f533c5982fe509b6f04233e26d0f7354e04de4b0d5c706e44e image: docker.io/valkey/valkey:9@sha256:3eeb09785cd61ec8e3be35f8804c8892080f3ca21934d628abc24ee4ed1698f6
healthcheck: healthcheck:
test: redis-cli ping || exit 1 test: redis-cli ping || exit 1
restart: always restart: always
+4 -3
View File
@@ -67,7 +67,8 @@ graph TD
C --> D["Thumbnail Generation (Large, small, blurred and person)"] C --> D["Thumbnail Generation (Large, small, blurred and person)"]
D --> E[Smart Search] D --> E[Smart Search]
D --> F[Face Detection] D --> F[Face Detection]
D --> G[Video Transcoding] D --> G[OCR]
E --> H[Duplicate Detection] D --> H[Video Transcoding]
F --> I[Facial Recognition] E --> I[Duplicate Detection]
F --> J[Facial Recognition]
``` ```
+1 -1
View File
@@ -230,7 +230,7 @@ The default value is `ultrafast`.
### Audio codec (`ffmpeg.targetAudioCodec`) {#ffmpeg.targetAudioCodec} ### Audio codec (`ffmpeg.targetAudioCodec`) {#ffmpeg.targetAudioCodec}
Which audio codec to use when the audio stream is being transcoded. Can be one of `mp3`, `aac`, `libopus`. Which audio codec to use when the audio stream is being transcoded. Can be one of `mp3`, `aac`, `opus`.
The default value is `aac`. The default value is `aac`.
@@ -1,4 +1,4 @@
# OpenAPI # API
Immich uses the [OpenAPI](https://swagger.io/specification/) standard to generate API documentation. To view the published docs see [here](https://api.immich.app/). Immich uses the [OpenAPI](https://swagger.io/specification/) standard to generate API documentation. To view the published docs see [here](https://api.immich.app/).
+2 -2
View File
@@ -24,7 +24,7 @@ Immich has three main clients:
3. CLI - Command-line utility for bulk upload 3. CLI - Command-line utility for bulk upload
:::info :::info
All three clients use [OpenAPI](./open-api.md) to auto-generate rest clients for easy integration. For more information about this process, see [OpenAPI](./open-api.md). All three clients use [OpenAPI](/api.md) to auto-generate rest clients for easy integration. For more information about this process, see [OpenAPI](/api.md).
::: :::
### Mobile App ### Mobile App
@@ -71,7 +71,7 @@ An incoming HTTP request is mapped to a controller (`src/controllers`). Controll
### Domain Transfer Objects (DTOs) ### Domain Transfer Objects (DTOs)
The server uses [Domain Transfer Objects](https://en.wikipedia.org/wiki/Data_transfer_object) as public interfaces for the inputs (query, params, and body) and outputs (response) for each endpoint. DTOs translate to [OpenAPI](./open-api.md) schemas and control the generated code used by each client. The server uses [Domain Transfer Objects](https://en.wikipedia.org/wiki/Data_transfer_object) as public interfaces for the inputs (query, params, and body) and outputs (response) for each endpoint. DTOs translate to [OpenAPI](/api.md) schemas and control the generated code used by each client.
### Background Jobs ### Background Jobs
+1 -1
View File
@@ -53,7 +53,7 @@ You can use `dart fix --apply` and `dcm fix lib` to potentially correct some iss
## OpenAPI ## OpenAPI
The OpenAPI client libraries need to be regenerated whenever there are changes to the `immich-openapi-specs.json` file. Note that you should not modify this file directly as it is auto-generated. See [OpenAPI](/developer/open-api.md) for more details. The OpenAPI client libraries need to be regenerated whenever there are changes to the `immich-openapi-specs.json` file. Note that you should not modify this file directly as it is auto-generated. See [OpenAPI](/api.md) for more details.
## Database Migrations ## Database Migrations
+4
View File
@@ -80,6 +80,10 @@ There is an automatic scan job that is scheduled to run once a day. Its schedule
This job also cleans up any libraries stuck in deletion. It is possible to trigger the cleanup by clicking "Scan all libraries" in the library management page. This job also cleans up any libraries stuck in deletion. It is possible to trigger the cleanup by clicking "Scan all libraries" in the library management page.
### Deleting a Library
When deleting an external library, all assets inside are immediately deleted along with the library. Note that while a library can take a long time to fully delete in the background, it is immediately removed from the library list. If the deletion process is interrupted (for example, due to server restart), it will be cleaned up in the next nightly cron job. The cleanup process can also be manually initiated by clicking the "Scan All Libraries" button in the library list.
## Usage ## Usage
Let's show a concrete example where we add an existing gallery to Immich. Here, we have the following folders we want to add: Let's show a concrete example where we add an existing gallery to Immich. Here, we have the following folders we want to add:
@@ -50,6 +50,7 @@ You do not need to redo any machine learning jobs after enabling hardware accele
- The GPU must be supported by ROCm. If it isn't officially supported, you can attempt to use the `HSA_OVERRIDE_GFX_VERSION` environmental variable: `HSA_OVERRIDE_GFX_VERSION=<a supported version, e.g. 10.3.0>`. If this doesn't work, you might need to also set `HSA_USE_SVM=0`. - The GPU must be supported by ROCm. If it isn't officially supported, you can attempt to use the `HSA_OVERRIDE_GFX_VERSION` environmental variable: `HSA_OVERRIDE_GFX_VERSION=<a supported version, e.g. 10.3.0>`. If this doesn't work, you might need to also set `HSA_USE_SVM=0`.
- The ROCm image is quite large and requires at least 35GiB of free disk space. However, pulling later updates to the service through Docker will generally only amount to a few hundred megabytes as the rest will be cached. - The ROCm image is quite large and requires at least 35GiB of free disk space. However, pulling later updates to the service through Docker will generally only amount to a few hundred megabytes as the rest will be cached.
- This backend is new and may experience some issues. For example, GPU power consumption can be higher than usual after running inference, even if the machine learning service is idle. In this case, it will only go back to normal after being idle for 5 minutes (configurable with the [MACHINE_LEARNING_MODEL_TTL](/install/environment-variables) setting). - This backend is new and may experience some issues. For example, GPU power consumption can be higher than usual after running inference, even if the machine learning service is idle. In this case, it will only go back to normal after being idle for 5 minutes (configurable with the [MACHINE_LEARNING_MODEL_TTL](/install/environment-variables) setting).
- MIGraphX is a new backend for AMD cards, which compiles models at runtime. As such, the first few inferences will be slow.
#### OpenVINO #### OpenVINO
+1 -1
View File
@@ -27,7 +27,7 @@ The default configuration looks like this:
"ffmpeg": { "ffmpeg": {
"accel": "disabled", "accel": "disabled",
"accelDecode": false, "accelDecode": false,
"acceptedAudioCodecs": ["aac", "mp3", "libopus"], "acceptedAudioCodecs": ["aac", "mp3", "opus"],
"acceptedContainers": ["mov", "ogg", "webm"], "acceptedContainers": ["mov", "ogg", "webm"],
"acceptedVideoCodecs": ["h264"], "acceptedVideoCodecs": ["h264"],
"bframes": -1, "bframes": -1,
@@ -166,6 +166,8 @@ Redis (Sentinel) URL example JSON before encoding:
| `MACHINE_LEARNING_PRELOAD__CLIP__VISUAL` | Comma-separated list of (visual) CLIP model(s) to preload and cache | | machine learning | | `MACHINE_LEARNING_PRELOAD__CLIP__VISUAL` | Comma-separated list of (visual) CLIP model(s) to preload and cache | | machine learning |
| `MACHINE_LEARNING_PRELOAD__FACIAL_RECOGNITION__RECOGNITION` | Comma-separated list of (recognition) facial recognition model(s) to preload and cache | | machine learning | | `MACHINE_LEARNING_PRELOAD__FACIAL_RECOGNITION__RECOGNITION` | Comma-separated list of (recognition) facial recognition model(s) to preload and cache | | machine learning |
| `MACHINE_LEARNING_PRELOAD__FACIAL_RECOGNITION__DETECTION` | Comma-separated list of (detection) facial recognition model(s) to preload and cache | | machine learning | | `MACHINE_LEARNING_PRELOAD__FACIAL_RECOGNITION__DETECTION` | Comma-separated list of (detection) facial recognition model(s) to preload and cache | | machine learning |
| `MACHINE_LEARNING_PRELOAD__OCR__RECOGNITION` | Comma-separated list of (recognition) OCR model(s) to preload and cache | | machine learning |
| `MACHINE_LEARNING_PRELOAD__OCR__DETECTION` | Comma-separated list of (detection) OCR model(s) to preload and cache | | machine learning |
| `MACHINE_LEARNING_ANN` | Enable ARM-NN hardware acceleration if supported | `True` | machine learning | | `MACHINE_LEARNING_ANN` | Enable ARM-NN hardware acceleration if supported | `True` | machine learning |
| `MACHINE_LEARNING_ANN_FP16_TURBO` | Execute operations in FP16 precision: increasing speed, reducing precision (applies only to ARM-NN) | `False` | machine learning | | `MACHINE_LEARNING_ANN_FP16_TURBO` | Execute operations in FP16 precision: increasing speed, reducing precision (applies only to ARM-NN) | `False` | machine learning |
| `MACHINE_LEARNING_ANN_TUNING_LEVEL` | ARM-NN GPU tuning level (1: rapid, 2: normal, 3: exhaustive) | `2` | machine learning | | `MACHINE_LEARNING_ANN_TUNING_LEVEL` | ARM-NN GPU tuning level (1: rapid, 2: normal, 3: exhaustive) | `2` | machine learning |
+70 -48
View File
@@ -6,7 +6,7 @@ const prism = require('prism-react-renderer');
/** @type {import('@docusaurus/types').Config} */ /** @type {import('@docusaurus/types').Config} */
const config = { const config = {
title: 'Immich', title: 'Immich',
tagline: 'High performance self-hosted photo and video backup solution directly from your mobile phone', tagline: 'Self-hosted photo and video management solution',
url: 'https://docs.immich.app', url: 'https://docs.immich.app',
baseUrl: '/', baseUrl: '/',
onBrokenLinks: 'throw', onBrokenLinks: 'throw',
@@ -93,35 +93,15 @@ const config = {
position: 'right', position: 'right',
}, },
{ {
to: '/overview/quick-start', href: 'https://immich.app/',
position: 'right', position: 'right',
label: 'Docs', label: 'Home',
},
{
href: 'https://immich.app/roadmap',
position: 'right',
label: 'Roadmap',
},
{
href: 'https://api.immich.app/',
position: 'right',
label: 'API',
},
{
href: 'https://immich.store',
position: 'right',
label: 'Merch',
}, },
{ {
href: 'https://github.com/immich-app/immich', href: 'https://github.com/immich-app/immich',
label: 'GitHub', label: 'GitHub',
position: 'right', position: 'right',
}, },
{
href: 'https://discord.immich.app',
label: 'Discord',
position: 'right',
},
{ {
type: 'html', type: 'html',
position: 'right', position: 'right',
@@ -134,19 +114,78 @@ const config = {
style: 'light', style: 'light',
links: [ links: [
{ {
title: 'Overview', title: 'Download',
items: [ items: [
{ {
label: 'Quick start', label: 'Android',
to: '/overview/quick-start', href: 'https://get.immich.app/android',
}, },
{ {
label: 'Installation', label: 'iOS',
to: '/install/requirements', href: 'https://get.immich.app/ios',
}, },
{ {
label: 'Contributing', label: 'Server',
to: '/overview/support-the-project', href: 'https://immich.app/download',
},
],
},
{
title: 'Company',
items: [
{
label: 'FUTO',
href: 'https://futo.tech/',
},
{
label: 'Purchase',
href: 'https://buy.immich.app/',
},
{
label: 'Merch',
href: 'https://immich.store/',
},
],
},
{
title: 'Sites',
items: [
{
label: 'Home',
href: 'https://immich.app',
},
{
label: 'My Immich',
href: 'https://my.immich.app/',
},
{
label: 'Awesome Immich',
href: 'https://awesome.immich.app/',
},
{
label: 'Immich API',
href: 'https://api.immich.app/',
},
{
label: 'Immich Data',
href: 'https://data.immich.app/',
},
{
label: 'Immich Datasets',
href: 'https://datasets.immich.app/',
},
],
},
{
title: 'Miscellaneous',
items: [
{
label: 'Roadmap',
href: 'https://immich.app/roadmap',
},
{
label: 'Cursed Knowledge',
href: 'https://immich.app/cursed-knowledge',
}, },
{ {
label: 'Privacy Policy', label: 'Privacy Policy',
@@ -155,24 +194,7 @@ const config = {
], ],
}, },
{ {
title: 'Documentation', title: 'Social',
items: [
{
label: 'Roadmap',
href: 'https://immich.app/roadmap',
},
{
label: 'API',
href: 'https://api.immich.app/',
},
{
label: 'Cursed Knowledge',
href: 'https://immich.app/cursed-knowledge',
},
],
},
{
title: 'Links',
items: [ items: [
{ {
label: 'GitHub', label: 'GitHub',
+3 -3
View File
@@ -4,11 +4,11 @@
"private": true, "private": true,
"scripts": { "scripts": {
"docusaurus": "docusaurus", "docusaurus": "docusaurus",
"format": "prettier --check .", "format": "prettier --cache --check .",
"format:fix": "prettier --write .", "format:fix": "prettier --cache --write --list-different .",
"start": "docusaurus start --port 3005", "start": "docusaurus start --port 3005",
"copy:openapi": "jq -c < ../open-api/immich-openapi-specs.json > ./static/openapi.json || exit 0", "copy:openapi": "jq -c < ../open-api/immich-openapi-specs.json > ./static/openapi.json || exit 0",
"build": "npm run copy:openapi && docusaurus build", "build": "pnpm run copy:openapi && docusaurus build",
"swizzle": "docusaurus swizzle", "swizzle": "docusaurus swizzle",
"deploy": "docusaurus deploy", "deploy": "docusaurus deploy",
"clear": "docusaurus clear", "clear": "docusaurus clear",
+1
View File
@@ -23,6 +23,7 @@
/features/storage-template /administration/storage-template 307 /features/storage-template /administration/storage-template 307
/features/user-management /administration/user-management 307 /features/user-management /administration/user-management 307
/developer/contributing /developer/pr-checklist 307 /developer/contributing /developer/pr-checklist 307
/developer/open-api /api 307
/guides/machine-learning /guides/remote-machine-learning 307 /guides/machine-learning /guides/remote-machine-learning 307
/administration/password-login /administration/system-settings 307 /administration/password-login /administration/system-settings 307
/features/search /features/searching 307 /features/search /features/searching 307
+4
View File
@@ -1,4 +1,8 @@
[ [
{
"label": "v2.6.0",
"url": "https://docs.v2.6.0.archive.immich.app"
},
{ {
"label": "v2.5.6", "label": "v2.5.6",
"url": "https://docs.v2.5.6.archive.immich.app" "url": "https://docs.v2.5.6.archive.immich.app"
+25 -4
View File
@@ -10,6 +10,7 @@ export enum OAuthClient {
export enum OAuthUser { export enum OAuthUser {
NO_EMAIL = 'no-email', NO_EMAIL = 'no-email',
NO_NAME = 'no-name', NO_NAME = 'no-name',
ID_TOKEN_CLAIMS = 'id-token-claims',
WITH_QUOTA = 'with-quota', WITH_QUOTA = 'with-quota',
WITH_USERNAME = 'with-username', WITH_USERNAME = 'with-username',
WITH_ROLE = 'with-role', WITH_ROLE = 'with-role',
@@ -52,12 +53,25 @@ const withDefaultClaims = (sub: string) => ({
email_verified: true, email_verified: true,
}); });
const getClaims = (sub: string) => claims.find((user) => user.sub === sub) || withDefaultClaims(sub); const getClaims = (sub: string, use?: string) => {
if (sub === OAuthUser.ID_TOKEN_CLAIMS) {
return {
sub,
email: `oauth-${sub}@immich.app`,
email_verified: true,
name: use === 'id_token' ? 'ID Token User' : 'Userinfo User',
};
}
return claims.find((user) => user.sub === sub) || withDefaultClaims(sub);
};
const setup = async () => { const setup = async () => {
const { privateKey, publicKey } = await generateKeyPair('RS256'); const { privateKey, publicKey } = await generateKeyPair('RS256');
const redirectUris = ['http://127.0.0.1:2285/auth/login', 'https://photos.immich.app/oauth/mobile-redirect']; const redirectUris = [
'http://127.0.0.1:2285/auth/login',
'https://photos.immich.app/oauth/mobile-redirect',
];
const port = 2286; const port = 2286;
const host = '0.0.0.0'; const host = '0.0.0.0';
const oidc = new Provider(`http://${host}:${port}`, { const oidc = new Provider(`http://${host}:${port}`, {
@@ -66,7 +80,10 @@ const setup = async () => {
console.error(error); console.error(error);
ctx.body = 'Internal Server Error'; ctx.body = 'Internal Server Error';
}, },
findAccount: (ctx, sub) => ({ accountId: sub, claims: () => getClaims(sub) }), findAccount: (ctx, sub) => ({
accountId: sub,
claims: (use) => getClaims(sub, use),
}),
scopes: ['openid', 'email', 'profile'], scopes: ['openid', 'email', 'profile'],
claims: { claims: {
openid: ['sub'], openid: ['sub'],
@@ -94,6 +111,7 @@ const setup = async () => {
state: 'oidc.state', state: 'oidc.state',
}, },
}, },
conformIdTokenClaims: false,
pkce: { pkce: {
required: () => false, required: () => false,
}, },
@@ -125,7 +143,10 @@ const setup = async () => {
], ],
}); });
const onStart = () => console.log(`[e2e-auth-server] http://${host}:${port}/.well-known/openid-configuration`); const onStart = () =>
console.log(
`[e2e-auth-server] http://${host}:${port}/.well-known/openid-configuration`,
);
const app = oidc.listen(port, host, onStart); const app = oidc.listen(port, host, onStart);
return () => app.close(); return () => app.close();
}; };
+1 -1
View File
@@ -44,7 +44,7 @@ services:
redis: redis:
container_name: immich-e2e-redis container_name: immich-e2e-redis
image: docker.io/valkey/valkey:9@sha256:930b41430fb727f533c5982fe509b6f04233e26d0f7354e04de4b0d5c706e44e image: docker.io/valkey/valkey:9@sha256:3eeb09785cd61ec8e3be35f8804c8892080f3ca21934d628abc24ee4ed1698f6
healthcheck: healthcheck:
test: redis-cli ping || exit 1 test: redis-cli ping || exit 1
+19 -18
View File
@@ -1,6 +1,6 @@
{ {
"name": "immich-e2e", "name": "immich-e2e",
"version": "2.5.6", "version": "2.6.0",
"description": "", "description": "",
"main": "index.js", "main": "index.js",
"type": "module", "type": "module",
@@ -8,41 +8,41 @@
"test": "vitest --run", "test": "vitest --run",
"test:watch": "vitest", "test:watch": "vitest",
"test:maintenance": "vitest --run --config vitest.maintenance.config.ts", "test:maintenance": "vitest --run --config vitest.maintenance.config.ts",
"test:web": "npx playwright test --project=web", "test:web": "pnpm exec playwright test --project=web",
"test:web:maintenance": "npx playwright test --project=maintenance", "test:web:maintenance": "pnpm exec playwright test --project=maintenance",
"test:web:ui": "npx playwright test --project=ui", "test:web:ui": "pnpm exec playwright test --project=ui",
"start:web": "npx playwright test --ui --project=web", "start:web": "pnpm exec playwright test --ui --project=web",
"start:web:maintenance": "npx playwright test --ui --project=maintenance", "start:web:maintenance": "pnpm exec playwright test --ui --project=maintenance",
"start:web:ui": "npx playwright test --ui --project=ui", "start:web:ui": "pnpm exec playwright test --ui --project=ui",
"format": "prettier --check .", "format": "prettier --cache --check .",
"format:fix": "prettier --write .", "format:fix": "prettier --cache --write --list-different .",
"lint": "eslint \"src/**/*.ts\" --max-warnings 0", "lint": "eslint \"src/**/*.ts\" --max-warnings 0",
"lint:fix": "npm run lint -- --fix", "lint:fix": "pnpm run lint --fix",
"check": "tsc --noEmit" "check": "tsc --noEmit"
}, },
"keywords": [], "keywords": [],
"author": "", "author": "",
"license": "GNU Affero General Public License version 3", "license": "GNU Affero General Public License version 3",
"devDependencies": { "devDependencies": {
"@eslint/js": "^9.8.0", "@eslint/js": "^10.0.0",
"@faker-js/faker": "^10.1.0", "@faker-js/faker": "^10.1.0",
"@immich/cli": "workspace:*", "@immich/cli": "workspace:*",
"@immich/e2e-auth-server": "workspace:*", "@immich/e2e-auth-server": "workspace:*",
"@immich/sdk": "workspace:*", "@immich/sdk": "workspace:*",
"@playwright/test": "^1.44.1", "@playwright/test": "^1.44.1",
"@socket.io/component-emitter": "^3.1.2", "@socket.io/component-emitter": "^3.1.2",
"@types/luxon": "^3.4.2", "@types/luxon": "^3.4.2",
"@types/node": "^24.10.13", "@types/node": "^24.11.0",
"@types/pg": "^8.15.1", "@types/pg": "^8.15.1",
"@types/pngjs": "^6.0.4", "@types/pngjs": "^6.0.4",
"@types/supertest": "^6.0.2", "@types/supertest": "^6.0.2",
"dotenv": "^17.2.3", "dotenv": "^17.2.3",
"eslint": "^9.14.0", "eslint": "^10.0.0",
"eslint-config-prettier": "^10.1.8", "eslint-config-prettier": "^10.1.8",
"eslint-plugin-prettier": "^5.1.3", "eslint-plugin-prettier": "^5.1.3",
"eslint-plugin-unicorn": "^62.0.0", "eslint-plugin-unicorn": "^63.0.0",
"exiftool-vendored": "^34.3.0", "exiftool-vendored": "^35.0.0",
"globals": "^16.0.0", "globals": "^17.0.0",
"luxon": "^3.4.4", "luxon": "^3.4.4",
"pg": "^8.11.3", "pg": "^8.11.3",
"pngjs": "^7.0.0", "pngjs": "^7.0.0",
@@ -54,7 +54,8 @@
"typescript": "^5.3.3", "typescript": "^5.3.3",
"typescript-eslint": "^8.28.0", "typescript-eslint": "^8.28.0",
"utimes": "^5.2.1", "utimes": "^5.2.1",
"vitest": "^3.0.0" "vite-tsconfig-paths": "^6.1.1",
"vitest": "^4.0.0"
}, },
"volta": { "volta": {
"node": "24.13.1" "node": "24.13.1"
+2 -1
View File
@@ -253,7 +253,8 @@ describe('/asset', () => {
expect(status).toBe(200); expect(status).toBe(200);
expect(body.id).toEqual(facesAsset.id); expect(body.id).toEqual(facesAsset.id);
expect(body.people).toMatchObject(expectedFaces); const sortedPeople = body.people.toSorted((a: any, b: any) => a.name.localeCompare(b.name));
expect(sortedPeople).toMatchObject(expectedFaces);
}); });
}); });
@@ -380,4 +380,23 @@ describe(`/oauth`, () => {
}); });
}); });
}); });
describe('idTokenClaims', () => {
it('should use claims from the ID token if IDP includes them', async () => {
await setupOAuth(admin.accessToken, {
enabled: true,
clientId: OAuthClient.DEFAULT,
clientSecret: OAuthClient.DEFAULT,
});
const callbackParams = await loginWithOAuth(OAuthUser.ID_TOKEN_CLAIMS);
const { status, body } = await request(app).post('/oauth/callback').send(callbackParams);
expect(status).toBe(201);
expect(body).toMatchObject({
accessToken: expect.any(String),
name: 'ID Token User',
userEmail: 'oauth-id-token-claims@immich.app',
userId: expect.any(String),
});
});
});
}); });
@@ -438,6 +438,16 @@ describe('/shared-links', () => {
expect(body).toEqual(errorDto.badRequest('Invalid shared link type')); expect(body).toEqual(errorDto.badRequest('Invalid shared link type'));
}); });
it('should reject guests removing assets from an individual shared link', async () => {
const { status, body } = await request(app)
.delete(`/shared-links/${linkWithAssets.id}/assets`)
.query({ key: linkWithAssets.key })
.send({ assetIds: [asset1.id] });
expect(status).toBe(403);
expect(body).toEqual(errorDto.forbidden);
});
it('should remove assets from a shared link (individual)', async () => { it('should remove assets from a shared link (individual)', async () => {
const { status, body } = await request(app) const { status, body } = await request(app)
.delete(`/shared-links/${linkWithAssets.id}/assets`) .delete(`/shared-links/${linkWithAssets.id}/assets`)
@@ -1,66 +0,0 @@
import { AssetMediaResponseDto, LoginResponseDto } from '@immich/sdk';
import { expect, Page, test } from '@playwright/test';
import { utils } from 'src/utils';
async function ensureDetailPanelVisible(page: Page) {
await page.waitForSelector('#immich-asset-viewer');
const isVisible = await page.locator('#detail-panel').isVisible();
if (!isVisible) {
await page.keyboard.press('i');
await page.waitForSelector('#detail-panel');
}
}
test.describe('Asset Viewer stack', () => {
let admin: LoginResponseDto;
let assetOne: AssetMediaResponseDto;
let assetTwo: AssetMediaResponseDto;
test.beforeAll(async () => {
utils.initSdk();
await utils.resetDatabase();
admin = await utils.adminSetup();
await utils.updateMyPreferences(admin.accessToken, { tags: { enabled: true } });
assetOne = await utils.createAsset(admin.accessToken);
assetTwo = await utils.createAsset(admin.accessToken);
await utils.createStack(admin.accessToken, [assetOne.id, assetTwo.id]);
const tags = await utils.upsertTags(admin.accessToken, ['test/1', 'test/2']);
const tagOne = tags.find((tag) => tag.value === 'test/1')!;
const tagTwo = tags.find((tag) => tag.value === 'test/2')!;
await utils.tagAssets(admin.accessToken, tagOne.id, [assetOne.id]);
await utils.tagAssets(admin.accessToken, tagTwo.id, [assetTwo.id]);
});
test('stack slideshow is visible', async ({ page, context }) => {
await utils.setAuthCookies(context, admin.accessToken);
await page.goto(`/photos/${assetOne.id}`);
const stackAssets = page.locator('#stack-slideshow [data-asset]');
await expect(stackAssets.first()).toBeVisible();
await expect(stackAssets.nth(1)).toBeVisible();
});
test('tags of primary asset are visible', async ({ page, context }) => {
await utils.setAuthCookies(context, admin.accessToken);
await page.goto(`/photos/${assetOne.id}`);
await ensureDetailPanelVisible(page);
const tags = page.getByTestId('detail-panel-tags').getByRole('link');
await expect(tags.first()).toHaveText('test/1');
});
test('tags of second asset are visible', async ({ page, context }) => {
await utils.setAuthCookies(context, admin.accessToken);
await page.goto(`/photos/${assetOne.id}`);
await ensureDetailPanelVisible(page);
const stackAssets = page.locator('#stack-slideshow [data-asset]');
await stackAssets.nth(1).click();
const tags = page.getByTestId('detail-panel-tags').getByRole('link');
await expect(tags.first()).toHaveText('test/2');
});
});
+57 -19
View File
@@ -1,14 +1,13 @@
import { AssetMediaResponseDto, LoginResponseDto } from '@immich/sdk'; import { AssetMediaResponseDto, LoginResponseDto } from '@immich/sdk';
import { Page, expect, test } from '@playwright/test'; import { expect, test } from '@playwright/test';
import type { Socket } from 'socket.io-client';
import { utils } from 'src/utils'; import { utils } from 'src/utils';
function imageLocator(page: Page) {
return page.getByAltText('Image taken').locator('visible=true');
}
test.describe('Photo Viewer', () => { test.describe('Photo Viewer', () => {
let admin: LoginResponseDto; let admin: LoginResponseDto;
let asset: AssetMediaResponseDto; let asset: AssetMediaResponseDto;
let rawAsset: AssetMediaResponseDto; let rawAsset: AssetMediaResponseDto;
let websocket: Socket;
test.beforeAll(async () => { test.beforeAll(async () => {
utils.initSdk(); utils.initSdk();
@@ -16,6 +15,11 @@ test.describe('Photo Viewer', () => {
admin = await utils.adminSetup(); admin = await utils.adminSetup();
asset = await utils.createAsset(admin.accessToken); asset = await utils.createAsset(admin.accessToken);
rawAsset = await utils.createAsset(admin.accessToken, { assetData: { filename: 'test.arw' } }); rawAsset = await utils.createAsset(admin.accessToken, { assetData: { filename: 'test.arw' } });
websocket = await utils.connectWebsocket(admin.accessToken);
});
test.afterAll(() => {
utils.disconnectWebsocket(websocket);
}); });
test.beforeEach(async ({ context, page }) => { test.beforeEach(async ({ context, page }) => {
@@ -26,31 +30,65 @@ test.describe('Photo Viewer', () => {
test('loads original photo when zoomed', async ({ page }) => { test('loads original photo when zoomed', async ({ page }) => {
await page.goto(`/photos/${asset.id}`); await page.goto(`/photos/${asset.id}`);
await expect.poll(async () => await imageLocator(page).getAttribute('src')).toContain('thumbnail');
const box = await imageLocator(page).boundingBox(); const preview = page.getByTestId('preview').filter({ visible: true });
expect(box).toBeTruthy(); await expect(preview).toHaveAttribute('src', /.+/);
const { x, y, width, height } = box!;
await page.mouse.move(x + width / 2, y + height / 2); const originalResponse = page.waitForResponse((response) => response.url().includes('/original'));
const { width, height } = page.viewportSize()!;
await page.mouse.move(width / 2, height / 2);
await page.mouse.wheel(0, -1); await page.mouse.wheel(0, -1);
await expect.poll(async () => await imageLocator(page).getAttribute('src')).toContain('original');
await originalResponse;
const original = page.getByTestId('original').filter({ visible: true });
await expect(original).toHaveAttribute('src', /original/);
}); });
test('loads fullsize image when zoomed and original is web-incompatible', async ({ page }) => { test('loads fullsize image when zoomed and original is web-incompatible', async ({ page }) => {
await page.goto(`/photos/${rawAsset.id}`); await page.goto(`/photos/${rawAsset.id}`);
await expect.poll(async () => await imageLocator(page).getAttribute('src')).toContain('thumbnail');
const box = await imageLocator(page).boundingBox(); const preview = page.getByTestId('preview').filter({ visible: true });
expect(box).toBeTruthy(); await expect(preview).toHaveAttribute('src', /.+/);
const { x, y, width, height } = box!;
await page.mouse.move(x + width / 2, y + height / 2); const fullsizeResponse = page.waitForResponse((response) => response.url().includes('fullsize'));
const { width, height } = page.viewportSize()!;
await page.mouse.move(width / 2, height / 2);
await page.mouse.wheel(0, -1); await page.mouse.wheel(0, -1);
await expect.poll(async () => await imageLocator(page).getAttribute('src')).toContain('fullsize');
await fullsizeResponse;
const original = page.getByTestId('original').filter({ visible: true });
await expect(original).toHaveAttribute('src', /fullsize/);
});
test('right-click targets the img element', async ({ page }) => {
await page.goto(`/photos/${asset.id}`);
const preview = page.getByTestId('preview').filter({ visible: true });
await expect(preview).toHaveAttribute('src', /.+/);
const box = await preview.boundingBox();
const tagAtCenter = await page.evaluate(({ x, y }) => document.elementFromPoint(x, y)?.tagName, {
x: box!.x + box!.width / 2,
y: box!.y + box!.height / 2,
});
expect(tagAtCenter).toBe('IMG');
}); });
test('reloads photo when checksum changes', async ({ page }) => { test('reloads photo when checksum changes', async ({ page }) => {
await page.goto(`/photos/${asset.id}`); await page.goto(`/photos/${asset.id}`);
await expect.poll(async () => await imageLocator(page).getAttribute('src')).toContain('thumbnail');
const initialSrc = await imageLocator(page).getAttribute('src'); const preview = page.getByTestId('preview').filter({ visible: true });
await expect(preview).toHaveAttribute('src', /.+/);
const initialSrc = await preview.getAttribute('src');
const websocketEvent = utils.waitForWebsocketEvent({ event: 'assetUpdate', id: asset.id });
await utils.replaceAsset(admin.accessToken, asset.id); await utils.replaceAsset(admin.accessToken, asset.id);
await expect.poll(async () => await imageLocator(page).getAttribute('src')).not.toBe(initialSrc); await websocketEvent;
await expect(preview).not.toHaveAttribute('src', initialSrc!);
}); });
}); });
+25 -2
View File
@@ -12,15 +12,18 @@ import { asBearerAuth, utils } from 'src/utils';
test.describe('Shared Links', () => { test.describe('Shared Links', () => {
let admin: LoginResponseDto; let admin: LoginResponseDto;
let asset: AssetMediaResponseDto; let asset: AssetMediaResponseDto;
let asset2: AssetMediaResponseDto;
let album: AlbumResponseDto; let album: AlbumResponseDto;
let sharedLink: SharedLinkResponseDto; let sharedLink: SharedLinkResponseDto;
let sharedLinkPassword: SharedLinkResponseDto; let sharedLinkPassword: SharedLinkResponseDto;
let individualSharedLink: SharedLinkResponseDto;
test.beforeAll(async () => { test.beforeAll(async () => {
utils.initSdk(); utils.initSdk();
await utils.resetDatabase(); await utils.resetDatabase();
admin = await utils.adminSetup(); admin = await utils.adminSetup();
asset = await utils.createAsset(admin.accessToken); asset = await utils.createAsset(admin.accessToken);
asset2 = await utils.createAsset(admin.accessToken);
album = await createAlbum( album = await createAlbum(
{ {
createAlbumDto: { createAlbumDto: {
@@ -39,14 +42,17 @@ test.describe('Shared Links', () => {
albumId: album.id, albumId: album.id,
password: 'test-password', password: 'test-password',
}); });
individualSharedLink = await utils.createSharedLink(admin.accessToken, {
type: SharedLinkType.Individual,
assetIds: [asset.id, asset2.id],
});
}); });
test('download from a shared link', async ({ page }) => { test('download from a shared link', async ({ page }) => {
await page.goto(`/share/${sharedLink.key}`); await page.goto(`/share/${sharedLink.key}`);
await page.getByRole('heading', { name: 'Test Album' }).waitFor(); await page.getByRole('heading', { name: 'Test Album' }).waitFor();
await page.locator(`[data-asset-id="${asset.id}"]`).hover(); await page.locator(`[data-asset-id="${asset.id}"]`).hover();
await page.waitForSelector('[data-group] svg'); await page.waitForSelector(`[data-asset-id="${asset.id}"] [role="checkbox"]`);
await page.getByRole('checkbox').click();
await Promise.all([page.waitForEvent('download'), page.getByRole('button', { name: 'Download' }).click()]); await Promise.all([page.waitForEvent('download'), page.getByRole('button', { name: 'Download' }).click()]);
}); });
@@ -110,4 +116,21 @@ test.describe('Shared Links', () => {
await page.waitForURL('/photos'); await page.waitForURL('/photos');
await page.locator(`[data-asset-id="${asset.id}"]`).waitFor(); await page.locator(`[data-asset-id="${asset.id}"]`).waitFor();
}); });
test('owner can remove assets from an individual shared link', async ({ context, page }) => {
await utils.setAuthCookies(context, admin.accessToken);
await page.goto(`/share/${individualSharedLink.key}`);
await page.locator(`[data-asset="${asset.id}"]`).waitFor();
await expect(page.locator(`[data-asset]`)).toHaveCount(2);
await page.locator(`[data-asset="${asset.id}"]`).hover();
await page.locator(`[data-asset="${asset.id}"] [role="checkbox"]`).click();
await page.getByRole('button', { name: 'Remove from shared link' }).click();
await page.getByRole('button', { name: 'Remove', exact: true }).click();
await expect(page.locator(`[data-asset="${asset.id}"]`)).toHaveCount(0);
await expect(page.locator(`[data-asset="${asset2.id}"]`)).toHaveCount(1);
});
}); });
@@ -0,0 +1,167 @@
import { faker } from '@faker-js/faker';
import { AssetTypeEnum, AssetVisibility, type AssetResponseDto, type StackResponseDto } from '@immich/sdk';
import { BrowserContext } from '@playwright/test';
import { randomPreview, randomThumbnail } from 'src/ui/generators/timeline';
export type MockStack = {
id: string;
primaryAssetId: string;
assets: AssetResponseDto[];
brokenAssetIds: Set<string>;
assetMap: Map<string, AssetResponseDto>;
};
export const createMockStackAsset = (ownerId: string): AssetResponseDto => {
const assetId = faker.string.uuid();
const now = new Date().toISOString();
return {
id: assetId,
deviceAssetId: `device-${assetId}`,
ownerId,
owner: {
id: ownerId,
email: 'admin@immich.cloud',
name: 'Admin',
profileImagePath: '',
profileChangedAt: now,
avatarColor: 'blue' as never,
},
libraryId: `library-${ownerId}`,
deviceId: `device-${ownerId}`,
type: AssetTypeEnum.Image,
originalPath: `/original/${assetId}.jpg`,
originalFileName: `${assetId}.jpg`,
originalMimeType: 'image/jpeg',
thumbhash: null,
fileCreatedAt: now,
fileModifiedAt: now,
localDateTime: now,
updatedAt: now,
createdAt: now,
isFavorite: false,
isArchived: false,
isTrashed: false,
visibility: AssetVisibility.Timeline,
duration: '0:00:00.00000',
exifInfo: {
make: null,
model: null,
exifImageWidth: 3000,
exifImageHeight: 4000,
fileSizeInByte: null,
orientation: null,
dateTimeOriginal: now,
modifyDate: null,
timeZone: null,
lensModel: null,
fNumber: null,
focalLength: null,
iso: null,
exposureTime: null,
latitude: null,
longitude: null,
city: null,
country: null,
state: null,
description: null,
},
livePhotoVideoId: null,
tags: [],
people: [],
unassignedFaces: [],
stack: null,
isOffline: false,
hasMetadata: true,
duplicateId: null,
resized: true,
checksum: faker.string.alphanumeric({ length: 28 }),
width: 3000,
height: 4000,
isEdited: false,
};
};
export const createMockStack = (
primaryAssetDto: AssetResponseDto,
additionalAssets: AssetResponseDto[],
brokenAssetIds?: Set<string>,
): MockStack => {
const stackId = faker.string.uuid();
const allAssets = [primaryAssetDto, ...additionalAssets];
const resolvedBrokenIds = brokenAssetIds ?? new Set(additionalAssets.map((a) => a.id));
const assetMap = new Map(allAssets.map((a) => [a.id, a]));
primaryAssetDto.stack = {
id: stackId,
assetCount: allAssets.length,
primaryAssetId: primaryAssetDto.id,
};
return {
id: stackId,
primaryAssetId: primaryAssetDto.id,
assets: allAssets,
brokenAssetIds: resolvedBrokenIds,
assetMap,
};
};
export const setupBrokenAssetMockApiRoutes = async (context: BrowserContext, mockStack: MockStack) => {
await context.route('**/api/stacks/*', async (route, request) => {
if (request.method() !== 'GET') {
return route.fallback();
}
const stackResponse: StackResponseDto = {
id: mockStack.id,
primaryAssetId: mockStack.primaryAssetId,
assets: mockStack.assets,
};
return route.fulfill({
status: 200,
contentType: 'application/json',
json: stackResponse,
});
});
await context.route('**/api/assets/*', async (route, request) => {
if (request.method() !== 'GET') {
return route.fallback();
}
const url = new URL(request.url());
const segments = url.pathname.split('/');
const assetId = segments.at(-1);
if (assetId && mockStack.assetMap.has(assetId)) {
return route.fulfill({
status: 200,
contentType: 'application/json',
json: mockStack.assetMap.get(assetId),
});
}
return route.fallback();
});
await context.route('**/api/assets/*/thumbnail?size=*', async (route, request) => {
if (!route.request().serviceWorker()) {
return route.continue();
}
const pattern = /\/api\/assets\/(?<assetId>[^/]+)\/thumbnail\?size=(?<size>preview|thumbnail)/;
const match = request.url().match(pattern);
if (!match?.groups || !mockStack.assetMap.has(match.groups.assetId)) {
return route.fallback();
}
if (mockStack.brokenAssetIds.has(match.groups.assetId)) {
return route.fulfill({ status: 404 });
}
const asset = mockStack.assetMap.get(match.groups.assetId)!;
const ratio = (asset.exifInfo?.exifImageWidth ?? 3000) / (asset.exifInfo?.exifImageHeight ?? 4000);
const body =
match.groups.size === 'preview'
? await randomPreview(match.groups.assetId, ratio)
: await randomThumbnail(match.groups.assetId, ratio);
return route.fulfill({
status: 200,
headers: { 'content-type': 'image/jpeg' },
body,
});
});
};
@@ -0,0 +1,127 @@
import { BrowserContext } from '@playwright/test';
import { randomThumbnail } from 'src/ui/generators/timeline';
// Minimal valid H.264 MP4 (8x8px, 1 frame) that browsers can decode to get videoWidth/videoHeight
const MINIMAL_MP4_BASE64 =
'AAAAIGZ0eXBpc29tAAACAGlzb21pc28yYXZjMW1wNDEAAAAIZnJlZQAAAr9tZGF0AAACoAYF//+c' +
'3EXpvebZSLeWLNgg2SPu73gyNjQgLSBjb3JlIDEyNSAtIEguMjY0L01QRUctNCBBVkMgY29kZWMg' +
'LSBDb3B5bGVmdCAyMDAzLTIwMTIgLSBodHRwOi8vd3d3LnZpZGVvbGFuLm9yZy94MjY0Lmh0bWwg' +
'LSBvcHRpb25zOiBjYWJhYz0xIHJlZj0zIGRlYmxvY2s9MTowOjAgYW5hbHlzZT0weDM6MHgxMTMg' +
'bWU9aGV4IHN1Ym1lPTcgcHN5PTEgcHN5X3JkPTEuMDA6MC4wMCBtaXhlZF9yZWY9MSBtZV9yYW5n' +
'ZT0xNiBjaHJvbWFfbWU9MSB0cmVsbGlzPTEgOHg4ZGN0PTEgY3FtPTAgZGVhZHpvbmU9MjEsMTEg' +
'ZmFzdF9wc2tpcD0xIGNocm9tYV9xcF9vZmZzZXQ9LTIgdGhyZWFkcz02IGxvb2thaGVhZF90aHJl' +
'YWRzPTEgc2xpY2VkX3RocmVhZHM9MCBucj0wIGRlY2ltYXRlPTEgaW50ZXJsYWNlZD0wIGJsdXJh' +
'eV9jb21wYXQ9MCBjb25zdHJhaW5lZF9pbnRyYT0wIGJmcmFtZXM9MyBiX3B5cmFtaWQ9MiBiX2Fk' +
'YXB0PTEgYl9iaWFzPTAgZGlyZWN0PTEgd2VpZ2h0Yj0xIG9wZW5fZ29wPTAgd2VpZ2h0cD0yIGtl' +
'eWludD0yNTAga2V5aW50X21pbj0yNCBzY2VuZWN1dD00MCBpbnRyYV9yZWZyZXNoPTAgcmNfbG9v' +
'a2FoZWFkPTQwIHJjPWNyZiBtYnRyZWU9MSBjcmY9MjMuMCBxY29tcD0wLjYwIHFwbWluPTAgcXBt' +
'YXg9NjkgcXBzdGVwPTQgaXBfcmF0aW89MS40MCBhcT0xOjEuMDAAgAAAAA9liIQAV/0TAAYdeBTX' +
'zg8AAALvbW9vdgAAAGxtdmhkAAAAAAAAAAAAAAAAAAAD6AAAACoAAQAAAQAAAAAAAAAAAAAAAAEAAAAA' +
'AAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgAA' +
'Ahl0cmFrAAAAXHRraGQAAAAPAAAAAAAAAAAAAAABAAAAAAAAACoAAAAAAAAAAAAAAAAAAAAAAAEAAAAA' +
'AAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAABAAAAAAAgAAAAIAAAAAAAkZWR0cwAAABxlbHN0AAAAAAAA' +
'AAEAAAAqAAAAAAABAAAAAAGRbWRpYQAAACBtZGhkAAAAAAAAAAAAAAAAAAAwAAAAAgBVxAAAAAAA' +
'LWhkbHIAAAAAAAAAAHZpZGUAAAAAAAAAAAAAAABWaWRlb0hhbmRsZXIAAAABPG1pbmYAAAAUdm1oZAAA' +
'AAEAAAAAAAAAAAAAACRkaW5mAAAAHGRyZWYAAAAAAAAAAQAAAAx1cmwgAAAAAQAAAPxzdGJsAAAAmHN0' +
'c2QAAAAAAAAAAQAAAIhhdmMxAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAgACABIAAAASAAAAAAAAAAB' +
'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGP//AAAAMmF2Y0MBZAAK/+EAGWdkAAqs' +
'2V+WXAWyAAADAAIAAAMAYB4kSywBAAZo6+PLIsAAAAAYc3R0cwAAAAAAAAABAAAAAQAAAgAAAAAcc3Rz' +
'YwAAAAAAAAABAAAAAQAAAAEAAAABAAAAFHN0c3oAAAAAAAACtwAAAAEAAAAUc3RjbwAAAAAAAAABAAAA' +
'MAAAAGJ1ZHRhAAAAWm1ldGEAAAAAAAAAIWhkbHIAAAAAAAAAAG1kaXJhcHBsAAAAAAAAAAAAAAAALWls' +
'c3QAAAAlqXRvbwAAAB1kYXRhAAAAAQAAAABMYXZmNTQuNjMuMTA0';
export const MINIMAL_MP4_BUFFER = Buffer.from(MINIMAL_MP4_BASE64, 'base64');
export type MockPerson = {
id: string;
name: string;
birthDate: string | null;
isHidden: boolean;
thumbnailPath: string;
updatedAt: string;
};
export const createMockPeople = (count: number): MockPerson[] => {
const names = [
'Alice Johnson',
'Bob Smith',
'Charlie Brown',
'Diana Prince',
'Eve Adams',
'Frank Castle',
'Grace Lee',
'Hank Pym',
'Iris West',
'Jack Ryan',
];
return Array.from({ length: count }, (_, index) => ({
id: `person-${index}`,
name: names[index % names.length],
birthDate: null,
isHidden: false,
thumbnailPath: `/upload/thumbs/person-${index}.jpeg`,
updatedAt: '2025-01-01T00:00:00.000Z',
}));
};
export type FaceCreateCapture = {
requests: Array<{
assetId: string;
personId: string;
x: number;
y: number;
width: number;
height: number;
imageWidth: number;
imageHeight: number;
}>;
};
export const setupFaceEditorMockApiRoutes = async (
context: BrowserContext,
mockPeople: MockPerson[],
faceCreateCapture: FaceCreateCapture,
) => {
await context.route('**/api/people?*', async (route, request) => {
if (request.method() !== 'GET') {
return route.fallback();
}
return route.fulfill({
status: 200,
contentType: 'application/json',
json: {
hasNextPage: false,
hidden: 0,
people: mockPeople,
total: mockPeople.length,
},
});
});
await context.route('**/api/faces', async (route, request) => {
if (request.method() !== 'POST') {
return route.fallback();
}
const body = request.postDataJSON();
faceCreateCapture.requests.push(body);
return route.fulfill({
status: 201,
contentType: 'text/plain',
body: 'OK',
});
});
await context.route('**/api/people/*/thumbnail', async (route) => {
if (!route.request().serviceWorker()) {
return route.continue();
}
return route.fulfill({
status: 200,
headers: { 'content-type': 'image/jpeg' },
body: await randomThumbnail('person-thumb', 1),
});
});
};
@@ -12,6 +12,7 @@ import {
TimelineData, TimelineData,
} from 'src/ui/generators/timeline'; } from 'src/ui/generators/timeline';
import { sleep } from 'src/ui/specs/timeline/utils'; import { sleep } from 'src/ui/specs/timeline/utils';
import { MINIMAL_MP4_BUFFER } from './face-editor-network';
export class TimelineTestContext { export class TimelineTestContext {
slowBucket = false; slowBucket = false;
@@ -135,6 +136,14 @@ export const setupTimelineMockApiRoutes = async (
return route.continue(); return route.continue();
}); });
await context.route('**/api/assets/*/video/playback*', async (route) => {
return route.fulfill({
status: 200,
headers: { 'content-type': 'video/mp4' },
body: MINIMAL_MP4_BUFFER,
});
});
await context.route('**/api/albums/**', async (route, request) => { await context.route('**/api/albums/**', async (route, request) => {
const albumsMatch = request.url().match(/\/api\/albums\/(?<albumId>[^/?]+)/); const albumsMatch = request.url().match(/\/api\/albums\/(?<albumId>[^/?]+)/);
if (albumsMatch) { if (albumsMatch) {
@@ -0,0 +1,86 @@
import { expect, test } from '@playwright/test';
import { toAssetResponseDto } from 'src/ui/generators/timeline';
import {
createMockStack,
createMockStackAsset,
MockStack,
setupBrokenAssetMockApiRoutes,
} from 'src/ui/mock-network/broken-asset-network';
import { assetViewerUtils } from '../timeline/utils';
import { setupAssetViewerFixture } from './utils';
test.describe.configure({ mode: 'parallel' });
test.describe('broken-asset responsiveness', () => {
const fixture = setupAssetViewerFixture(889);
let mockStack: MockStack;
test.beforeAll(async () => {
const primaryAssetDto = toAssetResponseDto(fixture.primaryAsset);
const brokenAssets = [
createMockStackAsset(fixture.adminUserId),
createMockStackAsset(fixture.adminUserId),
createMockStackAsset(fixture.adminUserId),
];
mockStack = createMockStack(primaryAssetDto, brokenAssets);
});
test.beforeEach(async ({ context }) => {
await setupBrokenAssetMockApiRoutes(context, mockStack);
});
test('broken asset in stack strip hides icon at small size', async ({ page }) => {
await page.goto(`/photos/${fixture.primaryAsset.id}`);
await assetViewerUtils.waitForViewerLoad(page, fixture.primaryAsset);
const stackSlideshow = page.locator('#stack-slideshow');
await expect(stackSlideshow).toBeVisible();
const brokenAssets = stackSlideshow.locator('[data-broken-asset]');
await expect(brokenAssets.first()).toBeVisible();
await expect(brokenAssets).toHaveCount(mockStack.brokenAssetIds.size);
for (const brokenAsset of await brokenAssets.all()) {
await expect(brokenAsset.locator('svg')).not.toBeVisible();
}
});
test('broken asset in stack strip uses text-xs class', async ({ page }) => {
await page.goto(`/photos/${fixture.primaryAsset.id}`);
await assetViewerUtils.waitForViewerLoad(page, fixture.primaryAsset);
const stackSlideshow = page.locator('#stack-slideshow');
await expect(stackSlideshow).toBeVisible();
const brokenAssets = stackSlideshow.locator('[data-broken-asset]');
await expect(brokenAssets.first()).toBeVisible();
for (const brokenAsset of await brokenAssets.all()) {
const messageSpan = brokenAsset.locator('span');
await expect(messageSpan).toHaveClass(/text-xs/);
}
});
test('broken asset in main viewer shows icon and uses text-base', async ({ context, page }) => {
await context.route(
(url) =>
url.pathname.includes(`/api/assets/${fixture.primaryAsset.id}/thumbnail`) ||
url.pathname.includes(`/api/assets/${fixture.primaryAsset.id}/original`),
async (route) => {
return route.fulfill({ status: 404 });
},
);
await page.goto(`/photos/${fixture.primaryAsset.id}`);
await page.waitForSelector('#immich-asset-viewer');
const viewerBrokenAsset = page.locator('[data-viewer-content] [data-broken-asset]').first();
await expect(viewerBrokenAsset).toBeVisible();
await expect(viewerBrokenAsset.locator('svg')).toBeVisible();
const messageSpan = viewerBrokenAsset.locator('span');
await expect(messageSpan).toHaveClass(/text-base/);
});
});
@@ -0,0 +1,285 @@
import { expect, Page, test } from '@playwright/test';
import { SeededRandom, selectRandom, TimelineAssetConfig } from 'src/ui/generators/timeline';
import {
createMockPeople,
FaceCreateCapture,
MockPerson,
setupFaceEditorMockApiRoutes,
} from 'src/ui/mock-network/face-editor-network';
import { assetViewerUtils } from '../timeline/utils';
import { setupAssetViewerFixture } from './utils';
const waitForSelectorTransition = async (page: Page) => {
await page.waitForFunction(
() => {
const selector = document.querySelector('#face-selector') as HTMLElement | null;
if (!selector) {
return false;
}
return selector.getAnimations({ subtree: false }).every((animation) => animation.playState === 'finished');
},
undefined,
{ timeout: 1000, polling: 50 },
);
};
const openFaceEditor = async (page: Page, asset: TimelineAssetConfig) => {
await page.goto(`/photos/${asset.id}`);
await assetViewerUtils.waitForViewerLoad(page, asset);
await page.keyboard.press('i');
await page.locator('#detail-panel').waitFor({ state: 'visible' });
await page.getByLabel('Tag people').click();
await page.locator('#face-selector').waitFor({ state: 'visible' });
await waitForSelectorTransition(page);
};
test.describe.configure({ mode: 'parallel' });
test.describe('face-editor', () => {
const fixture = setupAssetViewerFixture(777);
const rng = new SeededRandom(777);
let mockPeople: MockPerson[];
let faceCreateCapture: FaceCreateCapture;
test.beforeAll(async () => {
mockPeople = createMockPeople(8);
});
test.beforeEach(async ({ context }) => {
faceCreateCapture = { requests: [] };
await setupFaceEditorMockApiRoutes(context, mockPeople, faceCreateCapture);
});
type ScreenRect = { top: number; left: number; width: number; height: number };
const getFaceBoxRect = async (page: Page): Promise<ScreenRect> => {
const dataEl = page.locator('#face-editor-data');
await expect(dataEl).toHaveAttribute('data-face-left', /^-?\d+/);
await expect(dataEl).toHaveAttribute('data-face-top', /^-?\d+/);
await expect(dataEl).toHaveAttribute('data-face-width', /^[1-9]/);
await expect(dataEl).toHaveAttribute('data-face-height', /^[1-9]/);
const canvasBox = await page.locator('#face-editor').boundingBox();
if (!canvasBox) {
throw new Error('Canvas element not found');
}
const left = Number(await dataEl.getAttribute('data-face-left'));
const top = Number(await dataEl.getAttribute('data-face-top'));
const width = Number(await dataEl.getAttribute('data-face-width'));
const height = Number(await dataEl.getAttribute('data-face-height'));
return {
top: canvasBox.y + top,
left: canvasBox.x + left,
width,
height,
};
};
const getSelectorRect = async (page: Page): Promise<ScreenRect> => {
const box = await page.locator('#face-selector').boundingBox();
if (!box) {
throw new Error('Face selector element not found');
}
return { top: box.y, left: box.x, width: box.width, height: box.height };
};
const computeOverlapArea = (a: ScreenRect, b: ScreenRect): number => {
const overlapX = Math.max(0, Math.min(a.left + a.width, b.left + b.width) - Math.max(a.left, b.left));
const overlapY = Math.max(0, Math.min(a.top + a.height, b.top + b.height) - Math.max(a.top, b.top));
return overlapX * overlapY;
};
const dragFaceBox = async (page: Page, deltaX: number, deltaY: number) => {
const faceBox = await getFaceBoxRect(page);
const centerX = faceBox.left + faceBox.width / 2;
const centerY = faceBox.top + faceBox.height / 2;
await page.mouse.move(centerX, centerY);
await page.mouse.down();
await page.mouse.move(centerX + deltaX, centerY + deltaY, { steps: 5 });
await page.mouse.up();
await page.waitForTimeout(300);
};
test('Face editor opens with person list', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await expect(page.locator('#face-selector')).toBeVisible();
await expect(page.locator('#face-editor')).toBeVisible();
for (const person of mockPeople) {
await expect(page.locator('#face-selector').getByText(person.name)).toBeVisible();
}
});
test('Search filters people by name', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const searchInput = page.locator('#face-selector input');
await searchInput.fill('Alice');
await expect(page.locator('#face-selector').getByText('Alice Johnson')).toBeVisible();
await expect(page.locator('#face-selector').getByText('Bob Smith')).toBeHidden();
await searchInput.clear();
for (const person of mockPeople) {
await expect(page.locator('#face-selector').getByText(person.name)).toBeVisible();
}
});
test('Search with no results shows empty message', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const searchInput = page.locator('#face-selector input');
await searchInput.fill('Nonexistent Person XYZ');
for (const person of mockPeople) {
await expect(page.locator('#face-selector').getByText(person.name)).toBeHidden();
}
});
test('Selecting a person shows confirmation dialog', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const personToTag = mockPeople[0];
await page.locator('#face-selector').getByText(personToTag.name).click();
await expect(page.getByRole('dialog')).toBeVisible();
});
test('Confirming tag calls createFace API and closes editor', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const personToTag = mockPeople[0];
await page.locator('#face-selector').getByText(personToTag.name).click();
await expect(page.getByRole('dialog')).toBeVisible();
await page.getByRole('button', { name: /confirm/i }).click();
await expect(page.locator('#face-selector')).toBeHidden();
await expect(page.locator('#face-editor')).toBeHidden();
expect(faceCreateCapture.requests).toHaveLength(1);
expect(faceCreateCapture.requests[0].assetId).toBe(asset.id);
expect(faceCreateCapture.requests[0].personId).toBe(personToTag.id);
});
test('Cancel button closes face editor', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await expect(page.locator('#face-selector')).toBeVisible();
await expect(page.locator('#face-editor')).toBeVisible();
await page.getByRole('button', { name: /cancel/i }).click();
await expect(page.locator('#face-selector')).toBeHidden();
await expect(page.locator('#face-editor')).toBeHidden();
});
test('Selector does not overlap face box on initial open', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const faceBox = await getFaceBoxRect(page);
const selectorBox = await getSelectorRect(page);
const overlap = computeOverlapArea(faceBox, selectorBox);
expect(overlap).toBe(0);
});
test('Selector repositions without overlap after dragging face box down', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await dragFaceBox(page, 0, 150);
const faceBox = await getFaceBoxRect(page);
const selectorBox = await getSelectorRect(page);
const overlap = computeOverlapArea(faceBox, selectorBox);
expect(overlap).toBe(0);
});
test('Selector repositions without overlap after dragging face box right', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await dragFaceBox(page, 200, 0);
const faceBox = await getFaceBoxRect(page);
const selectorBox = await getSelectorRect(page);
const overlap = computeOverlapArea(faceBox, selectorBox);
expect(overlap).toBe(0);
});
test('Selector repositions without overlap after dragging face box to top-left corner', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await dragFaceBox(page, -300, -300);
const faceBox = await getFaceBoxRect(page);
const selectorBox = await getSelectorRect(page);
const overlap = computeOverlapArea(faceBox, selectorBox);
expect(overlap).toBe(0);
});
test('Selector repositions without overlap after dragging face box to bottom-right', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await dragFaceBox(page, 300, 300);
const faceBox = await getFaceBoxRect(page);
const selectorBox = await getSelectorRect(page);
const overlap = computeOverlapArea(faceBox, selectorBox);
expect(overlap).toBe(0);
});
test('Selector stays within viewport bounds', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const viewportSize = page.viewportSize()!;
const selectorBox = await getSelectorRect(page);
expect(selectorBox.top).toBeGreaterThanOrEqual(0);
expect(selectorBox.left).toBeGreaterThanOrEqual(0);
expect(selectorBox.top + selectorBox.height).toBeLessThanOrEqual(viewportSize.height);
expect(selectorBox.left + selectorBox.width).toBeLessThanOrEqual(viewportSize.width);
});
test('Selector stays within viewport after dragging to edge', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
await dragFaceBox(page, -400, -400);
const viewportSize = page.viewportSize()!;
const selectorBox = await getSelectorRect(page);
expect(selectorBox.top).toBeGreaterThanOrEqual(0);
expect(selectorBox.left).toBeGreaterThanOrEqual(0);
expect(selectorBox.top + selectorBox.height).toBeLessThanOrEqual(viewportSize.height);
expect(selectorBox.left + selectorBox.width).toBeLessThanOrEqual(viewportSize.width);
});
test('Face box is draggable on the canvas', async ({ page }) => {
const asset = selectRandom(fixture.assets, rng);
await openFaceEditor(page, asset);
const beforeDrag = await getFaceBoxRect(page);
await dragFaceBox(page, 100, 50);
const afterDrag = await getFaceBoxRect(page);
expect(afterDrag.left).toBeGreaterThan(beforeDrag.left + 50);
expect(afterDrag.top).toBeGreaterThan(beforeDrag.top + 20);
});
});
@@ -0,0 +1,84 @@
import { faker } from '@faker-js/faker';
import type { AssetResponseDto } from '@immich/sdk';
import { expect, test } from '@playwright/test';
import { toAssetResponseDto } from 'src/ui/generators/timeline';
import {
createMockStack,
createMockStackAsset,
MockStack,
setupBrokenAssetMockApiRoutes,
} from 'src/ui/mock-network/broken-asset-network';
import { assetViewerUtils } from '../timeline/utils';
import { enableTagsPreference, ensureDetailPanelVisible, setupAssetViewerFixture } from './utils';
test.describe.configure({ mode: 'parallel' });
test.describe('asset-viewer stack', () => {
const fixture = setupAssetViewerFixture(888);
let mockStack: MockStack;
let primaryAssetDto: AssetResponseDto;
let secondAssetDto: AssetResponseDto;
test.beforeAll(async () => {
primaryAssetDto = toAssetResponseDto(fixture.primaryAsset);
primaryAssetDto.tags = [
{
id: faker.string.uuid(),
name: '1',
value: 'test/1',
createdAt: new Date().toISOString(),
updatedAt: new Date().toISOString(),
},
];
secondAssetDto = createMockStackAsset(fixture.adminUserId);
secondAssetDto.tags = [
{
id: faker.string.uuid(),
name: '2',
value: 'test/2',
createdAt: new Date().toISOString(),
updatedAt: new Date().toISOString(),
},
];
mockStack = createMockStack(primaryAssetDto, [secondAssetDto], new Set());
});
test.beforeEach(async ({ context }) => {
await setupBrokenAssetMockApiRoutes(context, mockStack);
});
test('stack slideshow is visible', async ({ page }) => {
await page.goto(`/photos/${fixture.primaryAsset.id}`);
await assetViewerUtils.waitForViewerLoad(page, fixture.primaryAsset);
const stackSlideshow = page.locator('#stack-slideshow');
await expect(stackSlideshow).toBeVisible();
const stackAssets = stackSlideshow.locator('[data-asset]');
await expect(stackAssets).toHaveCount(mockStack.assets.length);
});
test('tags of primary asset are visible', async ({ context, page }) => {
await enableTagsPreference(context);
await page.goto(`/photos/${fixture.primaryAsset.id}`);
await ensureDetailPanelVisible(page);
const tags = page.getByTestId('detail-panel-tags').getByRole('link');
await expect(tags.first()).toHaveText('test/1');
});
test('tags of second asset are visible', async ({ context, page }) => {
await enableTagsPreference(context);
await page.goto(`/photos/${fixture.primaryAsset.id}`);
await ensureDetailPanelVisible(page);
const stackAssets = page.locator('#stack-slideshow [data-asset]');
await stackAssets.nth(1).click();
const tags = page.getByTestId('detail-panel-tags').getByRole('link');
await expect(tags.first()).toHaveText('test/2');
});
});
+116
View File
@@ -0,0 +1,116 @@
import { faker } from '@faker-js/faker';
import type { AssetResponseDto } from '@immich/sdk';
import { BrowserContext, Page, test } from '@playwright/test';
import {
Changes,
createDefaultTimelineConfig,
generateTimelineData,
SeededRandom,
selectRandom,
TimelineAssetConfig,
TimelineData,
toAssetResponseDto,
} from 'src/ui/generators/timeline';
import { setupBaseMockApiRoutes } from 'src/ui/mock-network/base-network';
import { setupTimelineMockApiRoutes, TimelineTestContext } from 'src/ui/mock-network/timeline-network';
import { utils } from 'src/utils';
export type AssetViewerTestFixture = {
adminUserId: string;
timelineRestData: TimelineData;
assets: TimelineAssetConfig[];
testContext: TimelineTestContext;
changes: Changes;
primaryAsset: TimelineAssetConfig;
primaryAssetDto: AssetResponseDto;
};
export function setupAssetViewerFixture(seed: number): AssetViewerTestFixture {
const rng = new SeededRandom(seed);
const testContext = new TimelineTestContext();
const fixture: AssetViewerTestFixture = {
adminUserId: undefined!,
timelineRestData: undefined!,
assets: [],
testContext,
changes: {
albumAdditions: [],
assetDeletions: [],
assetArchivals: [],
assetFavorites: [],
},
primaryAsset: undefined!,
primaryAssetDto: undefined!,
};
test.beforeAll(async () => {
test.fail(
process.env.PW_EXPERIMENTAL_SERVICE_WORKER_NETWORK_EVENTS !== '1',
'This test requires env var: PW_EXPERIMENTAL_SERVICE_WORKER_NETWORK_EVENTS=1',
);
utils.initSdk();
fixture.adminUserId = faker.string.uuid();
testContext.adminId = fixture.adminUserId;
fixture.timelineRestData = generateTimelineData({
...createDefaultTimelineConfig(),
ownerId: fixture.adminUserId,
});
for (const timeBucket of fixture.timelineRestData.buckets.values()) {
fixture.assets.push(...timeBucket);
}
fixture.primaryAsset = selectRandom(
fixture.assets.filter((a) => a.isImage),
rng,
);
fixture.primaryAssetDto = toAssetResponseDto(fixture.primaryAsset);
});
test.beforeEach(async ({ context }) => {
await setupBaseMockApiRoutes(context, fixture.adminUserId);
await setupTimelineMockApiRoutes(context, fixture.timelineRestData, fixture.changes, fixture.testContext);
});
test.afterEach(() => {
fixture.testContext.slowBucket = false;
fixture.changes.albumAdditions = [];
fixture.changes.assetDeletions = [];
fixture.changes.assetArchivals = [];
fixture.changes.assetFavorites = [];
});
return fixture;
}
export async function ensureDetailPanelVisible(page: Page) {
await page.waitForSelector('#immich-asset-viewer');
const isVisible = await page.locator('#detail-panel').isVisible();
if (!isVisible) {
await page.keyboard.press('i');
await page.waitForSelector('#detail-panel');
}
}
export async function enableTagsPreference(context: BrowserContext) {
await context.route('**/users/me/preferences', async (route) => {
return route.fulfill({
status: 200,
contentType: 'application/json',
json: {
albums: { defaultAssetOrder: 'desc' },
folders: { enabled: false, sidebarWeb: false },
memories: { enabled: true, duration: 5 },
people: { enabled: true, sidebarWeb: false },
sharedLinks: { enabled: true, sidebarWeb: false },
ratings: { enabled: false },
tags: { enabled: true, sidebarWeb: false },
emailNotifications: { enabled: true, albumInvite: true, albumUpdate: true },
download: { archiveSize: 4_294_967_296, includeEmbeddedVideos: false },
purchase: { showSupportBadge: true, hideBuyButtonUntil: '2100-02-12T00:00:00.000Z' },
cast: { gCastEnabled: false },
},
});
});
}
@@ -438,7 +438,7 @@ test.describe('Timeline', () => {
const asset = getAsset(timelineRestData, album.assetIds[0])!; const asset = getAsset(timelineRestData, album.assetIds[0])!;
await pageUtils.goToAsset(page, asset.fileCreatedAt); await pageUtils.goToAsset(page, asset.fileCreatedAt);
await thumbnailUtils.expectInViewport(page, asset.id); await thumbnailUtils.expectInViewport(page, asset.id);
await thumbnailUtils.expectSelectedReadonly(page, asset.id); await thumbnailUtils.expectSelectedDisabled(page, asset.id);
}); });
test('Add photos to album', async ({ page }) => { test('Add photos to album', async ({ page }) => {
const album = timelineRestData.album; const album = timelineRestData.album;
@@ -447,7 +447,7 @@ test.describe('Timeline', () => {
const asset = getAsset(timelineRestData, album.assetIds[0])!; const asset = getAsset(timelineRestData, album.assetIds[0])!;
await pageUtils.goToAsset(page, asset.fileCreatedAt); await pageUtils.goToAsset(page, asset.fileCreatedAt);
await thumbnailUtils.expectInViewport(page, asset.id); await thumbnailUtils.expectInViewport(page, asset.id);
await thumbnailUtils.expectSelectedReadonly(page, asset.id); await thumbnailUtils.expectSelectedDisabled(page, asset.id);
await pageUtils.selectDay(page, 'Tue, Feb 27, 2024'); await pageUtils.selectDay(page, 'Tue, Feb 27, 2024');
const put = pageRoutePromise(page, `**/api/albums/${album.id}/assets`, async (route, request) => { const put = pageRoutePromise(page, `**/api/albums/${album.id}/assets`, async (route, request) => {
const requestJson = request.postDataJSON(); const requestJson = request.postDataJSON();
+6 -8
View File
@@ -65,7 +65,7 @@ export const thumbnailUtils = {
return page.locator(`[data-thumbnail-focus-container][data-asset="${assetId}"] button`); return page.locator(`[data-thumbnail-focus-container][data-asset="${assetId}"] button`);
}, },
selectedAsset(page: Page) { selectedAsset(page: Page) {
return page.locator('[data-thumbnail-focus-container]:has(button[aria-checked])'); return page.locator('[data-thumbnail-focus-container][data-selected]');
}, },
async clickAssetId(page: Page, assetId: string) { async clickAssetId(page: Page, assetId: string) {
await thumbnailUtils.withAssetId(page, assetId).click(); await thumbnailUtils.withAssetId(page, assetId).click();
@@ -102,12 +102,9 @@ export const thumbnailUtils = {
async expectThumbnailIsNotArchive(page: Page, assetId: string) { async expectThumbnailIsNotArchive(page: Page, assetId: string) {
await expect(thumbnailUtils.withAssetId(page, assetId).locator('[data-icon-archive]')).toHaveCount(0); await expect(thumbnailUtils.withAssetId(page, assetId).locator('[data-icon-archive]')).toHaveCount(0);
}, },
async expectSelectedReadonly(page: Page, assetId: string) { async expectSelectedDisabled(page: Page, assetId: string) {
// todo - need a data attribute for selected
await expect( await expect(
page.locator( page.locator(`[data-thumbnail-focus-container][data-asset="${assetId}"][data-selected][data-disabled]`),
`[data-thumbnail-focus-container][data-asset="${assetId}"] > .group.cursor-not-allowed > .rounded-xl`,
),
).toBeVisible(); ).toBeVisible();
}, },
async expectTimelineHasOnScreenAssets(page: Page) { async expectTimelineHasOnScreenAssets(page: Page) {
@@ -218,8 +215,9 @@ export const pageUtils = {
await page.getByText('Confirm').click(); await page.getByText('Confirm').click();
}, },
async selectDay(page: Page, day: string) { async selectDay(page: Page, day: string) {
await page.getByTitle(day).hover(); const section = page.getByTitle(day).locator('xpath=ancestor::section[@data-group]');
await page.locator('[data-group] .w-8').click(); await section.hover();
await section.locator('.w-8').click();
}, },
async pauseTestDebug() { async pauseTestDebug() {
console.log('NOTE: pausing test indefinately for debug'); console.log('NOTE: pausing test indefinately for debug');
+40 -29
View File
@@ -177,40 +177,51 @@ export const utils = {
}, },
resetDatabase: async (tables?: string[]) => { resetDatabase: async (tables?: string[]) => {
try { client = await utils.connectDatabase();
client = await utils.connectDatabase();
tables = tables || [ tables = tables || [
// TODO e2e test for deleting a stack, since it is quite complex // TODO e2e test for deleting a stack, since it is quite complex
'stack', 'stack',
'library', 'library',
'shared_link', 'shared_link',
'person', 'person',
'album', 'album',
'asset', 'asset',
'asset_face', 'asset_face',
'activity', 'activity',
'api_key', 'api_key',
'session', 'session',
'user', 'user',
'system_metadata', 'system_metadata',
'tag', 'tag',
]; ];
const sql: string[] = []; const truncateTables = tables.filter((table) => table !== 'system_metadata');
const sql: string[] = [];
for (const table of tables) { if (truncateTables.length > 0) {
if (table === 'system_metadata') { sql.push(`TRUNCATE "${truncateTables.join('", "')}" CASCADE;`);
sql.push(`DELETE FROM "system_metadata" where "key" NOT IN ('reverse-geocoding-state', 'system-flags');`); }
} else {
sql.push(`DELETE FROM "${table}" CASCADE;`); if (tables.includes('system_metadata')) {
sql.push(`DELETE FROM "system_metadata" where "key" NOT IN ('reverse-geocoding-state', 'system-flags');`);
}
const query = sql.join('\n');
const maxRetries = 3;
for (let attempt = 1; attempt <= maxRetries; attempt++) {
try {
await client.query(query);
return;
} catch (error: any) {
if (error?.code === '40P01' && attempt < maxRetries) {
await new Promise((resolve) => setTimeout(resolve, 250 * attempt));
continue;
} }
console.error('Failed to reset database', error);
throw error;
} }
await client.query(sql.join('\n'));
} catch (error) {
console.error('Failed to reset database', error);
throw error;
} }
}, },
+1 -1
View File
@@ -17,6 +17,6 @@
"esModuleInterop": true, "esModuleInterop": true,
"baseUrl": "./" "baseUrl": "./"
}, },
"include": ["src/**/*.ts"], "include": ["src/**/*.ts", "vitest*.config.ts"],
"exclude": ["dist", "node_modules"] "exclude": ["dist", "node_modules"]
} }
+5 -5
View File
@@ -1,3 +1,4 @@
import tsconfigPaths from 'vite-tsconfig-paths';
import { defineConfig } from 'vitest/config'; import { defineConfig } from 'vitest/config';
const skipDockerSetup = process.env.VITEST_DISABLE_DOCKER_SETUP === 'true'; const skipDockerSetup = process.env.VITEST_DISABLE_DOCKER_SETUP === 'true';
@@ -14,15 +15,14 @@ if (!skipDockerSetup) {
export default defineConfig({ export default defineConfig({
test: { test: {
name: 'e2e:server',
retry: process.env.CI ? 4 : 0, retry: process.env.CI ? 4 : 0,
include: ['src/specs/server/**/*.e2e-spec.ts'], include: ['src/specs/server/**/*.e2e-spec.ts'],
globalSetup, globalSetup,
testTimeout: 15_000, testTimeout: 15_000,
pool: 'threads', pool: 'threads',
poolOptions: { maxWorkers: 1,
threads: { isolate: false,
singleThread: true,
},
},
}, },
plugins: [tsconfigPaths()],
}); });
+5 -5
View File
@@ -1,3 +1,4 @@
import tsconfigPaths from 'vite-tsconfig-paths';
import { defineConfig } from 'vitest/config'; import { defineConfig } from 'vitest/config';
const skipDockerSetup = process.env.VITEST_DISABLE_DOCKER_SETUP === 'true'; const skipDockerSetup = process.env.VITEST_DISABLE_DOCKER_SETUP === 'true';
@@ -14,15 +15,14 @@ if (!skipDockerSetup) {
export default defineConfig({ export default defineConfig({
test: { test: {
name: 'e2e:maintenance',
retry: process.env.CI ? 4 : 0, retry: process.env.CI ? 4 : 0,
include: ['src/specs/maintenance/server/**/*.e2e-spec.ts'], include: ['src/specs/maintenance/server/**/*.e2e-spec.ts'],
globalSetup, globalSetup,
testTimeout: 15_000, testTimeout: 15_000,
pool: 'threads', pool: 'threads',
poolOptions: { maxWorkers: 1,
threads: { isolate: false,
singleThread: true,
},
},
}, },
plugins: [tsconfigPaths()],
}); });
+211 -125
View File
@@ -2,147 +2,147 @@
"about": "Oor", "about": "Oor",
"account": "Rekening", "account": "Rekening",
"account_settings": "Rekeninginstellings", "account_settings": "Rekeninginstellings",
"acknowledge": "Erken", "acknowledge": "Neem kennis",
"action": "Aksie", "action": "Aksie",
"action_common_update": "Opdateur", "action_common_update": "Werk by",
"actions": "Aksies", "actions": "Aksies",
"active": "Aktief", "active": "Aktief",
"activity": "Aktiwiteite", "activity": "Aktiwiteite",
"activity_changed": "Aktiwiteit is {enabled, select, true {aangeskakel} other {afgeskakel}}", "activity_changed": "Aktiwiteit is {enabled, select, true {geaktiveer} other {gedeaktiveer}}",
"add": "Voegby", "add": "Voeg toe",
"add_a_description": "Voeg 'n beskrywing by", "add_a_description": "Voeg n beskrywing toe",
"add_a_location": "Voeg 'n ligging by", "add_a_location": "Voeg n ligging toe",
"add_a_name": "Voeg 'n naam by", "add_a_name": "Voeg n naam toe",
"add_a_title": "Voeg 'n titel by", "add_a_title": "Voeg n titel toe",
"add_birthday": "Voeg 'n verjaarsdag by", "add_birthday": "Voeg n verjaarsdag toe",
"add_endpoint": "Voeg Koppelvlakpunt by", "add_endpoint": "Voeg eindpunt toe",
"add_exclusion_pattern": "Voeg uitsgluitingspatrone by", "add_exclusion_pattern": "Voeg uitsluitingspatroon toe",
"add_location": "Voeg ligging by", "add_location": "Voeg ligging toe",
"add_more_users": "Voeg meer gebruikers by", "add_more_users": "Voeg meer gebruikers toe",
"add_partner": "Voeg vennoot by", "add_partner": "Voeg vennoot toe",
"add_path": "Voeg pad by", "add_path": "Voeg pad toe",
"add_photos": "Voeg foto's by", "add_photos": "Voeg fotos toe",
"add_tag": "Voeg tag by", "add_tag": "Voeg etiket toe",
"add_to": "Voeg by…", "add_to": "Voeg toe tot…",
"add_to_album": "Voeg na album", "add_to_album": "Voeg toe tot album",
"add_to_album_bottom_sheet_added": "By {album} bygevoeg", "add_to_album_bottom_sheet_added": "Tot {album} toegevoeg",
"add_to_album_bottom_sheet_already_exists": "Reeds in {album}", "add_to_album_bottom_sheet_already_exists": "Reeds in {album}",
"add_to_albums": "Voeg by albums", "add_to_albums": "Voeg toe tot albums",
"add_to_albums_count": "Voeg by ({count}) albums", "add_to_albums_count": "Voeg toe tot albums ({count})",
"add_to_shared_album": "Voeg toe aan gedeelde album", "add_to_shared_album": "Voeg toe tot gedeelde album",
"add_url": "Voeg URL by", "add_url": "Voeg bronadres toe",
"added_to_archive": "By argief toegevoegd", "added_to_archive": "Tot argief toegevoeg",
"added_to_favorites": "By gunstelinge toegevoegd", "added_to_favorites": "Tot gunstelinge toegevoeg",
"added_to_favorites_count": "Het {count, number} by gunstelinge toegevoegd", "added_to_favorites_count": "{count, number} tot gunstelinge toegevoeg",
"admin": { "admin": {
"add_exclusion_pattern_description": "Voeg uitsluitingspatrone by. Globbing met *, ** en ? word ondersteun. Om alle lêers in enige lêergids genaamd \"Raw\" te ignoreer, gebruik \"**/Raw/**\". Om alle lêers wat op \".tif\" eindig, te ignoreer, gebruik \"**/*.tif\". Om 'n absolute pad te ignoreer, gebruik \"/path/to/ignore/**\".", "add_exclusion_pattern_description": "Voeg uitsluitingspatrone toe. Plekhouers met *, ** en ? word ondersteun. Om alle lêers in enige vouer genaamd Raw te ignoreer, gebruik **/Raw/**. Om alle lêers wat op .tif eindig, te ignoreer, gebruik **/*.tif. Om n absolute pad te ignoreer, gebruik /path/to/ignore/**.",
"admin_user": "Admin gebruiker", "admin_user": "Admingebruiker",
"asset_offline_description": "Hierdie eksterne biblioteekbate word nie meer op skyf gevind nie en is na die asblik geskuif. As die lêer binne die biblioteek geskuif is, gaan jou tydlyn na vir die nuwe ooreenstemmende bate. Om hierdie bate te herstel, maak asseblief seker dat die lêerpad hieronder deur Immich verkry kan word en skandeer die biblioteek.", "asset_offline_description": "Hierdie eksterne biblioteekitem word nie meer op skyf gevind nie en is na die asblik geskuif. As die lêer binne die biblioteek geskuif is, gaan u tydlyn na vir die nuwe ooreenstemmende item. Om hierdie item te herstel, maak asseblief seker dat die lêerpad hieronder deur Immich verkry kan word en skandeer die biblioteek.",
"authentication_settings": "Verifikasie instellings", "authentication_settings": "Waarmerkinstellings",
"authentication_settings_description": "Bestuur wagwoord, OAuth en ander verifikasie instellings", "authentication_settings_description": "Bestuur wagwoord, OAuth en ander waarmerkinstellings",
"authentication_settings_disable_all": "Is jy seker jy wil alle aanmeldmetodes deaktiveer? Aanmelding sal heeltemal gedeaktiveer word.", "authentication_settings_disable_all": "Is u seker u wil alle aantekenmetodes deaktiveer? Aantekening sal heeltemal gedeaktiveer word.",
"authentication_settings_reenable": "Om te heraktiveer, gebruik 'n <link>Server Command</link>.", "authentication_settings_reenable": "Gebruik n <link>bedienerbevel</link> om te heraktiveer.",
"background_task_job": "Agtergrondtake", "background_task_job": "Agtergrondtake",
"backup_database": "Skep Datastortlêer", "backup_database": "Skep Databasisstortlêer",
"backup_database_enable_description": "Aktiveer databasisrugsteun", "backup_database_enable_description": "Aktiveer databasisstortlêers",
"backup_keep_last_amount": "Aantal vorige rugsteune om te hou", "backup_keep_last_amount": "Aantal vorige stortlêers om te hou",
"backup_onboarding_3_description": "totale kopieë van jou data, insluitende die oorspronklikke lêers. Dit sluit in 1 kopie op 'n ander perseel en 2 kopieë om die huidige rekenaar.", "backup_onboarding_3_description": "totale kopieë van u data, insluitend die oorspronklike lêers. Dit sluit 1 kopie op n ander perseel en 2 lokale kopieë in.",
"backup_onboarding_description": "'N <backblaze-link>3-2-1 rugsteun strategie</backblaze-link> word sterk aanbeveel om jou data veilig te hou. Hou kopieë van jou fotos/videos so wel as die Immich databasis vir 'n volledige rugsteun oplossing.", "backup_onboarding_description": "n <backblaze-link>3-2-1-rugsteunstrategie</backblaze-link> word sterk aanbeveel om u data veilig te hou. Hou kopieë van u fotos/videos sowel as die Immich-databasis vir n volledige rugsteunoplossing.",
"backup_onboarding_footer": "Vir meer inligting oor hoe om 'n rugsteun kopie van Immich te maak, gaan lees asseblief hierdie <link>dokument</link>.", "backup_onboarding_footer": "Lees hierdie <link>dokument</link> vir meer inligting oor hoe om n rugsteunkopie van Immich te maak.",
"backup_onboarding_parts_title": "'N 3-2-1 rugsteun sluit in:", "backup_onboarding_parts_title": "n 3-2-1-rugsteun sluit in:",
"backup_onboarding_title": "Rugsteun kopieë", "backup_onboarding_title": "Rugsteunkopieë",
"backup_settings": "Rugsteun instellings", "backup_settings": "Databasisstortinstellings",
"backup_settings_description": "Bestuur databasis rugsteun instellings.", "backup_settings_description": "Bestuur databasisrugsteuninstellings.",
"cleared_jobs": "Poste gevee vir: {job}", "cleared_jobs": "Take gewis vir: {job}",
"config_set_by_file": "Config word tans deur 'n konfigurasielêer gestel", "config_set_by_file": "Config word tans deur n konfigurasielêer gestel",
"confirm_delete_library": "Is jy seker jy wil {library}-biblioteek uitvee?", "confirm_delete_library": "Is u seker u wil {library}-biblioteek skrap?",
"confirm_delete_library_assets": "Is jy seker jy wil hierdie biblioteek uitvee? Dit sal {count, plural, one {# bevatte base} other {# bevatte bates}} uit Immich uitvee en kan nie ongedaan gemaak word nie. Lêers sal op skyf bly.", "confirm_delete_library_assets": "Is u seker u wil hierdie biblioteek skrap? Dit sal {count, plural, one {# bevatte item} other {# bevatte items}} uit Immich skrap en kan nie ongedaan gemaak word nie. Lêers sal op skyf bly.",
"confirm_email_below": "Om te bevestig, tik \"{email}\" hieronder", "confirm_email_below": "Tik {email} hieronder ter bevestiging",
"confirm_reprocess_all_faces": "Is jy seker jy wil alle gesigte herverwerk? Dit sal ook genoemde mense skoonmaak.", "confirm_reprocess_all_faces": "Is u seker u wil alle gesigte herverwerk? Dit sal ook genoemde mense skoonmaak.",
"confirm_user_password_reset": "Is jy seker jy wil {user} se wagwoord terugstel?", "confirm_user_password_reset": "Is u seker u wil {user} se wagwoord terugstel?",
"confirm_user_pin_code_reset": "Is jy seker jy wil {user} se PIN kode herstel?", "confirm_user_pin_code_reset": "Is u seker u wil {user} se PIN-kode herstel?",
"create_job": "Skep werk", "create_job": "Skep taak",
"cron_expression": "Cron uitdrukking", "cron_expression": "Cron-uitdrukking",
"cron_expression_description": "Stel die skanderingsinterval in met die cron-formaat. Vir meer inligting verwys asseblief na bv. <link>Crontab Guru</link>", "cron_expression_description": "Stel die skanderingsinterval in met die cron-formaat. Kyk gerus na bv. <link>Crontab Guru</link> vir meer inligting",
"cron_expression_presets": "Cron uitdrukking voorafinstellings", "cron_expression_presets": "Cron-uitdrukking voorafinstellings",
"disable_login": "Deaktiveer aanmelding", "disable_login": "Deaktiveer aantekening",
"duplicate_detection_job_description": "Begin masjienleer op bates om soortgelyke beelde op te spoor. Maak staat op Smart Search", "duplicate_detection_job_description": "Begin masjienleer op items om soortgelyke beelde op te spoor. Maak staat op Slimsoek",
"exclusion_pattern_description": "Met uitsluitingspatrone kan jy lêers en vouers ignoreer wanneer jy jou biblioteek skandeer. Dit is nuttig as jy vouers het wat lêers bevat wat jy nie wil invoer nie, soos RAW-lêers.", "exclusion_pattern_description": "Met uitsluitingspatrone kan u lêers en vouers ignoreer wanneer u u biblioteek skandeer. Dit is nuttig as u vouers het wat lêers bevat wat u nie wil invoer nie, soos RAW-lêers.",
"face_detection": "Gesig herkenning", "face_detection": "Gesigherkenning",
"face_detection_description": "Identifiseer die gesigte in media deur middel van masjienleer. Vir videos word slegs die duimnaelskets oorweeg. “Herlaai” (ver)werk al die media weer. “Stel terug” verwyder alle huidige gesigdata. “Onverwerk” plaas bates in die tou wat nog nie verwerk is nie. Geidentifiseerde gesigte sal ná voltooiing van Gesigidentifikasie vir Gesigherkenning in die tou geplaas word, om hulle in bestaande of nuwe persone te groepeer.", "face_detection_description": "Identifiseer die gesigte in media d.m.v. masjienleer. Vir videos word slegs die duimnael oorweeg. “Herlaai” (ver)werk al die media weer. “Stel terug” verwyder alle huidige gesigdata. “Onverwerk” plaas items in die ry wat nog nie verwerk is nie. Geïdentifiseerde gesigte sal ná voltooiing van Gesigidentifikasie vir Gesigherkenning in die ry geplaas word om hulle in bestaande of nuwe persone te groepeer.",
"facial_recognition_job_description": "Groepeer gesigte in mense in. Die stap is vinniger nadat Gesig Deteksie klaar is. \"Herstel\" (her-)groepeer alle gesigte. \"Vermiste\" plaas gesigte in ry wat nie 'n persoon gekoppel het nie.", "facial_recognition_job_description": "Groepeer gesigte in mense. Die stap is vinniger nadat Gesigherkenning klaar is. Herstel (her-)groepeer alle gesigte. Vermiste plaas gesigte in ry wat nie n persoon gekoppel het nie.",
"failed_job_command": "Opdrag {command} het misluk vir werk: {job}", "failed_job_command": "Bevel {command} het misluk vir taak: {job}",
"force_delete_user_warning": "WAARSKUWING: Dit sal onmiddellik die gebruiker en alle bates verwyder. Dit kan nie ontdoen word nie en die lêers kan nie herstel word nie.", "force_delete_user_warning": "WAARSKUWING: Dit sal onmiddellik die gebruiker en alle items verwyder. Dit kan nie ontdaan word nie en die lêers kan nie herstel word nie.",
"image_format": "Formaat", "image_format": "Formaat",
"image_format_description": "WebP produseer kleiner lêers as JPEG, maar is stadiger om te enkodeer.", "image_format_description": "WebP lewer kleiner lêers as JPEG, maar is stadiger om te enkodeer.",
"image_fullsize_description": "Vol grote prent met geen metadata, gebruik wanner ingezoem", "image_fullsize_description": "Volgrootte prent met geen metadata, gebruik wanner ingezoem",
"image_fullsize_enabled": "Skakel aan vol grote prent generasie", "image_fullsize_enabled": "Aktiveer spek van volgrootte prent",
"image_prefer_embedded_preview": "Verkies ingebedde voorskou", "image_prefer_embedded_preview": "Verkies ingebedde voorskou",
"image_prefer_wide_gamut": "Verkies wide gamut", "image_prefer_wide_gamut": "Verkies breëspektrum",
"image_prefer_wide_gamut_setting_description": "Gebruik Display P3 vir kleinkiekies. Dit behou die lewendheid van beelde met wye kleurruimtes beter, maar beelde kan anders verskyn op ou apparate met 'n ou blaaierweergawe. sRGB-beelde gebruik steeds sRGB om kleurverskuiwings te voorkom.", "image_prefer_wide_gamut_setting_description": "Gebruik Display P3 vir duimnaels. Dit behou die lewendheid van beelde met wye kleurruimtes beter, maar beelde kan anders verskyn op ou toestelle met n ou blaaierweergawe. sRGB-beelde gebruik steeds sRGB om kleurverskuiwings te voorkom.",
"image_preview_description": "Mediumgrootte prent met gestroopte metadata, wat gebruik word wanneer 'n enkele bate bekyk word en vir masjienleer", "image_preview_description": "Mediumgrootte prent met gestroopte metadata, wat gebruik word wanneer n enkele item bekyk word en vir masjienleer",
"image_preview_quality_description": "Voorskou kwaliteit van 1-100. Hoër is beter, maar produseer groter lêers en kan app-reaksie verminder. Die stel van 'n lae waarde kan masjienleerkwaliteit beïnvloed.", "image_preview_quality_description": "Voorskoukwaliteit van 1-100. Hoër is beter, maar lewer groter lêers en kan die toep vertraag. Die stel van n lae waarde kan masjienleerkwaliteit beïnvloed.",
"image_preview_title": "Voorskou Instellings", "image_preview_title": "Voorskou-instellings",
"image_quality": "Kwaliteit", "image_quality": "Kwaliteit",
"image_resolution": "Resolusie", "image_resolution": "Resolusie",
"image_resolution_description": "Hoër resolusies kan meer detail bewaar, maar neem langer om te enkodeer, het groter lêergroottes en kan app-reaksie verminder.", "image_resolution_description": "Hoër resolusies kan meer detail bewaar, maar neem langer om te enkodeer, het groter lêergroottes en kan die toep vertraag.",
"image_settings": "Prent Instellings", "image_settings": "Prentinstellings",
"image_settings_description": "Bestuur die kwaliteit en resolusie van gegenereerde beelde", "image_settings_description": "Bestuur die kwaliteit en resolusie van gegenereerde beelde",
"image_thumbnail_description": "Klein kleinkiekies sonder metadata, gebruik om groepe foto's soos die tydlyn te bekyk", "image_thumbnail_description": "Klein duimnaels sonder metadata, gebruik om groepe fotos soos die tydlyn te bekyk",
"image_thumbnail_quality_description": "Kleinkiekiekwaliteit van 1-100. Hoër is beter, maar produseer groter lêers en kan die toepassing vertraag.", "image_thumbnail_quality_description": "Duinmaelkwaliteit van 1-100. Hoër is beter, maar lewer groter lêers en kan die toep vertraag.",
"image_thumbnail_title": "Kleinkiekie-instellings", "image_thumbnail_title": "Duimnaelinstellings",
"job_concurrency": "{job} gelyktydigheid", "job_concurrency": "{job} gelyktydigheid",
"job_created": "Taak gemaak", "job_created": "Taak geskep",
"job_not_concurrency_safe": "Hierdie taak kan nie gelyktydig uitgevoer word nie.", "job_not_concurrency_safe": "Hierdie taak kan nie gelyktydig uitgevoer word nie.",
"job_settings": "Agtergrondtaakinstellings", "job_settings": "Taakinstellings",
"job_settings_description": "Bestuur werkgelyktydigheid", "job_settings_description": "Bestuur taakgelyktydigheid",
"library_created": "Biblioteek geskep: {library}", "library_created": "Biblioteek geskep: {library}",
"library_deleted": "Biblioteek verwyder", "library_deleted": "Biblioteek geskrap",
"library_scanning": "Periodieke Soek", "library_scanning": "Periodieke skandering",
"library_scanning_description": "Stel periodieke deursoek van biblioteek in", "library_scanning_description": "Stel periodieke skandering van biblioteek in",
"library_scanning_enable_description": "Aktiveer periodieke biblioteekskandering", "library_scanning_enable_description": "Aktiveer periodieke biblioteekskandering",
"library_settings": "Eksterne Biblioteek", "library_settings": "Eksterne biblioteek",
"library_settings_description": "Eksterne biblioteek verstellings", "library_settings_description": "Eksternebiblioteekinstellings",
"library_tasks_description": "Deursoek eksterne biblioteke vir nuwe of veranderde bates", "library_tasks_description": "Skandeer eksterne biblioteke vir nuwe of veranderde items",
"library_watching_enable_description": "Hou eksterne biblioteke dop vir leer veranderinge", "library_watching_enable_description": "Hou eksterne biblioteke dop vir lêerveranderinge",
"library_watching_settings": "Biblioteek dop hou (EKSPERIMENTEEL)", "library_watching_settings": "Biblioteekdophou [EKSPERIMENTEEL]",
"library_watching_settings_description": "Hou automaties dop vir veranderinge", "library_watching_settings_description": "Hou automaties dop vir veranderinge",
"logging_enable_description": "Aktifeer \"logging\"", "logging_enable_description": "Aktiveer logboekbyhouding",
"logging_level_description": "Wanneer aktief, watter vlak van \"logs\" om te skep.", "logging_level_description": "Wanneer aktief, welke logboekvlak om te gebruik.",
"logging_settings": "\"Logs\"", "logging_settings": "Logboek",
"machine_learning_clip_model": "CLIP model", "machine_learning_clip_model": "CLIP-model",
"machine_learning_duplicate_detection": "Duplikaat herkenning", "machine_learning_duplicate_detection": "Duplikaatbespeuring",
"machine_learning_duplicate_detection_enabled": "Aktifeer duplikaat herkenning", "machine_learning_duplicate_detection_enabled": "Aktiveer duplikaatbespeuring",
"machine_learning_enabled": "Aktifeer masjienleer", "machine_learning_enabled": "Aktiveer masjienleer",
"machine_learning_facial_recognition": "Gesigsherkenning", "machine_learning_facial_recognition": "Gesigherkenning",
"machine_learning_facial_recognition_description": "Herken, identifiseer en groepeer gesigte in fotos", "machine_learning_facial_recognition_description": "Bespeur, identifiseer en groepeer gesigte in fotos",
"machine_learning_facial_recognition_model": "Gesigsherkennings model", "machine_learning_facial_recognition_model": "Gesigherkenningsmodel",
"machine_learning_facial_recognition_setting": "Aktifeer gesigsherkenning", "machine_learning_facial_recognition_setting": "Aktiveer gesigherkenning",
"machine_learning_max_detection_distance": "Maksimum herkennings afstand", "machine_learning_max_detection_distance": "Maksimum herkenningsafstand",
"map_settings": "Kaart", "map_settings": "Kaart",
"migration_job": "Migrasie", "migration_job": "Migrasie",
"oauth_settings": "OAuth", "oauth_settings": "OAuth",
"transcoding_acceleration_vaapi": "VAAPI", "transcoding_acceleration_vaapi": "VAAPI",
"transcoding_preferred_hardware_device": "Verkiesde hardeware" "transcoding_preferred_hardware_device": "Voorkeurapparatuur"
}, },
"administration": "Administrasie", "administration": "Administrasie",
"advanced": "Gevorderde", "advanced": "Gevorderd",
"albums": "Albums", "albums": "Albums",
"all": "Alle", "all": "Alle",
"anti_clockwise": "Anti-kloksgewys", "anti_clockwise": "Linksom",
"archive": "Argief", "archive": "Argief",
"asset_skipped": "Oorgeslaan", "asset_skipped": "Oorgeslaan",
"asset_uploaded": "Opgelaai", "asset_uploaded": "Opgelaai",
"asset_uploading": "Oplaai…", "asset_uploading": "Laai tans op…",
"assets": "Bates", "assets": "Items",
"back": "Terug", "back": "Terug",
"backward": "Agteruit", "backward": "Agteruit",
"build": "Bou", "build": "Bou",
"camera": "Kamera", "camera": "Kamera",
"cancel": "Kanselleer", "cancel": "Kanselleer",
"city": "Stad", "city": "Stad",
"clockwise": "Kloksgewys", "clockwise": "Regsom",
"close": "Maak toe", "close": "Sluit",
"color": "Kleur", "color": "Kleur",
"confirm": "Bevestig", "confirm": "Bevestig",
"contain": "Bevat", "contain": "Bevat",
@@ -154,54 +154,140 @@
"created": "Geskep", "created": "Geskep",
"dark": "Donker", "dark": "Donker",
"day": "Dag", "day": "Dag",
"delete": "Verwyder", "delete": "Skrap",
"description": "Beskrywing", "description": "Beskrywing",
"details": "Besonderhede", "details": "Besonderhede",
"direction": "Rigting", "direction": "Rigting",
"discover": "Ontdek", "discover": "Ontdek",
"documentation": "Dokumentasie", "documentation": "Dokumentasie",
"done": "Klaar", "done": "Gereed",
"download": "Aflaai", "download": "Laai af",
"download_settings": "Aflaai", "download_settings": "Laai af",
"duplicates": "Duplikate", "duplicates": "Duplikate",
"duration": "Duur", "duration": "Duur",
"edit": "Wysig", "edit": "Wysig",
"search_by_description": "Soek by beskrywing", "search_by_description": "Soek op beskrywing",
"search_by_description_example": "Stapdag in Sapa", "search_by_description_example": "Stapdag in Sapa",
"stacktrace": "Stapelnasporing",
"start": "Begin",
"start_date": "Begindatum",
"start_date_before_end_date": "Begindatum moet voor einddatum wees",
"state": "Staat",
"status": "Status",
"stop_casting": "Stop sending",
"stop_motion_photo": "Stop bewegingsfoto",
"stop_photo_sharing": "Staak die deel van u fotos?",
"stop_photo_sharing_description": "{partner} sal nie meer toegang tot u fotos hê nie.",
"untitled_workflow": "Naamlose werkvloei",
"up_next": "Volgende",
"update_location_action_prompt": "Werk die ligging van {count} gekose items by met:",
"updated_at": "Bygewerk",
"updated_password": "Wagwoord bygewerk",
"upload": "Laai op",
"upload_concurrency": "Aantal gelyktydige oplaaie",
"upload_details": "Oplaaidetails",
"upload_dialog_info": "Wil u n rugsteun maak van die gekose item(s) op die bediener?",
"upload_error_with_count": "Oplaaifout vir {count, plural, one {# item} other {# items}}",
"upload_errors": "Oplaai voltooi met {count, plural, one {# fout} other {# foute}}, verfris die blad om die nuwe items te sien.",
"upload_finished": "Klaar opgelaai",
"upload_progress": "Oorblywend {remaining, number} - Verwerk {processed, number}/{total, number}",
"upload_skipped_duplicates": "{count, plural, one {# duplikaat item} other {# duplikaat items}} oorgeslaan",
"upload_status_duplicates": "Duplikate",
"upload_status_errors": "Foute",
"upload_status_uploaded": "Opgelaai",
"upload_success": "Oplaai suksesvol, verfris die blad om nuut opgelaaide items te sien.",
"upload_to_immich": "Laai op na Immich ({count})",
"uploading": "Word opgelaai",
"uploading_media": "Media word opgelaai",
"url": "URL",
"usage": "Gebruik",
"use_biometric": "Gebruik biometrie",
"use_browser_locale": "Gebruik blaaier se landinstelling",
"use_browser_locale_description": "Formatteer datums, tye en getalle gebaseer op u blaaier se landinstelling",
"use_current_connection": "Gebruik huidige verbinding",
"use_custom_date_range": "Gebruik eerder pasgemaakte datumomvang",
"user": "Gebruiker",
"user_has_been_deleted": "Hierdie gebruiker is geskrap.",
"user_id": "Gebruiker ID",
"user_liked": "{user} het van {type, select, photo {hierdie foto} video {hierdie video} asset {} other {hierdie item}} gehou",
"user_pin_code_settings": "PIN-kode",
"user_pin_code_settings_description": "Bestuur u PIN-kode",
"user_privacy": "Gebruikersprivaatheid",
"user_purchase_settings": "Koop",
"user_purchase_settings_description": "Bestuur u aankoop",
"user_role_set": "Stel {user} in as {role}",
"user_usage_detail": "Gedetailleerde gebruik van gebruikers",
"user_usage_stats": "Statistieke vir rekeninggebruik",
"user_usage_stats_description": "Bekyk statistieke van rekeninggebruik",
"username": "Gebruikersnaam",
"users": "Gebruikers",
"users_added_to_album_count": "{count, plural, one {# Gebruiker} other {# Gebruikers}} tot album toegevoeg",
"utilities": "Gereedskap",
"validate": "Valideer",
"validate_endpoint_error": "Voer asb. n geldige bronadres in",
"validation_error": "Valideerfout",
"variables": "Veranderlikes",
"version": "Weergawe", "version": "Weergawe",
"version_announcement_closing": "Jou friend, Alex", "version_announcement_closing": "Jou friend, Alex",
"version_announcement_message": "Hallo! Daar is n nuwe weergawe van Immich beskikbaar. Neem gerus bietjie tyd om die <link>vrystellingsnotas</link> te lees en maak seker u opstelling is op datum om wanopstellings te voorkom, veral as u WatchTower of n ander bywerkmeganisme gebruik.",
"version_history": "Weergawegeskiedenis", "version_history": "Weergawegeskiedenis",
"version_history_item": "{version} geinstaleerd op {date}", "version_history_item": "{version} geïnstaleer op {date}",
"video": "Video", "video": "Video",
"videos": "Video's", "video_hover_setting": "Speel videoduimnael by muishang",
"video_hover_setting_description": "Speel videoduimnael wanneer muis oor item hang. Selfs indien gedeaktiveer kan afspeel begin deur oor die afspeelknop te hang.",
"videos": "Videos",
"videos_count": "{count, plural, one {# video} other {# videos}}",
"videos_only": "Slegs videos",
"view": "Bekyk", "view": "Bekyk",
"view_album": "Bekyk Album", "view_album": "Bekyk album",
"view_all": "Bekyk alle", "view_all": "Bekyk alle",
"view_all_users": "Bekyk alle gebruikers", "view_all_users": "Bekyk alle gebruikers",
"view_asset_owners": "Bekyk itemeienaars",
"view_details": "Bekyk detail",
"view_in_timeline": "Bekyk in tydlyn", "view_in_timeline": "Bekyk in tydlyn",
"view_link": "Bekyk skakel", "view_link": "Bekyk skakel",
"view_links": "Bekyk skakels", "view_links": "Bekyk skakels",
"view_name": "Bekyk", "view_name": "Bekyk",
"view_next_asset": "Bekyk volgende bate", "view_next_asset": "Bekyk volgende item",
"view_previous_asset": "Bekyk vorige bate", "view_previous_asset": "Bekyk vorige item",
"view_qr_code": "Bekyk QR-kode", "view_qr_code": "Bekyk QR-kode",
"view_similar_photos": "Bekyk soortgelyke fotos",
"view_stack": "Bekyk stapel", "view_stack": "Bekyk stapel",
"view_user": "Bekyk gebruiker", "view_user": "Bekyk gebruiker",
"viewer_remove_from_stack": "Verwyder van stapel", "viewer_remove_from_stack": "Verwyder van stapel",
"viewer_stack_use_as_main_asset": "Gebruik as hoofbate", "viewer_stack_use_as_main_asset": "Gebruik as hoofitem",
"viewer_unstack": "Ontstapel", "viewer_unstack": "Ontstapel",
"visibility_changed": "Sigbaarheid verander voor {count, plural, one {# person} other {# people}}", "visibility_changed": "Sigbaarheid verander vir {count, plural, one {# mens} other {# mense}}",
"visual": "Visueel",
"visual_builder": "Visuele bouer",
"waiting": "Wag", "waiting": "Wag",
"warning": "Waaskuwing", "waiting_count": "Wagtend: {count}",
"warning": "Waarskuwing",
"week": "Week", "week": "Week",
"welcome": "Welkom", "welcome": "Welkom",
"welcome_to_immich": "Welkom by Immich", "welcome_to_immich": "Welkom by Immich",
"wifi_name": "Wi-Fi Naam", "width": "Breedte",
"wifi_name": "Wi-Fi-naam",
"workflow_delete_prompt": "Is u seker u wil hierdie werkvloei skrap?",
"workflow_deleted": "Werkvloei geskrap",
"workflow_description": "Werkvloeibeskrywing",
"workflow_info": "Werkvloei-inligting",
"workflow_json": "Werkvloei-JSON",
"workflow_json_help": "Wysig die werkvloei-opstelling in JSON-formaat. Veranderinge sal na die visuele bouer sinchroniseer.",
"workflow_name": "Werkvloeinaam",
"workflow_navigation_prompt": "Is u seker u wil verlaat sonder om u veranderinge te bewaar?",
"workflow_summary": "Werkvloei-opsomming",
"workflow_update_success": "Werkvloei suksesvol bygewerk",
"workflow_updated": "Werkvloei bygewerk",
"workflows": "Werkvloeie",
"workflows_help_text": "Werkvloeie outomatiseer aksies op u items gebaseer op snellers en filters",
"wrong_pin_code": "Verkeerde PIN-kode", "wrong_pin_code": "Verkeerde PIN-kode",
"year": "Jaar", "year": "Jaar",
"years_ago": "{years, plural, one {# year} other {# years}} gelede", "years_ago": "{years, plural, one {# jaar} other {# jaar}} gelede",
"yes": "Ja", "yes": "Ja",
"you_dont_have_any_shared_links": "Jy het geen gedeelde skakels", "you_dont_have_any_shared_links": "U het geen gedeelde skakels nie",
"your_wifi_name": "Jou Wi-Fi naam", "your_wifi_name": "U Wi-Fi-naam",
"zoom_image": "Vergroot Prent" "zero_to_clear_rating": "druk 0 om itemgradering te wis",
"zoom_image": "Zoem in",
"zoom_to_bounds": "Zoem na rande"
} }
+28 -8
View File
@@ -311,7 +311,7 @@
"search_jobs": "البحث عن وظائف…", "search_jobs": "البحث عن وظائف…",
"send_welcome_email": "إرسال بريد ترحيبي", "send_welcome_email": "إرسال بريد ترحيبي",
"server_external_domain_settings": "إسم النطاق الخارجي", "server_external_domain_settings": "إسم النطاق الخارجي",
"server_external_domain_settings_description": "إسم النطاق لروابط المشاركة العامة، بما في ذلك http(s)://", "server_external_domain_settings_description": "النطاق مستخدم لروابط خارجية",
"server_public_users": "المستخدمون العامون", "server_public_users": "المستخدمون العامون",
"server_public_users_description": "يتم إدراج جميع المستخدمين (الاسم والبريد الإلكتروني) عند إضافة مستخدم إلى الألبومات المشتركة. عند تعطيل هذه الميزة، ستكون قائمة المستخدمين متاحة فقط لمستخدمي الإدارة.", "server_public_users_description": "يتم إدراج جميع المستخدمين (الاسم والبريد الإلكتروني) عند إضافة مستخدم إلى الألبومات المشتركة. عند تعطيل هذه الميزة، ستكون قائمة المستخدمين متاحة فقط لمستخدمي الإدارة.",
"server_settings": "إعدادات الخادم", "server_settings": "إعدادات الخادم",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "رسم الخرائط النغمية", "transcoding_tone_mapping": "رسم الخرائط النغمية",
"transcoding_tone_mapping_description": "تحاول الحفاظ على مظهر مقاطع الفيديو HDR عند تحويلها إلى SDR. يقدم كل خوارزمية تنازلات مختلفة بين اللون والتفاصيل والسطوع. Hable تحافظ على التفاصيل، Mobius تحافظ على الألوان، و Reinhard تحافظ على السطوع.", "transcoding_tone_mapping_description": "تحاول الحفاظ على مظهر مقاطع الفيديو HDR عند تحويلها إلى SDR. يقدم كل خوارزمية تنازلات مختلفة بين اللون والتفاصيل والسطوع. Hable تحافظ على التفاصيل، Mobius تحافظ على الألوان، و Reinhard تحافظ على السطوع.",
"transcoding_transcode_policy": "سياسة الترميز", "transcoding_transcode_policy": "سياسة الترميز",
"transcoding_transcode_policy_description": "سياسة تحديد متى يجب ترميز الفيديو. سيتم دائمًا ترميز مقاطع الفيديو HDR (ما لم يتم تعطيل الترميز).", "transcoding_transcode_policy_description": "سياسة تحديد متى يجب ترميز الفيديو. سيتم دائمًا ترميز مقاطع الفيديو HDR و مقاطع الفديو اللتي تستدخم تنسيق غير YUV 4:2:0. (ما لم يتم تعطيل الترميز).",
"transcoding_two_pass_encoding": "الترميز بمرورين", "transcoding_two_pass_encoding": "الترميز بمرورين",
"transcoding_two_pass_encoding_setting_description": "ترميز بمرورين لإنتاج مقاطع فيديو بترميز أفضل. عند تمكين الحد الأقصى لمعدل البت (مطلوب لكي يعمل مع H.264 و HEVC)، يستخدم هذا الوضع نطاق معدل البت استنادًا إلى الحد الأقصى لمعدل البت ويتجاهل CRF. بالنسبة لـ VP9، يمكن استخدام CRF إذا تم تعطيل الحد الأقصى لمعدل البت.", "transcoding_two_pass_encoding_setting_description": "ترميز بمرورين لإنتاج مقاطع فيديو بترميز أفضل. عند تمكين الحد الأقصى لمعدل البت (مطلوب لكي يعمل مع H.264 و HEVC)، يستخدم هذا الوضع نطاق معدل البت استنادًا إلى الحد الأقصى لمعدل البت ويتجاهل CRF. بالنسبة لـ VP9، يمكن استخدام CRF إذا تم تعطيل الحد الأقصى لمعدل البت.",
"transcoding_video_codec": "ترميز الفيديو", "transcoding_video_codec": "ترميز الفيديو",
@@ -794,6 +794,11 @@
"color": "اللون", "color": "اللون",
"color_theme": "نمط الألوان", "color_theme": "نمط الألوان",
"command": "امر", "command": "امر",
"command_palette_prompt": "اعثر بسرعة على الصفحات أو الإجراءات أو الأوامر",
"command_palette_to_close": "للاغلاق",
"command_palette_to_navigate": "للدخول",
"command_palette_to_select": "للاختيار",
"command_palette_to_show_all": "لعرض الكل",
"comment_deleted": "تم حذف التعليق", "comment_deleted": "تم حذف التعليق",
"comment_options": "خيارات التعليق", "comment_options": "خيارات التعليق",
"comments_and_likes": "التعليقات والإعجابات", "comments_and_likes": "التعليقات والإعجابات",
@@ -867,7 +872,7 @@
"current_server_address": "عنوان الخادم الحالي", "current_server_address": "عنوان الخادم الحالي",
"custom_date": "تاريخ مخصص", "custom_date": "تاريخ مخصص",
"custom_locale": "لغة مخصصة", "custom_locale": "لغة مخصصة",
"custom_locale_description": "تنسيق التواريخ والأرقام بناءً على اللغة والمنطقة", "custom_locale_description": "تنسيق التواريخ, الأوقات والأرقام بناءً على اللغة والمنطقة المختاره",
"custom_url": "رابط مخصص", "custom_url": "رابط مخصص",
"cutoff_date_description": "احتفظ بالصور من آخر…", "cutoff_date_description": "احتفظ بالصور من آخر…",
"cutoff_day": "{count, plural, one {يوم} other {ايام}}", "cutoff_day": "{count, plural, one {يوم} other {ايام}}",
@@ -890,8 +895,6 @@
"deduplication_criteria_2": "عدد بيانات EXIF", "deduplication_criteria_2": "عدد بيانات EXIF",
"deduplication_info": "معلومات إلغاء البيانات المكررة", "deduplication_info": "معلومات إلغاء البيانات المكررة",
"deduplication_info_description": "لتحديد الأصول مسبقا تلقائيا وإزالة التكرارات بكميات كبيرة، ننظر إلى:", "deduplication_info_description": "لتحديد الأصول مسبقا تلقائيا وإزالة التكرارات بكميات كبيرة، ننظر إلى:",
"default_locale": "اللغة الافتراضية",
"default_locale_description": "تنسيق التواريخ والأرقام بناءً على لغة المتصفح الخاص بك",
"delete": "حذف", "delete": "حذف",
"delete_action_confirmation_message": "هل انت متأكد من حذف هذا الملف؟ هذا سؤدي الى نقل الملف الى سلة مهملات الخادم وسيتم اشعارك ان كنت تريد حذفه على الجهاز", "delete_action_confirmation_message": "هل انت متأكد من حذف هذا الملف؟ هذا سؤدي الى نقل الملف الى سلة مهملات الخادم وسيتم اشعارك ان كنت تريد حذفه على الجهاز",
"delete_action_prompt": "تم حذف {count}", "delete_action_prompt": "تم حذف {count}",
@@ -1004,6 +1007,8 @@
"editor_edits_applied_success": "تم تطبيق التعديلات بنجاح", "editor_edits_applied_success": "تم تطبيق التعديلات بنجاح",
"editor_flip_horizontal": "اقلب أفقيًا", "editor_flip_horizontal": "اقلب أفقيًا",
"editor_flip_vertical": "اقلب عموديًا", "editor_flip_vertical": "اقلب عموديًا",
"editor_handle_corner": "{corner, select, top_left {أعلى اليسار} top_right {أعلى اليمين} bottom_left {أسفل اليسار} bottom_right {أسفل اليمين} other {أخري}} corner handle",
"editor_handle_edge": "{edge, select, top {أعلي} bottom {أسفل} left {يسار} right {يمين} other {أخري}} edge handle",
"editor_orientation": "اتجاه", "editor_orientation": "اتجاه",
"editor_reset_all_changes": "اعادة ظبط التغييرات", "editor_reset_all_changes": "اعادة ظبط التغييرات",
"editor_rotate_left": "أدر 90° عكس اتجاه عقارب الساعة", "editor_rotate_left": "أدر 90° عكس اتجاه عقارب الساعة",
@@ -1069,6 +1074,7 @@
"failed_to_update_notification_status": "فشل في تحديث حالة الإشعار", "failed_to_update_notification_status": "فشل في تحديث حالة الإشعار",
"incorrect_email_or_password": "بريد أو كلمة مرور غير صحيحة", "incorrect_email_or_password": "بريد أو كلمة مرور غير صحيحة",
"library_folder_already_exists": "مسار الاستيراد موجود بالفعل.", "library_folder_already_exists": "مسار الاستيراد موجود بالفعل.",
"page_not_found": "الصفحة غير موجودة",
"paths_validation_failed": "فشل في التحقق من {paths, plural, one {# مسار} other {# مسارات}}", "paths_validation_failed": "فشل في التحقق من {paths, plural, one {# مسار} other {# مسارات}}",
"profile_picture_transparent_pixels": "لا يمكن أن تحتوي صور الملف الشخصي على أجزاء/بكسلات شفافة. يرجى التكبير و/أو تحريك الصورة.", "profile_picture_transparent_pixels": "لا يمكن أن تحتوي صور الملف الشخصي على أجزاء/بكسلات شفافة. يرجى التكبير و/أو تحريك الصورة.",
"quota_higher_than_disk_size": "لقد قمت بتعيين حصة نسبية أعلى من حجم القرص", "quota_higher_than_disk_size": "لقد قمت بتعيين حصة نسبية أعلى من حجم القرص",
@@ -1168,6 +1174,7 @@
"exif_bottom_sheet_people": "الناس", "exif_bottom_sheet_people": "الناس",
"exif_bottom_sheet_person_add_person": "اضف اسما", "exif_bottom_sheet_person_add_person": "اضف اسما",
"exit_slideshow": "خروج من العرض التقديمي", "exit_slideshow": "خروج من العرض التقديمي",
"expand": "توسعة",
"expand_all": "توسيع الكل", "expand_all": "توسيع الكل",
"experimental_settings_new_asset_list_subtitle": "أعمال جارية", "experimental_settings_new_asset_list_subtitle": "أعمال جارية",
"experimental_settings_new_asset_list_title": "تمكين شبكة الصور التجريبية", "experimental_settings_new_asset_list_title": "تمكين شبكة الصور التجريبية",
@@ -1212,6 +1219,7 @@
"filter_description": "شروط تصفية الأصول المستهدفة", "filter_description": "شروط تصفية الأصول المستهدفة",
"filter_people": "تصفية الاشخاص", "filter_people": "تصفية الاشخاص",
"filter_places": "تصفية الاماكن", "filter_places": "تصفية الاماكن",
"filter_tags": "تصفية العلامات",
"filters": "التصفيات", "filters": "التصفيات",
"find_them_fast": "يمكنك العثور عليها بسرعة بالاسم من خلال البحث", "find_them_fast": "يمكنك العثور عليها بسرعة بالاسم من خلال البحث",
"first": "الاول", "first": "الاول",
@@ -1642,6 +1650,7 @@
"online": "متصل", "online": "متصل",
"only_favorites": "المفضلة فقط", "only_favorites": "المفضلة فقط",
"open": "فتح", "open": "فتح",
"open_calendar": "افتح الرزنامة",
"open_in_map_view": "فتح في عرض الخريطة", "open_in_map_view": "فتح في عرض الخريطة",
"open_in_openstreetmap": "فتح في OpenStreetMap", "open_in_openstreetmap": "فتح في OpenStreetMap",
"open_the_search_filters": "افتح مرشحات البحث", "open_the_search_filters": "افتح مرشحات البحث",
@@ -1801,9 +1810,8 @@
"rate_asset": "تقييم الاصل", "rate_asset": "تقييم الاصل",
"rating": "تقييم نجمي", "rating": "تقييم نجمي",
"rating_clear": "مسح التقييم", "rating_clear": "مسح التقييم",
"rating_count": "{count, plural, one {# نجمة} other {# نجوم}}", "rating_count": "{count, plural, =0 {Unrated} one {# نجمة} other {# نجوم}}",
"rating_description": "‫‌اعرض تقييم EXIF في لوحة المعلومات", "rating_description": "‫‌اعرض تقييم EXIF في لوحة المعلومات",
"rating_set": "تم تحديد التصنيف {rating, plural, one {# نجمة} other {# نجوم}}",
"reaction_options": "خيارات رد الفعل", "reaction_options": "خيارات رد الفعل",
"read_changelog": "قراءة سجل التغيير", "read_changelog": "قراءة سجل التغيير",
"readonly_mode_disabled": "تم تعطيل وضع القراءة فقط", "readonly_mode_disabled": "تم تعطيل وضع القراءة فقط",
@@ -1875,7 +1883,10 @@
"reset_pin_code_success": "تم اعادة تعيين رمز الPIN بنجاح", "reset_pin_code_success": "تم اعادة تعيين رمز الPIN بنجاح",
"reset_pin_code_with_password": "يمكنك دائما اعادة تعيين رمز الPIN الخاص بك عن طريق كلمة المرور الخاصة بك", "reset_pin_code_with_password": "يمكنك دائما اعادة تعيين رمز الPIN الخاص بك عن طريق كلمة المرور الخاصة بك",
"reset_sqlite": "إعادة تعيين قاعدة بيانات SQLite", "reset_sqlite": "إعادة تعيين قاعدة بيانات SQLite",
"reset_sqlite_confirmation": "هل أنت متأكد من رغبتك في إعادة ضبط قاعدة بيانات SQLite؟ ستحتاج إلى تسجيل الخروج ثم تسجيل الدخول مرة أخرى لإعادة مزامنة البيانات", "reset_sqlite_clear_app_data": "مسح البيانات",
"reset_sqlite_confirmation": "هل أنت متأكد من رغبتك في حذف ضبط بيانات التطبيق؟ سيؤدي هذا إلى إزالة جميع الإعدادات وتسجيل خروجك.",
"reset_sqlite_confirmation_note": "ملاحظة: سيتعين عليك إعادة تشغيل التطبيق بعد المسح.",
"reset_sqlite_done": "تم مسح بيانات التطبيق. يرجى إعادة تشغيل تطبيق Immich وتسجيل الدخول مرة أخرى.",
"reset_sqlite_success": "تم إعادة تعيين قاعدة بيانات SQLite بنجاح", "reset_sqlite_success": "تم إعادة تعيين قاعدة بيانات SQLite بنجاح",
"reset_to_default": "إعادة التعيين إلى الافتراضي", "reset_to_default": "إعادة التعيين إلى الافتراضي",
"resolution": "دقة", "resolution": "دقة",
@@ -1903,6 +1914,7 @@
"saved_settings": "تم حفظ الإعدادات", "saved_settings": "تم حفظ الإعدادات",
"say_something": "قل شيئًا", "say_something": "قل شيئًا",
"scaffold_body_error_occurred": "حدث خطأ", "scaffold_body_error_occurred": "حدث خطأ",
"scaffold_body_error_unrecoverable": "حدث خطأ لا يمكن إصلاحه. يرجى مشاركة تفاصيل الخطأ وتسلسل الأخطاء على Discord أو GitHub حتى نتمكن من مساعدتك. إذا طُلب منك ذلك، يمكنك مسح بيانات التطبيق أدناه.",
"scan": "بحث", "scan": "بحث",
"scan_all_libraries": "فحص كل المكتبات", "scan_all_libraries": "فحص كل المكتبات",
"scan_library": "مسح", "scan_library": "مسح",
@@ -1938,6 +1950,7 @@
"search_filter_ocr": "البحث عن طريق التعرف البصري على الحروف", "search_filter_ocr": "البحث عن طريق التعرف البصري على الحروف",
"search_filter_people_title": "اختر الاشخاص", "search_filter_people_title": "اختر الاشخاص",
"search_filter_star_rating": "تقييم النجوم", "search_filter_star_rating": "تقييم النجوم",
"search_filter_tags_title": "‪تحديد العلامات",
"search_for": "البحث عن", "search_for": "البحث عن",
"search_for_existing_person": "البحث عن شخص موجود", "search_for_existing_person": "البحث عن شخص موجود",
"search_no_more_result": "لا توجد نتائج اضافية", "search_no_more_result": "لا توجد نتائج اضافية",
@@ -2017,6 +2030,9 @@
"set_profile_picture": "تحديد صورة الملف الشخصي", "set_profile_picture": "تحديد صورة الملف الشخصي",
"set_slideshow_to_fullscreen": "تحديد عرض الشرائح على وضع ملء الشاشة", "set_slideshow_to_fullscreen": "تحديد عرض الشرائح على وضع ملء الشاشة",
"set_stack_primary_asset": "تعيين كأصل اساسي", "set_stack_primary_asset": "تعيين كأصل اساسي",
"setting_image_navigation_enable_subtitle": "في حال تم التفعيل، يمكنك الانتقال إلى الصورة السابقة أو التالية عن طريق النقر على الربع الأيسر أو الربع الأيمن من الشاشة.",
"setting_image_navigation_enable_title": "النقر للتنقل",
"setting_image_navigation_title": "التنقل بين الصور",
"setting_image_viewer_help": "يقوم عارض التفاصيل بتحميل الصورة المصغرة الصغيرة أولاً ، ثم يقوم بتحميل المعاينة متوسطة الحجم (إذا تم تمكينها) ، ويقوم أخيرًا بتحميل الأصل (إذا تم تمكينه).", "setting_image_viewer_help": "يقوم عارض التفاصيل بتحميل الصورة المصغرة الصغيرة أولاً ، ثم يقوم بتحميل المعاينة متوسطة الحجم (إذا تم تمكينها) ، ويقوم أخيرًا بتحميل الأصل (إذا تم تمكينه).",
"setting_image_viewer_original_subtitle": "تمكين تحميل الصورة الكاملة الدقة الأصلية (كبيرة!).تعطيل لتقليل استخدام البيانات (كل من الشبكة وعلى ذاكرة التخزين المؤقت للجهاز).", "setting_image_viewer_original_subtitle": "تمكين تحميل الصورة الكاملة الدقة الأصلية (كبيرة!).تعطيل لتقليل استخدام البيانات (كل من الشبكة وعلى ذاكرة التخزين المؤقت للجهاز).",
"setting_image_viewer_original_title": "تحميل الصورة الأصلية", "setting_image_viewer_original_title": "تحميل الصورة الأصلية",
@@ -2183,6 +2199,7 @@
"support": "الدعم", "support": "الدعم",
"support_and_feedback": "الدعم والتعليقات", "support_and_feedback": "الدعم والتعليقات",
"support_third_party_description": "تم حزم تثبيت immich الخاص بك بواسطة جهة خارجية. قد تكون المشكلات التي تواجهها ناجمة عن هذه الحزمة، لذا يرجى طرح المشكلات معهم في المقام الأول باستخدام الروابط أدناه.", "support_third_party_description": "تم حزم تثبيت immich الخاص بك بواسطة جهة خارجية. قد تكون المشكلات التي تواجهها ناجمة عن هذه الحزمة، لذا يرجى طرح المشكلات معهم في المقام الأول باستخدام الروابط أدناه.",
"supporter": "داعم",
"swap_merge_direction": "تبديل اتجاه الدمج", "swap_merge_direction": "تبديل اتجاه الدمج",
"sync": "مزامنة", "sync": "مزامنة",
"sync_albums": "مزامنة الالبومات", "sync_albums": "مزامنة الالبومات",
@@ -2294,6 +2311,7 @@
"unstack_action_prompt": "تم ازالة تكديس {count}", "unstack_action_prompt": "تم ازالة تكديس {count}",
"unstacked_assets_count": "تم إخراج {count, plural, one {# الأصل} other {# الأصول}} من التكديس", "unstacked_assets_count": "تم إخراج {count, plural, one {# الأصل} other {# الأصول}} من التكديس",
"unsupported_field_type": "نوع حقل غير مدعوم", "unsupported_field_type": "نوع حقل غير مدعوم",
"unsupported_file_type": "لا يمكن رفع الملف {file} لأن نوع الملف {type} غير مدعوم.",
"untagged": "غير مُعَلَّم", "untagged": "غير مُعَلَّم",
"untitled_workflow": "خطة سير عمل بدون عنوان", "untitled_workflow": "خطة سير عمل بدون عنوان",
"up_next": "التالي", "up_next": "التالي",
@@ -2320,6 +2338,8 @@
"url": "عنوان URL", "url": "عنوان URL",
"usage": "الاستخدام", "usage": "الاستخدام",
"use_biometric": "استخدم البايومتري", "use_biometric": "استخدم البايومتري",
"use_browser_locale": "استخدم لغه للمتصفح",
"use_browser_locale_description": "تنسيق التواريخ والأوقات والأرقام وفقًا لإعدادات اللغة في متصفحك",
"use_current_connection": "استخدم الاتصال الحالي", "use_current_connection": "استخدم الاتصال الحالي",
"use_custom_date_range": "استخدم النطاق الزمني المخصص بدلاً من ذلك", "use_custom_date_range": "استخدم النطاق الزمني المخصص بدلاً من ذلك",
"user": "مستخدم", "user": "مستخدم",
+23
View File
@@ -104,6 +104,8 @@
"image_preview_description": "Відарыс сярэдняга памеру з выдаленымі метаданымі, выкарыстоўваецца пры праглядзе асобнага рэсурсу і для машыннага навучання", "image_preview_description": "Відарыс сярэдняга памеру з выдаленымі метаданымі, выкарыстоўваецца пры праглядзе асобнага рэсурсу і для машыннага навучання",
"image_preview_quality_description": "Якасць праявы ад 1 да 100. Чым вышэй, тым лепш, але пры гэтым ствараюцца файлы большага памеру і можа знізіцца хуткасць водгуку прыкладання. Ўстаноўка нізкага значэння можа паўплываць на якасць машыннага навучання.", "image_preview_quality_description": "Якасць праявы ад 1 да 100. Чым вышэй, тым лепш, але пры гэтым ствараюцца файлы большага памеру і можа знізіцца хуткасць водгуку прыкладання. Ўстаноўка нізкага значэння можа паўплываць на якасць машыннага навучання.",
"image_preview_title": "Налады папярэдняга прагляду", "image_preview_title": "Налады папярэдняга прагляду",
"image_progressive": "Прагрэсіўны",
"image_progressive_description": "Выявы з прагрэсіўным кодаваннем загружаюцца хутчэй, паступова паляпшаецца якасць. Налада не ўплывае на выяву ў фармаце WebP.",
"image_quality": "Якасць", "image_quality": "Якасць",
"image_resolution": "Раздзяляльнасць", "image_resolution": "Раздзяляльнасць",
"image_resolution_description": "Больш высокая раздзяляльнасць дазваляе захаваць больш дэталяў, але патрабуе больш часу для кадавання, прыводзіць да павялічвання памеру файлаў і можа знізіць хуткасць водгуку дадатку.", "image_resolution_description": "Больш высокая раздзяляльнасць дазваляе захаваць больш дэталяў, але патрабуе больш часу для кадавання, прыводзіць да павялічвання памеру файлаў і можа знізіць хуткасць водгуку дадатку.",
@@ -120,6 +122,7 @@
"job_settings_description": "Кіраваць наладамі паралельнага выканання заданняў", "job_settings_description": "Кіраваць наладамі паралельнага выканання заданняў",
"jobs_delayed": "{jobCount, plural, other {# адкладзена}}", "jobs_delayed": "{jobCount, plural, other {# адкладзена}}",
"jobs_failed": "{jobCount, plural, other {# не выканалася}}", "jobs_failed": "{jobCount, plural, other {# не выканалася}}",
"jobs_over_time": "Графік апрацоўкі",
"library_created": "Створана бібліятэка: {library}", "library_created": "Створана бібліятэка: {library}",
"library_deleted": "Бібліятэка выдалена", "library_deleted": "Бібліятэка выдалена",
"library_details": "Параметры бібліятэкі", "library_details": "Параметры бібліятэкі",
@@ -160,8 +163,27 @@
"machine_learning_facial_recognition_model_description": "Мадэлі пералічаны ў парадку ўбывання іх памеру. Большыя мадэлі павольней і выкарыстоўваюць больш памяці, але даюць лепшыя вынікі. Звярніце увагу, што пасля змены мадэлі трэба зноў запусціць заданне распазнавання твараў для ўсіх відарысаў.", "machine_learning_facial_recognition_model_description": "Мадэлі пералічаны ў парадку ўбывання іх памеру. Большыя мадэлі павольней і выкарыстоўваюць больш памяці, але даюць лепшыя вынікі. Звярніце увагу, што пасля змены мадэлі трэба зноў запусціць заданне распазнавання твараў для ўсіх відарысаў.",
"machine_learning_facial_recognition_setting": "Уключыць распазнаванне твараў", "machine_learning_facial_recognition_setting": "Уключыць распазнаванне твараў",
"machine_learning_facial_recognition_setting_description": "Калі адключана, відарысы не будуць кадавацца для распазнавання твараў, і не будзе запаўняцца раздзел \"Людзі\" на старонцы \"Агляд\".", "machine_learning_facial_recognition_setting_description": "Калі адключана, відарысы не будуць кадавацца для распазнавання твараў, і не будзе запаўняцца раздзел \"Людзі\" на старонцы \"Агляд\".",
"machine_learning_max_detection_distance": "Максімальная адлегласць выяўлення",
"machine_learning_max_detection_distance_description": "Максімальная розніца паміж двума выявамі, якія лічацца дублікатамі, складае ад 0,001 да 0,1. Больш высокія значэнні дазволяць выявіць больш дублікатаў, але могуць прывесці да няправільных выяўленняў.",
"machine_learning_max_recognition_distance": "Парог разпазнавання",
"machine_learning_max_recognition_distance_description": "Максімальнае адрозненне паміж двума асобамі, якія можна лічыць адным чалавекам (у дыяпазоне ад 0 да 2).Зніжэнне гэтага параметру можа прадухіліць распазнанне двух людзей як аднаго і таго ж чалавека, а павышэнне - як двух розных людзей. Майце на ўвазе, што прасцей аб'яднаць двух людзей, чым падзяліць аднаго чалавека на дваіх, таму па магчымасці выбірайце меншы парог.",
"machine_learning_min_detection_score": "Мінімальны парог разпазнавання",
"machine_learning_min_detection_score_description": "Мінімальны парог для выяўлення асобы (ад 0 да 1). Ніжэйшае значэнне дазволіць знаходзіць больш асоб, але можа прывесці да ілжывых спрацоўванняў.",
"machine_learning_min_recognized_faces": "Мінімум разпазнаных твараў",
"machine_learning_min_recognized_faces_description": "Мінімальная колькасць распазнаных твараў для стварэння асобы. Павялічэнне гэтага параметра робіць распазнанне асоб больш дакладным, але пры гэтым павялічваецца верагоднасць таго, што твар не будзе прысвоены асобе.",
"machine_learning_ocr": "Разпазнаванне тэксту (OCR)",
"machine_learning_ocr_description": "Выкарыстоўвайце машыннае навучанне для распазнавання тэксту на малюнках",
"machine_learning_ocr_enabled": "Дадаць OCR",
"machine_learning_ocr_enabled_description": "Калі адключана, выявы не будуць распазнавацца з выкарыстаннем тэксту.",
"machine_learning_ocr_max_resolution": "Максімальная раздзяляльнасць", "machine_learning_ocr_max_resolution": "Максімальная раздзяляльнасць",
"machine_learning_ocr_max_resolution_description": "Відарысы з раздзяляльнасцю больш гэтай будуць паменшаны з захаваннем суадносіны бакоў. Больш высокія значэнні павышаюць дакладнасць распазнавання, але патрабуюць больш часу на апрацоўку і выкарыстоўваюць больш памяці.", "machine_learning_ocr_max_resolution_description": "Відарысы з раздзяляльнасцю больш гэтай будуць паменшаны з захаваннем суадносіны бакоў. Больш высокія значэнні павышаюць дакладнасць распазнавання, але патрабуюць больш часу на апрацоўку і выкарыстоўваюць больш памяці.",
"machine_learning_ocr_min_detection_score": "Мінімальны бал выяўлення",
"machine_learning_ocr_min_detection_score_description": "Мінімальны бал даверу для выяўлення тэксту складае ад 0 да 1. Больш нізкія значэнні дазволяць выявіць больш тэксту, але могуць прывесці да хібных спрацоўванняў.",
"machine_learning_ocr_min_recognition_score": "Мінімальны бал распазнавання",
"machine_learning_ocr_min_score_recognition_description": "Мінімальны бал даверу для распазнавання выяўленага тэксту складае ад 0 да 1. Больш нізкія значэнні распазнаюць больш тэксту, але могуць прывесці да хібных спрацоўванняў.",
"machine_learning_ocr_model": "Мадэль машыннага навучання (OCR)",
"machine_learning_ocr_model_description": "Серверныя мадэлі больш дакладныя, чым мабільныя, але апрацоўваюць дадзеныя даўжэй і выкарыстоўваюць больш памяці.",
"machine_learning_settings": "Налады машыннага навучання",
"map_dark_style": "Цёмны стыль", "map_dark_style": "Цёмны стыль",
"map_enable_description": "Уключыць функцыі карты", "map_enable_description": "Уключыць функцыі карты",
"map_gps_settings": "Налады карты і GPS", "map_gps_settings": "Налады карты і GPS",
@@ -171,6 +193,7 @@
"map_style_description": "URL-адрас style.json тэмы карты", "map_style_description": "URL-адрас style.json тэмы карты",
"metadata_extraction_job_description": "Выняць метаданыя з файлаў, такія як месцазнаходжанне, твары і раздзяляльнасць", "metadata_extraction_job_description": "Выняць метаданыя з файлаў, такія як месцазнаходжанне, твары і раздзяляльнасць",
"metadata_settings": "Налады метаданых", "metadata_settings": "Налады метаданых",
"notification_email_port_description": "Порт паштовага сервера (напрыклад, 25, 465 або 587)",
"oauth_button_text": "Тэкст кнопкі", "oauth_button_text": "Тэкст кнопкі",
"oauth_settings": "OAuth", "oauth_settings": "OAuth",
"refreshing_all_libraries": "Абнаўленне ўсіх бібліятэк", "refreshing_all_libraries": "Абнаўленне ўсіх бібліятэк",
+34 -14
View File
@@ -61,7 +61,7 @@
"backup_onboarding_1_description": "копие на облака или друго физическо място.", "backup_onboarding_1_description": "копие на облака или друго физическо място.",
"backup_onboarding_2_description": "локални копия на различни устройства. Това включва основните файлове и локални архиви на тези файлове.", "backup_onboarding_2_description": "локални копия на различни устройства. Това включва основните файлове и локални архиви на тези файлове.",
"backup_onboarding_3_description": "общо копия на вашите данни, включитено оригиналните файлове. Това включва 1 копие извън системата и 2 локални копия.", "backup_onboarding_3_description": "общо копия на вашите данни, включитено оригиналните файлове. Това включва 1 копие извън системата и 2 локални копия.",
"backup_onboarding_description": "За надеждна защита препоръчваме стратегията <backblaze-link>3-2-1</backblaze-link>. Правете архивни копия както на качените снимки/видеа, така и на базата данни на Immich.", "backup_onboarding_description": "За надеждна защита препоръчваме <backblaze-link>стратегията 3-2-1</backblaze-link>. Правете архивни копия както на качените снимки/видеа, така и на базата данни на Immich.",
"backup_onboarding_footer": "За подробна информация относно архивирането в Immich, моля вижте в <link>документацията</link>.", "backup_onboarding_footer": "За подробна информация относно архивирането в Immich, моля вижте в <link>документацията</link>.",
"backup_onboarding_parts_title": "Стратегията 3-2-1 включва:", "backup_onboarding_parts_title": "Стратегията 3-2-1 включва:",
"backup_onboarding_title": "Резервни копия", "backup_onboarding_title": "Резервни копия",
@@ -104,7 +104,7 @@
"image_preview_description": "Среден размер на изображението с премахнати метаданни, използвано при преглед на един елемент и за машинно обучение", "image_preview_description": "Среден размер на изображението с премахнати метаданни, използвано при преглед на един елемент и за машинно обучение",
"image_preview_quality_description": "Качество на предварителния преглед от 1 до 100. По-високата стойност е по-добра, но води до по-големи файлове и може да намали бързодействието на приложението. Задаването на ниска стойност може да повлияе на качеството на машинното обучение.", "image_preview_quality_description": "Качество на предварителния преглед от 1 до 100. По-високата стойност е по-добра, но води до по-големи файлове и може да намали бързодействието на приложението. Задаването на ниска стойност може да повлияе на качеството на машинното обучение.",
"image_preview_title": "Настройки на прегледа", "image_preview_title": "Настройки на прегледа",
"image_progressive": "Прогресивен JPEG", "image_progressive": "Прогресивно",
"image_progressive_description": "Изображенията, кодирани в прогресивен JPEG формат, се зареждат по-бързо, с постепенно подобряващо се качество. Това няма влияние на кодираните като WebP изображения.", "image_progressive_description": "Изображенията, кодирани в прогресивен JPEG формат, се зареждат по-бързо, с постепенно подобряващо се качество. Това няма влияние на кодираните като WebP изображения.",
"image_quality": "Качество", "image_quality": "Качество",
"image_resolution": "Резолюция", "image_resolution": "Резолюция",
@@ -311,7 +311,7 @@
"search_jobs": "Търсене на задачи…", "search_jobs": "Търсене на задачи…",
"send_welcome_email": "Изпращане на имейл за добре дошли", "send_welcome_email": "Изпращане на имейл за добре дошли",
"server_external_domain_settings": "Външен домейн", "server_external_domain_settings": "Външен домейн",
"server_external_domain_settings_description": "Домейн за публични споделени връзки, включително http(s)://", "server_external_domain_settings_description": "Домейн за външни връзки",
"server_public_users": "Публични потребители", "server_public_users": "Публични потребители",
"server_public_users_description": "Всички потребители (име и имейл) са изброени при добавяне на потребител в споделени албуми. Когато е деактивирано, списъкът с потребители ще бъде достъпен само за администраторите.", "server_public_users_description": "Всички потребители (име и имейл) са изброени при добавяне на потребител в споделени албуми. Когато е деактивирано, списъкът с потребители ще бъде достъпен само за администраторите.",
"server_settings": "Настройки на сървъра", "server_settings": "Настройки на сървъра",
@@ -372,7 +372,7 @@
"transcoding_audio_codec": "Аудио кодек", "transcoding_audio_codec": "Аудио кодек",
"transcoding_audio_codec_description": "Opus е опцията с най-високо качество, но има по-ниска съвместимост със стари устройства или софтуер.", "transcoding_audio_codec_description": "Opus е опцията с най-високо качество, но има по-ниска съвместимост със стари устройства или софтуер.",
"transcoding_bitrate_description": "Видеоклипове с по-висок от максималния битрейт или не в приет формат", "transcoding_bitrate_description": "Видеоклипове с по-висок от максималния битрейт или не в приет формат",
"transcoding_codecs_learn_more": "За да научите повече за използваната терминология, вижте документацията на FFmpeg за <h264-link>кодек H.264</h264-link>, <hevc-link>кодек HEVC</hevc-link> и <vp9-link>VP9 кодек</vp9-link>.", "transcoding_codecs_learn_more": "За да научите повече за използваната терминология, вижте документацията на FFmpeg за <h264-link>кодек H.264</h264-link>, <hevc-link>кодек HEVC</hevc-link> и <vp9-link>кодек VP9</vp9-link>.",
"transcoding_constant_quality_mode": "Режим на постоянно качество", "transcoding_constant_quality_mode": "Режим на постоянно качество",
"transcoding_constant_quality_mode_description": "ICQ е по-добър от CQP, но някои устройства за хардуерно ускоряване не поддържат този режим. С задаването на тази опция ще предпочете посочения режим при използване на базирано на качество кодиране. Игнорирано от NVENC, тъй като не поддържа ICQ.", "transcoding_constant_quality_mode_description": "ICQ е по-добър от CQP, но някои устройства за хардуерно ускоряване не поддържат този режим. С задаването на тази опция ще предпочете посочения режим при използване на базирано на качество кодиране. Игнорирано от NVENC, тъй като не поддържа ICQ.",
"transcoding_constant_rate_factor": "Коефициент на постоянна скорост (-crf)", "transcoding_constant_rate_factor": "Коефициент на постоянна скорост (-crf)",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Тонално картографиране", "transcoding_tone_mapping": "Тонално картографиране",
"transcoding_tone_mapping_description": "Опитва се да запази външния вид на HDR видеоклипове, когато се преобразува в SDR. Всеки алгоритъм прави различни компромиси за цвят, детайлност и яркост. Hable запазва детайлите, Mobius запазва цвета, а Reinhard запазва яркостта.", "transcoding_tone_mapping_description": "Опитва се да запази външния вид на HDR видеоклипове, когато се преобразува в SDR. Всеки алгоритъм прави различни компромиси за цвят, детайлност и яркост. Hable запазва детайлите, Mobius запазва цвета, а Reinhard запазва яркостта.",
"transcoding_transcode_policy": "Правила за транскодиране", "transcoding_transcode_policy": "Правила за транскодиране",
"transcoding_transcode_policy_description": "Правила за това кога видеоклипът трябва да бъде транскодиран. HDR видеоклиповете винаги ще бъдат транскодирани (освен ако транскодирането е деактивирано).", "transcoding_transcode_policy_description": "Правила за това кога видеоклипът трябва да бъде транскодиран. HDR видеоклиповете и тези с формат, различен от YUV 4:2:0, ще бъдат винаги транскодирани (освен ако транскодирането е деактивирано).",
"transcoding_two_pass_encoding": "Кодиране с двойно минаване", "transcoding_two_pass_encoding": "Кодиране с двойно минаване",
"transcoding_two_pass_encoding_setting_description": "Транскодирането с две минавания създава по-добре кодиране видеа. Когато максималния битрейт е включен (задължително е да се работи с H.264 и HEVC), тази опция използва диапазон на битрейта базиран на максималния битрейт и игнорира CRF. За VP9, CRF може да се използва ако максималният битрейт е изключен.", "transcoding_two_pass_encoding_setting_description": "Транскодирането с две минавания създава по-добре кодиране видеа. Когато максималния битрейт е включен (задължително е да се работи с H.264 и HEVC), тази опция използва диапазон на битрейта базиран на максималния битрейт и игнорира CRF. За VP9, CRF може да се използва ако максималният битрейт е изключен.",
"transcoding_video_codec": "Видеокодек", "transcoding_video_codec": "Видеокодек",
@@ -794,6 +794,11 @@
"color": "Цвят", "color": "Цвят",
"color_theme": "Цветова тема", "color_theme": "Цветова тема",
"command": "Команда", "command": "Команда",
"command_palette_prompt": "Бързо намиране на страници, действия или команди",
"command_palette_to_close": "затвори",
"command_palette_to_navigate": "влез",
"command_palette_to_select": "избери",
"command_palette_to_show_all": "покажи всичко",
"comment_deleted": "Коментарът е изтрит", "comment_deleted": "Коментарът е изтрит",
"comment_options": "Опции за коментар", "comment_options": "Опции за коментар",
"comments_and_likes": "Коментари и харесвания", "comments_and_likes": "Коментари и харесвания",
@@ -866,8 +871,8 @@
"current_pin_code": "Сегашен PIN код", "current_pin_code": "Сегашен PIN код",
"current_server_address": "Настоящ адрес на сървъра", "current_server_address": "Настоящ адрес на сървъра",
"custom_date": "Персонализирана дата", "custom_date": "Персонализирана дата",
"custom_locale": "Персонализиран локал", "custom_locale": "Персонализирани езикови настройки",
"custom_locale_description": "Форматиране на дати и числа в зависимост от езика и региона", "custom_locale_description": "Форматиране на дата, време и числа в зависимост от избрания език и регион",
"custom_url": "Персонализиран URL адрес", "custom_url": "Персонализиран URL адрес",
"cutoff_date_description": "Запазване на снимки от последните…", "cutoff_date_description": "Запазване на снимки от последните…",
"cutoff_day": "{count, plural, one {ден} other {дни}}", "cutoff_day": "{count, plural, one {ден} other {дни}}",
@@ -890,8 +895,6 @@
"deduplication_criteria_2": "Брой EXIF данни", "deduplication_criteria_2": "Брой EXIF данни",
"deduplication_info": "Информация за дедупликацията", "deduplication_info": "Информация за дедупликацията",
"deduplication_info_description": "За автоматично предварително избиране на ресурси и премахване на дубликати на едро, разглеждаме:", "deduplication_info_description": "За автоматично предварително избиране на ресурси и премахване на дубликати на едро, разглеждаме:",
"default_locale": "Локализация по подразбиране",
"default_locale_description": "Форматиране на дати и числа в зависимост от езиковата настройка на браузъра",
"delete": "Изтрий", "delete": "Изтрий",
"delete_action_confirmation_message": "Сигурни ли сте, че искате да изтриете този обект? Следва преместване на обекта в коша за отпадъци на сървъра и ще получите предложение обекта да бъде изтрит локално", "delete_action_confirmation_message": "Сигурни ли сте, че искате да изтриете този обект? Следва преместване на обекта в коша за отпадъци на сървъра и ще получите предложение обекта да бъде изтрит локално",
"delete_action_prompt": "{count} са изтрити", "delete_action_prompt": "{count} са изтрити",
@@ -1004,6 +1007,8 @@
"editor_edits_applied_success": "Успешно прилагане на промените", "editor_edits_applied_success": "Успешно прилагане на промените",
"editor_flip_horizontal": "Обърни хоризонтално", "editor_flip_horizontal": "Обърни хоризонтално",
"editor_flip_vertical": "Обърни вертикално", "editor_flip_vertical": "Обърни вертикално",
"editor_handle_corner": "Манипулатор {corner, select, top_left {горен ляв} top_right {горен десен} bottom_left {долен ляв} bottom_right {долен десен} other {в}} ъгъл",
"editor_handle_edge": "Манипулатор {edge, select, top {горен} bottom {долен} left {ляв} right {десен} other {по}} ръб",
"editor_orientation": "Ориентация", "editor_orientation": "Ориентация",
"editor_reset_all_changes": "Възстанови всички промени", "editor_reset_all_changes": "Възстанови всички промени",
"editor_rotate_left": "Завърти 90° обратно на часовниковата стрелка", "editor_rotate_left": "Завърти 90° обратно на часовниковата стрелка",
@@ -1069,6 +1074,7 @@
"failed_to_update_notification_status": "Неуспешно обновяване на състоянието на известията", "failed_to_update_notification_status": "Неуспешно обновяване на състоянието на известията",
"incorrect_email_or_password": "Неправилен имейл или парола", "incorrect_email_or_password": "Неправилен имейл или парола",
"library_folder_already_exists": "Тази папка вече съществува.", "library_folder_already_exists": "Тази папка вече съществува.",
"page_not_found": "Страницата не е намерена",
"paths_validation_failed": "{paths, plural, one {# път} other {# пътища}} не преминаха валидация", "paths_validation_failed": "{paths, plural, one {# път} other {# пътища}} не преминаха валидация",
"profile_picture_transparent_pixels": "Профилните снимки не могат да имат прозрачни пиксели. Моля, увеличете и/или преместете изображението.", "profile_picture_transparent_pixels": "Профилните снимки не могат да имат прозрачни пиксели. Моля, увеличете и/или преместете изображението.",
"quota_higher_than_disk_size": "Зададена е квота, по-голяма от размера на диска", "quota_higher_than_disk_size": "Зададена е квота, по-голяма от размера на диска",
@@ -1168,6 +1174,7 @@
"exif_bottom_sheet_people": "ХОРА", "exif_bottom_sheet_people": "ХОРА",
"exif_bottom_sheet_person_add_person": "Добави име", "exif_bottom_sheet_person_add_person": "Добави име",
"exit_slideshow": "Изход от слайдшоуто", "exit_slideshow": "Изход от слайдшоуто",
"expand": "Разгъни",
"expand_all": "Разшири всички", "expand_all": "Разшири всички",
"experimental_settings_new_asset_list_subtitle": "В развитие", "experimental_settings_new_asset_list_subtitle": "В развитие",
"experimental_settings_new_asset_list_title": "Включи експериментална подредба на снимки", "experimental_settings_new_asset_list_title": "Включи експериментална подредба на снимки",
@@ -1212,6 +1219,7 @@
"filter_description": "Условия за филтриране на обекти", "filter_description": "Условия за филтриране на обекти",
"filter_people": "Филтриране на хора", "filter_people": "Филтриране на хора",
"filter_places": "Филтър по място", "filter_places": "Филтър по място",
"filter_tags": "Филтриране по етикети",
"filters": "Филтри", "filters": "Филтри",
"find_them_fast": "Намерете ги бързо по име с търсене", "find_them_fast": "Намерете ги бързо по име с търсене",
"first": "Първи", "first": "Първи",
@@ -1311,7 +1319,7 @@
"import_path": "Път за импортиране", "import_path": "Път за импортиране",
"in_albums": "В {count, plural, one {# албум} other {# албума}}", "in_albums": "В {count, plural, one {# албум} other {# албума}}",
"in_archive": "В архив", "in_archive": "В архив",
"in_year": "{year} г.", "in_year": "През {year}",
"in_year_selector": "През", "in_year_selector": "През",
"include_archived": "Включване на архивирани", "include_archived": "Включване на архивирани",
"include_shared_albums": "Включване на споделени албуми", "include_shared_albums": "Включване на споделени албуми",
@@ -1642,6 +1650,7 @@
"online": "Онлайн", "online": "Онлайн",
"only_favorites": "Само любими", "only_favorites": "Само любими",
"open": "Отвори", "open": "Отвори",
"open_calendar": "Отвори календар",
"open_in_map_view": "Отвори изглед на карта", "open_in_map_view": "Отвори изглед на карта",
"open_in_openstreetmap": "Отвори в OpenStreetMap", "open_in_openstreetmap": "Отвори в OpenStreetMap",
"open_the_search_filters": "Отвари филтрите за търсене", "open_the_search_filters": "Отвари филтрите за търсене",
@@ -1801,9 +1810,8 @@
"rate_asset": "Задаване на рейтинг", "rate_asset": "Задаване на рейтинг",
"rating": "Оценка със звезди", "rating": "Оценка със звезди",
"rating_clear": "Изчисти оценката", "rating_clear": "Изчисти оценката",
"rating_count": "{count, plural, one {# звезда} other {# звезди}}", "rating_count": "{count, plural, =0 {Без рейтинг} one {# звезда} other {# звезди}}",
"rating_description": "Покажи EXIF оценката в панела с информация", "rating_description": "Покажи EXIF оценката в панела с информация",
"rating_set": "Зададен е рейтинг {rating, plural, one {# звезда} other {# звезди}}",
"reaction_options": "Избор на реакция", "reaction_options": "Избор на реакция",
"read_changelog": "Прочети промените", "read_changelog": "Прочети промените",
"readonly_mode_disabled": "Режима само за четене е деактивиран", "readonly_mode_disabled": "Режима само за четене е деактивиран",
@@ -1875,7 +1883,10 @@
"reset_pin_code_success": "Успешно нулиран ПИН код", "reset_pin_code_success": "Успешно нулиран ПИН код",
"reset_pin_code_with_password": "С вашата парола можете винаги да нулирате своя ПИН код", "reset_pin_code_with_password": "С вашата парола можете винаги да нулирате своя ПИН код",
"reset_sqlite": "Нулиране на базата данни SQLite", "reset_sqlite": "Нулиране на базата данни SQLite",
"reset_sqlite_confirmation": "Наистина ли искате да нулирате базата данни SQLite? Ще трябва да излезете от системата и да се впишете отново за нова синхронизация на данните", "reset_sqlite_clear_app_data": "Премахни данните",
"reset_sqlite_confirmation": "Наистина ли искате да нулирате данните на приложението? Това ще премахни всички настройки и ще Ви отпише от системата.",
"reset_sqlite_confirmation_note": "Бележка: След премахване на данните ще трябва да рестартирате приложението.",
"reset_sqlite_done": "Данните на приложението са премахнати. Моля, рестартирайте Immich и се впишете отново.",
"reset_sqlite_success": "Успешно нулиране на базата данни SQLite", "reset_sqlite_success": "Успешно нулиране на базата данни SQLite",
"reset_to_default": "Връщане на фабрични настройки", "reset_to_default": "Връщане на фабрични настройки",
"resolution": "Резолюция", "resolution": "Резолюция",
@@ -1903,6 +1914,7 @@
"saved_settings": "Запазени настройки", "saved_settings": "Запазени настройки",
"say_something": "Кажи нещо", "say_something": "Кажи нещо",
"scaffold_body_error_occurred": "Възникна грешка", "scaffold_body_error_occurred": "Възникна грешка",
"scaffold_body_error_unrecoverable": "Възникна непоправима грешка. Моля, споделете грешката и трасирането на стека в Discord или GitHub, за да можем да Ви помогнем. Ако бъдете посъветвани, може да изчистите данните на приложението.",
"scan": "Сканиранe", "scan": "Сканиранe",
"scan_all_libraries": "Сканирай всички библиотеки", "scan_all_libraries": "Сканирай всички библиотеки",
"scan_library": "Сканирай", "scan_library": "Сканирай",
@@ -1938,6 +1950,7 @@
"search_filter_ocr": "Търсене нa текст", "search_filter_ocr": "Търсене нa текст",
"search_filter_people_title": "Избери хора", "search_filter_people_title": "Избери хора",
"search_filter_star_rating": "Класация със звезди", "search_filter_star_rating": "Класация със звезди",
"search_filter_tags_title": "Изберете етикети",
"search_for": "Търси за", "search_for": "Търси за",
"search_for_existing_person": "Търси съществуващ човек", "search_for_existing_person": "Търси съществуващ човек",
"search_no_more_result": "Няма други резултати", "search_no_more_result": "Няма други резултати",
@@ -2017,6 +2030,9 @@
"set_profile_picture": "Задайте профилна снимка", "set_profile_picture": "Задайте профилна снимка",
"set_slideshow_to_fullscreen": "Задайте Слайдшоу на цял екран", "set_slideshow_to_fullscreen": "Задайте Слайдшоу на цял екран",
"set_stack_primary_asset": "Задай като основни обекти", "set_stack_primary_asset": "Задай като основни обекти",
"setting_image_navigation_enable_subtitle": "Ако е избрано, можете да навигирате към предишна/следваща снимка като натиснете върху лявата/дясната страна на екрана.",
"setting_image_navigation_enable_title": "Натисни за навигиране",
"setting_image_navigation_title": "Навигиране на снимка",
"setting_image_viewer_help": "При показване на обект първо се зарежда миниатюра, после изображение със средно качество (ако е разрешено) и накрая оригинала (ако е разрешено).", "setting_image_viewer_help": "При показване на обект първо се зарежда миниатюра, после изображение със средно качество (ако е разрешено) и накрая оригинала (ако е разрешено).",
"setting_image_viewer_original_subtitle": "Разреши за да се зарежда оригиналното изображение в пълен размер (голям!). Забрани за да се намали обема на данните (по мрежата и в кеша на устройството).", "setting_image_viewer_original_subtitle": "Разреши за да се зарежда оригиналното изображение в пълен размер (голям!). Забрани за да се намали обема на данните (по мрежата и в кеша на устройството).",
"setting_image_viewer_original_title": "Зареждане на оригинално изображение", "setting_image_viewer_original_title": "Зареждане на оригинално изображение",
@@ -2183,6 +2199,7 @@
"support": "Поддръжка", "support": "Поддръжка",
"support_and_feedback": "Поддръжка и обратна връзка", "support_and_feedback": "Поддръжка и обратна връзка",
"support_third_party_description": "Вашата инсталация на Immich е пакетирана от трета страна. Проблемите, които изпитвате, може да са причинени от този пакет, затова моля, първо подавайте проблемите си към тях чрез линковете по-долу.", "support_third_party_description": "Вашата инсталация на Immich е пакетирана от трета страна. Проблемите, които изпитвате, може да са причинени от този пакет, затова моля, първо подавайте проблемите си към тях чрез линковете по-долу.",
"supporter": "Поддръжник",
"swap_merge_direction": "Размяна посоката на сливане", "swap_merge_direction": "Размяна посоката на сливане",
"sync": "Синхронизиране", "sync": "Синхронизиране",
"sync_albums": "Синхронизиране на албуми", "sync_albums": "Синхронизиране на албуми",
@@ -2196,7 +2213,7 @@
"tag_assets": "Тагни елементи", "tag_assets": "Тагни елементи",
"tag_created": "Създаден етикет: {tag}", "tag_created": "Създаден етикет: {tag}",
"tag_feature_description": "Разглеждане на снимки и видеоклипове, групирани по теми с логически тагове", "tag_feature_description": "Разглеждане на снимки и видеоклипове, групирани по теми с логически тагове",
"tag_not_found_question": "Не можете да намерите етикет? Създайте такъв <link>тук</link>", "tag_not_found_question": "Не можете да намерите етикет? <link>Създайте нов етикет.</link>",
"tag_people": "Отбележи Хора", "tag_people": "Отбележи Хора",
"tag_updated": "Обновен етикет: {tag}", "tag_updated": "Обновен етикет: {tag}",
"tagged_assets": "Тагнати {count, plural, one {# елемент} other {# елементи}}", "tagged_assets": "Тагнати {count, plural, one {# елемент} other {# елементи}}",
@@ -2294,6 +2311,7 @@
"unstack_action_prompt": "{count} са разгрупирани", "unstack_action_prompt": "{count} са разгрупирани",
"unstacked_assets_count": "Разкачени {count, plural, one {# елемент} other {# елементи}}", "unstacked_assets_count": "Разкачени {count, plural, one {# елемент} other {# елементи}}",
"unsupported_field_type": "Типа на полето не се поддържа", "unsupported_field_type": "Типа на полето не се поддържа",
"unsupported_file_type": "Файлът {file} не може да бъде зареден, защото неговият тип {type} не се поддържа.",
"untagged": "Немаркирани", "untagged": "Немаркирани",
"untitled_workflow": "Работен процес без име", "untitled_workflow": "Работен процес без име",
"up_next": "Следващ", "up_next": "Следващ",
@@ -2320,6 +2338,8 @@
"url": "URL", "url": "URL",
"usage": "Потребление", "usage": "Потребление",
"use_biometric": "Използвай биометрия", "use_biometric": "Използвай биометрия",
"use_browser_locale": "Използвай езиковите настройки на браузъра",
"use_browser_locale_description": "Формат на дата, време и числа според езиковата настройка на браузъра",
"use_current_connection": "Използвай текущата връзка", "use_current_connection": "Използвай текущата връзка",
"use_custom_date_range": "Използвайте собствен диапазон от дати вместо това", "use_custom_date_range": "Използвайте собствен диапазон от дати вместо това",
"user": "Потребител", "user": "Потребител",
+29 -27
View File
@@ -70,23 +70,23 @@
"cleared_jobs": "{job} এর জন্য jobs খালি করা হয়েছে", "cleared_jobs": "{job} এর জন্য jobs খালি করা হয়েছে",
"config_set_by_file": "কনফিগ বর্তমানে একটি কনফিগ ফাইল দ্বারা সেট করা আছে", "config_set_by_file": "কনফিগ বর্তমানে একটি কনফিগ ফাইল দ্বারা সেট করা আছে",
"confirm_delete_library": "আপনি কি নিশ্চিত যে আপনি {library} লাইব্রেরি মুছে ফেলতে চান?", "confirm_delete_library": "আপনি কি নিশ্চিত যে আপনি {library} লাইব্রেরি মুছে ফেলতে চান?",
"confirm_delete_library_assets": "আপনি কি নিশ্চিত যে আপনি এই লাইব্রেরিটি মুছে ফেলতে চান? এটি Immich থেকে {count, plural, one {# contained asset} other {all # contained asset}} মুছে ফেলবে এবং পূর্বাবস্থায় ফেরানো যাবে না। ফাইলগুলি ডিস্কে থাবে।", "confirm_delete_library_assets": "আপনি কি নিশ্চিতভাবে এই লাইব্রেরিটি মুছে ফেলতে চান? এতে Immich থেকে {count, plural, one {#টি অ্যাসেট} other {#টি অ্যাসেট}} মুছে যাবে এবং এই কাজটি পরে আর পূর্বাবস্থায় ফেরানো যাবে না। তবে ফাইলগুল ডিস্কে থেকে যাবে।",
"confirm_email_below": "নিশ্চিত করতে, নিচে \"{email}\" টাইপ করুন", "confirm_email_below": "নিশ্চিত করার জন্য নিচে \"{email}\" টাইপ করুন",
"confirm_reprocess_all_faces": "আপনি কি নিশ্চিত যে আপনি সমস্ত মুখ পুনরায় প্রক্রিয়া করতে চান? এটি নামযুক্ত ব্যক্তিদেরও মুছে ফেলবে।", "confirm_reprocess_all_faces": "আপনি কি নিশ্চিত যে আপনি সমস্ত মুখ পুনরায় পরিশোধন করতে চান? এতে নাম দেওয়া ব্যক্তিদের তথ্যও মুছে যাবে।",
"confirm_user_password_reset": "আপনি কি নিশ্চিত যে আপনি {user} এর পাসওয়ার্ড রিসেট করতে চান?", "confirm_user_password_reset": "আপনি কি নিশ্চিত যে আপনি {user}-এর পাসওয়ার্ড রিসেট করতে চান?",
"confirm_user_pin_code_reset": "আপনি কি নিশ্চিত যে আপনি {user} এর পিন কোড রিসেট করতে চান?", "confirm_user_pin_code_reset": "আপনি কি নিশ্চিত যে আপনি {user}-এর পিন কোড রিসেট করতে চান?",
"copy_config_to_clipboard_description": "বর্তমান সিস্টেম কনফিগারেশন একটি JSON অবজেক্ট হিসেবে ক্লিপবোর্ডে কপি করুন", "copy_config_to_clipboard_description": "বর্তমান সিস্টেম কনফিগারেশনটিকে একটি JSON অবজেক্ট হিসেবে ক্লিপবোর্ডে কপি করুন",
"create_job": "job তৈরি করুন", "create_job": "Job তৈরি করুন",
"cron_expression": "ক্রোন এক্সপ্রেশন", "cron_expression": "Cron এক্সপ্রেশন",
"cron_expression_description": "ক্রোন ফরম্যাট ব্যবহার করে স্ক্যানিং ব্যবধান সেট করুন। আরও তথ্যের জন্য দয়া করে দেখুন যেমন <link>Crontab Guru</link>", "cron_expression_description": "Cron ফরম্যাট ব্যবহার করে স্ক্যানিং ইন্টারভ্যাল নির্ধারণ করুন। আরও তথ্যের জন্য দা করে <link>Crontab Guru</link> দেখুন",
"cron_expression_presets": "ক্রোন এক্সপ্রেশন প্রিসেট", "cron_expression_presets": "Cron এক্সপ্রেশন প্রিসেট",
"disable_login": "লগইন অক্ষম করুন", "disable_login": "লগইন অক্ষম করুন",
"duplicate_detection_job_description": "অনুরূপ ছবি নাক্ত করতে সম্পদগুলিতে মেশিন লার্নিং চালান। স্মার্ট অনুসন্ধানের উপর নির্ভর করে", "duplicate_detection_job_description": "সদৃশ ছবি নাক্ত করতে অ্যাসেটগুলোর উপর মেশিন লার্নিং চালান। এটি Smart Search-এর উপর নির্ভর করে",
"exclusion_pattern_description": "এক্সক্লুশন প্যাটার্ন ব্যবহার করে আপনি আপনার লাইব্রেরি স্ক্যান করার সময় ফাইল এবং ফোল্ডারগুলিকে উপেক্ষা করতে পারবেন। যদি আপনার এমন ফোল্ডার থাকে যেখানে এমন ফাইল থাকে যা আপনি আমদানি করতে চান না, যেমন RAW ফাইল।", "exclusion_pattern_description": "এক্সক্লুশন প্যাটার্ন ব্যবহার করে লাইব্রেরি স্ক্যান করার সময় নির্দিষ্ট ফাইল ফোল্ডার উপেক্ষা করা যায়। এটি তখনই উপকারী যখন কিছু ফোল্ডারে এমন ফাইল থাকে যা আপনি ইমপোর্ট করতে চান না, যেমন RAW ফাইল।",
"export_config_as_json_description": "বর্তমান সিস্টেম কনফিগারেশন একটি JSON ফাইল হিসেবে ডাউনলোড করুন", "export_config_as_json_description": "বর্তমান সিস্টেম কনফিগারেশনটিকে একটি JSON ফাইল হিসেবে ডাউনলোড করুন",
"external_libraries_page_description": "অ্যাডমিন external লাইব্রেরি পেজ", "external_libraries_page_description": "অ্যাডমিন এক্সটার্নাল লাইব্রেরি পেজ",
"face_detection": "মুখ নাক্তকরণ", "face_detection": "মুখ নাক্তকরণ",
"face_detection_description": "মেশিন লার্নিং ব্যবহার করে অ্যাসেটে থাকা মুখ/চেহারা গুলি সনাক্ত করুন। ভিডিও গুলির জন্য, শুধুমাত্র থাম্বনেইল বিবেচনা করা হয়। \"রিফ্রেশ\" (পুনরায়) সমস্ত অ্যাসেট প্রক্রিয়া করে। \"রিসেট\" করার মাধ্যমে অতিরিক্তভাবে সমস্ত বর্তমান মুখের ডেটা সাফ করে। \"অনুপস্থিত\" অ্যাসেটগুলিকে সারিবদ্ধ করে যা এখন প্রক্রিয়া করা হয়নি। নাক্ত করা মুখগুলিকে ফেসিয়াল রিকগনিশনের জন্য সারিবদ্ধ করা হবে, ফেসিয়াল ডিটেকশন সম্পূর্ণ হওয়ার পরে, বিদ্যমান বা নতুন ব্যক্তিদের মধ্যে গোষ্ঠীবদ্ধ করে।", "face_detection_description": "মেশিন লার্নিং ব্যবহার করে অ্যাসেটে থাকা মুখ/চেহারা নাক্ত করুন। ভিডিওর ক্ষেত্রে শুধুমাত্র থাম্বনেইল বিবেচনা করা হয়। \"রিফ্রেশ\" সব অ্যাসেট পুনরায় প্রক্রিয়া করে। \"রিসেট\" করলে বিদ্যমান সব মুখের ডেটা মুছে যায়। \"মিসিং\" ওই অ্যাসেটগুলকে সারিতে যোগ করে যাদেরকে এখন প্রক্রিয়া করা হয়নি। ফেস ডিটেকশন সম্পন্ন হলে শনাক্ত হওয়া মুখগুল ফেসিয়াল রিকগনিশনের জন্য সারিতে যোগ করা হবে এবং সেগুলোকে বিদ্যমান বা নতুন ব্যক্তিদের সাথে গ্রুপ করা হবে।",
"facial_recognition_job_description": "শনাক্ত করা মুখগুলিকে মানুষের মধ্যে গোষ্ঠীভুক্ত/গ্রুপ করুন। মুখ সনাক্তকরণ সম্পূর্ণ হওয়ার পরে এই ধাপটি চলে। \"রিসেট\" (পুনরায়) সমস্ত মুখকে ক্লাস্টার করে। \"অনুপস্থিত/মিসিং\" মুখগুলিকে সারিতে রাখে যেগুলো কোনও ব্যক্তিকে এসাইন/বরাদ্দ করা হয়নি।", "facial_recognition_job_description": "শনাক্ত করা মুখগুলিকে মানুষের মধ্যে গোষ্ঠীভুক্ত/গ্রুপ করুন। মুখ সনাক্তকরণ সম্পূর্ণ হওয়ার পরে এই ধাপটি চলে। \"রিসেট\" (পুনরায়) সমস্ত মুখকে ক্লাস্টার করে। \"অনুপস্থিত/মিসিং\" মুখগুলিকে সারিতে রাখে যেগুলো কোনও ব্যক্তিকে এসাইন/বরাদ্দ করা হয়নি।",
"failed_job_command": "কমান্ড {command} কাজের জন্য ব্যর্থ হয়েছে: {job}", "failed_job_command": "কমান্ড {command} কাজের জন্য ব্যর্থ হয়েছে: {job}",
"force_delete_user_warning": "সতর্কতা: এটি ব্যবহারকারী এবং সমস্ত সম্পদ অবিলম্বে সরিয়ে ফেলবে। এটি পূর্বাবস্থায় ফেরানো যাবে না এবং ফাইলগুলি পুনরুদ্ধার করা যাবে না।", "force_delete_user_warning": "সতর্কতা: এটি ব্যবহারকারী এবং সমস্ত সম্পদ অবিলম্বে সরিয়ে ফেলবে। এটি পূর্বাবস্থায় ফেরানো যাবে না এবং ফাইলগুলি পুনরুদ্ধার করা যাবে না।",
@@ -98,9 +98,9 @@
"image_fullsize_quality_description": "পূর্ণ-আকারের ছবির মান ১-১০০। উচ্চতর হলে ভালো, কিন্তু আরও বড় ফাইল তৈরি হয়।", "image_fullsize_quality_description": "পূর্ণ-আকারের ছবির মান ১-১০০। উচ্চতর হলে ভালো, কিন্তু আরও বড় ফাইল তৈরি হয়।",
"image_fullsize_title": "পূর্ণ-আকারের চিত্র সেটিংস", "image_fullsize_title": "পূর্ণ-আকারের চিত্র সেটিংস",
"image_prefer_embedded_preview": "এম্বেড করা প্রিভিউ পছন্দ করুন", "image_prefer_embedded_preview": "এম্বেড করা প্রিভিউ পছন্দ করুন",
"image_prefer_embedded_preview_setting_description": "যদি পাওয়া যায়, RAW ছবির ভেতরে থাকা প্রিভিউ ব্যবহার করুন। এতে কিছু ছবির রঙ আরও সঠিক দেখা যেতে পারে, তবে মান ক্যামেরার পর নির্ভর করে এবং ছবিতে বাড়তি কমপ্রেশন আর্টিফ্যাক্ট দেখা যেতে পারে।", "image_prefer_embedded_preview_setting_description": "RAW ছবিে থাকা এমবেডেড প্রিভিউগুলোকে ইমেজ প্রসেসিংয়ের ইনপুট হিসেবে ব্যবহার করুন যদি তা উপলভ্য থাকে। এতে কিছু ছবির রঙ আরও সঠিকভাবে পাওয়া যেতে পারে, তবে প্রিভিউয়ের মান ক্যামেরার পর নির্ভর করে এবং ছবিতে বেশি কমপ্রেশন আর্টিফ্যাক্ট থাকতে পারে।",
"image_prefer_wide_gamut": "প্রশস্ত পরিসর পছন্দ করুন", "image_prefer_wide_gamut": "প্রশস্ত পরিসর পছন্দ করুন",
"image_prefer_wide_gamut_setting_description": "থাম্বনেইলের জন্য Display P3 ব্যবহার করুন। এটি ওয়াইড কালারস্পেস ছবির উজ্জ্বলতা ও প্রাণবন্ত রঙ ভালোভাবে ধরে রাখে, তবে পুরনো ডিভাইস বা ব্রাউজারে ছবিগুলো ভিন্নভাবে দেখা যেতে পারে। sRGB ছবিগুলো রঙের পরিবর্তন এাতে sRGB হিসেবেই রাখা হবে।", "image_prefer_wide_gamut_setting_description": "থাম্বনেইলের জন্য Display P3 ব্যবহার করুন। এতে বিস্তীর্ণ কালারস্পেসের ছবিতে ছবির উজ্জ্বলতা ও প্রাণবন্ততা আরও ভালোভাবে বজায় থাকে। তবে পুরনো ডিভাইস বা পুরোনো ব্রাউজারের দোষে ছবিগুলো কিছুটা ভিন্নভাবে দেখা দিতে পারে। sRGB ছবিগুলোতে রঙের পরিবর্তন এড়াতে sRGB হিসেবেই রাখা হয়।",
"image_preview_description": "স্ট্রিপড মেটাডেটা সহ মাঝারি আকারের ছবি, একটি একক সম্পদ দেখার সময় এবং মেশিন লার্নিংয়ের জন্য ব্যবহৃত হয়", "image_preview_description": "স্ট্রিপড মেটাডেটা সহ মাঝারি আকারের ছবি, একটি একক সম্পদ দেখার সময় এবং মেশিন লার্নিংয়ের জন্য ব্যবহৃত হয়",
"image_preview_quality_description": "১-১০০ এর মধ্যে প্রিভিউ কোয়ালিটি। বেশি হলে ভালো, কিন্তু বড় ফাইল তৈরি হয় এবং অ্যাপের প্রতিক্রিয়াশীলতা কমাতে পারে। কম মান সেট করলে মেশিন লার্নিং কোয়ালিটির উপর প্রভাব পড়তে পারে।", "image_preview_quality_description": "১-১০০ এর মধ্যে প্রিভিউ কোয়ালিটি। বেশি হলে ভালো, কিন্তু বড় ফাইল তৈরি হয় এবং অ্যাপের প্রতিক্রিয়াশীলতা কমাতে পারে। কম মান সেট করলে মেশিন লার্নিং কোয়ালিটির উপর প্রভাব পড়তে পারে।",
"image_preview_title": "প্রিভিউ সেটিংস", "image_preview_title": "প্রিভিউ সেটিংস",
@@ -117,7 +117,7 @@
"import_config_from_json_description": "একটি JSON কনফিগ ফাইল আপলোড করে সিস্টেম কনফিগারেশন ইমপোর্ট করুন।", "import_config_from_json_description": "একটি JSON কনফিগ ফাইল আপলোড করে সিস্টেম কনফিগারেশন ইমপোর্ট করুন।",
"job_concurrency": "{job} কনকারেন্সি", "job_concurrency": "{job} কনকারেন্সি",
"job_created": "Job তৈরি হয়েছে", "job_created": "Job তৈরি হয়েছে",
"job_not_concurrency_safe": "এই কাজটি সমান্তরালভাবে চালানো নিরাপদ নয়", "job_not_concurrency_safe": "এই কাজটি সমান্তরালভাবে চালানো নিরাপদ নয়",
"job_settings": "কাজের সেটিংস", "job_settings": "কাজের সেটিংস",
"job_settings_description": "কাজের সমান্তরালতা পরিচালনা করুন", "job_settings_description": "কাজের সমান্তরালতা পরিচালনা করুন",
"jobs_delayed": "{jobCount, plural, other {# বিলম্বিত}}", "jobs_delayed": "{jobCount, plural, other {# বিলম্বিত}}",
@@ -137,20 +137,20 @@
"library_tasks_description": "নতুন এবং/অথবা পরিবর্তিত সম্পদের জন্য বহিরাগত লাইব্রেরি স্ক্যান করুন", "library_tasks_description": "নতুন এবং/অথবা পরিবর্তিত সম্পদের জন্য বহিরাগত লাইব্রেরি স্ক্যান করুন",
"library_updated": "আপডেটকৃত লাইব্রেরি।", "library_updated": "আপডেটকৃত লাইব্রেরি।",
"library_watching_enable_description": "ফাইল পরিবর্তনের জন্য বহিরাগত লাইব্রেরিগুলি দেখুন", "library_watching_enable_description": "ফাইল পরিবর্তনের জন্য বহিরাগত লাইব্রেরিগুলি দেখুন",
"library_watching_settings": "লাইব্রেরি দেখা (পরীক্ষামূলক)", "library_watching_settings": "লাইব্রেরি পর্যবেক্ষণ [পরীক্ষামূলক]",
"library_watching_settings_description": "পরিবর্তিত ফাইলগুলির জন্য স্বয়ংক্রিয়ভাবে নজর রাখুন", "library_watching_settings_description": "পরিবর্তিত ফাইলগুলির জন্য স্বয়ংক্রিয়ভাবে নজর রাখুন",
"logging_enable_description": "লগিং এনাবল/সক্ষম করুন", "logging_enable_description": "লগিং এনাবল/সক্ষম করুন",
"logging_level_description": "সক্রিয় থাকাকালীন, কোন লগ স্তর ব্যবহার করতে হবে।", "logging_level_description": "সক্রিয় থাকাকালীন, কোন লগ স্তর ব্যবহার করতে হবে।",
"logging_settings": "লগিং", "logging_settings": "লগিং",
"machine_learning_availability_checks": "প্রাপ্যতা পরীক্ষা", "machine_learning_availability_checks": "প্রাপ্যতা পরীক্ষা",
"machine_learning_availability_checks_description": "স্বয়ংক্রিয়ভাবে উপলব্ধ মেশিন লার্নিং সার্ভারগুলিনাক্ত করুন এবং পছন্দ করুন", "machine_learning_availability_checks_description": "উপলভ্য মেশিন লার্নিং সার্ভারগুল্বয়ংক্রিয়ভাবে শনাক্ত করে সেগুলোকে অগ্রাধিকার দিন",
"machine_learning_availability_checks_enabled": "প্রাপ্যতা পরীক্ষা সক্ষম করুন", "machine_learning_availability_checks_enabled": "প্রাপ্যতা পরীক্ষা সক্ষম করুন",
"machine_learning_availability_checks_interval": "চেক ব্যবধান", "machine_learning_availability_checks_interval": "চেক ব্যবধান",
"machine_learning_availability_checks_interval_description": "প্রাপ্যতা পরীক্ষাগুলির মধ্যে ব্যবধান মিলিসেকেন্ডে", "machine_learning_availability_checks_interval_description": "প্রাপ্যতা পরীক্ষাগুলির মধ্যে ব্যবধান মিলিসেকেন্ডে",
"machine_learning_availability_checks_timeout": "অনুরোধের সময়সীমা শেষ", "machine_learning_availability_checks_timeout": "অনুরোধের সময়সীমা শেষ",
"machine_learning_availability_checks_timeout_description": "প্রাপ্যতার পরীক্ষার জন্য মিলিসেকেন্ডে সময়সীমা।", "machine_learning_availability_checks_timeout_description": "প্রাপ্যতার পরীক্ষার জন্য মিলিসেকেন্ডে সময়সীমা।",
"machine_learning_clip_model": "CLIP মডেল", "machine_learning_clip_model": "CLIP মডেল",
"machine_learning_clip_model_description": "<link>এখানে</link> তালিকাভুক্ত একটি CLIP মডেলের নাম। মনে রাখবেন, মডেল পরিবর্তনের পর সব ছবির জন্য অবশ্যই Smart Search কাজটি আবার চালাতে হবে।", "machine_learning_clip_model_description": "<link>এখানে</link> তালিকাভুক্ত একটি CLIP মডেলের নাম। মনে রাখবেন, মডেল পরিবর্তন করলে সব ছবির জন্য 'Smart Search' জবটি পুনরায় চালাতে হবে।",
"machine_learning_duplicate_detection": "পুনরাবৃত্তি সনাক্তকরণ", "machine_learning_duplicate_detection": "পুনরাবৃত্তি সনাক্তকরণ",
"machine_learning_duplicate_detection_enabled": "পুনরাবৃত্তি শনাক্তকরণ চালু করুন", "machine_learning_duplicate_detection_enabled": "পুনরাবৃত্তি শনাক্তকরণ চালু করুন",
"machine_learning_duplicate_detection_enabled_description": "নিষ্ক্রিয় থাকলেও হুবহু একই সম্পদগুলোর ডুপ্লিকেট সরিয়ে ফেলা হবে।", "machine_learning_duplicate_detection_enabled_description": "নিষ্ক্রিয় থাকলেও হুবহু একই সম্পদগুলোর ডুপ্লিকেট সরিয়ে ফেলা হবে।",
@@ -192,7 +192,7 @@
"machine_learning_url_description": "মেশিন লার্নিং সার্ভারের URL। যদি একের বেশি URL প্রদান করা হয়, তবে একটি সফলভাবে সাড়া না দেওয়া পর্যন্ত প্রতিটি সার্ভারে এক এক করে চেষ্টা করা হবে (প্রথম থেকে শেষ ক্রমানুসারে)। যে সার্ভারগুলো সাড়া দেবে না, সেগুলো পুনরায় সচল হওয়া পর্যন্ত সাময়িকভাবে উপেক্ষা করা হবে।", "machine_learning_url_description": "মেশিন লার্নিং সার্ভারের URL। যদি একের বেশি URL প্রদান করা হয়, তবে একটি সফলভাবে সাড়া না দেওয়া পর্যন্ত প্রতিটি সার্ভারে এক এক করে চেষ্টা করা হবে (প্রথম থেকে শেষ ক্রমানুসারে)। যে সার্ভারগুলো সাড়া দেবে না, সেগুলো পুনরায় সচল হওয়া পর্যন্ত সাময়িকভাবে উপেক্ষা করা হবে।",
"maintenance_delete_backup": "ব্যাকআপ (Backup)মুছুন", "maintenance_delete_backup": "ব্যাকআপ (Backup)মুছুন",
"maintenance_delete_backup_description": "এই ফাইলটি চিরতরে মুছে ফেলা হবে।", "maintenance_delete_backup_description": "এই ফাইলটি চিরতরে মুছে ফেলা হবে।",
"maintenance_delete_error": "ব্যাকআপ মুছতে ব্যর্থ হয়েছে।", "maintenance_delete_error": "ব্যাকআপ মুছে ফেলতে ব্যর্থ হয়েছে।",
"maintenance_restore_backup": "ব্যাকআপ পুনরুদ্ধার(Restore) করুন", "maintenance_restore_backup": "ব্যাকআপ পুনরুদ্ধার(Restore) করুন",
"maintenance_restore_backup_description": "Immich মুছে ফেলা হবে এবং নির্বাচিত ব্যাকআপ থেকে পুনরুদ্ধার করা হবে। কার্যক্রম চালিয়ে যাওয়ার আগে একটি ব্যাকআপ তৈরি করা হবে।", "maintenance_restore_backup_description": "Immich মুছে ফেলা হবে এবং নির্বাচিত ব্যাকআপ থেকে পুনরুদ্ধার করা হবে। কার্যক্রম চালিয়ে যাওয়ার আগে একটি ব্যাকআপ তৈরি করা হবে।",
"maintenance_restore_backup_different_version": "এই ব্যাকআপটি Immich-এর একটি ভিন্ন সংস্করণের মাধ্যমে তৈরি করা হয়েছিল!", "maintenance_restore_backup_different_version": "এই ব্যাকআপটি Immich-এর একটি ভিন্ন সংস্করণের মাধ্যমে তৈরি করা হয়েছিল!",
@@ -220,7 +220,7 @@
"map_reverse_geocoding_settings": "রিভার্স জিওকোডিং সেটিংস (Reverse Geocoding Settings)", "map_reverse_geocoding_settings": "রিভার্স জিওকোডিং সেটিংস (Reverse Geocoding Settings)",
"map_settings": "মানচিত্র (Map)", "map_settings": "মানচিত্র (Map)",
"map_settings_description": "মানচিত্রের সেটিংস পরিচালনা করুন (Manage map settings)", "map_settings_description": "মানচিত্রের সেটিংস পরিচালনা করুন (Manage map settings)",
"map_style_description": "একটি style.json ম্যাপ থিমের URL (URL to a style.json map theme)", "map_style_description": "style.json ম্যাপ থিমের URL ঠিকানা",
"memory_cleanup_job": "মেমরি ক্লিনআপ (Memory cleanup)", "memory_cleanup_job": "মেমরি ক্লিনআপ (Memory cleanup)",
"memory_generate_job": "স্মৃতি তৈরি করা(Memory generation)", "memory_generate_job": "স্মৃতি তৈরি করা(Memory generation)",
"metadata_extraction_job": "মেটাডেটা এক্সট্র্যাক্ট করুন (Extract metadata)", "metadata_extraction_job": "মেটাডেটা এক্সট্র্যাক্ট করুন (Extract metadata)",
@@ -295,7 +295,7 @@
"search_jobs": "জব সার্চ করুন…", "search_jobs": "জব সার্চ করুন…",
"send_welcome_email": "স্বাগত ইমেল পাঠান", "send_welcome_email": "স্বাগত ইমেল পাঠান",
"server_external_domain_settings": "এক্সটার্নাল ডোমেইন (External Domain)", "server_external_domain_settings": "এক্সটার্নাল ডোমেইন (External Domain)",
"server_external_domain_settings_description": "পাবলিক শেয়ারিং লিঙ্কের জন্য ডোমেইন (http(s):// সহ)", "server_external_domain_settings_description": "বাইরের লিঙ্কের জন্য ব্যবহৃত ডোমেইন",
"server_public_users": "পাবলিক ইউজার (Public Users)", "server_public_users": "পাবলিক ইউজার (Public Users)",
"server_public_users_description": "শেয়ার করা অ্যালবামে কোনো ব্যবহারকারীকে যোগ করার সময় সমস্ত ব্যবহারকারীর (নাম এবং ইমেল) তালিকা দেখানো হয়। এটি নিষ্ক্রিয় (Disabled) করা হলে, ব্যবহারকারীর তালিকা শুধুমাত্র অ্যাডমিনদের জন্য উপলব্ধ হবে।", "server_public_users_description": "শেয়ার করা অ্যালবামে কোনো ব্যবহারকারীকে যোগ করার সময় সমস্ত ব্যবহারকারীর (নাম এবং ইমেল) তালিকা দেখানো হয়। এটি নিষ্ক্রিয় (Disabled) করা হলে, ব্যবহারকারীর তালিকা শুধুমাত্র অ্যাডমিনদের জন্য উপলব্ধ হবে।",
"server_settings": "সার্ভার সেটিংস (Server Settings)", "server_settings": "সার্ভার সেটিংস (Server Settings)",
@@ -317,9 +317,9 @@
"storage_template_migration_description": "পূর্বে আপলোড করা অ্যাসেটগুলোতে বর্তমান <link>{template}</link> প্রয়োগ করুন", "storage_template_migration_description": "পূর্বে আপলোড করা অ্যাসেটগুলোতে বর্তমান <link>{template}</link> প্রয়োগ করুন",
"storage_template_migration_info": "স্টোরেজ টেমপ্লেটটি সমস্ত এক্সটেনশনকে ছোট হাতের অক্ষরে (lowercase) রূপান্তর করবে। টেমপ্লেটের পরিবর্তনগুলো কেবল নতুন অ্যাসেটগুলোর ক্ষেত্রে প্রযোজ্য হবে। পূর্বে আপলোড করা অ্যাসেটগুলোতে এই টেমপ্লেটটি ভূতাপেক্ষভাবে (retroactively) প্রয়োগ করতে <link>{job}</link> রান করুন।", "storage_template_migration_info": "স্টোরেজ টেমপ্লেটটি সমস্ত এক্সটেনশনকে ছোট হাতের অক্ষরে (lowercase) রূপান্তর করবে। টেমপ্লেটের পরিবর্তনগুলো কেবল নতুন অ্যাসেটগুলোর ক্ষেত্রে প্রযোজ্য হবে। পূর্বে আপলোড করা অ্যাসেটগুলোতে এই টেমপ্লেটটি ভূতাপেক্ষভাবে (retroactively) প্রয়োগ করতে <link>{job}</link> রান করুন।",
"storage_template_migration_job": "স্টোরেজ টেমপ্লেট মাইগ্রেশন জব", "storage_template_migration_job": "স্টোরেজ টেমপ্লেট মাইগ্রেশন জব",
"storage_template_more_details": "এই ফিচারটি সম্পর্কে আরও বিস্তারিত জানতে, <template-link>Storage Template</template-link> এবং এর <implications-link>প্রভাবগুলো (implications)</implications-link> দেখুন", "storage_template_more_details": "এই ফিচার সম্পর্কে আরও বিস্তারিতভাবে জানতে <template-link>Storage Template</template-link> এবং এর <implications-link>প্রভাব</implications-link> দেখুন",
"storage_template_onboarding_description_v2": "এটি সক্রিয় থাকলে, ফিচারটি ব্যবহারকারীর নির্ধারিত টেমপ্লেট অনুযায়ী ফাইলগুলোকে স্বয়ংক্রিয়ভাবে অর্গানাইজ (Auto-organize) করবে। আরও তথ্যের জন্য অনুগ্রহ করে <link>ডকুমেন্টেশন</link> দেখুন।", "storage_template_onboarding_description_v2": "এটি সক্রিয় থাকলে, ফিচারটি ব্যবহারকারীর নির্ধারিত টেমপ্লেট অনুযায়ী ফাইলগুলোকে স্বয়ংক্রিয়ভাবে অর্গানাইজ (Auto-organize) করবে। আরও তথ্যের জন্য অনুগ্রহ করে <link>ডকুমেন্টেশন</link> দেখুন।",
"storage_template_path_length": "আনুমানিক পাথ লেন্থ লিমিট (Path length limit): <b>{length, number}</b>/{limit, number}", "storage_template_path_length": "আনুমানিকভাবে পথের দৈর্ঘ্যের সীমা: <b>{length, number}</b>/{limit, number}",
"storage_template_settings": "স্টোরেজ টেমপ্লেট (Storage Template)", "storage_template_settings": "স্টোরেজ টেমপ্লেট (Storage Template)",
"storage_template_settings_description": "আপলোড করা অ্যাসেটের ফোল্ডার স্ট্রাকচার এবং ফাইল নেম ম্যানেজ করুন", "storage_template_settings_description": "আপলোড করা অ্যাসেটের ফোল্ডার স্ট্রাকচার এবং ফাইল নেম ম্যানেজ করুন",
"storage_template_user_label": "<code>{label}</code> হলো ব্যবহারকারীর স্টোরেজ লেবেল (Storage Label)", "storage_template_user_label": "<code>{label}</code> হলো ব্যবহারকারীর স্টোরেজ লেবেল (Storage Label)",
@@ -336,6 +336,8 @@
"transcoding_accepted_audio_codecs_description": "কোন অডিও কোডেকগুলো ট্রানসকোড করার প্রয়োজন নেই তা নির্বাচন করুন। এটি শুধুমাত্র নির্দিষ্ট ট্রানসকোড পলিসির (transcode policies) জন্য ব্যবহৃত হয়।", "transcoding_accepted_audio_codecs_description": "কোন অডিও কোডেকগুলো ট্রানসকোড করার প্রয়োজন নেই তা নির্বাচন করুন। এটি শুধুমাত্র নির্দিষ্ট ট্রানসকোড পলিসির (transcode policies) জন্য ব্যবহৃত হয়।",
"transcoding_accepted_containers": "গ্রহণযোগ্য কন্টেইনারসমূহ (Accepted containers)" "transcoding_accepted_containers": "গ্রহণযোগ্য কন্টেইনারসমূহ (Accepted containers)"
}, },
"user_usage_stats": "অ্যাকাউন্ট ব্যবহারের পরিসংখ্যান",
"user_usage_stats_description": "অ্যাকাউন্ট ব্যবহারের পরিসংখ্যান দেখুন",
"yes": "হ্যাঁ", "yes": "হ্যাঁ",
"you_dont_have_any_shared_links": "আপনার কোনো শেয়ার করা লিঙ্ক নেই (You don't have any shared links)", "you_dont_have_any_shared_links": "আপনার কোনো শেয়ার করা লিঙ্ক নেই (You don't have any shared links)",
"your_wifi_name": "আপনার ওয়াই-ফাই এর নাম (Your Wi-Fi name)", "your_wifi_name": "আপনার ওয়াই-ফাই এর নাম (Your Wi-Fi name)",
+23 -13
View File
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mapeig de to", "transcoding_tone_mapping": "Mapeig de to",
"transcoding_tone_mapping_description": "Intenta preservar l'aspecte dels vídeos HDR quan es converteixen a SDR. Cada algorisme fa diferents compensacions pel color, el detall i la brillantor. Hable conserva els detalls, Mobius conserva el color i Reinhard conserva la brillantor.", "transcoding_tone_mapping_description": "Intenta preservar l'aspecte dels vídeos HDR quan es converteixen a SDR. Cada algorisme fa diferents compensacions pel color, el detall i la brillantor. Hable conserva els detalls, Mobius conserva el color i Reinhard conserva la brillantor.",
"transcoding_transcode_policy": "Política de transcodificació", "transcoding_transcode_policy": "Política de transcodificació",
"transcoding_transcode_policy_description": "Política sobre quan s'ha de transcodificar un vídeo. Els vídeos HDR sempre es transcodificaran (excepte si la transcodificació està desactivada).", "transcoding_transcode_policy_description": "Política sobre quan s'ha de transcodificar un vídeo. Els vídeos HDR i els vídeos amb un format de píxel diferent a YUV 4:2:0 sempre es transcodificaran (excepte si la transcodificació està desactivada).",
"transcoding_two_pass_encoding": "Codificació de dues passades", "transcoding_two_pass_encoding": "Codificació de dues passades",
"transcoding_two_pass_encoding_setting_description": "Transcodifica en dos passos per produir vídeos millor codificats. Quan la taxa de bits màxima està habilitada (necessari perquè funcioni amb H.264 i HEVC), aquest mode utilitza un interval de velocitat de bits basat en la taxa de bits màxima i ignora CRF. Per a VP9, es pot utilitzar CRF si la taxa de bits màxima està desactivada.", "transcoding_two_pass_encoding_setting_description": "Transcodifica en dos passos per produir vídeos millor codificats. Quan la taxa de bits màxima està habilitada (necessari perquè funcioni amb H.264 i HEVC), aquest mode utilitza un interval de velocitat de bits basat en la taxa de bits màxima i ignora CRF. Per a VP9, es pot utilitzar CRF si la taxa de bits màxima està desactivada.",
"transcoding_video_codec": "Còdec de video", "transcoding_video_codec": "Còdec de video",
@@ -872,7 +872,7 @@
"current_server_address": "Adreça actual del servidor", "current_server_address": "Adreça actual del servidor",
"custom_date": "Data personalitzada", "custom_date": "Data personalitzada",
"custom_locale": "Localització personalitzada", "custom_locale": "Localització personalitzada",
"custom_locale_description": "Format de dates i números segons la llengua i regió", "custom_locale_description": "Format de dates i números segons la llengua i regió seleccionades",
"custom_url": "URL personalitzada", "custom_url": "URL personalitzada",
"cutoff_date_description": "Manté fotos des de l'últim…", "cutoff_date_description": "Manté fotos des de l'últim…",
"cutoff_day": "{count, plural, one {dia} other {dies}}", "cutoff_day": "{count, plural, one {dia} other {dies}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Quantitat de dades EXIF", "deduplication_criteria_2": "Quantitat de dades EXIF",
"deduplication_info": "Informació de deduplicació", "deduplication_info": "Informació de deduplicació",
"deduplication_info_description": "Per preseleccionar recursos automàticament i eliminar els duplicats de manera massiva, ens fixem en:", "deduplication_info_description": "Per preseleccionar recursos automàticament i eliminar els duplicats de manera massiva, ens fixem en:",
"default_locale": "Localització predeterminada",
"default_locale_description": "Format de dates i números segons la configuració del navegador",
"delete": "Esborrar", "delete": "Esborrar",
"delete_action_confirmation_message": "Segur que vols eliminar aquest recurs? Aquesta acció el mourà a la paperera del servidor, i et preguntarà si el vols eliminar localment", "delete_action_confirmation_message": "Segur que vols eliminar aquest recurs? Aquesta acció el mourà a la paperera del servidor, i et preguntarà si el vols eliminar localment",
"delete_action_prompt": "{count} eliminats", "delete_action_prompt": "{count} eliminats",
@@ -1074,6 +1072,7 @@
"failed_to_update_notification_status": "Error en actualitzar l'estat de les notificacions", "failed_to_update_notification_status": "Error en actualitzar l'estat de les notificacions",
"incorrect_email_or_password": "Correu electrònic o contrasenya incorrectes", "incorrect_email_or_password": "Correu electrònic o contrasenya incorrectes",
"library_folder_already_exists": "Aquesta ruta d'importació ja existeix.", "library_folder_already_exists": "Aquesta ruta d'importació ja existeix.",
"page_not_found": "Pàgina no trobada",
"paths_validation_failed": "{paths, plural, one {# ruta} other {# rutes}} no ha pogut validar", "paths_validation_failed": "{paths, plural, one {# ruta} other {# rutes}} no ha pogut validar",
"profile_picture_transparent_pixels": "Les fotos de perfil no poden tenir píxels transparents. Per favor, feu zoom in, mogueu la imatge o ambdues.", "profile_picture_transparent_pixels": "Les fotos de perfil no poden tenir píxels transparents. Per favor, feu zoom in, mogueu la imatge o ambdues.",
"quota_higher_than_disk_size": "Heu establert una quota més gran que la mida de disc", "quota_higher_than_disk_size": "Heu establert una quota més gran que la mida de disc",
@@ -1218,6 +1217,7 @@
"filter_description": "Condicions per filtrar els actius de destinació", "filter_description": "Condicions per filtrar els actius de destinació",
"filter_people": "Filtra persones", "filter_people": "Filtra persones",
"filter_places": "Filtrar per llocs", "filter_places": "Filtrar per llocs",
"filter_tags": "Filtrar etiquetes",
"filters": "Filtres", "filters": "Filtres",
"find_them_fast": "Trobeu-los ràpidament pel nom amb la cerca", "find_them_fast": "Trobeu-los ràpidament pel nom amb la cerca",
"first": "Primer", "first": "Primer",
@@ -1808,9 +1808,8 @@
"rate_asset": "Valorar Recurs", "rate_asset": "Valorar Recurs",
"rating": "Valoració", "rating": "Valoració",
"rating_clear": "Esborrar valoració", "rating_clear": "Esborrar valoració",
"rating_count": "{count, plural, one {# estrella} other {# estrelles}}", "rating_count": "{count, plural, =0 {Unrated} one {# estrella} other {# estrelles}}",
"rating_description": "Mostrar la valoració EXIF al panell d'informació", "rating_description": "Mostrar la valoració EXIF al panell d'informació",
"rating_set": "Valoració establerta a {rating, plural, one {# estrella} other {# estrelles}}",
"reaction_options": "Opcions de reacció", "reaction_options": "Opcions de reacció",
"read_changelog": "Llegeix el registre de canvis", "read_changelog": "Llegeix el registre de canvis",
"readonly_mode_disabled": "Mode de només lectura desactivat", "readonly_mode_disabled": "Mode de només lectura desactivat",
@@ -1882,7 +1881,10 @@
"reset_pin_code_success": "Codi PIN reiniciat correctament", "reset_pin_code_success": "Codi PIN reiniciat correctament",
"reset_pin_code_with_password": "Sempre pots reiniciar el codi PIN amb la teva contrasenya", "reset_pin_code_with_password": "Sempre pots reiniciar el codi PIN amb la teva contrasenya",
"reset_sqlite": "Reiniciar base de dades SQLite", "reset_sqlite": "Reiniciar base de dades SQLite",
"reset_sqlite_confirmation": "Segur que vols reiniciar la base de dades SQLite? Hauràs de tancar la sessió i tornar a accedir per a resincronitzar les dades", "reset_sqlite_clear_app_data": "Netejar dada",
"reset_sqlite_confirmation": "Segur que vols esborrar les dades de l'aplicació? Això eliminarà tota la configuració i tancarà la sessió.",
"reset_sqlite_confirmation_note": "Nota: Hauràs de reiniciar l'app després d'eliminar.",
"reset_sqlite_done": "Les dades de l'app s'han netejat. Si us plau, reinicia l'app Immich i inicia sessió de nou.",
"reset_sqlite_success": "S'ha reiniciat la base de dades correctament", "reset_sqlite_success": "S'ha reiniciat la base de dades correctament",
"reset_to_default": "Restableix els valors predeterminats", "reset_to_default": "Restableix els valors predeterminats",
"resolution": "Resolució", "resolution": "Resolució",
@@ -1910,6 +1912,7 @@
"saved_settings": "Configuració guardada", "saved_settings": "Configuració guardada",
"say_something": "Digues quelcom", "say_something": "Digues quelcom",
"scaffold_body_error_occurred": "S'ha produït un error", "scaffold_body_error_occurred": "S'ha produït un error",
"scaffold_body_error_unrecoverable": "S'ha produït un error irrecuperable. Comparteix l'error i el rastre de la pila a Discord o GitHub perquè puguem ajudar-te. Si us ho aconsella, podeu esborrar les dades de l'aplicació a continuació.",
"scan": "Escaneja", "scan": "Escaneja",
"scan_all_libraries": "Escanejar totes les llibreries", "scan_all_libraries": "Escanejar totes les llibreries",
"scan_library": "Escaneja", "scan_library": "Escaneja",
@@ -1945,6 +1948,7 @@
"search_filter_ocr": "Buscar per OCR", "search_filter_ocr": "Buscar per OCR",
"search_filter_people_title": "Selecciona persones", "search_filter_people_title": "Selecciona persones",
"search_filter_star_rating": "Classificació per estrelles", "search_filter_star_rating": "Classificació per estrelles",
"search_filter_tags_title": "Seleccionar etiquetes",
"search_for": "Cercar", "search_for": "Cercar",
"search_for_existing_person": "Busca una persona existent", "search_for_existing_person": "Busca una persona existent",
"search_no_more_result": "No més resultats", "search_no_more_result": "No més resultats",
@@ -2024,6 +2028,9 @@
"set_profile_picture": "Establir imatge de perfil", "set_profile_picture": "Establir imatge de perfil",
"set_slideshow_to_fullscreen": "Mostra Diapositives en pantalla completa", "set_slideshow_to_fullscreen": "Mostra Diapositives en pantalla completa",
"set_stack_primary_asset": "Estableix com a actiu principal", "set_stack_primary_asset": "Estableix com a actiu principal",
"setting_image_navigation_enable_subtitle": "Si està activat, pots navegar a la imatge anterior/següent tocant la quarta part més esquerra/dreta de la pantalla.",
"setting_image_navigation_enable_title": "Toca per navegar",
"setting_image_navigation_title": "Navegació d'imatges",
"setting_image_viewer_help": "El visor de detalls carrega primer la miniatura petita, després carrega la vista prèvia de mida mitjana (si està habilitada), finalment carrega l'original (si està habilitada).", "setting_image_viewer_help": "El visor de detalls carrega primer la miniatura petita, després carrega la vista prèvia de mida mitjana (si està habilitada), finalment carrega l'original (si està habilitada).",
"setting_image_viewer_original_subtitle": "Activa per carregar la imatge en resolució original (molt gran!). Desactiva per reduir el consum de dades (tant de xarxa com de memòria cau).", "setting_image_viewer_original_subtitle": "Activa per carregar la imatge en resolució original (molt gran!). Desactiva per reduir el consum de dades (tant de xarxa com de memòria cau).",
"setting_image_viewer_original_title": "Carrega la imatge original", "setting_image_viewer_original_title": "Carrega la imatge original",
@@ -2191,20 +2198,20 @@
"support_and_feedback": "Suport i comentaris", "support_and_feedback": "Suport i comentaris",
"support_third_party_description": "La vostra instal·lació immich la va empaquetar un tercer. Els problemes que experimenteu poden ser causats per aquest paquet així que, si us plau, plantegeu els poblemes amb ells en primer lloc mitjançant els enllaços següents.", "support_third_party_description": "La vostra instal·lació immich la va empaquetar un tercer. Els problemes que experimenteu poden ser causats per aquest paquet així que, si us plau, plantegeu els poblemes amb ells en primer lloc mitjançant els enllaços següents.",
"supporter": "Contribuïdor", "supporter": "Contribuïdor",
"swap_merge_direction": "Canvia la direcció d'unió", "swap_merge_direction": "Intercanvia la direcció d'unió",
"sync": "Sincronitza", "sync": "Sincronitza",
"sync_albums": "Sincronitzar àlbums", "sync_albums": "Sincronitza àlbums",
"sync_albums_manual_subtitle": "Sincronitza tots els vídeos i fotos penjats amb els àlbums de còpia de seguretat seleccionats", "sync_albums_manual_subtitle": "Sincronitza tots els vídeos i fotos penjats amb els àlbums de còpia de seguretat seleccionats",
"sync_local": "Sincronitza Local", "sync_local": "Sincronitza localment",
"sync_remote": "Sincronitza Remot", "sync_remote": "Sincronitza remotament",
"sync_status": "Estat de sincronització", "sync_status": "Estat de la incronització",
"sync_status_subtitle": "Observa i administra el sistema de sincronització", "sync_status_subtitle": "Observa i administra el sistema de sincronització",
"sync_upload_album_setting_subtitle": "Creeu i pugeu les seves fotos i vídeos als àlbums seleccionats a Immich", "sync_upload_album_setting_subtitle": "Creeu i pugeu les seves fotos i vídeos als àlbums seleccionats a Immich",
"tag": "Etiqueta", "tag": "Etiqueta",
"tag_assets": "Etiquetar actius", "tag_assets": "Etiquetar actius",
"tag_created": "Etiqueta creada: {tag}", "tag_created": "Etiqueta creada: {tag}",
"tag_feature_description": "Exploreu fotos i vídeos agrupats per temes d'etiquetes lògiques", "tag_feature_description": "Exploreu fotos i vídeos agrupats per temes d'etiquetes lògiques",
"tag_not_found_question": "No trobeu una etiqueta? <link>Crear una nova etiqueta</link>", "tag_not_found_question": "No trobeu una etiqueta? <link>Crear una nova etiqueta.</link>",
"tag_people": "Etiquetar personas", "tag_people": "Etiquetar personas",
"tag_updated": "Etiqueta actualizada: {tag}", "tag_updated": "Etiqueta actualizada: {tag}",
"tagged_assets": "{count, plural, one {#Etiquetat} other {#Etiquetats}} {count, plural, one {# actiu} other {# actius}}", "tagged_assets": "{count, plural, one {#Etiquetat} other {#Etiquetats}} {count, plural, one {# actiu} other {# actius}}",
@@ -2302,6 +2309,7 @@
"unstack_action_prompt": "{count} sense apilar", "unstack_action_prompt": "{count} sense apilar",
"unstacked_assets_count": "No apilat {count, plural, one {# recurs} other {# recursos}}", "unstacked_assets_count": "No apilat {count, plural, one {# recurs} other {# recursos}}",
"unsupported_field_type": "Tipus de camp no suportat", "unsupported_field_type": "Tipus de camp no suportat",
"unsupported_file_type": "No es pot carregar el fitxer {file} perquè el seu tipus de fitxer {type} no és compatible.",
"untagged": "Sense etiqueta", "untagged": "Sense etiqueta",
"untitled_workflow": "Automatització sense títol", "untitled_workflow": "Automatització sense títol",
"up_next": "Pròxim", "up_next": "Pròxim",
@@ -2328,6 +2336,8 @@
"url": "URL", "url": "URL",
"usage": "Ús", "usage": "Ús",
"use_biometric": "Empra biometria", "use_biometric": "Empra biometria",
"use_browser_locale": "Fer servir la localització del navegador",
"use_browser_locale_description": "Formatejar dates, hores i números segons la llengua i regió del navegador",
"use_current_connection": "Utilitza la connexió actual", "use_current_connection": "Utilitza la connexió actual",
"use_custom_date_range": "Fes servir un rang de dates personalitzat", "use_custom_date_range": "Fes servir un rang de dates personalitzat",
"user": "Usuari", "user": "Usuari",
+24 -11
View File
@@ -40,7 +40,7 @@
"add_to_albums_count": "Přidat do alb ({count})", "add_to_albums_count": "Přidat do alb ({count})",
"add_to_bottom_bar": "Přidat do", "add_to_bottom_bar": "Přidat do",
"add_to_shared_album": "Přidat do sdíleného alba", "add_to_shared_album": "Přidat do sdíleného alba",
"add_upload_to_stack": "Přidat nahrané do zásobníku", "add_upload_to_stack": "Přidat nahrané do seskupení",
"add_url": "Přidat URL", "add_url": "Přidat URL",
"add_workflow_step": "Přidat krok pracovního postupu", "add_workflow_step": "Přidat krok pracovního postupu",
"added_to_archive": "Přidáno do archivu", "added_to_archive": "Přidáno do archivu",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mapování tónů", "transcoding_tone_mapping": "Mapování tónů",
"transcoding_tone_mapping_description": "Snaží se zachovat vzhled videí HDR při převodu na SDR. Každý algoritmus dělá různé kompromisy v oblasti barev, detailů a jasu. Hable zachovává detaily, Mobius zachovává barvy a Reinhard zachovává jas.", "transcoding_tone_mapping_description": "Snaží se zachovat vzhled videí HDR při převodu na SDR. Každý algoritmus dělá různé kompromisy v oblasti barev, detailů a jasu. Hable zachovává detaily, Mobius zachovává barvy a Reinhard zachovává jas.",
"transcoding_transcode_policy": "Zásady překódování", "transcoding_transcode_policy": "Zásady překódování",
"transcoding_transcode_policy_description": "Zásady, kdy má být video překódováno. Videa HDR budou překódována vždy (kromě případů, kdy je překódování zakázáno).", "transcoding_transcode_policy_description": "Zásady, kdy má být video překódováno. HDR videa a videa s jiným formátem pixelů než YUV 4:2:0 budou překódována vždy (kromě případů, kdy je překódování zakázáno).",
"transcoding_two_pass_encoding": "Dvouprůchodové kódování", "transcoding_two_pass_encoding": "Dvouprůchodové kódování",
"transcoding_two_pass_encoding_setting_description": "Překódováním ve dvou průchodech získáte lépe zakódovaná videa. Pokud je povolen maximální datový tok (nutný pro práci s H.264 a HEVC), tento režim používá rozsah datového toku založený na maximálním datovém toku a ignoruje CRF. U VP9 lze CRF použít, pokud je max. datový tok zakázán.", "transcoding_two_pass_encoding_setting_description": "Překódováním ve dvou průchodech získáte lépe zakódovaná videa. Pokud je povolen maximální datový tok (nutný pro práci s H.264 a HEVC), tento režim používá rozsah datového toku založený na maximálním datovém toku a ignoruje CRF. U VP9 lze CRF použít, pokud je max. datový tok zakázán.",
"transcoding_video_codec": "Video kodek", "transcoding_video_codec": "Video kodek",
@@ -872,7 +872,7 @@
"current_server_address": "Aktuální adresa serveru", "current_server_address": "Aktuální adresa serveru",
"custom_date": "Vlastní datum", "custom_date": "Vlastní datum",
"custom_locale": "Vlastní lokalizace", "custom_locale": "Vlastní lokalizace",
"custom_locale_description": "Formátovat datumy a čísla podle jazyka a oblasti", "custom_locale_description": "Formátovat datumy, časy a čísla podle vybraného jazyka a oblasti",
"custom_url": "Vlastní URL", "custom_url": "Vlastní URL",
"cutoff_date_description": "Zanechat fotografie a videa z posledních…", "cutoff_date_description": "Zanechat fotografie a videa z posledních…",
"cutoff_day": "{count, plural, one {den} few {dny} other {dnů}}", "cutoff_day": "{count, plural, one {den} few {dny} other {dnů}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Počet EXIF dat", "deduplication_criteria_2": "Počet EXIF dat",
"deduplication_info": "Informace o deduplikaci", "deduplication_info": "Informace o deduplikaci",
"deduplication_info_description": "Pro automatický předvýběr položek a hromadné odstranění duplicit se zohledňuje:", "deduplication_info_description": "Pro automatický předvýběr položek a hromadné odstranění duplicit se zohledňuje:",
"default_locale": "Výchozí jazyk",
"default_locale_description": "Formátovat datumy a čísla podle místního prostředí prohlížeče",
"delete": "Smazat", "delete": "Smazat",
"delete_action_confirmation_message": "Opravdu chcete odstranit tuto položku? Tato akce přesune položku do serverového koše a zeptá se vás, zda ji chcete odstranit lokálně", "delete_action_confirmation_message": "Opravdu chcete odstranit tuto položku? Tato akce přesune položku do serverového koše a zeptá se vás, zda ji chcete odstranit lokálně",
"delete_action_prompt": "{count} smazáno", "delete_action_prompt": "{count} smazáno",
@@ -1003,12 +1001,14 @@
"editor_close_without_save_title": "Zavřít editor?", "editor_close_without_save_title": "Zavřít editor?",
"editor_confirm_reset_all_changes": "Opravdu chcete zrušit všechny změny?", "editor_confirm_reset_all_changes": "Opravdu chcete zrušit všechny změny?",
"editor_discard_edits_confirm": "Zrušit úpravy", "editor_discard_edits_confirm": "Zrušit úpravy",
"editor_discard_edits_prompt": "Máte neuložené úpravy. Opravdu je chcete smazat?", "editor_discard_edits_prompt": "Máte neuložené úpravy. Opravdu je chcete zahodit?",
"editor_discard_edits_title": "Zrušit úpravy?", "editor_discard_edits_title": "Zrušit úpravy?",
"editor_edits_applied_error": "Nepodařilo se použít úpravy", "editor_edits_applied_error": "Nepodařilo se použít úpravy",
"editor_edits_applied_success": "Úpravy byly úspěšně provedeny", "editor_edits_applied_success": "Úpravy byly úspěšně provedeny",
"editor_flip_horizontal": "Otočit vodorovně", "editor_flip_horizontal": "Otočit vodorovně",
"editor_flip_vertical": "Otočit svisle", "editor_flip_vertical": "Otočit svisle",
"editor_handle_corner": "{corner, select, top_left {Vlevo nahoře} top_right {Vpravo nahoře} bottom_left {Vlevo dole} bottom_right {Vpravo dole} other {A}} rohová úchytka",
"editor_handle_edge": "{edge, select, top {Nahoře} bottom {Dole} left {Vlevo} right {Vpravo} other {An}}úchyt hrany",
"editor_orientation": "Orientace", "editor_orientation": "Orientace",
"editor_reset_all_changes": "Zrušit změny", "editor_reset_all_changes": "Zrušit změny",
"editor_rotate_left": "Otočit o 90° doleva", "editor_rotate_left": "Otočit o 90° doleva",
@@ -1074,6 +1074,7 @@
"failed_to_update_notification_status": "Nepodařilo se aktualizovat stav oznámení", "failed_to_update_notification_status": "Nepodařilo se aktualizovat stav oznámení",
"incorrect_email_or_password": "Nesprávný e-mail nebo heslo", "incorrect_email_or_password": "Nesprávný e-mail nebo heslo",
"library_folder_already_exists": "Tato importní cesta již existuje.", "library_folder_already_exists": "Tato importní cesta již existuje.",
"page_not_found": "Stránka nebyla nalezena",
"paths_validation_failed": "{paths, plural, one {# cesta neprošla} few {# cesty neprošly} other {# cest neprošlo}} kontrolou", "paths_validation_failed": "{paths, plural, one {# cesta neprošla} few {# cesty neprošly} other {# cest neprošlo}} kontrolou",
"profile_picture_transparent_pixels": "Profilové obrázky nemohou mít průhledné pixely. Obrázek si prosím zvětšete nebo posuňte.", "profile_picture_transparent_pixels": "Profilové obrázky nemohou mít průhledné pixely. Obrázek si prosím zvětšete nebo posuňte.",
"quota_higher_than_disk_size": "Nastavili jste kvótu vyšší, než je velikost disku", "quota_higher_than_disk_size": "Nastavili jste kvótu vyšší, než je velikost disku",
@@ -1218,6 +1219,7 @@
"filter_description": "Podmínky pro filtrování cílových položek", "filter_description": "Podmínky pro filtrování cílových položek",
"filter_people": "Filtrovat lidi", "filter_people": "Filtrovat lidi",
"filter_places": "Filtrovat místa", "filter_places": "Filtrovat místa",
"filter_tags": "Filtrovat značky",
"filters": "Filtry", "filters": "Filtry",
"find_them_fast": "Najděte je rychle vyhledáním jejich jména", "find_them_fast": "Najděte je rychle vyhledáním jejich jména",
"first": "První", "first": "První",
@@ -1649,6 +1651,7 @@
"only_favorites": "Pouze oblíbené", "only_favorites": "Pouze oblíbené",
"open": "Otevřít", "open": "Otevřít",
"open_calendar": "Otevřít kalendář", "open_calendar": "Otevřít kalendář",
"open_in_browser": "Otevřít v prohlížeči",
"open_in_map_view": "Otevřít v zobrazení mapy", "open_in_map_view": "Otevřít v zobrazení mapy",
"open_in_openstreetmap": "Otevřít v OpenStreetMap", "open_in_openstreetmap": "Otevřít v OpenStreetMap",
"open_the_search_filters": "Otevřít vyhledávací filtry", "open_the_search_filters": "Otevřít vyhledávací filtry",
@@ -1808,9 +1811,8 @@
"rate_asset": "Hodnotit položku", "rate_asset": "Hodnotit položku",
"rating": "Hodnocení hvězdičkami", "rating": "Hodnocení hvězdičkami",
"rating_clear": "Vyčistit hodnocení", "rating_clear": "Vyčistit hodnocení",
"rating_count": "{count, plural, one {# hvězdička} few {# hvězdičky} other {# hvězdček}}", "rating_count": "{count, plural, =0 {Nehodnoceno} one {# hvězdička} few {# hvězdičky} other {# hvězdček}}",
"rating_description": "Zobrazit EXIF hodnocení v informačním panelu", "rating_description": "Zobrazit EXIF hodnocení v informačním panelu",
"rating_set": "Hodnocení nastaveno na {rating, plural, one {# hvězdičku} few {# hvězdičky} other {# hvězdiček}}",
"reaction_options": "Možnosti reakce", "reaction_options": "Možnosti reakce",
"read_changelog": "Přečtěte si seznam změn", "read_changelog": "Přečtěte si seznam změn",
"readonly_mode_disabled": "Režim pouze pro čtení je deaktivován", "readonly_mode_disabled": "Režim pouze pro čtení je deaktivován",
@@ -1882,7 +1884,10 @@
"reset_pin_code_success": "PIN kód úspěšně resetován", "reset_pin_code_success": "PIN kód úspěšně resetován",
"reset_pin_code_with_password": "Svůj PIN kód můžete vždy resetovat pomocí hesla", "reset_pin_code_with_password": "Svůj PIN kód můžete vždy resetovat pomocí hesla",
"reset_sqlite": "Obnovit databázi SQLite", "reset_sqlite": "Obnovit databázi SQLite",
"reset_sqlite_confirmation": "Jste si jisti, že chcete obnovit databázi SQLite? Pro opětovnou synchronizaci dat se budete muset odhlásit a znovu přihlásit", "reset_sqlite_clear_app_data": "Vymazat data",
"reset_sqlite_confirmation": "Opravdu chcete vymazat data aplikace? Tím se odstraní všechna nastavení a odhlásíte se.",
"reset_sqlite_confirmation_note": "Poznámka: Po vymazání budete muset aplikaci restartovat.",
"reset_sqlite_done": "Data aplikace byla vymazána. Restartujte Immich a znovu se přihlaste.",
"reset_sqlite_success": "Obnovení SQLite databáze proběhlo úspěšně", "reset_sqlite_success": "Obnovení SQLite databáze proběhlo úspěšně",
"reset_to_default": "Obnovit výchozí nastavení", "reset_to_default": "Obnovit výchozí nastavení",
"resolution": "Rozlišení", "resolution": "Rozlišení",
@@ -1910,6 +1915,7 @@
"saved_settings": "Nastavení uloženo", "saved_settings": "Nastavení uloženo",
"say_something": "Napište něco", "say_something": "Napište něco",
"scaffold_body_error_occurred": "Došlo k chybě", "scaffold_body_error_occurred": "Došlo k chybě",
"scaffold_body_error_unrecoverable": "Došlo k neopravitelné chybě. Abychom vám mohli pomoci, sdělte nám prosím chybu a výpis zásobníku na Discordu nebo GitHubu. Pokud vám bylo doporučeno, můžete vymazat data aplikace níže.",
"scan": "Prohledat", "scan": "Prohledat",
"scan_all_libraries": "Prohledat všechny knihovny", "scan_all_libraries": "Prohledat všechny knihovny",
"scan_library": "Prohledat", "scan_library": "Prohledat",
@@ -1945,6 +1951,7 @@
"search_filter_ocr": "Hledat pomocí OCR", "search_filter_ocr": "Hledat pomocí OCR",
"search_filter_people_title": "Výběr lidí", "search_filter_people_title": "Výběr lidí",
"search_filter_star_rating": "Hodnocení hvězdičkami", "search_filter_star_rating": "Hodnocení hvězdičkami",
"search_filter_tags_title": "Vybrat značky",
"search_for": "Vyhledat", "search_for": "Vyhledat",
"search_for_existing_person": "Vyhledat existující osobu", "search_for_existing_person": "Vyhledat existující osobu",
"search_no_more_result": "Žádné další výsledky", "search_no_more_result": "Žádné další výsledky",
@@ -2024,6 +2031,9 @@
"set_profile_picture": "Nastavit profilový obrázek", "set_profile_picture": "Nastavit profilový obrázek",
"set_slideshow_to_fullscreen": "Nastavit prezentaci na celou obrazovku", "set_slideshow_to_fullscreen": "Nastavit prezentaci na celou obrazovku",
"set_stack_primary_asset": "Nastavit jako hlavní položku", "set_stack_primary_asset": "Nastavit jako hlavní položku",
"setting_image_navigation_enable_subtitle": "Pokud je zapnuto, budete moci přejít na předchozí/další obrázek klepnutím do levé/pravé čtvrtiny obrazovky.",
"setting_image_navigation_enable_title": "Klepněte pro navigaci",
"setting_image_navigation_title": "Navigace mezi obrázky",
"setting_image_viewer_help": "V prohlížeči detailů se nejprve načte malá miniatura, poté se načte náhled střední velikosti (je-li povolen) a nakonec se načte originál (je-li povolen).", "setting_image_viewer_help": "V prohlížeči detailů se nejprve načte malá miniatura, poté se načte náhled střední velikosti (je-li povolen) a nakonec se načte originál (je-li povolen).",
"setting_image_viewer_original_subtitle": "Umožňuje načíst původní obrázek v plném rozlišení (velký!). Zakažte pro snížení využití dat (v síti i v mezipaměti zařízení).", "setting_image_viewer_original_subtitle": "Umožňuje načíst původní obrázek v plném rozlišení (velký!). Zakažte pro snížení využití dat (v síti i v mezipaměti zařízení).",
"setting_image_viewer_original_title": "Načíst původní obrázek", "setting_image_viewer_original_title": "Načíst původní obrázek",
@@ -2302,6 +2312,7 @@
"unstack_action_prompt": "{count} seskupených zrušeno", "unstack_action_prompt": "{count} seskupených zrušeno",
"unstacked_assets_count": "{count, plural, one {Rozložená # položka} few {Rozložené # položky} other {Rozložených # položek}}", "unstacked_assets_count": "{count, plural, one {Rozložená # položka} few {Rozložené # položky} other {Rozložených # položek}}",
"unsupported_field_type": "Nepodporovaný typ pole", "unsupported_field_type": "Nepodporovaný typ pole",
"unsupported_file_type": "Soubor {file} nelze nahrát, protože jeho typ {type} není podporován.",
"untagged": "Neoznačeno", "untagged": "Neoznačeno",
"untitled_workflow": "Pracovní postup bez názvu", "untitled_workflow": "Pracovní postup bez názvu",
"up_next": "To je prozatím vše", "up_next": "To je prozatím vše",
@@ -2328,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Využití", "usage": "Využití",
"use_biometric": "Použít biometrické údaje", "use_biometric": "Použít biometrické údaje",
"use_browser_locale": "Použít jazyk prohlížeče",
"use_browser_locale_description": "Formátujte data, časy a čísla podle nastavení místního formátu vašeho prohlížeče",
"use_current_connection": "Použít aktuální připojení", "use_current_connection": "Použít aktuální připojení",
"use_custom_date_range": "Použít vlastní rozsah dat", "use_custom_date_range": "Použít vlastní rozsah dat",
"user": "Uživatel", "user": "Uživatel",
@@ -2378,9 +2391,9 @@
"view_similar_photos": "Zobrazit podobné fotky", "view_similar_photos": "Zobrazit podobné fotky",
"view_stack": "Zobrazit seskupení", "view_stack": "Zobrazit seskupení",
"view_user": "Zobrazit uživatele", "view_user": "Zobrazit uživatele",
"viewer_remove_from_stack": "Odstranit ze zásobníku", "viewer_remove_from_stack": "Odstranit ze seskupení",
"viewer_stack_use_as_main_asset": "Použít jako hlavní položku", "viewer_stack_use_as_main_asset": "Použít jako hlavní položku",
"viewer_unstack": "Zrušit zásobk", "viewer_unstack": "Zrušit seskupení",
"visibility_changed": "Viditelnost změněna u {count, plural, one {# osoby} few {# osob} other {# lidí}}", "visibility_changed": "Viditelnost změněna u {count, plural, one {# osoby} few {# osob} other {# lidí}}",
"visual": "Vizuální", "visual": "Vizuální",
"visual_builder": "Vizuální návrhář", "visual_builder": "Vizuální návrhář",
+26 -8
View File
@@ -311,7 +311,7 @@
"search_jobs": "Søg opgaver…", "search_jobs": "Søg opgaver…",
"send_welcome_email": "Send velkomst-email", "send_welcome_email": "Send velkomst-email",
"server_external_domain_settings": "Eksternt domæne", "server_external_domain_settings": "Eksternt domæne",
"server_external_domain_settings_description": "Domæne til offentligt delte links, inklusiv http(s)://", "server_external_domain_settings_description": "Domæne brugt til eksterne links",
"server_public_users": "Offentlige brugere", "server_public_users": "Offentlige brugere",
"server_public_users_description": "Alle brugere (navn og e-mail) vises, når en bruger tilføjes til delte album. Når den er deaktiveret, vil brugerlisten kun være tilgængelig for administratorbrugere.", "server_public_users_description": "Alle brugere (navn og e-mail) vises, når en bruger tilføjes til delte album. Når den er deaktiveret, vil brugerlisten kun være tilgængelig for administratorbrugere.",
"server_settings": "Serverindstillinger", "server_settings": "Serverindstillinger",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Tone-kortlægning", "transcoding_tone_mapping": "Tone-kortlægning",
"transcoding_tone_mapping_description": "Forsøger at bevare HDR-videoers udseende når konverteret til SDR. Hver algoritme har forskellige afvejninger af farve, detalje og lysstyrke. Hable bevarer farve og Reinhard bevarer lysstyrke.", "transcoding_tone_mapping_description": "Forsøger at bevare HDR-videoers udseende når konverteret til SDR. Hver algoritme har forskellige afvejninger af farve, detalje og lysstyrke. Hable bevarer farve og Reinhard bevarer lysstyrke.",
"transcoding_transcode_policy": "Transkodningspolitik", "transcoding_transcode_policy": "Transkodningspolitik",
"transcoding_transcode_policy_description": "Politik for hvornår en video skal transkodes. HDR videoer vil altid blive transkodet (bortset fra, hvis transkodning er slået fra).", "transcoding_transcode_policy_description": "Politik for hvornår en video skal transkodes. HDR videoer og videoer med en anden pixelformat end YUV 4:2:0 vil altid blive transkodet (bortset fra, hvis transkodning er slået fra).",
"transcoding_two_pass_encoding": "To-omgangsindkodning", "transcoding_two_pass_encoding": "To-omgangsindkodning",
"transcoding_two_pass_encoding_setting_description": "Transkoder af to omgange for at producere bedre indkodede videoer. Når den maksimale bitrate er slået til (som det kræver for at det fungerer med H.264 og HEVC), bruger denne tilstand en bitrateinterval baseret på den maksimale birate og ignorerer CRF. For VP9, kan CRF bruges hvis den maksimale bitrate er slået fra.", "transcoding_two_pass_encoding_setting_description": "Transkoder af to omgange for at producere bedre indkodede videoer. Når den maksimale bitrate er slået til (som det kræver for at det fungerer med H.264 og HEVC), bruger denne tilstand en bitrateinterval baseret på den maksimale birate og ignorerer CRF. For VP9, kan CRF bruges hvis den maksimale bitrate er slået fra.",
"transcoding_video_codec": "Videocodec", "transcoding_video_codec": "Videocodec",
@@ -794,6 +794,11 @@
"color": "Farve", "color": "Farve",
"color_theme": "Farvetema", "color_theme": "Farvetema",
"command": "Kommando", "command": "Kommando",
"command_palette_prompt": "Find hurtigt sider, handlinger eller kommandoer",
"command_palette_to_close": "for at lukke",
"command_palette_to_navigate": "for at indtaste",
"command_palette_to_select": "for at vælge",
"command_palette_to_show_all": "for at vise alle",
"comment_deleted": "Kommentar slettet", "comment_deleted": "Kommentar slettet",
"comment_options": "Kommentarindstillinger", "comment_options": "Kommentarindstillinger",
"comments_and_likes": "Kommentarer og likes", "comments_and_likes": "Kommentarer og likes",
@@ -867,7 +872,7 @@
"current_server_address": "Nuværende serveraddresse", "current_server_address": "Nuværende serveraddresse",
"custom_date": "Brugerdefineret dato", "custom_date": "Brugerdefineret dato",
"custom_locale": "Brugerdefineret lokale", "custom_locale": "Brugerdefineret lokale",
"custom_locale_description": "Formatér datoer og tal baseret på sproget og regionen", "custom_locale_description": "Formatér datoer, klokkeslæt og tal baseret på det valgte sprog og den valgte region",
"custom_url": "Tilpasset URL", "custom_url": "Tilpasset URL",
"cutoff_date_description": "Behold fotos fra den sidste…", "cutoff_date_description": "Behold fotos fra den sidste…",
"cutoff_day": "{count, plural, one {dag} other {dage}}", "cutoff_day": "{count, plural, one {dag} other {dage}}",
@@ -890,8 +895,6 @@
"deduplication_criteria_2": "Antal EXIF-data", "deduplication_criteria_2": "Antal EXIF-data",
"deduplication_info": "Deduplikerings info", "deduplication_info": "Deduplikerings info",
"deduplication_info_description": "For automatisk at forudvælge emner og fjerne dubletter i bulk ser vi på:", "deduplication_info_description": "For automatisk at forudvælge emner og fjerne dubletter i bulk ser vi på:",
"default_locale": "Standardlokalitet",
"default_locale_description": "Formatér datoer og tal baseret på din browsers regions indstillinger",
"delete": "Slet", "delete": "Slet",
"delete_action_confirmation_message": "Er du sikker på, at du vil slette dette objekt? Denne handling vil flytte objektet til serverens papirkurv, og vil spørge dig, om du vil slette den lokalt", "delete_action_confirmation_message": "Er du sikker på, at du vil slette dette objekt? Denne handling vil flytte objektet til serverens papirkurv, og vil spørge dig, om du vil slette den lokalt",
"delete_action_prompt": "{count} slettet", "delete_action_prompt": "{count} slettet",
@@ -1069,6 +1072,7 @@
"failed_to_update_notification_status": "Kunne ikke uploade notifikations status", "failed_to_update_notification_status": "Kunne ikke uploade notifikations status",
"incorrect_email_or_password": "Forkert email eller kodeord", "incorrect_email_or_password": "Forkert email eller kodeord",
"library_folder_already_exists": "Denne import sti findes allerede.", "library_folder_already_exists": "Denne import sti findes allerede.",
"page_not_found": "Siden blev ikke fundet :/",
"paths_validation_failed": "{paths, plural, one {# sti} other {# stier}} slog fejl ved validering", "paths_validation_failed": "{paths, plural, one {# sti} other {# stier}} slog fejl ved validering",
"profile_picture_transparent_pixels": "Profilbilleder kan ikke have gennemsigtige pixels. Zoom venligst ind og/eller flyt billedet.", "profile_picture_transparent_pixels": "Profilbilleder kan ikke have gennemsigtige pixels. Zoom venligst ind og/eller flyt billedet.",
"quota_higher_than_disk_size": "Du har sat en kvote der er større end disken", "quota_higher_than_disk_size": "Du har sat en kvote der er større end disken",
@@ -1168,6 +1172,7 @@
"exif_bottom_sheet_people": "PERSONER", "exif_bottom_sheet_people": "PERSONER",
"exif_bottom_sheet_person_add_person": "Tilføj navn", "exif_bottom_sheet_person_add_person": "Tilføj navn",
"exit_slideshow": "Afslut slideshow", "exit_slideshow": "Afslut slideshow",
"expand": "Udvid",
"expand_all": "Udvid alle", "expand_all": "Udvid alle",
"experimental_settings_new_asset_list_subtitle": "Under udarbejdelse", "experimental_settings_new_asset_list_subtitle": "Under udarbejdelse",
"experimental_settings_new_asset_list_title": "Aktiver eksperimentelt fotogitter", "experimental_settings_new_asset_list_title": "Aktiver eksperimentelt fotogitter",
@@ -1212,6 +1217,7 @@
"filter_description": "Betingelser for filtrering af valgte mediefiler", "filter_description": "Betingelser for filtrering af valgte mediefiler",
"filter_people": "Filtrér personer", "filter_people": "Filtrér personer",
"filter_places": "Filtrer steder", "filter_places": "Filtrer steder",
"filter_tags": "Filtrer tags",
"filters": "Filtre", "filters": "Filtre",
"find_them_fast": "Find dem hurtigt med søgning via navn", "find_them_fast": "Find dem hurtigt med søgning via navn",
"first": "Første", "first": "Første",
@@ -1642,6 +1648,7 @@
"online": "Online", "online": "Online",
"only_favorites": "Kun favoritter", "only_favorites": "Kun favoritter",
"open": "Åben", "open": "Åben",
"open_calendar": "Åbn kalender",
"open_in_map_view": "Åben i kortvisning", "open_in_map_view": "Åben i kortvisning",
"open_in_openstreetmap": "Åben i OpenStreetMap", "open_in_openstreetmap": "Åben i OpenStreetMap",
"open_the_search_filters": "Åbn søgefiltre", "open_the_search_filters": "Åbn søgefiltre",
@@ -1801,9 +1808,8 @@
"rate_asset": "Vurder filer", "rate_asset": "Vurder filer",
"rating": "Stjernebedømmelse", "rating": "Stjernebedømmelse",
"rating_clear": "Nulstil vurdering", "rating_clear": "Nulstil vurdering",
"rating_count": "{count, plural, one {# stjerne} other {# stjerner}}", "rating_count": "{count, plural, =0 {Unrated} one {# stjerne} other {# stjerner}}",
"rating_description": "Vis EXIF-klassificeringen i infopanelet", "rating_description": "Vis EXIF-klassificeringen i infopanelet",
"rating_set": "Vurdering sat til {rating, plural, one {# stjerne} other {# stjerner}}",
"reaction_options": "Reaktionsindstillinger", "reaction_options": "Reaktionsindstillinger",
"read_changelog": "Læs ændringslog", "read_changelog": "Læs ændringslog",
"readonly_mode_disabled": "Skrivebeskyttet tilstand deaktiveret", "readonly_mode_disabled": "Skrivebeskyttet tilstand deaktiveret",
@@ -1875,7 +1881,10 @@
"reset_pin_code_success": "PIN-koden er Nulstillet", "reset_pin_code_success": "PIN-koden er Nulstillet",
"reset_pin_code_with_password": "Du kan altid nulstille din PIN-kode med dit password", "reset_pin_code_with_password": "Du kan altid nulstille din PIN-kode med dit password",
"reset_sqlite": "Reset SQLite Databasen", "reset_sqlite": "Reset SQLite Databasen",
"reset_sqlite_confirmation": "Er du sikker på, at du vil nulstille SQLite databasen? Du er nødt til at logge ud og ind igen for at gensynkronisere dine data", "reset_sqlite_clear_app_data": "Ryd data",
"reset_sqlite_confirmation": "Er du sikker på, at du vil ryde app dataen? Dette vil fjerne alle settings og logge dig ud.",
"reset_sqlite_confirmation_note": "Bemærk: Du skal genstarte appen efter rydning.",
"reset_sqlite_done": "Appdata er blevet slettet. Genstart Immich og log ind igen.",
"reset_sqlite_success": "Vellykket reset af SQLite databasen", "reset_sqlite_success": "Vellykket reset af SQLite databasen",
"reset_to_default": "Nulstil til standard", "reset_to_default": "Nulstil til standard",
"resolution": "Opløsning", "resolution": "Opløsning",
@@ -1903,6 +1912,7 @@
"saved_settings": "Gemte indstillinger", "saved_settings": "Gemte indstillinger",
"say_something": "Skriv noget", "say_something": "Skriv noget",
"scaffold_body_error_occurred": "Der opstod en fejl", "scaffold_body_error_occurred": "Der opstod en fejl",
"scaffold_body_error_unrecoverable": "Der er opstået en uoprettelig fejl. Del venligst fejlen og stack trace på Discord eller GitHub, så vi kan hjælpe. Hvis du bliver bedt om det, kan du rydde appdataene nedenfor.",
"scan": "Skan", "scan": "Skan",
"scan_all_libraries": "Skan alle biblioteker", "scan_all_libraries": "Skan alle biblioteker",
"scan_library": "Skan", "scan_library": "Skan",
@@ -1938,6 +1948,7 @@
"search_filter_ocr": "Søg via OCR", "search_filter_ocr": "Søg via OCR",
"search_filter_people_title": "Vælg personer", "search_filter_people_title": "Vælg personer",
"search_filter_star_rating": "Stjerne Vurdering", "search_filter_star_rating": "Stjerne Vurdering",
"search_filter_tags_title": "Vælg tags",
"search_for": "Søg efter", "search_for": "Søg efter",
"search_for_existing_person": "Søg efter eksisterende person", "search_for_existing_person": "Søg efter eksisterende person",
"search_no_more_result": "Ikke flere resultater", "search_no_more_result": "Ikke flere resultater",
@@ -2017,6 +2028,9 @@
"set_profile_picture": "Indstil profilbillede", "set_profile_picture": "Indstil profilbillede",
"set_slideshow_to_fullscreen": "Sæt diasshow til fuldskærmsvisning", "set_slideshow_to_fullscreen": "Sæt diasshow til fuldskærmsvisning",
"set_stack_primary_asset": "Angiv som primært billede", "set_stack_primary_asset": "Angiv som primært billede",
"setting_image_navigation_enable_subtitle": "Hvis aktiveret, kan du navigere til det forrige/næste billede ved at trykke på den yderste venstre/højre fjerdedel af skærmen.",
"setting_image_navigation_enable_title": "Tryk for at navigere",
"setting_image_navigation_title": "Billednavigation",
"setting_image_viewer_help": "Detaljeret visning indlæser miniaturebilleder først. Herefter indlæses mediumstørrelse forhåndsvisning af billedet (hvis dette er slået til), for til sidst at vise originalen (hvis dette er slået til).", "setting_image_viewer_help": "Detaljeret visning indlæser miniaturebilleder først. Herefter indlæses mediumstørrelse forhåndsvisning af billedet (hvis dette er slået til), for til sidst at vise originalen (hvis dette er slået til).",
"setting_image_viewer_original_subtitle": "Slå indlæsning af originalbillede i fuld størrelse til (stort!). Deaktiver for at reducere dataforbruget (både på netværket og for enhedscache).", "setting_image_viewer_original_subtitle": "Slå indlæsning af originalbillede i fuld størrelse til (stort!). Deaktiver for at reducere dataforbruget (både på netværket og for enhedscache).",
"setting_image_viewer_original_title": "Indlæs originalbillede", "setting_image_viewer_original_title": "Indlæs originalbillede",
@@ -2183,6 +2197,7 @@
"support": "Support", "support": "Support",
"support_and_feedback": "Support og feedback", "support_and_feedback": "Support og feedback",
"support_third_party_description": "Din Immich-installation blev sammensat af en tredjepart. Problemer, du oplever, kan være forårsaget af denne udvikler, så rejs venligst problemer med dem i første omgang ved at bruge nedenstående links.", "support_third_party_description": "Din Immich-installation blev sammensat af en tredjepart. Problemer, du oplever, kan være forårsaget af denne udvikler, så rejs venligst problemer med dem i første omgang ved at bruge nedenstående links.",
"supporter": "Supporter",
"swap_merge_direction": "Byt retning for sammenfletning", "swap_merge_direction": "Byt retning for sammenfletning",
"sync": "Synkronisér", "sync": "Synkronisér",
"sync_albums": "Synkroniser albummer", "sync_albums": "Synkroniser albummer",
@@ -2294,6 +2309,7 @@
"unstack_action_prompt": "{count} ustakket", "unstack_action_prompt": "{count} ustakket",
"unstacked_assets_count": "Ikke-stablet {count, plural, one {# aktiv} other {# aktiver}}", "unstacked_assets_count": "Ikke-stablet {count, plural, one {# aktiv} other {# aktiver}}",
"unsupported_field_type": "Ikke-understøttet felttype", "unsupported_field_type": "Ikke-understøttet felttype",
"unsupported_file_type": "Filen {file} kan ikke uploades, fordi filtypen {type} ikke understøttes.",
"untagged": "Umærket", "untagged": "Umærket",
"untitled_workflow": "Unavngivet arbejdsgang", "untitled_workflow": "Unavngivet arbejdsgang",
"up_next": "Næste", "up_next": "Næste",
@@ -2320,6 +2336,8 @@
"url": "URL", "url": "URL",
"usage": "Forbrug", "usage": "Forbrug",
"use_biometric": "Brug biometrisk", "use_biometric": "Brug biometrisk",
"use_browser_locale": "Brug browserens lokalitet",
"use_browser_locale_description": "Formatér datoer, klokkeslæt og tal baseret på din browsers lokalitet",
"use_current_connection": "Brug nuværende forbindelse", "use_current_connection": "Brug nuværende forbindelse",
"use_custom_date_range": "Brug tilpasset datointerval i stedet", "use_custom_date_range": "Brug tilpasset datointerval i stedet",
"user": "Bruger", "user": "Bruger",
+36 -15
View File
@@ -77,7 +77,7 @@
"confirm_user_pin_code_reset": "Bist du sicher, dass du den PIN-Code von {user} zurücksetzen möchtest?", "confirm_user_pin_code_reset": "Bist du sicher, dass du den PIN-Code von {user} zurücksetzen möchtest?",
"copy_config_to_clipboard_description": "Kopieren Sie die aktuelle Systemkonfiguration als JSON-Objekt in die Zwischenablage", "copy_config_to_clipboard_description": "Kopieren Sie die aktuelle Systemkonfiguration als JSON-Objekt in die Zwischenablage",
"create_job": "Aufgabe erstellen", "create_job": "Aufgabe erstellen",
"cron_expression": "Cron-Zeitangabe", "cron_expression": "Cron-Ausdruck",
"cron_expression_description": "Setze das Scanintervall im Cron-Format. Hilfe mit dem Format bietet dir dabei z. B. der <link>Crontab Guru</link>", "cron_expression_description": "Setze das Scanintervall im Cron-Format. Hilfe mit dem Format bietet dir dabei z. B. der <link>Crontab Guru</link>",
"cron_expression_presets": "Vorlagen für Cron-Zeitangabe", "cron_expression_presets": "Vorlagen für Cron-Zeitangabe",
"disable_login": "Login deaktivieren", "disable_login": "Login deaktivieren",
@@ -311,7 +311,7 @@
"search_jobs": "Suchaufgaben…", "search_jobs": "Suchaufgaben…",
"send_welcome_email": "Begrüssungsmail senden", "send_welcome_email": "Begrüssungsmail senden",
"server_external_domain_settings": "Externe Domain", "server_external_domain_settings": "Externe Domain",
"server_external_domain_settings_description": "Domäne für öffentlich freigegebene Links, einschließlich http(s)://", "server_external_domain_settings_description": "Für externe Links verwendete Domäne",
"server_public_users": "Öffentliche Benutzer", "server_public_users": "Öffentliche Benutzer",
"server_public_users_description": "Beim Hinzufügen eines Benutzers zu freigegebenen Alben werden alle Benutzer (Name und E-Mail) aufgelistet. Wenn diese Option deaktiviert ist, steht die Benutzerliste nur Administratoren zur Verfügung.", "server_public_users_description": "Beim Hinzufügen eines Benutzers zu freigegebenen Alben werden alle Benutzer (Name und E-Mail) aufgelistet. Wenn diese Option deaktiviert ist, steht die Benutzerliste nur Administratoren zur Verfügung.",
"server_settings": "Servereinstellungen", "server_settings": "Servereinstellungen",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Farbton-Mapping", "transcoding_tone_mapping": "Farbton-Mapping",
"transcoding_tone_mapping_description": "Versucht, das Aussehen von HDR-Videos bei der Konvertierung in SDR beizubehalten. Jeder Algorithmus geht unterschiedliche Kompromisse bei Farbe, Details und Helligkeit ein. Hable bewahrt Details, Mobius bewahrt die Farbe und Reinhard bewahrt die Helligkeit.", "transcoding_tone_mapping_description": "Versucht, das Aussehen von HDR-Videos bei der Konvertierung in SDR beizubehalten. Jeder Algorithmus geht unterschiedliche Kompromisse bei Farbe, Details und Helligkeit ein. Hable bewahrt Details, Mobius bewahrt die Farbe und Reinhard bewahrt die Helligkeit.",
"transcoding_transcode_policy": "Transcodierungsrichtlinie", "transcoding_transcode_policy": "Transcodierungsrichtlinie",
"transcoding_transcode_policy_description": "Richtlinie, wann ein Video transkodiert werden soll. HDR-Videos werden immer transkodiert (außer wenn die Transkodierung deaktiviert ist).", "transcoding_transcode_policy_description": "Richtlinie, wann ein Video transkodiert werden soll. HDR-Videos und Videos ohne das Format YUV 4:2:0 werden immer transkodiert (außer wenn die Transkodierung deaktiviert ist).",
"transcoding_two_pass_encoding": "Two-Pass Codierung", "transcoding_two_pass_encoding": "Two-Pass Codierung",
"transcoding_two_pass_encoding_setting_description": "Führt eine Transkodierung in zwei Durchgängen durch, um besser kodierte Videos zu erzeugen. Wenn die maximale Bitrate aktiviert ist (erforderlich für die Verwendung mit H.264 und HEVC), verwendet dieser Modus einen Bitratenbereich, der auf der maximalen Bitrate basiert, und ignoriert CRF. Für VP9 kann CRF verwendet werden, wenn die maximale Bitrate deaktiviert ist.", "transcoding_two_pass_encoding_setting_description": "Führt eine Transkodierung in zwei Durchgängen durch, um besser kodierte Videos zu erzeugen. Wenn die maximale Bitrate aktiviert ist (erforderlich für die Verwendung mit H.264 und HEVC), verwendet dieser Modus einen Bitratenbereich, der auf der maximalen Bitrate basiert, und ignoriert CRF. Für VP9 kann CRF verwendet werden, wenn die maximale Bitrate deaktiviert ist.",
"transcoding_video_codec": "Video-Codec", "transcoding_video_codec": "Video-Codec",
@@ -697,8 +697,8 @@
"birthdate_set_description": "Das Geburtsdatum wird verwendet, um das Alter dieser Person zum Zeitpunkt eines Fotos zu berechnen.", "birthdate_set_description": "Das Geburtsdatum wird verwendet, um das Alter dieser Person zum Zeitpunkt eines Fotos zu berechnen.",
"blurred_background": "Unscharfer Hintergrund", "blurred_background": "Unscharfer Hintergrund",
"bugs_and_feature_requests": "Fehler & Verbesserungsvorschläge", "bugs_and_feature_requests": "Fehler & Verbesserungsvorschläge",
"build": "Build", "build": "Erstelle",
"build_image": "Build Abbild", "build_image": "Bild erstellen",
"bulk_delete_duplicates_confirmation": "Bist du sicher, dass du {count, plural, one {# duplizierte Datei} other {# duplizierte Dateien gemeinsam}} löschen möchtest? Dabei wird die größte Datei jeder Gruppe behalten und alle anderen Duplikate endgültig gelöscht. Diese Aktion kann nicht rückgängig gemacht werden!", "bulk_delete_duplicates_confirmation": "Bist du sicher, dass du {count, plural, one {# duplizierte Datei} other {# duplizierte Dateien gemeinsam}} löschen möchtest? Dabei wird die größte Datei jeder Gruppe behalten und alle anderen Duplikate endgültig gelöscht. Diese Aktion kann nicht rückgängig gemacht werden!",
"bulk_keep_duplicates_confirmation": "Bist du sicher, dass du {count, plural, one {# duplizierte Datei} other {# duplizierte Dateien}} behalten möchtest? Dies wird alle Duplikat-Gruppen auflösen ohne etwas zu löschen.", "bulk_keep_duplicates_confirmation": "Bist du sicher, dass du {count, plural, one {# duplizierte Datei} other {# duplizierte Dateien}} behalten möchtest? Dies wird alle Duplikat-Gruppen auflösen ohne etwas zu löschen.",
"bulk_trash_duplicates_confirmation": "Bist du sicher, dass du {count, plural, one {# duplizierte Datei} other {# duplizierte Dateien gemeinsam}} in den Papierkorb verschieben möchtest? Dies wird die größte Datei jeder Gruppe behalten und alle anderen Duplikate in den Papierkorb verschieben.", "bulk_trash_duplicates_confirmation": "Bist du sicher, dass du {count, plural, one {# duplizierte Datei} other {# duplizierte Dateien gemeinsam}} in den Papierkorb verschieben möchtest? Dies wird die größte Datei jeder Gruppe behalten und alle anderen Duplikate in den Papierkorb verschieben.",
@@ -794,6 +794,11 @@
"color": "Farbe", "color": "Farbe",
"color_theme": "Farb-Theme", "color_theme": "Farb-Theme",
"command": "Befehl", "command": "Befehl",
"command_palette_prompt": "Finde schnell Seiten, Aktionen oder Befehle",
"command_palette_to_close": "Schließen",
"command_palette_to_navigate": "eingeben",
"command_palette_to_select": "Auswählen",
"command_palette_to_show_all": "Alle anzeigen",
"comment_deleted": "Kommentar gelöscht", "comment_deleted": "Kommentar gelöscht",
"comment_options": "Kommentaroptionen", "comment_options": "Kommentaroptionen",
"comments_and_likes": "Kommentare & Likes", "comments_and_likes": "Kommentare & Likes",
@@ -866,8 +871,8 @@
"current_pin_code": "Aktueller PIN-Code", "current_pin_code": "Aktueller PIN-Code",
"current_server_address": "Aktuelle Serveradresse", "current_server_address": "Aktuelle Serveradresse",
"custom_date": "Benutzerdefiniertes Datum", "custom_date": "Benutzerdefiniertes Datum",
"custom_locale": "Benutzerdefinierte Sprache", "custom_locale": "Benutzerdefiniertes Gebietsschema",
"custom_locale_description": "Datumsangaben und Zahlen je nach Sprache und Land formatieren", "custom_locale_description": "Datumsangaben, Uhrzeiten und Zahlen je nach Sprache und Land formatieren",
"custom_url": "Benutzerdefinierte URL", "custom_url": "Benutzerdefinierte URL",
"cutoff_date_description": "Behalte Fotos der letzten…", "cutoff_date_description": "Behalte Fotos der letzten…",
"cutoff_day": "{count, plural, one {Tag} other {Tage}}", "cutoff_day": "{count, plural, one {Tag} other {Tage}}",
@@ -890,8 +895,6 @@
"deduplication_criteria_2": "Anzahl der EXIF-Daten", "deduplication_criteria_2": "Anzahl der EXIF-Daten",
"deduplication_info": "Deduplizierungsinformationen", "deduplication_info": "Deduplizierungsinformationen",
"deduplication_info_description": "Für die automatische Datei-Vorauswahl und das Deduplizieren aller Dateien berücksichtigen wir:", "deduplication_info_description": "Für die automatische Datei-Vorauswahl und das Deduplizieren aller Dateien berücksichtigen wir:",
"default_locale": "Standard-Sprache",
"default_locale_description": "Datumsangaben und Zahlen basierend auf dem Gebietsschema des Browsers formatieren",
"delete": "Löschen", "delete": "Löschen",
"delete_action_confirmation_message": "Bist du sicher, dass du dieses Objekt löschen willst? Diese Aktion wird das Objekt in den Papierkorb des Servers verschieben und fragen, ob du es lokal löschen willst", "delete_action_confirmation_message": "Bist du sicher, dass du dieses Objekt löschen willst? Diese Aktion wird das Objekt in den Papierkorb des Servers verschieben und fragen, ob du es lokal löschen willst",
"delete_action_prompt": "{count} gelöscht", "delete_action_prompt": "{count} gelöscht",
@@ -1004,6 +1007,8 @@
"editor_edits_applied_success": "Änderungen erfolgreich angewendet", "editor_edits_applied_success": "Änderungen erfolgreich angewendet",
"editor_flip_horizontal": "Horizontal spiegeln", "editor_flip_horizontal": "Horizontal spiegeln",
"editor_flip_vertical": "Vertikal spiegeln", "editor_flip_vertical": "Vertikal spiegeln",
"editor_handle_corner": "{corner, select, top_left {Oben links} top_right {Oben rechts} bottom_left {Unten links} bottom_right {Unten rechts} other {A}} Eckgriff",
"editor_handle_edge": "{edge, select, top {Oben} bottom {Unten} left {Links} right {Rechts} other {Ein}} Kantenanfasser",
"editor_orientation": "Ausrichtung", "editor_orientation": "Ausrichtung",
"editor_reset_all_changes": "Änderungen zurücksetzen", "editor_reset_all_changes": "Änderungen zurücksetzen",
"editor_rotate_left": "Um 90° gegen den Uhrzeigersinn drehen", "editor_rotate_left": "Um 90° gegen den Uhrzeigersinn drehen",
@@ -1069,6 +1074,7 @@
"failed_to_update_notification_status": "Benachrichtigungsstatus aktualisieren fehlgeschlagen", "failed_to_update_notification_status": "Benachrichtigungsstatus aktualisieren fehlgeschlagen",
"incorrect_email_or_password": "Ungültige E-Mail oder Passwort", "incorrect_email_or_password": "Ungültige E-Mail oder Passwort",
"library_folder_already_exists": "Dieser Importpfad existiert bereits.", "library_folder_already_exists": "Dieser Importpfad existiert bereits.",
"page_not_found": "Seite nicht gefunden",
"paths_validation_failed": "{paths, plural, one {# Pfad konnte} other {# Pfade konnten}} nicht validiert werden", "paths_validation_failed": "{paths, plural, one {# Pfad konnte} other {# Pfade konnten}} nicht validiert werden",
"profile_picture_transparent_pixels": "Profilbilder dürfen keine transparenten Pixel haben. Bitte zoome heran und/oder verschiebe das Bild.", "profile_picture_transparent_pixels": "Profilbilder dürfen keine transparenten Pixel haben. Bitte zoome heran und/oder verschiebe das Bild.",
"quota_higher_than_disk_size": "Dein festgelegtes Kontingent ist größer als der verfügbare Speicher", "quota_higher_than_disk_size": "Dein festgelegtes Kontingent ist größer als der verfügbare Speicher",
@@ -1168,6 +1174,7 @@
"exif_bottom_sheet_people": "PERSONEN", "exif_bottom_sheet_people": "PERSONEN",
"exif_bottom_sheet_person_add_person": "Namen hinzufügen", "exif_bottom_sheet_person_add_person": "Namen hinzufügen",
"exit_slideshow": "Diashow beenden", "exit_slideshow": "Diashow beenden",
"expand": "Erweitern",
"expand_all": "Alle aufklappen", "expand_all": "Alle aufklappen",
"experimental_settings_new_asset_list_subtitle": "In Arbeit", "experimental_settings_new_asset_list_subtitle": "In Arbeit",
"experimental_settings_new_asset_list_title": "Experimentelles Fotogitter aktivieren", "experimental_settings_new_asset_list_title": "Experimentelles Fotogitter aktivieren",
@@ -1212,6 +1219,7 @@
"filter_description": "Bedingungen zur Filterung der betreffenden Dateien", "filter_description": "Bedingungen zur Filterung der betreffenden Dateien",
"filter_people": "Personen filtern", "filter_people": "Personen filtern",
"filter_places": "Orte filtern", "filter_places": "Orte filtern",
"filter_tags": "Tags filtern",
"filters": "Filter", "filters": "Filter",
"find_them_fast": "Finde sie schneller mit der Suche nach Namen", "find_them_fast": "Finde sie schneller mit der Suche nach Namen",
"first": "Erste", "first": "Erste",
@@ -1613,7 +1621,7 @@
"not_available": "N/A", "not_available": "N/A",
"not_in_any_album": "In keinem Album", "not_in_any_album": "In keinem Album",
"not_selected": "Nicht ausgewählt", "not_selected": "Nicht ausgewählt",
"notes": "Notizen", "notes": "Hinweise",
"nothing_here_yet": "Noch nichts hier", "nothing_here_yet": "Noch nichts hier",
"notification_permission_dialog_content": "Um Benachrichtigungen zu aktivieren, navigiere zu Einstellungen und klicke \"Erlauben\".", "notification_permission_dialog_content": "Um Benachrichtigungen zu aktivieren, navigiere zu Einstellungen und klicke \"Erlauben\".",
"notification_permission_list_tile_content": "Erlaube Berechtigung für Benachrichtigungen.", "notification_permission_list_tile_content": "Erlaube Berechtigung für Benachrichtigungen.",
@@ -1642,6 +1650,8 @@
"online": "Online", "online": "Online",
"only_favorites": "Nur Favoriten", "only_favorites": "Nur Favoriten",
"open": "Öffnen", "open": "Öffnen",
"open_calendar": "Kalender öffnen",
"open_in_browser": "Im Browser öffnen",
"open_in_map_view": "In Kartenansicht öffnen", "open_in_map_view": "In Kartenansicht öffnen",
"open_in_openstreetmap": "In OpenStreetMap öffnen", "open_in_openstreetmap": "In OpenStreetMap öffnen",
"open_the_search_filters": "Die Suchfilter öffnen", "open_the_search_filters": "Die Suchfilter öffnen",
@@ -1710,8 +1720,8 @@
"permission_onboarding_permission_limited": "Berechtigungen unzureichend. Um Immich das Sichern von ganzen Sammlungen zu ermöglichen, muss der Zugriff auf alle Fotos und Videos in den Einstellungen erlaubt werden.", "permission_onboarding_permission_limited": "Berechtigungen unzureichend. Um Immich das Sichern von ganzen Sammlungen zu ermöglichen, muss der Zugriff auf alle Fotos und Videos in den Einstellungen erlaubt werden.",
"permission_onboarding_request": "Immich benötigt Berechtigung um auf deine Fotos und Videos zuzugreifen.", "permission_onboarding_request": "Immich benötigt Berechtigung um auf deine Fotos und Videos zuzugreifen.",
"person": "Person", "person": "Person",
"person_age_months": "{months, plural, one {# month} other {# months}} alt", "person_age_months": "{months, plural, one {# Monat} other {# Monate}} alt",
"person_age_year_months": "1 Jahr, {months, plural, one {# month} other {# months}} alt", "person_age_year_months": "1 Jahr, {months, plural, one {# Monat} other {# Monate}} alt",
"person_age_years": "{years, plural, one {# Jahr} other {# Jahre}} alt", "person_age_years": "{years, plural, one {# Jahr} other {# Jahre}} alt",
"person_birthdate": "Geboren am {date}", "person_birthdate": "Geboren am {date}",
"person_hidden": "{name}{hidden, select, true { (verborgen)} other {}}", "person_hidden": "{name}{hidden, select, true { (verborgen)} other {}}",
@@ -1801,9 +1811,8 @@
"rate_asset": "Datei bewerten", "rate_asset": "Datei bewerten",
"rating": "Bewertung", "rating": "Bewertung",
"rating_clear": "Bewertung löschen", "rating_clear": "Bewertung löschen",
"rating_count": "{count, plural, one {# Stern} other {# Sterne}}", "rating_count": "{count, plural, =0 {Unbewertet} one {# Stern} other {# Sterne}}",
"rating_description": "Stellt die EXIF-Bewertung im Informationsbereich dar", "rating_description": "Stellt die EXIF-Bewertung im Informationsbereich dar",
"rating_set": "Mit {rating, plural, one {# Stern} other {# Sternen}} bewertet",
"reaction_options": "Reaktionsmöglichkeiten", "reaction_options": "Reaktionsmöglichkeiten",
"read_changelog": "Changelog lesen", "read_changelog": "Changelog lesen",
"readonly_mode_disabled": "Schreibgeschützter Modus deaktiviert", "readonly_mode_disabled": "Schreibgeschützter Modus deaktiviert",
@@ -1875,7 +1884,10 @@
"reset_pin_code_success": "PIN-Code erfolgreich zurückgesetzt", "reset_pin_code_success": "PIN-Code erfolgreich zurückgesetzt",
"reset_pin_code_with_password": "Mit deinem Passwort kannst du jederzeit deinen PIN-Code zurücksetzen", "reset_pin_code_with_password": "Mit deinem Passwort kannst du jederzeit deinen PIN-Code zurücksetzen",
"reset_sqlite": "SQLite Datenbank zurücksetzen", "reset_sqlite": "SQLite Datenbank zurücksetzen",
"reset_sqlite_confirmation": "Bist du sicher, dass du die SQLite-Datenbank zurücksetzen willst? Du musst dich ab- und wieder anmelden, um die Daten neu zu synchronisieren", "reset_sqlite_clear_app_data": "Daten löschen",
"reset_sqlite_confirmation": "Bist du sicher, dass du die SQLite-Datenbank zurücksetzen willst? Es werden alle Einstellungen zurückgesetzt und du wirst abgemeldet.",
"reset_sqlite_confirmation_note": "Warnung: Du musst nach dem Zurücksetzten die App neu starten.",
"reset_sqlite_done": "Die Anwendungsdaten wurden gelöscht. Bitte starte Immich neu um dich erneut anzumelden.",
"reset_sqlite_success": "SQLite Datenbank erfolgreich zurückgesetzt", "reset_sqlite_success": "SQLite Datenbank erfolgreich zurückgesetzt",
"reset_to_default": "Auf Standard zurücksetzen", "reset_to_default": "Auf Standard zurücksetzen",
"resolution": "Auflösung", "resolution": "Auflösung",
@@ -1903,6 +1915,7 @@
"saved_settings": "Einstellungen gespeichert", "saved_settings": "Einstellungen gespeichert",
"say_something": "Etwas sagen", "say_something": "Etwas sagen",
"scaffold_body_error_occurred": "Ein Fehler ist aufgetreten", "scaffold_body_error_occurred": "Ein Fehler ist aufgetreten",
"scaffold_body_error_unrecoverable": "Es ist ein nicht behebbarer Fehler aufgetreten. Bitte teilen Sie uns den Fehler und den Stacktrace auf Discord oder GitHub mit, damit wir Ihnen helfen können. Falls nötig, können Sie unten die App-Daten löschen.",
"scan": "Scannen", "scan": "Scannen",
"scan_all_libraries": "Alle Bibliotheken scannen", "scan_all_libraries": "Alle Bibliotheken scannen",
"scan_library": "Scannen", "scan_library": "Scannen",
@@ -1938,6 +1951,7 @@
"search_filter_ocr": "Suche per OCR", "search_filter_ocr": "Suche per OCR",
"search_filter_people_title": "Personen auswählen", "search_filter_people_title": "Personen auswählen",
"search_filter_star_rating": "Sternebewertung", "search_filter_star_rating": "Sternebewertung",
"search_filter_tags_title": "Tags auswählen",
"search_for": "Suche nach", "search_for": "Suche nach",
"search_for_existing_person": "Suche nach vorhandener Person", "search_for_existing_person": "Suche nach vorhandener Person",
"search_no_more_result": "Keine weiteren Ergebnisse", "search_no_more_result": "Keine weiteren Ergebnisse",
@@ -2017,6 +2031,9 @@
"set_profile_picture": "Profilbild einstellen", "set_profile_picture": "Profilbild einstellen",
"set_slideshow_to_fullscreen": "Diashow auf Vollbild einstellen", "set_slideshow_to_fullscreen": "Diashow auf Vollbild einstellen",
"set_stack_primary_asset": "Als primäre Datei festlegen", "set_stack_primary_asset": "Als primäre Datei festlegen",
"setting_image_navigation_enable_subtitle": "Aktivieren, um durch Tippen auf den linksäußeren/rechtsäußeren Bildschirmrand zum vorherigen/nächsten Bild zu navigieren.",
"setting_image_navigation_enable_title": "Tippen zum Navigieren",
"setting_image_navigation_title": "Bild Navigation",
"setting_image_viewer_help": "Der Detailbildbetrachter lädt zuerst ein (kleines) Vorschaubild, dann ein Vorschaubild in mittlerer Größe (falls aktiviert) und schließlich das Original (falls aktiviert).", "setting_image_viewer_help": "Der Detailbildbetrachter lädt zuerst ein (kleines) Vorschaubild, dann ein Vorschaubild in mittlerer Größe (falls aktiviert) und schließlich das Original (falls aktiviert).",
"setting_image_viewer_original_subtitle": "Aktivieren, um das Originalbild in voller Auflösung (groß!) zu laden. Deaktivieren, um den Datenverbrauch zu reduzieren (sowohl im Netzwerk als auch im Gerätespeicher).", "setting_image_viewer_original_subtitle": "Aktivieren, um das Originalbild in voller Auflösung (groß!) zu laden. Deaktivieren, um den Datenverbrauch zu reduzieren (sowohl im Netzwerk als auch im Gerätespeicher).",
"setting_image_viewer_original_title": "Original laden", "setting_image_viewer_original_title": "Original laden",
@@ -2183,6 +2200,7 @@
"support": "Unterstützung", "support": "Unterstützung",
"support_and_feedback": "Unterstützung & Feedback", "support_and_feedback": "Unterstützung & Feedback",
"support_third_party_description": "Deine Immich-Installation wurde von einem Drittanbieter zusammengestellt. Probleme, die bei dir auftreten, können durch dieses Paket verursacht werden. Bitte wende dich daher in erster Linie an diesen Anbieter, indem du die unten stehenden Links verwendest.", "support_third_party_description": "Deine Immich-Installation wurde von einem Drittanbieter zusammengestellt. Probleme, die bei dir auftreten, können durch dieses Paket verursacht werden. Bitte wende dich daher in erster Linie an diesen Anbieter, indem du die unten stehenden Links verwendest.",
"supporter": "Unterstützer",
"swap_merge_direction": "Vertauschen der Zusammenführungsrichtung", "swap_merge_direction": "Vertauschen der Zusammenführungsrichtung",
"sync": "Synchronisieren", "sync": "Synchronisieren",
"sync_albums": "Alben synchronisieren", "sync_albums": "Alben synchronisieren",
@@ -2294,6 +2312,7 @@
"unstack_action_prompt": "{count} entstapelt", "unstack_action_prompt": "{count} entstapelt",
"unstacked_assets_count": "{count, plural, one {# Datei} other {# Dateien}} entstapelt", "unstacked_assets_count": "{count, plural, one {# Datei} other {# Dateien}} entstapelt",
"unsupported_field_type": "Nicht unterstützter Feldtyp", "unsupported_field_type": "Nicht unterstützter Feldtyp",
"unsupported_file_type": "Die Datei {file} kann nicht hochgeladen werden, da der Dateityp {type} nicht unterstützt wird.",
"untagged": "Ohne Tag", "untagged": "Ohne Tag",
"untitled_workflow": "Unbenannter Workflow", "untitled_workflow": "Unbenannter Workflow",
"up_next": "Weiter", "up_next": "Weiter",
@@ -2320,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Verwendung", "usage": "Verwendung",
"use_biometric": "Biometrie verwenden", "use_biometric": "Biometrie verwenden",
"use_browser_locale": "Benutze lokalen Browser",
"use_browser_locale_description": "Datum, Uhrzeit und Zahlen werden entsprechend den Einstellungen Ihres Browsers formatiert",
"use_current_connection": "Aktuelle Verbindung verwenden", "use_current_connection": "Aktuelle Verbindung verwenden",
"use_custom_date_range": "Stattdessen einen benutzerdefinierten Datumsbereich verwenden", "use_custom_date_range": "Stattdessen einen benutzerdefinierten Datumsbereich verwenden",
"user": "Nutzer", "user": "Nutzer",
+40 -12
View File
@@ -75,30 +75,58 @@
"confirm_reprocess_all_faces": "Bisch sicher, dass du alli Gsichter neu verarbeite wotsch? Däbii werde au benannti Persone glöscht.", "confirm_reprocess_all_faces": "Bisch sicher, dass du alli Gsichter neu verarbeite wotsch? Däbii werde au benannti Persone glöscht.",
"confirm_user_password_reset": "Bisch sicher, dass du s Passwort für {user} möchtisch zruggsetze?", "confirm_user_password_reset": "Bisch sicher, dass du s Passwort für {user} möchtisch zruggsetze?",
"confirm_user_pin_code_reset": "Bisch sicher, dass du de PIN-Code vo {user} möchtisch zruggsetze?", "confirm_user_pin_code_reset": "Bisch sicher, dass du de PIN-Code vo {user} möchtisch zruggsetze?",
"copy_config_to_clipboard_description": "Kopiere die aktuelle Systemkonfiguration als JSON-Objekt in die Zwischenablage", "copy_config_to_clipboard_description": "Kopier die aktuelli Systemkonfiguration als JSON-Objekt i d'Zwüschenablage",
"create_job": "Uufgabe erstelle", "create_job": "Uufgabe erstelle",
"cron_expression": "Cron-Ziitagabe", "cron_expression": "Cron-Ziitagabe",
"cron_expression_description": "Setz s Scanintervall im Cron-Format. Hilf mit däm Format bütet z. B. der <link>Crontab Guru</link>", "cron_expression_description": "Setz s Scanintervall im Cron-Format. Hilf mit däm Format bütet z. B. der <link>Crontab Guru</link>",
"cron_expression_presets": "Vorlage für Cron-Uusdruck", "cron_expression_presets": "Vorlage für Cron-Uusdruck",
"disable_login": "Login deaktiviere", "disable_login": "Login deaktiviere",
"duplicate_detection_job_description": "Die Uufgab füehrt s maschinelle Lärne für jedi Datei us, zum Duplikat finde. Die Uufgabe berueht uf de intelligente Suechi", "duplicate_detection_job_description": "Die Uufgab füehrt s maschinelle Lärne für jedi Datei us, zum Duplikat finde. Die Uufgabe berueht uf de intelligente Suechi",
"exclusion_pattern_description": "Mit Ausschlussmustern können Dateien und Ordner beim Scannen Ihrer Bibliothek ignoriert werden. Dies ist nützlich, wenn du Ordner hast, die Dateien enthalten, die du nicht importieren möchtest, wie z. B. RAW-Dateien.", "exclusion_pattern_description": "Mit Uusschlussmuster chönnd Dateie und Ordner bim Scanne vo dinere Bibliothek ignoriert wärde. Das isch nützlich, wenn du Ordner häsch, wo Dateien drin händ, wo d nöd wotsch importiere, wie z. B. RAW-Dateie.",
"export_config_as_json_description": "Lade die aktuelle Systemkonfiguration als JSON-Datei herunter", "export_config_as_json_description": "Lad die aktuelli Systemkonfiguration als JSON-Datei abe",
"external_libraries_page_description": "Externe Bibliotheksseite für Administratoren", "external_libraries_page_description": "Externi Bibliothekssiite für Administratore",
"face_detection": "Gsichtserkennig", "face_detection": "Gsichtserkennig",
"face_detection_description": "Diese Aufgabe erfasst Gesichter in Dateien mittels maschinellen Lernens. Bei Videos wird nur die Miniaturansicht verwendet. „Aktualisieren“ verarbeitet alle Dateien neu. „Zurücksetzen“ setzt zusätzlich alle Gesichter zurück. „Fehlende“ stellt nur nicht verarbeitete Dateien in die Warteschlange. Erfasste Gesichter werden zur Gesichtsidentifizierung in die Warteschlange gestellt, um sie in bestehende oder neue Personen zu gruppieren.", "face_detection_description": "Die Uufgab erfasst Gsichter in Dateien dur maschinells Lerne. Bi Video wird nur d'Miniaturasicht brucht. „Aktualisiere“ verarbeitet all Dateie neu. „Zruggsetze“ setzt au no all Gsichter zrugg. „Fehlendi“ stellt nur nöd verarbeiteti Dateie in d'Warteschlange. Erfassti Gsichter wärdet zur Gsichtsidentifizierig in diWarteschlange gstellt, damit sie i bestehendi oder neui Persone z'gruppiere.",
"facial_recognition_job_description": "Diese Aufgabe gruppiert im Anschluss an die Gesichtserfassung die erfassten Gesichter zu Personen. „Zurücksetzen“ gruppiert alle Gesichter neu, während „Fehlende Gesichter ohne Zuordnung in die Warteschlange stellt.", "facial_recognition_job_description": "Die Uufgabe gruppiert im Anschluss an d'Gsichtserfassig die erfasste Gsichter zu Persone. „Zruggsetze“ gruppiert alli Gsichter neu und mit „Fehlendi“ werdet Gsichter ohni Zuordnig i d'Warteschlange gstellt.",
"failed_job_command": "Befehl {command} ist für Aufgabe {job} fehlgeschlagen", "failed_job_command": "Befehl {command} t für d'Uufgabe {job} nöd funktioniert",
"force_delete_user_warning": "WARNUNG: Diese Aktion löscht sofort den Benutzer und all seine Dateien. Dies kann nicht rückgängig gemacht werden und die Dateien können nicht wiederhergestellt werden.", "force_delete_user_warning": "WARNIG: Die Aktion löscht Benutzer und all sini Dateie. Das chann nöd rückgängig gmacht wärde und d'Dateie chönnd nöd wiederhergstellt wärde.",
"image_format": "Format", "image_format": "Format",
"image_format_description": "WebP erzeugt kleinere Dateien als JPEG, ist aber etwas langsamer in der Erstellung.", "image_format_description": "WebP erzeugt chlineri Dateie we JPEG, isch aber es bitz langsamer i de Erstellig.",
"image_fullsize_description": "Hochauflösendes Bild mit entfernten Metadaten, das beim Zoomen verwendet wird", "image_fullsize_description": "Hochuflösends Bild mit glöschte Metadate, wo bim Zoome brucht wird",
"image_fullsize_enabled": "Hochauflösende Vorschaubilder aktivieren", "image_fullsize_enabled": "Hochuflösendi Vorschaubilder aktiviere",
"image_fullsize_enabled_description": "Generiere hochauflösende Vorschaubilder in Originalauflösung für nicht web-kompatibel Formate. Wenn \"Eingebettete Vorschau bevorzugen\" aktiviert ist, werden eingebettete Vorschaubilder direkt verwendet. Hat keinen Einfluss auf web-kompatible Formate wie JPEG.", "image_fullsize_enabled_description": "Generiere hochauflösende Vorschaubilder in Originalauflösung für nicht web-kompatibel Formate. Wenn \"Eingebettete Vorschau bevorzugen\" aktiviert ist, werden eingebettete Vorschaubilder direkt verwendet. Hat keinen Einfluss auf web-kompatible Formate wie JPEG.",
"image_fullsize_quality_description": "Qualität der hochauflösenden Vorschaubilder von 1-100. Höher ist besser, erzeugt aber grössere Dateien.", "image_fullsize_quality_description": "Qualität der hochauflösenden Vorschaubilder von 1-100. Höher ist besser, erzeugt aber grössere Dateien.",
"image_fullsize_title": "Hochauflösende Vorschaueinstellungen", "image_fullsize_title": "Hochauflösende Vorschaueinstellungen",
"image_prefer_embedded_preview": "Eingebettete Vorschau bevorzugen", "image_prefer_embedded_preview": "Eingebettete Vorschau bevorzugen",
"image_prefer_embedded_preview_setting_description": "Verwende eingebettete Vorschaubilder in RAW-Fotos als Grundlage für die Bildverarbeitung, sofern diese zur Verfügung stehen. Dies kann bei einigen Bildern genauere Farben erzeugen, allerdings ist die Qualität der Vorschau kameraabhängig und das Bild kann mehr Kompressionsartefakte aufweisen.", "image_prefer_embedded_preview_setting_description": "Verwende eingebettete Vorschaubilder in RAW-Fotos als Grundlage für die Bildverarbeitung, sofern diese zur Verfügung stehen. Dies kann bei einigen Bildern genauere Farben erzeugen, allerdings ist die Qualität der Vorschau kameraabhängig und das Bild kann mehr Kompressionsartefakte aufweisen.",
"image_prefer_wide_gamut": "Breites Spektrum bevorzugen" "image_prefer_wide_gamut": "Breites Spektrum bevorzugen",
"image_prefer_wide_gamut_setting_description": "Bruuch Display P3 für Vorschaubildli. Das erhaltet d'Vitalität von Bildli mit grossem Farbruum besser. Uf alte Grät mit alte Browser chann das aber andersch uusgseh. sRGB-Bildli wärdet als sRGB bhalte zum Farbänderige vermiide.",
"image_preview_description": "Mittelgrossi Bildli ohni Metadate, bruuchts für Einzelaasichte und fürs maschinelle Lärne",
"image_preview_quality_description": "Vorschauqualität vo 1-100. Höcher isch besser, git aber grösseri Dateie und chan d'App Schwuppdizität reduziere. Z tüffi Wert chönnd s maschinelle Lärne beiträchtige.",
"image_preview_title": "Vorschauiistellige",
"image_progressive": "Fortlaufend",
"image_progressive_description": "Codier fortlaufendi JPEG-Bildi: Sie wärdet bim Lade aufbauend aazeiget. Das hät kei Würkig uf WebP-Bildi.",
"image_quality": "Qualität",
"image_resolution": "Uuflösig",
"image_resolution_description": "Höcheri Uuflösig erhaltet meh Detail, gaht aber länger zum codiere, macht grösseri Dateie und chan d'App Schuppdizität reduziere.",
"image_settings": "Bild-Iistellige",
"image_settings_description": "Qualität und Uuflösig von erstellte Bildli verwalte",
"image_thumbnail_description": "Chlini Vorschaubildli ohni Metadate, bruuchts für Aasichte mit Gruppe vo Föteli wie i de Hauptziitachse",
"image_thumbnail_quality_description": "Vorschauqualität vo 1-100. Höcher isch besser, git aber grösseri Dateie und chan d'App Schwuppdizität reduziere.",
"image_thumbnail_title": "Iistellige für Vorschaubildli",
"import_config_from_json_description": "Systemkonfiguration importiere durs Ufelade vonere JSON-Datei",
"job_concurrency": "{job} Näbeläufigkeit",
"job_created": "Uufgab erstellt",
"job_not_concurrency_safe": "Die Uufgabe ist nöd für Paralleluusführig gmacht.",
"job_settings": "Uufgabe-Iistellige",
"job_settings_description": "Uufgabe-Näbeläufigkeit verwalte",
"jobs_over_time": "Uufgabe in ziitliche Verlauf",
"library_created": "Bibliothek erstellt: {library}",
"library_deleted": "Bibliothek glöscht",
"library_details": "Bibliotheks-Details",
"library_folder_description": "Gib en Order zum Importiere a. Dä Order mit sine Underordner wird nach Bildli und Videos durchsucht.",
"library_remove_exclusion_pattern_prompt": "Bisch sicher, dass das Uuschluss-Muster wotsch lösche?",
"library_remove_folder_prompt": "Bisch sicher, dass dä Import-Ordner wotsch lösche?",
"library_scanning": "Regelmässigi Überprüefig"
} }
} }
+32 -11
View File
@@ -61,7 +61,7 @@
"backup_onboarding_1_description": "αντίγραφο ασφαλείας εκτός εγκατάστασης, είτε στο cloud είτε σε άλλη φυσική τοποθεσία.", "backup_onboarding_1_description": "αντίγραφο ασφαλείας εκτός εγκατάστασης, είτε στο cloud είτε σε άλλη φυσική τοποθεσία.",
"backup_onboarding_2_description": "τοπικά αντίγραφα σε διαφορετικές συσκευές. Αυτό περιλαμβάνει τα κύρια αρχεία και ένα τοπικό αντίγραφο ασφαλείας αυτών των αρχείων.", "backup_onboarding_2_description": "τοπικά αντίγραφα σε διαφορετικές συσκευές. Αυτό περιλαμβάνει τα κύρια αρχεία και ένα τοπικό αντίγραφο ασφαλείας αυτών των αρχείων.",
"backup_onboarding_3_description": "συνολικά αντίγραφα των δεδομένων σας, συμπεριλαμβανομένων των αρχικών αρχείων. Αυτό περιλαμβάνει 1 αντίγραφο εκτός εγκατάστασης (offsite) και 2 τοπικά αντίγραφα.", "backup_onboarding_3_description": "συνολικά αντίγραφα των δεδομένων σας, συμπεριλαμβανομένων των αρχικών αρχείων. Αυτό περιλαμβάνει 1 αντίγραφο εκτός εγκατάστασης (offsite) και 2 τοπικά αντίγραφα.",
"backup_onboarding_description": "Συνιστάται η στρατηγική <backblaze-link>αντιγράφων ασφαλείας 3-2-1</backblaze-link> για την προστασία των δεδομένων σας. Θα πρέπει να διατηρείτε αντίγραφα των ανεβασμένων φωτογραφιών/βίντεό σας, καθώς και της βάσης δεδομένων του Immich, για μια ολοκληρωμένη λύση backup.", "backup_onboarding_description": "Συνιστάται η <backblaze-link>3-2-1 στρατηγική αντιγράφων ασφαλείας</backblaze-link> για την προστασία των δεδομένων σας. Θα πρέπει να διατηρείτε αντίγραφα των ανεβασμένων φωτογραφιών/βίντεό σας, καθώς και της βάσης δεδομένων του Immich, για μια ολοκληρωμένη λύση backup.",
"backup_onboarding_footer": "Για περισσότερες πληροφορίες σχετικά με τη δημιουργία αντιγράφων ασφαλείας του Immich, ανατρέξε στον <link>οδηγό τεκμηρίωσης</link>.", "backup_onboarding_footer": "Για περισσότερες πληροφορίες σχετικά με τη δημιουργία αντιγράφων ασφαλείας του Immich, ανατρέξε στον <link>οδηγό τεκμηρίωσης</link>.",
"backup_onboarding_parts_title": "Ένα αντίγραφο ασφαλείας τύπου 3-2-1 περιλαμβάνει:", "backup_onboarding_parts_title": "Ένα αντίγραφο ασφαλείας τύπου 3-2-1 περιλαμβάνει:",
"backup_onboarding_title": "Αντίγραφα ασφαλείας", "backup_onboarding_title": "Αντίγραφα ασφαλείας",
@@ -311,7 +311,7 @@
"search_jobs": "Αναζήτηση εργασιών…", "search_jobs": "Αναζήτηση εργασιών…",
"send_welcome_email": "Αποστολή email καλωσορίσματος", "send_welcome_email": "Αποστολή email καλωσορίσματος",
"server_external_domain_settings": "Εξωτερική διεύθυνση τομέα", "server_external_domain_settings": "Εξωτερική διεύθυνση τομέα",
"server_external_domain_settings_description": "Διεύθυνση τομέα για δημόσιους κοινούς συνδέσμους, περιλαμβανομένου του http(s)://", "server_external_domain_settings_description": "Η διεύθυνση που χρησιμοποιείται για εξωτερικούς συνδέσμους",
"server_public_users": "Δημόσιοι Χρήστες", "server_public_users": "Δημόσιοι Χρήστες",
"server_public_users_description": "Όλοι οι χρήστες (όνομα και email) εμφανίζονται κατά την προσθήκη ενός χρήστη σε κοινόχρηστα άλμπουμ. Όταν αυτή η επιλογή είναι απενεργοποιημένη, η λίστα χρηστών θα είναι διαθέσιμη μόνο στους διαχειριστές.", "server_public_users_description": "Όλοι οι χρήστες (όνομα και email) εμφανίζονται κατά την προσθήκη ενός χρήστη σε κοινόχρηστα άλμπουμ. Όταν αυτή η επιλογή είναι απενεργοποιημένη, η λίστα χρηστών θα είναι διαθέσιμη μόνο στους διαχειριστές.",
"server_settings": "Ρυθμίσεις διακομιστή", "server_settings": "Ρυθμίσεις διακομιστή",
@@ -372,7 +372,7 @@
"transcoding_audio_codec": "Κωδικοποιητής ήχου", "transcoding_audio_codec": "Κωδικοποιητής ήχου",
"transcoding_audio_codec_description": "Το Opus είναι η επιλογή για την υψηλότερη ποιότητα, αλλά έχει χαμηλότερη συμβατότητα με παλιές συσκευές ή λογισμικό.", "transcoding_audio_codec_description": "Το Opus είναι η επιλογή για την υψηλότερη ποιότητα, αλλά έχει χαμηλότερη συμβατότητα με παλιές συσκευές ή λογισμικό.",
"transcoding_bitrate_description": "Βίντεο με ρυθμό μετάδοσης μεγαλύτερο από το μέγιστο ή που δεν είναι σε αποδεκτή μορφή", "transcoding_bitrate_description": "Βίντεο με ρυθμό μετάδοσης μεγαλύτερο από το μέγιστο ή που δεν είναι σε αποδεκτή μορφή",
"transcoding_codecs_learn_more": "Για να μάθετε περισσότερα για την ορολογία που χρησιμοποιείται εδώ, ανατρέξτε στην τεκμηρίωση του FFmpeg για τους κωδικοποιητές <h264-link>H.264</h264-link>, <hevc-link>HEVC</hevc-link> και <vp9-link>VP9</vp9-link>.", "transcoding_codecs_learn_more": "Για να μάθετε περισσότερα για την ορολογία που χρησιμοποιείται εδώ, ανατρέξτε στην τεκμηρίωση του FFmpeg για τους κωδικοποιητές <h264-link>H.264 codec</h264-link>, <hevc-link>HEVC codec</hevc-link> και <vp9-link>VP9 codec</vp9-link>.",
"transcoding_constant_quality_mode": "Λειτουργία σταθερής ποιότητας", "transcoding_constant_quality_mode": "Λειτουργία σταθερής ποιότητας",
"transcoding_constant_quality_mode_description": "Το ICQ είναι καλύτερο από το CQP, αλλά ορισμένες συσκευές επιτάχυνσης υλικού δεν υποστηρίζουν αυτήν τη λειτουργία. Η ρύθμιση αυτής της επιλογής θα προτιμήσει την καθορισμένη λειτουργία κατά τη χρήση κωδικοποίησης βάσει ποιότητας. Αγνοείται από το NVENC, καθώς δεν υποστηρίζει το ICQ.", "transcoding_constant_quality_mode_description": "Το ICQ είναι καλύτερο από το CQP, αλλά ορισμένες συσκευές επιτάχυνσης υλικού δεν υποστηρίζουν αυτήν τη λειτουργία. Η ρύθμιση αυτής της επιλογής θα προτιμήσει την καθορισμένη λειτουργία κατά τη χρήση κωδικοποίησης βάσει ποιότητας. Αγνοείται από το NVENC, καθώς δεν υποστηρίζει το ICQ.",
"transcoding_constant_rate_factor": "Σταθερός παράγοντας ρυθμού (-crf)", "transcoding_constant_rate_factor": "Σταθερός παράγοντας ρυθμού (-crf)",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Χαρτογράφηση χρωματικών τόνων", "transcoding_tone_mapping": "Χαρτογράφηση χρωματικών τόνων",
"transcoding_tone_mapping_description": "Προσπαθεί να διατηρήσει την εμφάνιση των HDR βίντεο όταν μετατρέπονται σε SDR. Κάθε αλγόριθμος κάνει διαφορετικές επιλογές σχετικά με τα χρώματα, τις λεπτομέρειες και τη φωτεινότητα. Ο αλγόριθμος Hable διατηρεί τις λεπτομέρειες, ο Mobius διατηρεί τα χρώματα και ο Reinhard διατηρεί τη φωτεινότητα.", "transcoding_tone_mapping_description": "Προσπαθεί να διατηρήσει την εμφάνιση των HDR βίντεο όταν μετατρέπονται σε SDR. Κάθε αλγόριθμος κάνει διαφορετικές επιλογές σχετικά με τα χρώματα, τις λεπτομέρειες και τη φωτεινότητα. Ο αλγόριθμος Hable διατηρεί τις λεπτομέρειες, ο Mobius διατηρεί τα χρώματα και ο Reinhard διατηρεί τη φωτεινότητα.",
"transcoding_transcode_policy": "Πολιτική μετατροπής (βίντεο / ήχου)", "transcoding_transcode_policy": "Πολιτική μετατροπής (βίντεο / ήχου)",
"transcoding_transcode_policy_description": "Πολιτική για το πότε πρέπει να μετατραπεί ένα βίντεο. Τα βίντεο HDR θα μετατρέπονται πάντα (εκτός αν η μετατροπή είναι απενεργοποιημένη).", "transcoding_transcode_policy_description": "Πολιτική για το πότε πρέπει να γίνει μετατροπή ενός βίντεο. Τα HDR βίντεο και τα βίντεο με pixel format διαφορετικό από YUV 4:2:0 θα μετατρέπονται πάντα (εκτός αν η μετατροπή είναι απενεργοποιημένη).",
"transcoding_two_pass_encoding": "Κωδικοποίηση δύο περασμάτων", "transcoding_two_pass_encoding": "Κωδικοποίηση δύο περασμάτων",
"transcoding_two_pass_encoding_setting_description": "Μετατροπή σε δύο περάσματα για την παραγωγή βίντεο με καλύτερη κωδικοποίηση. Όταν είναι ενεργοποιημένος ο μέγιστος ρυθμός μετάδοσης (απαραίτητος για λειτουργία με H.264 και HEVC), αυτή η λειτουργία χρησιμοποιεί ένα εύρος ρυθμού μετάδοσης βάσει του μέγιστου ρυθμού μετάδοσης και αγνοεί το CRF. Στον κωδικοποιητή VP9, το CRF μπορεί να χρησιμοποιηθεί εάν ο μέγιστος ρυθμός μετάδοσης είναι απενεργοποιημένος.", "transcoding_two_pass_encoding_setting_description": "Μετατροπή σε δύο περάσματα για την παραγωγή βίντεο με καλύτερη κωδικοποίηση. Όταν είναι ενεργοποιημένος ο μέγιστος ρυθμός μετάδοσης (απαραίτητος για λειτουργία με H.264 και HEVC), αυτή η λειτουργία χρησιμοποιεί ένα εύρος ρυθμού μετάδοσης βάσει του μέγιστου ρυθμού μετάδοσης και αγνοεί το CRF. Στον κωδικοποιητή VP9, το CRF μπορεί να χρησιμοποιηθεί εάν ο μέγιστος ρυθμός μετάδοσης είναι απενεργοποιημένος.",
"transcoding_video_codec": "Κωδικοποιητής βίντεο", "transcoding_video_codec": "Κωδικοποιητής βίντεο",
@@ -794,6 +794,11 @@
"color": "Χρώμα", "color": "Χρώμα",
"color_theme": "Χρώμα θέματος", "color_theme": "Χρώμα θέματος",
"command": "Εντολή", "command": "Εντολή",
"command_palette_prompt": "Γρήγορη εύρεση σελίδων, ενεργειών ή εντολών",
"command_palette_to_close": "για κλείσιμο",
"command_palette_to_navigate": "για είσοδο",
"command_palette_to_select": "για επιλογή",
"command_palette_to_show_all": "για προβολή όλων",
"comment_deleted": "Το σχόλιο διαγράφηκε", "comment_deleted": "Το σχόλιο διαγράφηκε",
"comment_options": "Επιλογές σχολίου", "comment_options": "Επιλογές σχολίου",
"comments_and_likes": "Σχόλια & αντιδράσεις (likes)", "comments_and_likes": "Σχόλια & αντιδράσεις (likes)",
@@ -866,8 +871,8 @@
"current_pin_code": "Τρέχων κωδικός PIN", "current_pin_code": "Τρέχων κωδικός PIN",
"current_server_address": "Τρέχουσα διεύθυνση διακομιστή", "current_server_address": "Τρέχουσα διεύθυνση διακομιστή",
"custom_date": "Προσαρμοσμένη ημερομηνία", "custom_date": "Προσαρμοσμένη ημερομηνία",
"custom_locale": "Προσαρμοσμένη Τοπική Ρύθμιση", "custom_locale": "Προσαρμοσμένη τοπική ρύθμιση",
"custom_locale_description": "Μορφοποιήστε τις ημερομηνίες και τους αριθμούς, σύμφωνα με τη γλώσσα και την περιοχή", "custom_locale_description": "Μορφοποιήστε τις ημερομηνίες, τους χρόνους και τους αριθμούς, σύμφωνα με την επιλεγμένη γλώσσα και περιοχή",
"custom_url": "Προσαρμοσμένη διεύθυνση URL", "custom_url": "Προσαρμοσμένη διεύθυνση URL",
"cutoff_date_description": "Διατήρηση φωτογραφιών από τις τελευταίες…", "cutoff_date_description": "Διατήρηση φωτογραφιών από τις τελευταίες…",
"cutoff_day": "{count, plural, one {ημέρα} other {ημέρες}}", "cutoff_day": "{count, plural, one {ημέρα} other {ημέρες}}",
@@ -890,8 +895,6 @@
"deduplication_criteria_2": "Αριθμός δεδομένων EXIF", "deduplication_criteria_2": "Αριθμός δεδομένων EXIF",
"deduplication_info": "Πληροφορίες Αφαίρεσης Διπλοτύπων", "deduplication_info": "Πληροφορίες Αφαίρεσης Διπλοτύπων",
"deduplication_info_description": "Για να προεπιλέξουμε αυτόματα τα αρχεία και να αφαιρέσουμε τα διπλότυπα σε μαζική επεξεργασία, εξετάζουμε σε:", "deduplication_info_description": "Για να προεπιλέξουμε αυτόματα τα αρχεία και να αφαιρέσουμε τα διπλότυπα σε μαζική επεξεργασία, εξετάζουμε σε:",
"default_locale": "Προεπιλεγμένη Τοπική Ρύθμιση",
"default_locale_description": "Μορφοποιήστε τις ημερομηνίες και τους αριθμούς με βάση την τοπική ρύθμιση του προγράμματος περιήγησής σας",
"delete": "Διαγραφή", "delete": "Διαγραφή",
"delete_action_confirmation_message": "Είστε σίγουροι ότι θέλετε να διαγράψετε αυτό το αρχείο; Αυτή η ενέργεια θα το μετακινήσει στον κάδο απορριμμάτων του διακομιστή και θα εμφανιστεί μήνυμα για το αν θέλετε να το διαγράψετε και τοπικά", "delete_action_confirmation_message": "Είστε σίγουροι ότι θέλετε να διαγράψετε αυτό το αρχείο; Αυτή η ενέργεια θα το μετακινήσει στον κάδο απορριμμάτων του διακομιστή και θα εμφανιστεί μήνυμα για το αν θέλετε να το διαγράψετε και τοπικά",
"delete_action_prompt": "{count} διαγράφηκαν", "delete_action_prompt": "{count} διαγράφηκαν",
@@ -1004,6 +1007,8 @@
"editor_edits_applied_success": "Οι αλλαγές εφαρμόστηκαν με επιτυχία", "editor_edits_applied_success": "Οι αλλαγές εφαρμόστηκαν με επιτυχία",
"editor_flip_horizontal": "Οριζόντια αναστροφή", "editor_flip_horizontal": "Οριζόντια αναστροφή",
"editor_flip_vertical": "Κάθετη αναστροφή", "editor_flip_vertical": "Κάθετη αναστροφή",
"editor_handle_corner": "{corner, select, top_left {Πάνω αριστερά} top_right {Πάνω δεξιά} bottom_left {Κάτω αριστερά} bottom_right {Κάτω δεξιά} other {A}} λαβή γωνίας",
"editor_handle_edge": "{edge, select, top {Πάνω} bottom {Κάτω} left {Αριστερά} right {Δεξιά} other {Μια}} λαβή πλευράς",
"editor_orientation": "Προσανατολισμός", "editor_orientation": "Προσανατολισμός",
"editor_reset_all_changes": "Επαναφορά αλλαγών", "editor_reset_all_changes": "Επαναφορά αλλαγών",
"editor_rotate_left": "Περιστροφή 90° αριστερόστροφα", "editor_rotate_left": "Περιστροφή 90° αριστερόστροφα",
@@ -1069,6 +1074,7 @@
"failed_to_update_notification_status": "Αποτυχία ενημέρωσης της κατάστασης ειδοποίησης", "failed_to_update_notification_status": "Αποτυχία ενημέρωσης της κατάστασης ειδοποίησης",
"incorrect_email_or_password": "Λανθασμένο email ή κωδικός πρόσβασης", "incorrect_email_or_password": "Λανθασμένο email ή κωδικός πρόσβασης",
"library_folder_already_exists": "Η διαδρομή εισαγωγής υπάρχει ήδη.", "library_folder_already_exists": "Η διαδρομή εισαγωγής υπάρχει ήδη.",
"page_not_found": "Η σελίδα δεν βρέθηκε",
"paths_validation_failed": "{paths, plural, one {# διαδρομή} other {# διαδρομές}} απέτυχαν κατά την επικύρωση", "paths_validation_failed": "{paths, plural, one {# διαδρομή} other {# διαδρομές}} απέτυχαν κατά την επικύρωση",
"profile_picture_transparent_pixels": "Οι εικόνες προφίλ δεν μπορούν να έχουν διαφανή εικονοστοιχεία. Παρακαλώ μεγεθύνετε ή/και μετακινήστε την εικόνα.", "profile_picture_transparent_pixels": "Οι εικόνες προφίλ δεν μπορούν να έχουν διαφανή εικονοστοιχεία. Παρακαλώ μεγεθύνετε ή/και μετακινήστε την εικόνα.",
"quota_higher_than_disk_size": "Έχετε ορίσει ένα όριο, μεγαλύτερο από το μέγεθος του δίσκου", "quota_higher_than_disk_size": "Έχετε ορίσει ένα όριο, μεγαλύτερο από το μέγεθος του δίσκου",
@@ -1168,6 +1174,7 @@
"exif_bottom_sheet_people": "ΑΤΟΜΑ", "exif_bottom_sheet_people": "ΑΤΟΜΑ",
"exif_bottom_sheet_person_add_person": "Προσθήκη ονόματος", "exif_bottom_sheet_person_add_person": "Προσθήκη ονόματος",
"exit_slideshow": "Έξοδος από την παρουσίαση", "exit_slideshow": "Έξοδος από την παρουσίαση",
"expand": "Ανάπτυξη",
"expand_all": "Ανάπτυξη όλων", "expand_all": "Ανάπτυξη όλων",
"experimental_settings_new_asset_list_subtitle": "Σε εξέλιξη", "experimental_settings_new_asset_list_subtitle": "Σε εξέλιξη",
"experimental_settings_new_asset_list_title": "Ενεργοποίηση πειραματικού πλέγματος φωτογραφιών", "experimental_settings_new_asset_list_title": "Ενεργοποίηση πειραματικού πλέγματος φωτογραφιών",
@@ -1212,6 +1219,7 @@
"filter_description": "Συνθήκες για φιλτράρισμα των στοχευμένων στοιχείων", "filter_description": "Συνθήκες για φιλτράρισμα των στοχευμένων στοιχείων",
"filter_people": "Φιλτράρισμα ατόμων", "filter_people": "Φιλτράρισμα ατόμων",
"filter_places": "Φιλτράρισμα τοποθεσιών", "filter_places": "Φιλτράρισμα τοποθεσιών",
"filter_tags": "Φιλτράρισμα ετικετών",
"filters": "Φίλτρα", "filters": "Φίλτρα",
"find_them_fast": "Βρείτε τους γρήγορα με αναζήτηση κατά όνομα", "find_them_fast": "Βρείτε τους γρήγορα με αναζήτηση κατά όνομα",
"first": "Αρχικά", "first": "Αρχικά",
@@ -1642,6 +1650,8 @@
"online": "Σε σύνδεση", "online": "Σε σύνδεση",
"only_favorites": "Μόνο αγαπημένα", "only_favorites": "Μόνο αγαπημένα",
"open": "Άνοιγμα", "open": "Άνοιγμα",
"open_calendar": "Άνοιγμα ημερολογίου",
"open_in_browser": "Άνοιγμα στο πρόγραμμα περιήγησης",
"open_in_map_view": "Άνοιγμα σε προβολή χάρτη", "open_in_map_view": "Άνοιγμα σε προβολή χάρτη",
"open_in_openstreetmap": "Άνοιγμα στο OpenStreetMap", "open_in_openstreetmap": "Άνοιγμα στο OpenStreetMap",
"open_the_search_filters": "Ανοίξτε τα φίλτρα αναζήτησης", "open_the_search_filters": "Ανοίξτε τα φίλτρα αναζήτησης",
@@ -1801,9 +1811,8 @@
"rate_asset": "Βαθμολογήστε το στοιχείο", "rate_asset": "Βαθμολογήστε το στοιχείο",
"rating": "Αξιολόγηση με αστέρια", "rating": "Αξιολόγηση με αστέρια",
"rating_clear": "Εκκαθάριση αξιολόγησης", "rating_clear": "Εκκαθάριση αξιολόγησης",
"rating_count": "{count, plural, one {# αστέρι} other {# αστέρια}}", "rating_count": "{count, plural, =0 {Χωρίς αξιολόγηση} one {# αστέρι} other {# αστέρια}}",
"rating_description": "Εμφάνιση της αξιολόγησης EXIF στον πίνακα πληροφοριών", "rating_description": "Εμφάνιση της αξιολόγησης EXIF στον πίνακα πληροφοριών",
"rating_set": "Η βαθμολογία ορίστηκε σε {rating, plural, one {# αστέρι} other {# αστέρια}}",
"reaction_options": "Επιλογές αντίδρασης", "reaction_options": "Επιλογές αντίδρασης",
"read_changelog": "Διαβάστε το Αρχείο Καταγραφής Αλλαγών", "read_changelog": "Διαβάστε το Αρχείο Καταγραφής Αλλαγών",
"readonly_mode_disabled": "Η λειτουργία μόνο-για-ανάγνωση απενεργοποιήθηκε", "readonly_mode_disabled": "Η λειτουργία μόνο-για-ανάγνωση απενεργοποιήθηκε",
@@ -1875,7 +1884,10 @@
"reset_pin_code_success": "Ο κωδικός PIN επαναφέρθηκε επιτυχώς", "reset_pin_code_success": "Ο κωδικός PIN επαναφέρθηκε επιτυχώς",
"reset_pin_code_with_password": "Μπορείτε πάντα να επαναφέρετε τον κωδικό PIN χρησιμοποιώντας τον κωδικό πρόσβασής σας", "reset_pin_code_with_password": "Μπορείτε πάντα να επαναφέρετε τον κωδικό PIN χρησιμοποιώντας τον κωδικό πρόσβασής σας",
"reset_sqlite": "Επαναφορά SQLite βάσης δεδομένων", "reset_sqlite": "Επαναφορά SQLite βάσης δεδομένων",
"reset_sqlite_confirmation": "Είσαι σίγουρος ότι θέλεις να επαναφέρεις τη βάση δεδομένων SQLite; Θα χρειαστεί να κάνεις αποσύνδεση και επανασύνδεση για να επανασυγχρονίσεις τα δεδομένα", "reset_sqlite_clear_app_data": "Εκκαθάριση δεδομένων",
"reset_sqlite_confirmation": "Είστε βέβαιοι ότι θέλετε να διαγράψετε τα δεδομένα της εφαρμογής; Αυτό θα διαγράψει όλες τις ρυθμίσεις και θα σας αποσυνδέσει.",
"reset_sqlite_confirmation_note": "Σημείωση: Θα χρειαστεί να επανεκκινήσετε την εφαρμογή μετά την εκκαθάριση.",
"reset_sqlite_done": "Τα δεδομένα της εφαρμογής διαγράφηκαν. Παρακαλώ επανεκκινήστε το Immich και συνδεθείτε ξανά.",
"reset_sqlite_success": "Η επαναφορά της SQLite βάσης δεδομένων ολοκληρώθηκε με επιτυχία", "reset_sqlite_success": "Η επαναφορά της SQLite βάσης δεδομένων ολοκληρώθηκε με επιτυχία",
"reset_to_default": "Επαναφορά στις προεπιλογές", "reset_to_default": "Επαναφορά στις προεπιλογές",
"resolution": "Ανάλυση", "resolution": "Ανάλυση",
@@ -1903,6 +1915,7 @@
"saved_settings": "Αποθηκευμένες ρυθμίσεις", "saved_settings": "Αποθηκευμένες ρυθμίσεις",
"say_something": "Πείτε κάτι", "say_something": "Πείτε κάτι",
"scaffold_body_error_occurred": "Παρουσιάστηκε σφάλμα", "scaffold_body_error_occurred": "Παρουσιάστηκε σφάλμα",
"scaffold_body_error_unrecoverable": "Παρουσιάστηκε ένα μη ανακτήσιμο σφάλμα. Παρακαλώ κοινοποιήστε το σφάλμα και το stack trace σε Discord ή GitHub για να μπορέσουμε να βοηθήσουμε. Αν σας ζητηθεί, μπορείτε να διαγράψετε τα δεδομένα της εφαρμογής παρακάτω.",
"scan": "Σάρωση", "scan": "Σάρωση",
"scan_all_libraries": "Σάρωση Όλων των Βιβλιοθηκών", "scan_all_libraries": "Σάρωση Όλων των Βιβλιοθηκών",
"scan_library": "Σάρωση", "scan_library": "Σάρωση",
@@ -1938,6 +1951,7 @@
"search_filter_ocr": "Αναζήτηση κατά OCR", "search_filter_ocr": "Αναζήτηση κατά OCR",
"search_filter_people_title": "Επιλέξτε άτομα", "search_filter_people_title": "Επιλέξτε άτομα",
"search_filter_star_rating": "Βαθμολογία με αστέρια", "search_filter_star_rating": "Βαθμολογία με αστέρια",
"search_filter_tags_title": "Επιλογή ετικετών",
"search_for": "Αναζήτηση για", "search_for": "Αναζήτηση για",
"search_for_existing_person": "Αναζήτηση υπάρχοντος ατόμου", "search_for_existing_person": "Αναζήτηση υπάρχοντος ατόμου",
"search_no_more_result": "Δεν υπάρχουν άλλα αποτελέσματα", "search_no_more_result": "Δεν υπάρχουν άλλα αποτελέσματα",
@@ -2017,6 +2031,9 @@
"set_profile_picture": "Ορισμός εικόνας προφίλ", "set_profile_picture": "Ορισμός εικόνας προφίλ",
"set_slideshow_to_fullscreen": "Ορίστε την παρουσίαση σε πλήρη οθόνη", "set_slideshow_to_fullscreen": "Ορίστε την παρουσίαση σε πλήρη οθόνη",
"set_stack_primary_asset": "Ορισμός ως κύριο στοιχείο", "set_stack_primary_asset": "Ορισμός ως κύριο στοιχείο",
"setting_image_navigation_enable_subtitle": "Αν είναι ενεργοποιημένο, μπορείτε να μεταβείτε στην προηγούμενη/επόμενη εικόνα πατώντας στο αριστερότερο/δεξιότερο τέταρτο της οθόνης.",
"setting_image_navigation_enable_title": "Πατήστε για Περιήγηση",
"setting_image_navigation_title": "Περιήγηση εικόνων",
"setting_image_viewer_help": "Το πρόγραμμα προβολής λεπτομερειών φορτώνει πρώτα τη μικρογραφία, στη συνέχεια φορτώνει την προεπισκόπηση μεσαίου μεγέθους (αν είναι ενεργοποιημένη), τέλος φορτώνει το πρωτότυπο (αν είναι ενεργοποιημένο).", "setting_image_viewer_help": "Το πρόγραμμα προβολής λεπτομερειών φορτώνει πρώτα τη μικρογραφία, στη συνέχεια φορτώνει την προεπισκόπηση μεσαίου μεγέθους (αν είναι ενεργοποιημένη), τέλος φορτώνει το πρωτότυπο (αν είναι ενεργοποιημένο).",
"setting_image_viewer_original_subtitle": "Ενεργοποιήστε τη φόρτωση της πρωτότυπης εικόνας πλήρους ανάλυσης (μεγάλη!). Απενεργοποιήστε για να μειώσετε τη χρήση δεδομένων (τόσο στο δίκτυο όσο και στην κρυφή μνήμη της συσκευής).", "setting_image_viewer_original_subtitle": "Ενεργοποιήστε τη φόρτωση της πρωτότυπης εικόνας πλήρους ανάλυσης (μεγάλη!). Απενεργοποιήστε για να μειώσετε τη χρήση δεδομένων (τόσο στο δίκτυο όσο και στην κρυφή μνήμη της συσκευής).",
"setting_image_viewer_original_title": "Φόρτωση πρωτότυπης εικόνας", "setting_image_viewer_original_title": "Φόρτωση πρωτότυπης εικόνας",
@@ -2183,6 +2200,7 @@
"support": "Υποστήριξη", "support": "Υποστήριξη",
"support_and_feedback": "Υποστήριξη & Σχόλια", "support_and_feedback": "Υποστήριξη & Σχόλια",
"support_third_party_description": "Η εγκατάσταση του Immich που χρησιμοποιείτε, έχει πακεταριστεί από τρίτους. Τα προβλήματα που αντιμετωπίζετε μπορεί να οφείλονται σε αυτό το πακέτο, οπότε παρακαλούμε να αναφέρετε τα προβλήματα πρώτα σε εκείνους, χρησιμοποιώντας τους παρακάτω συνδέσμους.", "support_third_party_description": "Η εγκατάσταση του Immich που χρησιμοποιείτε, έχει πακεταριστεί από τρίτους. Τα προβλήματα που αντιμετωπίζετε μπορεί να οφείλονται σε αυτό το πακέτο, οπότε παρακαλούμε να αναφέρετε τα προβλήματα πρώτα σε εκείνους, χρησιμοποιώντας τους παρακάτω συνδέσμους.",
"supporter": "Υποστηρικτής",
"swap_merge_direction": "Εναλλαγή κατεύθυνσης συγχώνευσης", "swap_merge_direction": "Εναλλαγή κατεύθυνσης συγχώνευσης",
"sync": "Συγχρονισμός", "sync": "Συγχρονισμός",
"sync_albums": "Συγχρονισμός άλμπουμ", "sync_albums": "Συγχρονισμός άλμπουμ",
@@ -2294,6 +2312,7 @@
"unstack_action_prompt": "{count} αποσυσσωρεύτηκαν", "unstack_action_prompt": "{count} αποσυσσωρεύτηκαν",
"unstacked_assets_count": "Αποστοιβάξατε {count, plural, one {# στοιχείο} other {# στοιχεία}}", "unstacked_assets_count": "Αποστοιβάξατε {count, plural, one {# στοιχείο} other {# στοιχεία}}",
"unsupported_field_type": "Μη υποστηριζόμενος τύπος πεδίου", "unsupported_field_type": "Μη υποστηριζόμενος τύπος πεδίου",
"unsupported_file_type": "Το αρχείο {file} δεν μπορεί να μεταφορτωθεί επειδή ο τύπος αρχείου {type} δεν υποστηρίζεται.",
"untagged": "Χωρίς ετικέτα", "untagged": "Χωρίς ετικέτα",
"untitled_workflow": "Νέα ροή εργασίας", "untitled_workflow": "Νέα ροή εργασίας",
"up_next": "Ακολουθεί", "up_next": "Ακολουθεί",
@@ -2320,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Χρήση", "usage": "Χρήση",
"use_biometric": "Χρήση βιομετρικών στοιχείων", "use_biometric": "Χρήση βιομετρικών στοιχείων",
"use_browser_locale": "Χρήση γλώσσας προγράμματος περιήγησης",
"use_browser_locale_description": "Μορφοποιήστε τις ημερομηνίες, τους χρόνους και τους αριθμούς σύμφωνα με τη γλώσσα του προγράμματος περιήγησής σας",
"use_current_connection": "Χρήση τρέχουσας σύνδεσης", "use_current_connection": "Χρήση τρέχουσας σύνδεσης",
"use_custom_date_range": "Χρήση προσαρμοσμένου εύρους ημερομηνιών", "use_custom_date_range": "Χρήση προσαρμοσμένου εύρους ημερομηνιών",
"user": "Χρήστης", "user": "Χρήστης",
+19 -8
View File
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Tone-mapping", "transcoding_tone_mapping": "Tone-mapping",
"transcoding_tone_mapping_description": "Attempts to preserve the appearance of HDR videos when converted to SDR. Each algorithm makes different tradeoffs for color, detail and brightness. Hable preserves detail, Mobius preserves color, and Reinhard preserves brightness.", "transcoding_tone_mapping_description": "Attempts to preserve the appearance of HDR videos when converted to SDR. Each algorithm makes different tradeoffs for color, detail and brightness. Hable preserves detail, Mobius preserves color, and Reinhard preserves brightness.",
"transcoding_transcode_policy": "Transcode policy", "transcoding_transcode_policy": "Transcode policy",
"transcoding_transcode_policy_description": "Policy for when a video should be transcoded. HDR videos will always be transcoded (except if transcoding is disabled).", "transcoding_transcode_policy_description": "Policy for when a video should be transcoded. HDR videos and videos with a pixel format other than YUV 4:2:0 will always be transcoded (except if transcoding is disabled).",
"transcoding_two_pass_encoding": "Two-pass encoding", "transcoding_two_pass_encoding": "Two-pass encoding",
"transcoding_two_pass_encoding_setting_description": "Transcode in two passes to produce better encoded videos. When max bitrate is enabled (required for it to work with H.264 and HEVC), this mode uses a bitrate range based on the max bitrate and ignores CRF. For VP9, CRF can be used if max bitrate is disabled.", "transcoding_two_pass_encoding_setting_description": "Transcode in two passes to produce better encoded videos. When max bitrate is enabled (required for it to work with H.264 and HEVC), this mode uses a bitrate range based on the max bitrate and ignores CRF. For VP9, CRF can be used if max bitrate is disabled.",
"transcoding_video_codec": "Video codec", "transcoding_video_codec": "Video codec",
@@ -871,8 +871,8 @@
"current_pin_code": "Current PIN code", "current_pin_code": "Current PIN code",
"current_server_address": "Current server address", "current_server_address": "Current server address",
"custom_date": "Custom date", "custom_date": "Custom date",
"custom_locale": "Custom Locale", "custom_locale": "Custom locale",
"custom_locale_description": "Format dates and numbers based on the language and the region", "custom_locale_description": "Format dates, times, and numbers based on the selected language and region",
"custom_url": "Custom URL", "custom_url": "Custom URL",
"cutoff_date_description": "Keep photos from the last…", "cutoff_date_description": "Keep photos from the last…",
"cutoff_day": "{count, plural, one {day} other {days}}", "cutoff_day": "{count, plural, one {day} other {days}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Count of EXIF data", "deduplication_criteria_2": "Count of EXIF data",
"deduplication_info": "Deduplication Info", "deduplication_info": "Deduplication Info",
"deduplication_info_description": "To automatically preselect assets and remove duplicates in bulk, we look at:", "deduplication_info_description": "To automatically preselect assets and remove duplicates in bulk, we look at:",
"default_locale": "Default Locale",
"default_locale_description": "Format dates and numbers based on your browser locale",
"delete": "Delete", "delete": "Delete",
"delete_action_confirmation_message": "Are you sure you want to delete this asset? This action will move the asset to the server's trash and will prompt if you want to delete it locally", "delete_action_confirmation_message": "Are you sure you want to delete this asset? This action will move the asset to the server's trash and will prompt if you want to delete it locally",
"delete_action_prompt": "{count} deleted", "delete_action_prompt": "{count} deleted",
@@ -1009,6 +1007,8 @@
"editor_edits_applied_success": "Edits applied successfully", "editor_edits_applied_success": "Edits applied successfully",
"editor_flip_horizontal": "Flip horizontal", "editor_flip_horizontal": "Flip horizontal",
"editor_flip_vertical": "Flip vertical", "editor_flip_vertical": "Flip vertical",
"editor_handle_corner": "{corner, select, top_left {Top-left} top_right {Top-right} bottom_left {Bottom-left} bottom_right {Bottom-right} other {A}} corner handle",
"editor_handle_edge": "{edge, select, top {Top} bottom {Bottom} left {Left} right {Right} other {An}} edge handle",
"editor_orientation": "Orientation", "editor_orientation": "Orientation",
"editor_reset_all_changes": "Reset changes", "editor_reset_all_changes": "Reset changes",
"editor_rotate_left": "Rotate 90° counterclockwise", "editor_rotate_left": "Rotate 90° counterclockwise",
@@ -1074,6 +1074,7 @@
"failed_to_update_notification_status": "Failed to update notification status", "failed_to_update_notification_status": "Failed to update notification status",
"incorrect_email_or_password": "Incorrect email or password", "incorrect_email_or_password": "Incorrect email or password",
"library_folder_already_exists": "This import path already exists.", "library_folder_already_exists": "This import path already exists.",
"page_not_found": "Page not found",
"paths_validation_failed": "{paths, plural, one {# path} other {# paths}} failed validation", "paths_validation_failed": "{paths, plural, one {# path} other {# paths}} failed validation",
"profile_picture_transparent_pixels": "Profile pictures cannot have transparent pixels. Please zoom in and/or move the image.", "profile_picture_transparent_pixels": "Profile pictures cannot have transparent pixels. Please zoom in and/or move the image.",
"quota_higher_than_disk_size": "You set a quota higher than the disk size", "quota_higher_than_disk_size": "You set a quota higher than the disk size",
@@ -1650,6 +1651,7 @@
"only_favorites": "Only favorites", "only_favorites": "Only favorites",
"open": "Open", "open": "Open",
"open_calendar": "Open calendar", "open_calendar": "Open calendar",
"open_in_browser": "Open in browser",
"open_in_map_view": "Open in map view", "open_in_map_view": "Open in map view",
"open_in_openstreetmap": "Open in OpenStreetMap", "open_in_openstreetmap": "Open in OpenStreetMap",
"open_the_search_filters": "Open the search filters", "open_the_search_filters": "Open the search filters",
@@ -1809,9 +1811,8 @@
"rate_asset": "Rate Asset", "rate_asset": "Rate Asset",
"rating": "Star rating", "rating": "Star rating",
"rating_clear": "Clear rating", "rating_clear": "Clear rating",
"rating_count": "{count, plural, one {# star} other {# stars}}", "rating_count": "{count, plural, =0 {Unrated} one {# star} other {# stars}}",
"rating_description": "Display the EXIF rating in the info panel", "rating_description": "Display the EXIF rating in the info panel",
"rating_set": "Rating set to {rating, plural, one {# star} other {# stars}}",
"reaction_options": "Reaction options", "reaction_options": "Reaction options",
"read_changelog": "Read Changelog", "read_changelog": "Read Changelog",
"readonly_mode_disabled": "Read-only mode disabled", "readonly_mode_disabled": "Read-only mode disabled",
@@ -1883,7 +1884,10 @@
"reset_pin_code_success": "Successfully reset PIN code", "reset_pin_code_success": "Successfully reset PIN code",
"reset_pin_code_with_password": "You can always reset your PIN code with your password", "reset_pin_code_with_password": "You can always reset your PIN code with your password",
"reset_sqlite": "Reset SQLite Database", "reset_sqlite": "Reset SQLite Database",
"reset_sqlite_confirmation": "Are you sure you want to reset the SQLite database? You will need to log out and log in again to resync the data", "reset_sqlite_clear_app_data": "Clear Data",
"reset_sqlite_confirmation": "Are you sure you want to clear the app data? This will remove all settings and sign you out.",
"reset_sqlite_confirmation_note": "Note: You will need to restart the app after clearing.",
"reset_sqlite_done": "App data has been cleared. Please restart Immich and log in again.",
"reset_sqlite_success": "Successfully reset the SQLite database", "reset_sqlite_success": "Successfully reset the SQLite database",
"reset_to_default": "Reset to default", "reset_to_default": "Reset to default",
"resolution": "Resolution", "resolution": "Resolution",
@@ -1911,6 +1915,7 @@
"saved_settings": "Saved settings", "saved_settings": "Saved settings",
"say_something": "Say something", "say_something": "Say something",
"scaffold_body_error_occurred": "Error occurred", "scaffold_body_error_occurred": "Error occurred",
"scaffold_body_error_unrecoverable": "An unrecoverable error has occurred. Please share the error and stack trace on Discord or GitHub so we can help. If advised, you can clear the app data below.",
"scan": "Scan", "scan": "Scan",
"scan_all_libraries": "Scan All Libraries", "scan_all_libraries": "Scan All Libraries",
"scan_library": "Scan", "scan_library": "Scan",
@@ -2026,6 +2031,9 @@
"set_profile_picture": "Set profile picture", "set_profile_picture": "Set profile picture",
"set_slideshow_to_fullscreen": "Set Slideshow to fullscreen", "set_slideshow_to_fullscreen": "Set Slideshow to fullscreen",
"set_stack_primary_asset": "Set as primary asset", "set_stack_primary_asset": "Set as primary asset",
"setting_image_navigation_enable_subtitle": "If enabled, you can navigate to the previous/next image by tapping the leftmost/rightmost quarter of the screen.",
"setting_image_navigation_enable_title": "Tap to Navigate",
"setting_image_navigation_title": "Image Navigation",
"setting_image_viewer_help": "The detail viewer loads the small thumbnail first, then loads the medium-size preview (if enabled), finally loads the original (if enabled).", "setting_image_viewer_help": "The detail viewer loads the small thumbnail first, then loads the medium-size preview (if enabled), finally loads the original (if enabled).",
"setting_image_viewer_original_subtitle": "Enable to load the original full-resolution image (large!). Disable to reduce data usage (both network and on device cache).", "setting_image_viewer_original_subtitle": "Enable to load the original full-resolution image (large!). Disable to reduce data usage (both network and on device cache).",
"setting_image_viewer_original_title": "Load original image", "setting_image_viewer_original_title": "Load original image",
@@ -2304,6 +2312,7 @@
"unstack_action_prompt": "{count} unstacked", "unstack_action_prompt": "{count} unstacked",
"unstacked_assets_count": "Un-stacked {count, plural, one {# asset} other {# assets}}", "unstacked_assets_count": "Un-stacked {count, plural, one {# asset} other {# assets}}",
"unsupported_field_type": "Unsupported field type", "unsupported_field_type": "Unsupported field type",
"unsupported_file_type": "File {file} can't be uploaded because its file type {type} is not supported.",
"untagged": "Untagged", "untagged": "Untagged",
"untitled_workflow": "Untitled workflow", "untitled_workflow": "Untitled workflow",
"up_next": "Up next", "up_next": "Up next",
@@ -2330,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Usage", "usage": "Usage",
"use_biometric": "Use biometric", "use_biometric": "Use biometric",
"use_browser_locale": "Use browser locale",
"use_browser_locale_description": "Format dates, times, and numbers based on your browser locale",
"use_current_connection": "Use current connection", "use_current_connection": "Use current connection",
"use_custom_date_range": "Use custom date range instead", "use_custom_date_range": "Use custom date range instead",
"user": "User", "user": "User",
+246 -4
View File
@@ -1,7 +1,7 @@
{ {
"about": "Pri", "about": "Pri",
"account": "Konto", "account": "Konto",
"account_settings": "Agordoj de konto", "account_settings": "Agordoj pri konto",
"acknowledge": "Komprenite", "acknowledge": "Komprenite",
"action": "Ago", "action": "Ago",
"action_common_update": "Ĝisdatigi", "action_common_update": "Ĝisdatigi",
@@ -311,7 +311,7 @@
"search_jobs": "Serĉi taskojn…", "search_jobs": "Serĉi taskojn…",
"send_welcome_email": "Sendi bonvenan retmesaĝon", "send_welcome_email": "Sendi bonvenan retmesaĝon",
"server_external_domain_settings": "Ekstera domajno", "server_external_domain_settings": "Ekstera domajno",
"server_external_domain_settings_description": "Domajno por publike dividitaj ligiloj, inkl. http(s)://", "server_external_domain_settings_description": "Domajno por eksteraj ligiloj",
"server_public_users": "Publikaj uzantoj", "server_public_users": "Publikaj uzantoj",
"server_public_users_description": "Nomo kaj retadreso de ĉiuj uzantoj estas listigitaj kiam oni aldonas uzanton al dividita albumo. Kiam malŝaltita, la listo de uzantoj estos videbla nur por administrantoj.", "server_public_users_description": "Nomo kaj retadreso de ĉiuj uzantoj estas listigitaj kiam oni aldonas uzanton al dividita albumo. Kiam malŝaltita, la listo de uzantoj estos videbla nur por administrantoj.",
"server_settings": "Agordoj de servilo", "server_settings": "Agordoj de servilo",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mapado de tonoj", "transcoding_tone_mapping": "Mapado de tonoj",
"transcoding_tone_mapping_description": "Klopodas konservi aspekton de HDR-videoj dum transkodigo al SDR. Ĉiu algoritmo faras proprajn kompromisojn pri koloroj, detaloj kaj heleco. Hable konservas detalojn, Mobius konservas kolorojn, kaj Reinhard konservas helecon.", "transcoding_tone_mapping_description": "Klopodas konservi aspekton de HDR-videoj dum transkodigo al SDR. Ĉiu algoritmo faras proprajn kompromisojn pri koloroj, detaloj kaj heleco. Hable konservas detalojn, Mobius konservas kolorojn, kaj Reinhard konservas helecon.",
"transcoding_transcode_policy": "Politiko de transkodado", "transcoding_transcode_policy": "Politiko de transkodado",
"transcoding_transcode_policy_description": "Politiko pri kiam video estos transkodita. HDR-videoj ĉiam estas transkoditaj (krom se transkodado estas malŝaltita).", "transcoding_transcode_policy_description": "Politiko pri kiam video estos transkodita. HDR-videoj, kune kun videoj kun ciuj bilderaj formatoj krom YUV 4:2:0, ĉiam estas transkoditaj (krom se transkodado estas malŝaltita).",
"transcoding_two_pass_encoding": "Dupasa kodigo", "transcoding_two_pass_encoding": "Dupasa kodigo",
"transcoding_two_pass_encoding_setting_description": "Transkodigo per du pasoj por krei pli bone kodigitajn videojn. Kiam eblas uzi maksimuman bitrapidon (bezonate por funkcii kun H.264 kaj kun HEVC), tiu ĉi modo uzas gamon de bitrapidoj surbaze de tiu maksimumo, kaj ignoras CRF. Por VP9, eblas uzi CRF se maksimuma bitrapido estas malŝaltita.", "transcoding_two_pass_encoding_setting_description": "Transkodigo per du pasoj por krei pli bone kodigitajn videojn. Kiam eblas uzi maksimuman bitrapidon (bezonate por funkcii kun H.264 kaj kun HEVC), tiu ĉi modo uzas gamon de bitrapidoj surbaze de tiu maksimumo, kaj ignoras CRF. Por VP9, eblas uzi CRF se maksimuma bitrapido estas malŝaltita.",
"transcoding_video_codec": "Videa kodeko", "transcoding_video_codec": "Videa kodeko",
@@ -433,9 +433,248 @@
"user_details": "Detaloj pri uzanto", "user_details": "Detaloj pri uzanto",
"user_management": "Administrado de uzantoj", "user_management": "Administrado de uzantoj",
"user_password_has_been_reset": "Pasvorto de tiu ĉi uzanto estas restarigita:", "user_password_has_been_reset": "Pasvorto de tiu ĉi uzanto estas restarigita:",
"user_settings_description": "Administri agordojn pri uzantoj" "user_password_reset_description": "Bonvolu sendi la dumtempan pasvorton al la uzanto, kaj informu ke ĝi devos esti ŝanĝita je la sekva ensaluto.",
"user_restore_description": "La konto de <b>{user}</b> estos restaŭrita.",
"user_restore_scheduled_removal": "Restaŭri uzanton - forviŝo planita je {date, date, long}",
"user_settings": "Agordoj de uzanto",
"user_settings_description": "Administri agordojn pri uzantoj",
"user_successfully_removed": "La uzanto {email} estas forigita.",
"users_page_description": "Paĝo por administri uzantojn",
"version_check_enabled_description": "Ebligi kontrolon de versio",
"version_check_implications": "La funkcio de kontrolado de versio bezonas de temp' al tempan komunikadon kun github.com",
"version_check_settings": "Kontrolo de versio",
"version_check_settings_description": "Ŝalti/malŝalti atentigilon pri novaj versioj",
"video_conversion_job": "Transkodado de videoj",
"video_conversion_job_description": "Transkodi videojn por pli vasta kongruo kun retumiloj kaj aparatoj"
}, },
"admin_email": "Retadreso de administranto",
"admin_password": "Pasvorto de administranto",
"administration": "Administrado",
"advanced": "Altnivelaj agordoj",
"advanced_settings_clear_image_cache": "Malplenigi kaŝmemoron de bildoj",
"advanced_settings_clear_image_cache_error": "Malsukcesis malplenigi kaŝmemoron",
"advanced_settings_clear_image_cache_success": "Sukcesis liberigi {size}",
"advanced_settings_enable_alternate_media_filter_subtitle": "Uzu tiun ĉi agordon por filtri elementojn dum sinkronigo laŭ alternativaj kriterioj. Uzu tion ĉi nur se vi vidas, ke la apo ne sukcesas trovi ĉiujn albumojn.",
"advanced_settings_enable_alternate_media_filter_title": "[TESTATA] Uzi alternativan filtrilon por sinkronigi albumojn",
"advanced_settings_log_level_title": "Nivelo de protokolado: {level}",
"advanced_settings_prefer_remote_subtitle": "Kelkaj aparatoj ege malrapide ŝargas bildetojn el lokaj elementoj. Ŝaltu tiun ĉi agordon por anstataŭe ŝargi bildetojn de la servilo.",
"advanced_settings_prefer_remote_title": "Preferi bildojn el servilo",
"advanced_settings_proxy_headers_subtitle": "Aldoni paĝokapoj pri prokurilo, kiujn immich sendu kun ĉiu reta peto",
"advanced_settings_proxy_headers_title": "Tajloritaj paĝokapoj pri prokurilo [EKSPERIMENTA]",
"advanced_settings_readonly_mode_subtitle": "Ŝaltas nurlegan reĝimon, kie oni povas nur rigardi fotojn. Funkcioj kiel elekti plurajn bildojn, dividi kun aliaj, forigi k.a. estas ĉiuj neeblaj. Vi povas ŝalti/malŝalti tiun reĝimon per la profilbildo de uzanto ĉe la hejmpaĝo",
"advanced_settings_readonly_mode_title": "Nurlega reĝimo",
"advanced_settings_self_signed_ssl_subtitle": "Ignoras kontrolon de SSL-atestilo ĉe la servilo. Bezonata por memsubskribita atestilo.",
"advanced_settings_self_signed_ssl_title": "Permesi memsubskribitajn SSL-atestilojn [EKSPERIMENTA]",
"advanced_settings_sync_remote_deletions_subtitle": "Aŭtomate forigi aŭ malforigi elementojn en tiu ĉi aparato kiam oni faras tiun agon per retumilo",
"advanced_settings_sync_remote_deletions_title": "Sinkronigi forigojn [EKSPERIMENTA]",
"advanced_settings_tile_subtitle": "Altnivelaj agordaĵoj",
"advanced_settings_troubleshooting_subtitle": "Ŝalti pliajn funkciojn por problemsolvi",
"advanced_settings_troubleshooting_title": "Problemsolvi",
"age_months": "Aĝo {months, plural, one {# monato} other {# monatoj}}",
"age_year_months": "Aĝo 1 jaro, {months, plural, one {# monato} other {# monatoj}}",
"age_years": "Aĝo {years, plural, one {# jaro} other {# jaroj}}",
"album": "Albumo",
"album_added": "Albumo aldonita",
"album_added_notification_setting_description": "Ricevi retmesaĝon kiam iu aldonas vin al dividita albumo",
"album_cover_updated": "Kovrilo de albumo ĝisdatigita",
"album_delete_confirmation": "Ĉu vi certas, ke vi volas forigi la albumon {album}?",
"album_delete_confirmation_description": "Se temas pri dividita albumo, aliaj uzantoj ne plu povos vidi ĝin.",
"album_deleted": "Albumo forigita",
"album_info_card_backup_album_excluded": "EKSKLUDITA",
"album_info_card_backup_album_included": "INKLUZIVITA",
"album_info_updated": "Informoj pri albumo ĝisdatigitaj",
"album_leave": "Foriri de albumo?",
"album_leave_confirmation": "Ĉu vi certas, ke vi volas forlasi la albumon {album}?",
"album_name": "Nomo de albumo",
"album_options": "Agordoj de albumo",
"album_remove_user": "Ĉu forigi uzanton?",
"album_remove_user_confirmation": "Ĉu vi certas, ke vi volas forigi la uzanton {user}?",
"album_search_not_found": "Neniu albumo kongruas kun via serĉo",
"album_selected": "Albumo elektita",
"album_share_no_users": "Ŝajne vi jam dividis tiun albumon kun ĉiuj uzantoj AŬ ne ekzistas uzantoj kun kiuj vi povus dividi ĝin.",
"album_summary": "Resumo de albumo",
"album_updated": "Albumo ĝisdatigita",
"album_updated_setting_description": "Ricevi retmesaĝon kiam dividita albumo havas novajn elementojn",
"album_upload_assets": "Alŝuti elementojn el via komputilo kaj aldoni ilin al albumo",
"album_user_left": "Foriris de {album}",
"album_user_removed": "Uzanto {user} forigita",
"album_viewer_appbar_delete_confirm": "Ĉu vi certas, ke vi volas forigi tiun ĉi albumon de via konto?",
"album_viewer_appbar_share_err_delete": "Malsukcesis forigi albumon",
"album_viewer_appbar_share_err_leave": "Malsukcesis foriri de albumo",
"album_viewer_appbar_share_err_remove": "Okazis problemo dum forigo de elementoj el albumo",
"album_viewer_appbar_share_err_title": "Malsukcesis ŝanĝi titolon de albumo",
"album_viewer_appbar_share_leave": "Foriri de albumo",
"album_viewer_appbar_share_to": "Dividi al",
"album_viewer_page_share_add_users": "Aldoni uzantojn",
"album_with_link_access": "Permesi, ke iu ajn kun la ligilo povu vidi la fotojn kaj homojn en la albumo.",
"albums": "Albumoj",
"albums_count": "{count, plural, one {{count, number} Albumo} other {{count, number} Albumoj}}",
"albums_default_sort_order": "Defaŭlta vicordigo en albumoj",
"albums_default_sort_order_description": "Metodo por vicordigi elementojn defaŭlte uzata en nova albumo.",
"albums_feature_description": "Kolektoj de elementoj, kiujn vi povas dividi kun aliaj uzantoj.",
"albums_on_device_count": "Albumoj ĉe la aparato ({count})",
"albums_selected": "{count, plural, one {# albumo elektita} other {# albumoj elektitaj}}",
"all": "Ĉiuj",
"all_albums": "Ĉiuj albumoj",
"all_people": "Ĉiuj homoj",
"all_photos": "Ĉiuj fotoj",
"all_videos": "Ĉiuj videoj",
"allow_dark_mode": "Permesi malhelan reĝimon",
"allow_edits": "Permesi redaktojn",
"allow_public_user_to_download": "Permesu, ke publikano elŝutu el la albumo",
"allow_public_user_to_upload": "Permesu, ke publikano alŝutu al la albumo",
"allowed": "Permesita",
"alt_text_qr_code": "Bildo de QR-kodo",
"always_keep": "Ĉiam konservi",
"always_keep_photos_hint": "La funkcio 'Liberigi spacon' konservos ĉiujn fotojn en tiu ĉi aparato.",
"always_keep_videos_hint": "La funkcio 'Liberigi spacon\" konservos ĉiujn videojn en tiu ĉi aparato.",
"anti_clockwise": "Kontraŭ-horloĝdirekte",
"api_key": "API-ŝlosilo",
"api_key_description": "Tio ĉi montriĝos nur unufoje. Certiĝu, ke vi kopiis ĝin antaŭ ol fermi la fenestron.",
"api_key_empty": "La nomo de via API-ŝlosilo ne devus esti malplena",
"api_keys": "API-ŝlosiloj",
"app_architecture_variant": "Varianto (arkitekturo)",
"app_bar_signout_dialog_content": "Ĉu vi certas, ke vi volas elsaluti?",
"app_bar_signout_dialog_ok": "Jes",
"app_bar_signout_dialog_title": "Elsaluti",
"app_download_links": "Ligiloj por elŝuti la apon",
"app_settings": "Agordoj pri apo",
"app_stores": "Ap-vendejoj",
"app_update_available": "Ĝisdatigo de apo disponeblas",
"appears_in": "Aperas en",
"apply_count": "Apliki ({count, number})",
"archive": "Arĥivo",
"archive_action_prompt": "{count} aldonita(j) al arĥivo",
"archive_or_unarchive_photo": "Enarĥivigi aŭ elarĥivigi foton",
"archive_page_no_archived_assets": "Neniuj elementoj trovitaj en arĥivo",
"archive_page_title": "Arĥivo ({count})",
"archive_size": "Grandeco de arĥivo",
"archive_size_description": "Agordu la grandecon de arĥivaj dosieroj por elŝuti (en GiB)",
"archived": "Enarĥivigita(j)",
"archived_count": "{count, plural, one {# enarĥivigita} other {# enarĥivigitaj}}",
"are_these_the_same_person": "Ĉu la sama homo?",
"are_you_sure_to_do_this": "Ĉu vi certas, ke vi volas fari tion?",
"array_field_not_fully_supported": "Tablaj kampoj postulas permanan redakton de JSON",
"asset_action_delete_err_read_only": "Ne eblas forigi nurlegajn elementojn, ili estos lasitaj senŝanĝaj",
"asset_action_share_err_offline": "Ne eblis repreni nekonektitajn elementojn, ili estos ignoritaj",
"asset_added_to_album": "Aldonita al albumo",
"asset_adding_to_album": "Aldonas al albumo…",
"asset_created": "Elemento kreita",
"asset_description_updated": "Priskribo de elemento ĝisdatigita",
"asset_filename_is_offline": "Elemento {filename} estas nedisponebla",
"asset_has_unassigned_faces": "Elemento enhavas nekonatajn vizaĝojn",
"asset_hashing": "Haketado…",
"asset_list_group_by_sub_title": "Grupigi laŭ",
"asset_list_layout_settings_dynamic_layout_title": "Dinamika enpaĝigo",
"asset_list_layout_settings_group_automatically": "Aŭtomata",
"asset_list_layout_settings_group_by": "Ĝrupigi elementojn laŭ",
"asset_list_layout_settings_group_by_month_day": "Monato + tago",
"asset_list_layout_sub_title": "Enpaĝigo",
"asset_list_settings_subtitle": "Agordoj pri enpaĝigo",
"asset_list_settings_title": "Krado de fotoj",
"asset_not_found_on_device_android": "Elemento ne trovita en aparato",
"asset_not_found_on_device_ios": "Elemento ne trovita en aparato. Se vi uzas iCloud, povus esti ke la kopio ĉe iCloud estas rompita",
"asset_not_found_on_icloud": "Elemento ne trovita en iCloud. Povus esti, ke la kopio ĉe iCloud estas rompita",
"asset_offline": "Elemento nedisponebla",
"asset_offline_description": "Ne eblis trovi tiun eksteran elementon. Kontaktu la administranton de via Immich por helpo pri tio.",
"asset_restored_successfully": "Elemento sukcese riparita",
"asset_skipped": "Preterlasita(j)",
"asset_skipped_in_trash": "En rubujo",
"asset_trashed": "Elemento enrubujigita",
"asset_troubleshoot": "Problemsolvi pri elemento",
"asset_uploaded": "Alŝutita(j)",
"asset_uploading": "Alŝutado…",
"asset_viewer_settings_subtitle": "Administri agordojn pri vidilo de galerioj", "asset_viewer_settings_subtitle": "Administri agordojn pri vidilo de galerioj",
"asset_viewer_settings_title": "Montrilo de elemento",
"assets": "Elementoj",
"assets_added_count": "Sukcese aldonis {count, plural, one {# elementon} other {# elementojn}}",
"assets_added_to_album_count": "Sukcese aldonis {count, plural, one {# elementon} other {# elementojn}} al la albumo",
"assets_added_to_albums_count": "Sukcese aldonis {assetTotal, plural, one {# elementon} other {# elementojn}} al {albumTotal, plural, one {# albumo} other {# albumoj}}",
"assets_cannot_be_added_to_album_count": "Ne eblis aldoni {count, plural, one {tiun elementon} other {tiujn elementojn}} al la albumo",
"assets_cannot_be_added_to_albums": "Ne eblis aldoni {count, plural, one {tiun elementon} other {tiujn elementojn}} al iu ajn el la albumoj",
"assets_count": "{count, plural, one {# elemento} other {# elementoj}}",
"assets_deleted_permanently": "{count} elemento(j) porĉiam forigita(j)",
"assets_deleted_permanently_from_server": "{count} elemento(j) porĉiam forigita(j) de la Immich-servilo",
"assets_downloaded_failed": "{count, plural, one {Elŝutis # dosieron - dosiero {error} malsukcesis} other {Elŝutis # dosierojn - dosieroj {error} malsukcesis}}",
"assets_downloaded_successfully": "{count, plural, one {Sukcese elŝutis # dosieron} other {Sukcese elŝutis # dosierojn}}",
"assets_moved_to_trash_count": "Movis {count, plural, one {# elementon} other {# elementojn}} al la rubujo",
"assets_permanently_deleted_count": "Porĉiam forigis {count, plural, one {# elementon} other {# elementojn}}",
"assets_removed_count": "Forigis {count, plural, one {# elementon} other {# elementojn}}",
"assets_removed_permanently_from_device": "{count} elemento(j) porĉiam forigita(j) de via aparato",
"assets_restore_confirmation": "Ĉu vi certas, ke vi volas restaŭri ĉion el la rubujo? Ne eblos poste malfari tion. Notu, ke ne eblas tiel restaŭri eksterretajn elementojn.",
"assets_restored_count": "Sukcese restaŭris {count, plural, one {# elementon} other {# elementojn}}",
"assets_restored_successfully": "{count} elemento(j) sukcese restaŭrita(j)",
"assets_trashed": "{count} elemento(j) enrubujigita(j)",
"assets_trashed_count": "Sukcese enrubujigis {count, plural, one {# elementon} other {# elementojn}}",
"assets_trashed_from_server": "{count} elemento(j) forigitaj de la immich-servilo",
"assets_were_part_of_album_count": "{count, plural, one {# Tiu elemento} other {# Tiuj elementoj}} jam estis en la albumo",
"assets_were_part_of_albums_count": "{count, plural, one {# Tiu elemento} other {# Tiuj elementoj}} jam estis en la albumoj",
"authorized_devices": "Aprobitaj aparatoj",
"automatic_endpoint_switching_subtitle": "Konekti per elektita vifio kiam eblas, kaj alikaze uzi aliajn alirojn",
"automatic_endpoint_switching_title": "Aŭtomata ŝanĝo de URL",
"autoplay_slideshow": "Aŭtomate vidigi bildserion",
"back": "Malantaŭen",
"back_close_deselect": "Malantaŭen, fermi, aŭ malelekti",
"background_backup_running_error": "Sekurkopiado jam estas fone okazanta, do ne eblas nun lanĉi alian sekurkopiadon",
"background_location_permission": "Rajtigo fone uzi geografian lokon",
"background_location_permission_content": "Por ŝanĝi retaliron dum fona funkciado, Immich devas *ĉiam* havi atingorajton al lokiga informo, por povi legi nomojn de vifiaj retoj",
"background_options": "Agordoj pri fonaj funkcioj",
"backup": "Sekurkopio",
"backup_album_selection_page_albums_device": "Albumoj en la aparato ({count})",
"backup_album_selection_page_albums_tap": "Tuŝeti por inkluzivi, duoble tuŝeti por ekskludi",
"backup_album_selection_page_assets_scatter": "Foje elementoj troviĝas disĵetitaj al pluraj albumoj, do albumoj povas esti inkluzivitaj aŭ ekskluzivitaj de la savkopiado.",
"backup_album_selection_page_select_albums": "Elekti albumojn",
"backup_album_selection_page_selection_info": "Info pri la elektitaĵoj",
"backup_album_selection_page_total_assets": "Nombro da unikaj elementoj",
"backup_albums_sync": "Sinkronigo de la savkopioj de albumoj",
"backup_all": "Ĉiuj",
"backup_background_service_backup_failed_message": "Malsukcesis krei savkopion de tiuj elementoj. Reprovante…",
"backup_background_service_complete_notification": "Savkopiado finita",
"backup_background_service_connection_failed_message": "Malsukcesis konektiĝi al la servilo. Reprovante…",
"backup_background_service_current_upload_notification": "Alŝutiĝas {filename}",
"backup_background_service_default_notification": "Serĉas novajn elementojn…",
"backup_background_service_error_title": "Eraro de savkopiado",
"backup_background_service_in_progress_notification": "Kreado de savkopio de viaj elementoj…",
"backup_background_service_upload_failure_notification": "Malsukcesis alŝuti {filename}",
"backup_controller_page_albums": "Savkopiado de albumoj",
"backup_controller_page_background_app_refresh_disabled_content": "Por aktivigi la fonan savkopiadon, ŝaltu fonan aktualigon de la apo en Agordoj > Ĝeneralaj > Fona aktualigo de apo.",
"backup_controller_page_background_app_refresh_disabled_title": "Fona aktualigo de apo malŝaltita",
"backup_controller_page_background_app_refresh_enable_button_text": "Iri al Agordoj",
"backup_controller_page_background_battery_info_link": "Montri al mi",
"backup_controller_page_background_battery_info_message": "Por bona funkciado de la fona savkopiado, bonvolu malŝalti optimumigon de bateria uzo por Immich.\n\nTiu funkcio dependas de via aparato, do vi devos mem serĉi helpon pri kiel atingi tion.",
"backup_controller_page_background_battery_info_ok": "Okej",
"backup_controller_page_background_battery_info_title": "Optimumigo de bateria uzo",
"backup_controller_page_background_charging": "Nur dum ŝargado",
"backup_controller_page_background_configure_error": "Malsukcesis agordi la fonan servon",
"backup_controller_page_background_delay": "Prokrasti savkopiadon de novaj elementoj: {duration}",
"backup_controller_page_background_description": "Ŝaltu la fonan servon por aŭtomate krei savkopion de novaj elementoj sen malfermi la apon",
"backup_controller_page_background_is_off": "Aŭtomata fona savkopiado estas malŝaltita",
"backup_controller_page_background_is_on": "Aŭtomata fona savkopiado estas ŝaltita",
"backup_controller_page_background_turn_off": "Malŝalti fonan servon",
"backup_controller_page_background_turn_on": "Ŝalti fonan servon",
"backup_controller_page_background_wifi": "Nur per vifio",
"backup_controller_page_backup": "Savkopiado",
"backup_controller_page_backup_selected": "Elektita(j): ",
"backup_controller_page_backup_sub": "Fotoj kaj videoj kun jama savkopio",
"backup_controller_page_created": "Kreita(j) je: {date}",
"backup_controller_page_desc_backup": "Ŝaltu malfonan savkopiadon por aŭtomate alŝuti novajn elementojn al la servilo kiam la apo estas malfermita.",
"backup_controller_page_excluded": "Ekskluzivita(j): ",
"backup_controller_page_failed": "Malsukcesis ({count})",
"backup_controller_page_filename": "Dosiernomo: {filename} [{size}]",
"backup_controller_page_id": "ID: {id}",
"backup_controller_page_info": "Informoj pri savkopio",
"backup_controller_page_none_selected": "Neniuj elektitaj",
"backup_controller_page_remainder": "Restas",
"backup_controller_page_remainder_sub": "Fotoj kaj videoj ankoraŭ ne savkopiitaj el la elektitaj",
"backup_controller_page_server_storage": "Stokado ĉe servilo",
"backup_controller_page_start_backup": "Komenci savkopiadon",
"backup_controller_page_status_off": "Aŭtomata malfona savkopiado estas malŝaltita",
"backup_controller_page_status_on": "Aŭtomata malfona savkopiado estas ŝaltita",
"backup_controller_page_storage_format": "{used} el {total} uzita",
"backup_controller_page_to_backup": "Albumoj savkopiotaj",
"backup_controller_page_total_sub": "Ĉiuj unikaj fotoj kaj videoj el elektitaj albumoj",
"backup_controller_page_turn_off": "Malŝalti malfonan savkopiadon",
"backup_controller_page_turn_on": "Ŝalti malfonan savkopiadon",
"backup_setting_subtitle": "Administri agordojn pri fona kaj malfona alŝutado", "backup_setting_subtitle": "Administri agordojn pri fona kaj malfona alŝutado",
"backup_settings_subtitle": "Administri agordojn pri alŝutado", "backup_settings_subtitle": "Administri agordojn pri alŝutado",
"cleanup_icloud_shared_albums_excluded": "Dividitaj albumoj ĉe iCloud estas ekskluditaj de la analizado", "cleanup_icloud_shared_albums_excluded": "Dividitaj albumoj ĉe iCloud estas ekskluditaj de la analizado",
@@ -453,11 +692,14 @@
"exclusion_pattern": "Skemo de ekskludo", "exclusion_pattern": "Skemo de ekskludo",
"explore": "Esplori", "explore": "Esplori",
"explorer": "Foliumilo", "explorer": "Foliumilo",
"general": "Ĝeneralaj",
"manage_media_access_settings": "Malfermi agordaĵaron", "manage_media_access_settings": "Malfermi agordaĵaron",
"manage_the_app_settings": "Agordi la apon", "manage_the_app_settings": "Agordi la apon",
"missing": "Netraktitaj", "missing": "Netraktitaj",
"networking_subtitle": "Administri agordojn pri finpunktoj de la servilo", "networking_subtitle": "Administri agordojn pri finpunktoj de la servilo",
"no_devices": "Neniuj aprobitaj aparatoj",
"no_explore_results_message": "Alŝutu pli da fotoj por esplori vian kolekton.", "no_explore_results_message": "Alŝutu pli da fotoj por esplori vian kolekton.",
"no_results_description": "Provu sinonimon aŭ pli ĝeneralan ŝlosilvorton",
"preferences_settings_subtitle": "Administri agordojn pri la apo", "preferences_settings_subtitle": "Administri agordojn pri la apo",
"purchase_settings_server_activated": "La administranto respondecas pri la ŝlosilo de aŭtentikeco por la servilo", "purchase_settings_server_activated": "La administranto respondecas pri la ŝlosilo de aŭtentikeco por la servilo",
"refresh": "Denove", "refresh": "Denove",
+25 -12
View File
@@ -61,7 +61,7 @@
"backup_onboarding_1_description": "Copia en un lugar externo, en la nube u otra ubicación física.", "backup_onboarding_1_description": "Copia en un lugar externo, en la nube u otra ubicación física.",
"backup_onboarding_2_description": "copias locales en diferentes dispositivos. Incluye los archivos principales y una copia de seguridad local de dichos archivos.", "backup_onboarding_2_description": "copias locales en diferentes dispositivos. Incluye los archivos principales y una copia de seguridad local de dichos archivos.",
"backup_onboarding_3_description": "copias totales de tu data, incluyendo los archivos originales. Incluye 1 copia fuera de sitio y 2 copias locales.", "backup_onboarding_3_description": "copias totales de tu data, incluyendo los archivos originales. Incluye 1 copia fuera de sitio y 2 copias locales.",
"backup_onboarding_description": "Una estrategia de <backblaze-link>copia de seguridad 3-2-1</backblaze-link> es recomendada para proteger tu data. Deberías mantener tanto copias de tus fotos/videos subidos como de la base de datos de Immich para tener una solución de copia de seguridad integral.", "backup_onboarding_description": "Se recomienda una <backblaze-link>estrategia de copia de seguridad 3-2-1</backblaze-link> para proteger tus datos. Deberías mantener copias de las fotos y vídeos que subas, así como de la base de datos de Immich, para contar con una solución de copia de seguridad completa.",
"backup_onboarding_footer": "Para obtener más información sobre cómo hacer una copia de seguridad de Immich, consulta la <link>documentación</link>.", "backup_onboarding_footer": "Para obtener más información sobre cómo hacer una copia de seguridad de Immich, consulta la <link>documentación</link>.",
"backup_onboarding_parts_title": "Una copia de seguridad 3-2-1 incluye:", "backup_onboarding_parts_title": "Una copia de seguridad 3-2-1 incluye:",
"backup_onboarding_title": "Copias de seguridad", "backup_onboarding_title": "Copias de seguridad",
@@ -351,7 +351,7 @@
"template_settings": "Plantillas de notificación", "template_settings": "Plantillas de notificación",
"template_settings_description": "Gestione plantillas personalizadas para las notificaciones", "template_settings_description": "Gestione plantillas personalizadas para las notificaciones",
"theme_custom_css_settings": "CSS personalizado", "theme_custom_css_settings": "CSS personalizado",
"theme_custom_css_settings_description": "El CSS permite personalizar el diseño de Immich.", "theme_custom_css_settings_description": "Las Hojas de Estilo permiten personalizar el diseño de Immich.",
"theme_settings": "Ajustes del tema", "theme_settings": "Ajustes del tema",
"theme_settings_description": "Gestionar la personalización de la interfaz web de Immich", "theme_settings_description": "Gestionar la personalización de la interfaz web de Immich",
"thumbnail_generation_job": "Generar miniaturas", "thumbnail_generation_job": "Generar miniaturas",
@@ -372,7 +372,7 @@
"transcoding_audio_codec": "Codec de audio", "transcoding_audio_codec": "Codec de audio",
"transcoding_audio_codec_description": "Opus es la opción de mayor calidad, pero tiene menor compatibilidad con dispositivos o software antiguos.", "transcoding_audio_codec_description": "Opus es la opción de mayor calidad, pero tiene menor compatibilidad con dispositivos o software antiguos.",
"transcoding_bitrate_description": "Vídeos con una tasa de bits superior a la máxima o que no están en un formato aceptado", "transcoding_bitrate_description": "Vídeos con una tasa de bits superior a la máxima o que no están en un formato aceptado",
"transcoding_codecs_learn_more": "Para obtener más información sobre la terminología utilizada aquí, consulte la documentación de FFmpeg sobre los codecs <h264-link>H.264</h264-link>, <hevc-link>HEVC</hevc-link> y <vp9-link>VP9</vp9-link>.", "transcoding_codecs_learn_more": "Para obtener más información sobre la terminología utilizada aquí, consulte la documentación de FFmpeg sobre <h264-link>el códec H.264</h264-link>, <hevc-link>el códec HEVC</hevc-link> y <vp9-link>el códec VP9</vp9-link>.",
"transcoding_constant_quality_mode": "Modo de calidad constante", "transcoding_constant_quality_mode": "Modo de calidad constante",
"transcoding_constant_quality_mode_description": "ICQ es mejor que CQP, pero algunos dispositivos de aceleración de hardware no admiten este modo. Al configurar esta opción, se preferirá el modo especificado cuando se utilice codificación basada en calidad. NVENC lo ignora porque no es compatible con ICQ.", "transcoding_constant_quality_mode_description": "ICQ es mejor que CQP, pero algunos dispositivos de aceleración de hardware no admiten este modo. Al configurar esta opción, se preferirá el modo especificado cuando se utilice codificación basada en calidad. NVENC lo ignora porque no es compatible con ICQ.",
"transcoding_constant_rate_factor": "Factor de tasa constante (-crf)", "transcoding_constant_rate_factor": "Factor de tasa constante (-crf)",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mapeo de tonos", "transcoding_tone_mapping": "Mapeo de tonos",
"transcoding_tone_mapping_description": "Intenta preservar la apariencia de los videos HDR cuando se convierten a SDR. Cada algoritmo realiza diferentes compensaciones en cuanto a color, detalle y brillo. Hable conserva los detalles, Mobius conserva el color y Reinhard conserva el brillo.", "transcoding_tone_mapping_description": "Intenta preservar la apariencia de los videos HDR cuando se convierten a SDR. Cada algoritmo realiza diferentes compensaciones en cuanto a color, detalle y brillo. Hable conserva los detalles, Mobius conserva el color y Reinhard conserva el brillo.",
"transcoding_transcode_policy": "Políticas de transcodificación", "transcoding_transcode_policy": "Políticas de transcodificación",
"transcoding_transcode_policy_description": "Política sobre cuándo se debe transcodificar un vídeo. Los vídeos HDR siempre se transcodificarán (excepto si la transcodificación está desactivada).", "transcoding_transcode_policy_description": "Política sobre cuándo se debe transcodificar un vídeo. Los vídeos HDR y vídeos con un formato de píxel diferente a YUV 4:2:0 siempre se transcodificarán (excepto si la transcodificación está desactivada).",
"transcoding_two_pass_encoding": "Codificación en dos pasadas", "transcoding_two_pass_encoding": "Codificación en dos pasadas",
"transcoding_two_pass_encoding_setting_description": "Transcodifica en dos pasadas para producir vídeos mejor codificados. Cuando la velocidad de bits máxima está habilitada (es necesaria para que funcione con H.264 y HEVC), este modo utiliza un rango de velocidad de bits basado en la velocidad de bits máxima e ignora CRF. Para VP9, se puede utilizar CRF si la tasa de bits máxima está deshabilitada.", "transcoding_two_pass_encoding_setting_description": "Transcodifica en dos pasadas para producir vídeos mejor codificados. Cuando la velocidad de bits máxima está habilitada (es necesaria para que funcione con H.264 y HEVC), este modo utiliza un rango de velocidad de bits basado en la velocidad de bits máxima e ignora CRF. Para VP9, se puede utilizar CRF si la tasa de bits máxima está deshabilitada.",
"transcoding_video_codec": "Códecs de video", "transcoding_video_codec": "Códecs de video",
@@ -459,7 +459,7 @@
"advanced_settings_log_level_title": "Nivel de registro: {level}", "advanced_settings_log_level_title": "Nivel de registro: {level}",
"advanced_settings_prefer_remote_subtitle": "Algunos dispositivos tardan mucho en cargar las miniaturas desde los recursos locales. Activa esta opción para cargar imágenes remotas en su lugar.", "advanced_settings_prefer_remote_subtitle": "Algunos dispositivos tardan mucho en cargar las miniaturas desde los recursos locales. Activa esta opción para cargar imágenes remotas en su lugar.",
"advanced_settings_prefer_remote_title": "Preferir imágenes remotas", "advanced_settings_prefer_remote_title": "Preferir imágenes remotas",
"advanced_settings_proxy_headers_subtitle": "Configura encabezados HTTP que Immich incluirá en cada petición de red", "advanced_settings_proxy_headers_subtitle": "Configura encabezados de proxy que Immich incluirá en cada petición de red",
"advanced_settings_proxy_headers_title": "Cabeceras proxy personalizadas [EXPERIMENTAL]", "advanced_settings_proxy_headers_title": "Cabeceras proxy personalizadas [EXPERIMENTAL]",
"advanced_settings_readonly_mode_subtitle": "Habilita el modo de solo lectura donde las fotografías sólo pueden ser vistas, funciones como seleccionar múltiples imágenes, compartir, transmitir, eliminar son deshabilitadas. Habilita/Deshabilita solo lectura vía el avatar del usuario en la pantalla principal", "advanced_settings_readonly_mode_subtitle": "Habilita el modo de solo lectura donde las fotografías sólo pueden ser vistas, funciones como seleccionar múltiples imágenes, compartir, transmitir, eliminar son deshabilitadas. Habilita/Deshabilita solo lectura vía el avatar del usuario en la pantalla principal",
"advanced_settings_readonly_mode_title": "Modo solo lectura", "advanced_settings_readonly_mode_title": "Modo solo lectura",
@@ -872,7 +872,7 @@
"current_server_address": "Dirección actual del servidor", "current_server_address": "Dirección actual del servidor",
"custom_date": "Fecha personalizada", "custom_date": "Fecha personalizada",
"custom_locale": "Configuración regional personalizada", "custom_locale": "Configuración regional personalizada",
"custom_locale_description": "Formatear fechas y números según el idioma y la región", "custom_locale_description": "Dar formato a fechas, horas y números según el idioma y región seleccionados",
"custom_url": "URL personalizada", "custom_url": "URL personalizada",
"cutoff_date_description": "Conserva fotos del último…", "cutoff_date_description": "Conserva fotos del último…",
"cutoff_day": "{count, plural, one {día} other {días}}", "cutoff_day": "{count, plural, one {día} other {días}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Conteo de datos EXIF", "deduplication_criteria_2": "Conteo de datos EXIF",
"deduplication_info": "Información de Deduplicación", "deduplication_info": "Información de Deduplicación",
"deduplication_info_description": "Para automáticamente preseleccionar recursos y eliminar duplicados en conjunto, nosotros consideramos lo siguiente:", "deduplication_info_description": "Para automáticamente preseleccionar recursos y eliminar duplicados en conjunto, nosotros consideramos lo siguiente:",
"default_locale": "Configuración regional predeterminada",
"default_locale_description": "Formatee fechas y números según la configuración regional de su navegador",
"delete": "Eliminar", "delete": "Eliminar",
"delete_action_confirmation_message": "¿Está seguro que desea eliminar este recurso? Esta acción lo moverá a la papelera del servidor y le preguntará si desea eliminarlo localmente", "delete_action_confirmation_message": "¿Está seguro que desea eliminar este recurso? Esta acción lo moverá a la papelera del servidor y le preguntará si desea eliminarlo localmente",
"delete_action_prompt": "{count} eliminados", "delete_action_prompt": "{count} eliminados",
@@ -1009,6 +1007,8 @@
"editor_edits_applied_success": "Edición aplicada con éxito", "editor_edits_applied_success": "Edición aplicada con éxito",
"editor_flip_horizontal": "Girar horizontalmente", "editor_flip_horizontal": "Girar horizontalmente",
"editor_flip_vertical": "Girar verticalmente", "editor_flip_vertical": "Girar verticalmente",
"editor_handle_corner": "{corner, select, top_left {Superior izquierda} top_right {Superior derecha} bottom_left {Inferior izquierda} bottom_right {Inferior derecha} other {Un}} controlador de esquina",
"editor_handle_edge": "{edge, select, top {Superior} bottom {Inferior} left {Izquierdo} right {Derecho} other {Un}} controlador de borde",
"editor_orientation": "Orientación", "editor_orientation": "Orientación",
"editor_reset_all_changes": "Restablecer cambios", "editor_reset_all_changes": "Restablecer cambios",
"editor_rotate_left": "Rotar 90º sentido antihorario", "editor_rotate_left": "Rotar 90º sentido antihorario",
@@ -1074,6 +1074,7 @@
"failed_to_update_notification_status": "Error al actualizar el estado de la notificación", "failed_to_update_notification_status": "Error al actualizar el estado de la notificación",
"incorrect_email_or_password": "Contraseña o email incorrecto", "incorrect_email_or_password": "Contraseña o email incorrecto",
"library_folder_already_exists": "Esta ruta de importación ya existe.", "library_folder_already_exists": "Esta ruta de importación ya existe.",
"page_not_found": "Página no encontrada",
"paths_validation_failed": "Falló la validación en {paths, plural, one {# carpeta} other {# carpetas}}", "paths_validation_failed": "Falló la validación en {paths, plural, one {# carpeta} other {# carpetas}}",
"profile_picture_transparent_pixels": "Las imágenes de perfil no pueden tener píxeles transparentes. Por favor amplíe y/o mueva la imagen.", "profile_picture_transparent_pixels": "Las imágenes de perfil no pueden tener píxeles transparentes. Por favor amplíe y/o mueva la imagen.",
"quota_higher_than_disk_size": "Se ha establecido una cuota superior al tamaño del disco", "quota_higher_than_disk_size": "Se ha establecido una cuota superior al tamaño del disco",
@@ -1218,6 +1219,7 @@
"filter_description": "Condiciones para filtrar los recursos objetivo", "filter_description": "Condiciones para filtrar los recursos objetivo",
"filter_people": "Filtrar personas", "filter_people": "Filtrar personas",
"filter_places": "Filtrar lugares", "filter_places": "Filtrar lugares",
"filter_tags": "Filtrar etiquetas",
"filters": "Filtros", "filters": "Filtros",
"find_them_fast": "Encuéntrelos rápidamente por nombre con la búsqueda", "find_them_fast": "Encuéntrelos rápidamente por nombre con la búsqueda",
"first": "Primero", "first": "Primero",
@@ -1649,6 +1651,7 @@
"only_favorites": "Solo favoritos", "only_favorites": "Solo favoritos",
"open": "Abierto", "open": "Abierto",
"open_calendar": "Abrir calendario", "open_calendar": "Abrir calendario",
"open_in_browser": "Abrir en el navegador",
"open_in_map_view": "Abrir en la vista del mapa", "open_in_map_view": "Abrir en la vista del mapa",
"open_in_openstreetmap": "Abrir en OpenStreetMap", "open_in_openstreetmap": "Abrir en OpenStreetMap",
"open_the_search_filters": "Abre los filtros de búsqueda", "open_the_search_filters": "Abre los filtros de búsqueda",
@@ -1808,9 +1811,8 @@
"rate_asset": "Valorar recurso", "rate_asset": "Valorar recurso",
"rating": "Valoración", "rating": "Valoración",
"rating_clear": "Borrar calificación", "rating_clear": "Borrar calificación",
"rating_count": "{count, plural, one {# estrella} other {# estrellas}}", "rating_count": "{count, plural, =0 {# estrella} one {# estrella} other {# estrellas}}",
"rating_description": "Mostrar la clasificación exif en el panel de información", "rating_description": "Mostrar la clasificación exif en el panel de información",
"rating_set": "Calificación establecida en {rating, plural, one {# estrella} other {# estrellas}}",
"reaction_options": "Opciones de reacción", "reaction_options": "Opciones de reacción",
"read_changelog": "Leer registro de cambios", "read_changelog": "Leer registro de cambios",
"readonly_mode_disabled": "Modo solo lectura deshabilitado", "readonly_mode_disabled": "Modo solo lectura deshabilitado",
@@ -1882,7 +1884,10 @@
"reset_pin_code_success": "Código PIN restablecido correctamente", "reset_pin_code_success": "Código PIN restablecido correctamente",
"reset_pin_code_with_password": "Siempre puedes restablecer tu código PIN usando tu contraseña", "reset_pin_code_with_password": "Siempre puedes restablecer tu código PIN usando tu contraseña",
"reset_sqlite": "Restablecer la base de datos SQLite", "reset_sqlite": "Restablecer la base de datos SQLite",
"reset_sqlite_confirmation": "¿Estás seguro que deseas restablecer la base de datos SQLite? Deberás cerrar sesión y volver a iniciarla para resincronizar los datos", "reset_sqlite_clear_app_data": "Limpiar datos",
"reset_sqlite_confirmation": "¿Seguro que quieres borrar los datos de la aplicación? Esto eliminará toda la configuración y cerrará tu sesión.",
"reset_sqlite_confirmation_note": "Nota: Deberás reiniciar la aplicación después de borrarla.",
"reset_sqlite_done": "Se han borrado los datos de la aplicación. Reinicie Immich y vuelva a iniciar sesión.",
"reset_sqlite_success": "Restablecer exitosamente la base de datos SQLite", "reset_sqlite_success": "Restablecer exitosamente la base de datos SQLite",
"reset_to_default": "Restablecer los valores predeterminados", "reset_to_default": "Restablecer los valores predeterminados",
"resolution": "Resolución", "resolution": "Resolución",
@@ -1910,6 +1915,7 @@
"saved_settings": "Configuraciones guardadas", "saved_settings": "Configuraciones guardadas",
"say_something": "Comenta algo", "say_something": "Comenta algo",
"scaffold_body_error_occurred": "Ha ocurrido un error", "scaffold_body_error_occurred": "Ha ocurrido un error",
"scaffold_body_error_unrecoverable": "Se ha producido un error irrecuperable. Comparte el error y el seguimiento de la pila en Discord o GitHub para que podamos ayudarte. Si se indica, puedes borrar los datos de la aplicación a continuación.",
"scan": "Escanear", "scan": "Escanear",
"scan_all_libraries": "Escanear todas las bibliotecas", "scan_all_libraries": "Escanear todas las bibliotecas",
"scan_library": "Escanear", "scan_library": "Escanear",
@@ -1945,6 +1951,7 @@
"search_filter_ocr": "Buscar por OCR", "search_filter_ocr": "Buscar por OCR",
"search_filter_people_title": "Seleccionar personas", "search_filter_people_title": "Seleccionar personas",
"search_filter_star_rating": "Clasificación de estrellas", "search_filter_star_rating": "Clasificación de estrellas",
"search_filter_tags_title": "Seleccionar etiquetas",
"search_for": "Buscar", "search_for": "Buscar",
"search_for_existing_person": "Buscar persona existente", "search_for_existing_person": "Buscar persona existente",
"search_no_more_result": "No hay más resultados", "search_no_more_result": "No hay más resultados",
@@ -2024,6 +2031,9 @@
"set_profile_picture": "Establecer foto de perfil", "set_profile_picture": "Establecer foto de perfil",
"set_slideshow_to_fullscreen": "Mostrar diapositivas en pantalla completa", "set_slideshow_to_fullscreen": "Mostrar diapositivas en pantalla completa",
"set_stack_primary_asset": "Establecer como recurso principal", "set_stack_primary_asset": "Establecer como recurso principal",
"setting_image_navigation_enable_subtitle": "Si está habilitado, puedes navegar a la imagen anterior/siguiente tocando una cuarta parte más a la izquierda/derecha de la pantalla.",
"setting_image_navigation_enable_title": "Toca para navegar",
"setting_image_navigation_title": "Navegación de imágenes",
"setting_image_viewer_help": "El visor de detalles carga primero la miniatura pequeña, luego carga la vista previa de tamaño mediano (si está habilitada), finalmente carga la original (si está habilitada).", "setting_image_viewer_help": "El visor de detalles carga primero la miniatura pequeña, luego carga la vista previa de tamaño mediano (si está habilitada), finalmente carga la original (si está habilitada).",
"setting_image_viewer_original_subtitle": "Activar para cargar la imagen en resolución original (¡muy grande!). Deshabilitar para reducir el consumo de datos (de red y caché).", "setting_image_viewer_original_subtitle": "Activar para cargar la imagen en resolución original (¡muy grande!). Deshabilitar para reducir el consumo de datos (de red y caché).",
"setting_image_viewer_original_title": "Cargar imagen original", "setting_image_viewer_original_title": "Cargar imagen original",
@@ -2302,6 +2312,7 @@
"unstack_action_prompt": "{count} desapilado(s)", "unstack_action_prompt": "{count} desapilado(s)",
"unstacked_assets_count": "Desapilado(s) {count, plural, one {# recurso} other {# recursos}}", "unstacked_assets_count": "Desapilado(s) {count, plural, one {# recurso} other {# recursos}}",
"unsupported_field_type": "Tipo de campo no soportado", "unsupported_field_type": "Tipo de campo no soportado",
"unsupported_file_type": "El archivo {file} no puede ser cargado porque su tipo de archivo {type} no es soportado.",
"untagged": "Sin etiqueta", "untagged": "Sin etiqueta",
"untitled_workflow": "Flujo de trabajo sin título", "untitled_workflow": "Flujo de trabajo sin título",
"up_next": "A continuación", "up_next": "A continuación",
@@ -2328,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Uso", "usage": "Uso",
"use_biometric": "Uso biométrico", "use_biometric": "Uso biométrico",
"use_browser_locale": "Utilizar la localización del navegador",
"use_browser_locale_description": "Dar formato a fechas, horas y números según la localización de su navegador",
"use_current_connection": "Utilice la conexión actual", "use_current_connection": "Utilice la conexión actual",
"use_custom_date_range": "Usa un intervalo de fechas personalizado", "use_custom_date_range": "Usa un intervalo de fechas personalizado",
"user": "Usuario", "user": "Usuario",
@@ -2353,7 +2366,7 @@
"variables": "Variables", "variables": "Variables",
"version": "Versión", "version": "Versión",
"version_announcement_closing": "Tu amigo, Alex", "version_announcement_closing": "Tu amigo, Alex",
"version_announcement_message": "¡Hola! Hay una nueva versión de Immich disponible. Tómese un tiempo para leer las <link> notas de la versión </link> para asegurarse de que su configuración esté actualizada y evitar errores de configuración, especialmente si utiliza WatchTower o cualquier mecanismo que se encargue de actualizar su instancia de Immich automáticamente.", "version_announcement_message": "¡Hola! Hay una nueva versión de Immich disponible. Tómese un tiempo para leer las <link>notas de la versión</link> para asegurarse de que su configuración esté actualizada y evitar errores de configuración, especialmente si utiliza WatchTower o cualquier mecanismo que se encargue de actualizar su instancia de Immich automáticamente.",
"version_history": "Historial de versiones", "version_history": "Historial de versiones",
"version_history_item": "Instalada {version} el {date}", "version_history_item": "Instalada {version} el {date}",
"video": "Vídeo", "video": "Vídeo",
+21 -8
View File
@@ -5,7 +5,7 @@
"acknowledge": "Sain aru", "acknowledge": "Sain aru",
"action": "Tegevus", "action": "Tegevus",
"action_common_update": "Uuenda", "action_common_update": "Uuenda",
"action_description": "Komplekt tegevusi, mida teostada filtreeritud üksustega", "action_description": "Tegevused, mida teostada filtreeritud üksustega",
"actions": "Tegevused", "actions": "Tegevused",
"active": "Aktiivne", "active": "Aktiivne",
"active_count": "Aktiivsed: {count}", "active_count": "Aktiivsed: {count}",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Toonivastendus", "transcoding_tone_mapping": "Toonivastendus",
"transcoding_tone_mapping_description": "Üritab säilitada HDR videote kvaliteeti SDR-iks teisendamisel. Iga algoritm teeb värvi, detailide ja ereduse osas erinevaid kompromisse. Hable säilitab detaile, Mobius säilitab värve ning Reinhard säilitab eredust.", "transcoding_tone_mapping_description": "Üritab säilitada HDR videote kvaliteeti SDR-iks teisendamisel. Iga algoritm teeb värvi, detailide ja ereduse osas erinevaid kompromisse. Hable säilitab detaile, Mobius säilitab värve ning Reinhard säilitab eredust.",
"transcoding_transcode_policy": "Transkodeerimise reegel", "transcoding_transcode_policy": "Transkodeerimise reegel",
"transcoding_transcode_policy_description": "Reegel, millal tuleks videot transkodeerida. HDR-videosid transkodeeritakse alati (v.a. kui transkodeerimine on keelatud).", "transcoding_transcode_policy_description": "Reegel, millal tuleks videot transkodeerida. HDR-videod ja muu piksliformaadiga kui YUV 4:2:0 videod transkodeeritakse alati (v.a. kui transkodeerimine on keelatud).",
"transcoding_two_pass_encoding": "Kahekäiguline kodeerimine", "transcoding_two_pass_encoding": "Kahekäiguline kodeerimine",
"transcoding_two_pass_encoding_setting_description": "Transkodeeri kahes osas, et parandada kodeeritud videote kvaliteeti. Maksimaalse bitisageduse puhul (mis on vajalik H.264 ja HEVC jaoks) kasutab see režiim bitisageduse vahemikku ja ignoreerib CRF-i. VP9 puhul saab kasutada CRF-i, kui maksimaalset bitisagedust pole määratud.", "transcoding_two_pass_encoding_setting_description": "Transkodeeri kahes osas, et parandada kodeeritud videote kvaliteeti. Maksimaalse bitisageduse puhul (mis on vajalik H.264 ja HEVC jaoks) kasutab see režiim bitisageduse vahemikku ja ignoreerib CRF-i. VP9 puhul saab kasutada CRF-i, kui maksimaalset bitisagedust pole määratud.",
"transcoding_video_codec": "Videokoodek", "transcoding_video_codec": "Videokoodek",
@@ -872,7 +872,7 @@
"current_server_address": "Praegune serveri aadress", "current_server_address": "Praegune serveri aadress",
"custom_date": "Muu kuupäev", "custom_date": "Muu kuupäev",
"custom_locale": "Kohandatud lokaat", "custom_locale": "Kohandatud lokaat",
"custom_locale_description": "Vorminda kuupäevad ja arvud vastavalt keelele ja regioonile", "custom_locale_description": "Vorminda kuupäevad, kellaajad ja arvud vastavalt valitud keelele ja regioonile",
"custom_url": "Kohandatud URL", "custom_url": "Kohandatud URL",
"cutoff_date_description": "Jäta alles fotod ja videod viimasest…", "cutoff_date_description": "Jäta alles fotod ja videod viimasest…",
"cutoff_day": "{count, plural, one {päev} other {päeva}}", "cutoff_day": "{count, plural, one {päev} other {päeva}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "EXIF andmete hulk", "deduplication_criteria_2": "EXIF andmete hulk",
"deduplication_info": "Dedubleerimise info", "deduplication_info": "Dedubleerimise info",
"deduplication_info_description": "Üksuste automaatsel eelvalimisel ja duplikaatide eemaldamisel võetakse arvesse:", "deduplication_info_description": "Üksuste automaatsel eelvalimisel ja duplikaatide eemaldamisel võetakse arvesse:",
"default_locale": "Vaikimisi lokaat",
"default_locale_description": "Vorminda kuupäevad ja numbrid vastavalt brauseri lokaadile",
"delete": "Kustuta", "delete": "Kustuta",
"delete_action_confirmation_message": "Kas oled kindel, et soovid selle üksuse kustutada? See toiming liigutab üksuse serveri prügikasti ja küsib, kas soovid selle lokaalselt kustutada", "delete_action_confirmation_message": "Kas oled kindel, et soovid selle üksuse kustutada? See toiming liigutab üksuse serveri prügikasti ja küsib, kas soovid selle lokaalselt kustutada",
"delete_action_prompt": "{count} kustutatud", "delete_action_prompt": "{count} kustutatud",
@@ -1009,6 +1007,8 @@
"editor_edits_applied_success": "Muudatused edukalt rakendatud", "editor_edits_applied_success": "Muudatused edukalt rakendatud",
"editor_flip_horizontal": "Peegelda horisontaalselt", "editor_flip_horizontal": "Peegelda horisontaalselt",
"editor_flip_vertical": "Peegelda vertikaalselt", "editor_flip_vertical": "Peegelda vertikaalselt",
"editor_handle_corner": "{corner, select, top_left {Vasak ülemine nurk} top_right {Parem ülemine nurk} bottom_left {Vasak alumine nurk} bottom_right {Parem alumine nurk} other {Nurk}}",
"editor_handle_edge": "{edge, select, top {Ülemine serv} bottom {Alumine serv} left {Vasak serv} right {Parem serv} other {Serv}}",
"editor_orientation": "Orientatsioon", "editor_orientation": "Orientatsioon",
"editor_reset_all_changes": "Tühista muudatused", "editor_reset_all_changes": "Tühista muudatused",
"editor_rotate_left": "Pööra 90° vastupäeva", "editor_rotate_left": "Pööra 90° vastupäeva",
@@ -1074,6 +1074,7 @@
"failed_to_update_notification_status": "Teavituste seisundi uuendamine ebaõnnestus", "failed_to_update_notification_status": "Teavituste seisundi uuendamine ebaõnnestus",
"incorrect_email_or_password": "Vale e-posti aadress või parool", "incorrect_email_or_password": "Vale e-posti aadress või parool",
"library_folder_already_exists": "See imporditee on juba olemas.", "library_folder_already_exists": "See imporditee on juba olemas.",
"page_not_found": "Lehekülge ei leitud",
"paths_validation_failed": "{paths, plural, one {# tee} other {# teed}} ei valideerunud", "paths_validation_failed": "{paths, plural, one {# tee} other {# teed}} ei valideerunud",
"profile_picture_transparent_pixels": "Profiilipildis ei tohi olla läbipaistvaid piksleid. Palun suumi sisse ja/või liiguta pilti.", "profile_picture_transparent_pixels": "Profiilipildis ei tohi olla läbipaistvaid piksleid. Palun suumi sisse ja/või liiguta pilti.",
"quota_higher_than_disk_size": "Määratud kvoot on suurem kui kettamaht", "quota_higher_than_disk_size": "Määratud kvoot on suurem kui kettamaht",
@@ -1218,6 +1219,7 @@
"filter_description": "Tingimused, mille alusel üksuseid filtreerida", "filter_description": "Tingimused, mille alusel üksuseid filtreerida",
"filter_people": "Filtreeri isikuid", "filter_people": "Filtreeri isikuid",
"filter_places": "Filtreeri kohti", "filter_places": "Filtreeri kohti",
"filter_tags": "Filtreeri silte",
"filters": "Filtrid", "filters": "Filtrid",
"find_them_fast": "Leia teda kiiresti nime järgi otsides", "find_them_fast": "Leia teda kiiresti nime järgi otsides",
"first": "Esimene", "first": "Esimene",
@@ -1649,6 +1651,7 @@
"only_favorites": "Ainult lemmikud", "only_favorites": "Ainult lemmikud",
"open": "Ava", "open": "Ava",
"open_calendar": "Ava kalender", "open_calendar": "Ava kalender",
"open_in_browser": "Ava brauseris",
"open_in_map_view": "Ava kaardi vaates", "open_in_map_view": "Ava kaardi vaates",
"open_in_openstreetmap": "Ava OpenStreetMap", "open_in_openstreetmap": "Ava OpenStreetMap",
"open_the_search_filters": "Ava otsingufiltrid", "open_the_search_filters": "Ava otsingufiltrid",
@@ -1808,9 +1811,8 @@
"rate_asset": "Hinda üksust", "rate_asset": "Hinda üksust",
"rating": "Hinnang", "rating": "Hinnang",
"rating_clear": "Tühjenda hinnang", "rating_clear": "Tühjenda hinnang",
"rating_count": "{count, plural, one {# tärn} other {# tärni}}", "rating_count": "{count, plural, =0 {Hindamata} one {# tärn} other {# tärni}}",
"rating_description": "Kuva infopaneelis EXIF hinnangut", "rating_description": "Kuva infopaneelis EXIF hinnangut",
"rating_set": "Hinnanguks seatud {rating, plural, one {# tärn} other {# tärni}}",
"reaction_options": "Reaktsiooni valikud", "reaction_options": "Reaktsiooni valikud",
"read_changelog": "Vaata muudatuste ülevaadet", "read_changelog": "Vaata muudatuste ülevaadet",
"readonly_mode_disabled": "Kirjutuskaitserežiim välja lülitatud", "readonly_mode_disabled": "Kirjutuskaitserežiim välja lülitatud",
@@ -1882,7 +1884,10 @@
"reset_pin_code_success": "PIN-kood edukalt lähtestatud", "reset_pin_code_success": "PIN-kood edukalt lähtestatud",
"reset_pin_code_with_password": "Saad oma PIN-koodi alati oma parooli abil lähtestada", "reset_pin_code_with_password": "Saad oma PIN-koodi alati oma parooli abil lähtestada",
"reset_sqlite": "Lähtesta SQLite andmebaas", "reset_sqlite": "Lähtesta SQLite andmebaas",
"reset_sqlite_confirmation": "Kas oled kindel, et soovid SQLite andmebaasi lähtestada? Andmete uuesti sünkroonimiseks pead välja ja jälle sisse logima", "reset_sqlite_clear_app_data": "Kustuta andmed",
"reset_sqlite_confirmation": "Kas oled kindel, et soovid rakenduse andmed kustutada? See eemaldab kõik seaded ja logib su välja.",
"reset_sqlite_confirmation_note": "Märkus: Pärast kustutamist pead rakenduse taasavama.",
"reset_sqlite_done": "Rakenduse andmed kustutatud. Taaskäivita Immich ja logi uuesti sisse.",
"reset_sqlite_success": "SQLite andmebaas edukalt lähtestatud", "reset_sqlite_success": "SQLite andmebaas edukalt lähtestatud",
"reset_to_default": "Lähtesta", "reset_to_default": "Lähtesta",
"resolution": "Resolutsioon", "resolution": "Resolutsioon",
@@ -1910,6 +1915,7 @@
"saved_settings": "Seaded salvestatud", "saved_settings": "Seaded salvestatud",
"say_something": "Ütle midagi", "say_something": "Ütle midagi",
"scaffold_body_error_occurred": "Tekkis viga", "scaffold_body_error_occurred": "Tekkis viga",
"scaffold_body_error_unrecoverable": "Esines parandumatu viga. Palun jaga viga ja pinujälge Discord'is või GitHub'is, et saaksime aidata. Kui seda soovitatakse, saad allpool rakenduse andmed kustutada.",
"scan": "Otsi", "scan": "Otsi",
"scan_all_libraries": "Skaneeri kõik kogud", "scan_all_libraries": "Skaneeri kõik kogud",
"scan_library": "Skaneeri", "scan_library": "Skaneeri",
@@ -1945,6 +1951,7 @@
"search_filter_ocr": "Otsi OCR-i abil", "search_filter_ocr": "Otsi OCR-i abil",
"search_filter_people_title": "Vali isikud", "search_filter_people_title": "Vali isikud",
"search_filter_star_rating": "Hinnang", "search_filter_star_rating": "Hinnang",
"search_filter_tags_title": "Vali sildid",
"search_for": "Otsi", "search_for": "Otsi",
"search_for_existing_person": "Otsi olemasolevat isikut", "search_for_existing_person": "Otsi olemasolevat isikut",
"search_no_more_result": "Rohkem vasteid pole", "search_no_more_result": "Rohkem vasteid pole",
@@ -2024,6 +2031,9 @@
"set_profile_picture": "Sea profiilipilt", "set_profile_picture": "Sea profiilipilt",
"set_slideshow_to_fullscreen": "Kuva slaidiesitlus täisekraanil", "set_slideshow_to_fullscreen": "Kuva slaidiesitlus täisekraanil",
"set_stack_primary_asset": "Sea peamiseks üksuseks", "set_stack_primary_asset": "Sea peamiseks üksuseks",
"setting_image_navigation_enable_subtitle": "Kui lubatud, saad liikuda eelmise/järgmise pildi juurde ekraani vasakut/paremat serva puudutades.",
"setting_image_navigation_enable_title": "Puudutusega navigeerimine",
"setting_image_navigation_title": "Piltide navigeerimine",
"setting_image_viewer_help": "Detailivaatur laadib kõigepealt väikese pisipildi, seejärel keskmises mõõdus eelvaate (kui lubatud) ja lõpuks originaalpildi (kui lubatud).", "setting_image_viewer_help": "Detailivaatur laadib kõigepealt väikese pisipildi, seejärel keskmises mõõdus eelvaate (kui lubatud) ja lõpuks originaalpildi (kui lubatud).",
"setting_image_viewer_original_subtitle": "Lülita sisse, et laadida algne täisresolutsiooniga pilt (suur!). Lülita välja, et vähendada andmekasutust (nii võrgu kui seadme puhvri).", "setting_image_viewer_original_subtitle": "Lülita sisse, et laadida algne täisresolutsiooniga pilt (suur!). Lülita välja, et vähendada andmekasutust (nii võrgu kui seadme puhvri).",
"setting_image_viewer_original_title": "Laadi algne pilt", "setting_image_viewer_original_title": "Laadi algne pilt",
@@ -2302,6 +2312,7 @@
"unstack_action_prompt": "{count} eraldatud", "unstack_action_prompt": "{count} eraldatud",
"unstacked_assets_count": "{count, plural, one {# üksus} other {# üksust}} eraldatud", "unstacked_assets_count": "{count, plural, one {# üksus} other {# üksust}} eraldatud",
"unsupported_field_type": "Mittetoetatud välja tüüp", "unsupported_field_type": "Mittetoetatud välja tüüp",
"unsupported_file_type": "Faili {file} ei saa üles laadida, kuna selle tüüp {type} ei ole toetatud.",
"untagged": "Sildistamata", "untagged": "Sildistamata",
"untitled_workflow": "Pealkirjata töövoog", "untitled_workflow": "Pealkirjata töövoog",
"up_next": "Järgmine", "up_next": "Järgmine",
@@ -2328,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Kasutus", "usage": "Kasutus",
"use_biometric": "Kasuta biomeetriat", "use_biometric": "Kasuta biomeetriat",
"use_browser_locale": "Kasuta brauseri lokaati",
"use_browser_locale_description": "Vorminda kuupäevad, kellaajad ja arvud vastavalt brauseri lokaadile",
"use_current_connection": "Kasuta praegust ühendust", "use_current_connection": "Kasuta praegust ühendust",
"use_custom_date_range": "Kasuta kohandatud kuupäevavahemikku", "use_custom_date_range": "Kasuta kohandatud kuupäevavahemikku",
"user": "Kasutaja", "user": "Kasutaja",
+3
View File
@@ -14,6 +14,9 @@
"add_a_location": "Kokapena gehitu", "add_a_location": "Kokapena gehitu",
"add_a_name": "Izena gehitu", "add_a_name": "Izena gehitu",
"add_a_title": "Izenburua gehitu", "add_a_title": "Izenburua gehitu",
"add_action": "Ekintza gehitu",
"add_action_description": "Egin klik gauzatu beharreko ekintza bat gehitzeko",
"add_assets": "Aktiboak gehitu",
"add_birthday": "Urtebetetzea gehitu", "add_birthday": "Urtebetetzea gehitu",
"add_endpoint": "Endpoint-a gehitu", "add_endpoint": "Endpoint-a gehitu",
"add_exclusion_pattern": "Bazterketa eredua gehitu", "add_exclusion_pattern": "Bazterketa eredua gehitu",
+105 -26
View File
@@ -3,9 +3,10 @@
"account": "Tili", "account": "Tili",
"account_settings": "Tilin asetukset", "account_settings": "Tilin asetukset",
"acknowledge": "Hyväksy", "acknowledge": "Hyväksy",
"action": "Toiminta", "action": "Toiminto",
"action_common_update": "Päivitä", "action_common_update": "Päivitä",
"actions": "Toimintoja", "action_description": "Lista toimista, jotka toteutetaan suodatettuun sisältöön",
"actions": "Toiminnot",
"active": "Aktiivinen", "active": "Aktiivinen",
"active_count": "Aktiivisia: {count}", "active_count": "Aktiivisia: {count}",
"activity": "Tapahtumat", "activity": "Tapahtumat",
@@ -17,6 +18,7 @@
"add_a_title": "Lisää otsikko", "add_a_title": "Lisää otsikko",
"add_action": "Lisää toiminto", "add_action": "Lisää toiminto",
"add_action_description": "Klikkaa lisätäksesi suoritettava toiminto", "add_action_description": "Klikkaa lisätäksesi suoritettava toiminto",
"add_assets": "Lisää sisältöä",
"add_birthday": "Lisää syntymäpäivä", "add_birthday": "Lisää syntymäpäivä",
"add_endpoint": "Lisää päätepiste", "add_endpoint": "Lisää päätepiste",
"add_exclusion_pattern": "Lisää poissulkemismalli", "add_exclusion_pattern": "Lisää poissulkemismalli",
@@ -47,7 +49,7 @@
"admin": { "admin": {
"add_exclusion_pattern_description": "Lisää mallit, jonka mukaan jätetään tiedostoja pois. Jokerimerkit *, ** ja ? ovat tuettuna. Jättääksesi pois kaikki tiedostot mistä tahansa löytyvästä kansiosta \"Raw\" käytä \"**/Raw/**\". Jättääksesi pois kaikki \". tif\" päätteiset tiedot, käytä \"**/*.tif\". Jättääksesi pois tarkan tiedostopolun, käytä \"/path/to/ignore/**\".", "add_exclusion_pattern_description": "Lisää mallit, jonka mukaan jätetään tiedostoja pois. Jokerimerkit *, ** ja ? ovat tuettuna. Jättääksesi pois kaikki tiedostot mistä tahansa löytyvästä kansiosta \"Raw\" käytä \"**/Raw/**\". Jättääksesi pois kaikki \". tif\" päätteiset tiedot, käytä \"**/*.tif\". Jättääksesi pois tarkan tiedostopolun, käytä \"/path/to/ignore/**\".",
"admin_user": "Ylläpitäjä", "admin_user": "Ylläpitäjä",
"asset_offline_description": "Ulkoista kirjaston resurssia ei enää löydy levyltä, ja se on siirretty roskakoriin. Jos tiedosto siirrettiin kirjaston sisällä, tarkista aikajanaltasi uusi vastaava resurssi. Palauttaaksesi tämän resurssin, varmista, että alla oleva tiedostopolku on Immichin käytettävissä ja skannaa kirjasto uudelleen.", "asset_offline_description": "Ulkoista kirjaston kohdetta ei enää löydy levyltä, ja se on siirretty roskakoriin. Jos tiedosto siirrettiin kirjaston sisällä, tarkista aikajanaltasi uusi vastaava kohde. Palauttaaksesi tämän kohteen, varmista, että alla oleva tiedostopolku on Immichin käytettävissä ja skannaa kirjasto uudelleen.",
"authentication_settings": "Autentikointiasetukset", "authentication_settings": "Autentikointiasetukset",
"authentication_settings_description": "Hallitse salasana-, OAuth- ja muut autentikoinnin asetukset", "authentication_settings_description": "Hallitse salasana-, OAuth- ja muut autentikoinnin asetukset",
"authentication_settings_disable_all": "Haluatko varmasti poistaa kaikki kirjautumistavat käytöstä? Kirjautuminen on tämän jälkeen mahdotonta.", "authentication_settings_disable_all": "Haluatko varmasti poistaa kaikki kirjautumistavat käytöstä? Kirjautuminen on tämän jälkeen mahdotonta.",
@@ -99,10 +101,11 @@
"image_prefer_embedded_preview_setting_description": "Käytä RAW-kuviin upotettuja esikatseluja kuvankäsittelyn syötteenä ja aina kun mahdollista. Tämä voi tarjota tarkempia värejä joillekin kuville, mutta esikatselun laatu riippuu kamerasta ja kuvassa voi olla enemmän pakkausartefakteja.", "image_prefer_embedded_preview_setting_description": "Käytä RAW-kuviin upotettuja esikatseluja kuvankäsittelyn syötteenä ja aina kun mahdollista. Tämä voi tarjota tarkempia värejä joillekin kuville, mutta esikatselun laatu riippuu kamerasta ja kuvassa voi olla enemmän pakkausartefakteja.",
"image_prefer_wide_gamut": "Suosi laajaa väriskaalaa", "image_prefer_wide_gamut": "Suosi laajaa väriskaalaa",
"image_prefer_wide_gamut_setting_description": "Käytä Display P3 -nimiavaruutta pikkukuville. Tämä säilöö värien vivahteet paremmin, mutta kuvat saattavat näyttää erilaisilta vanhemmissa laitteissa. sRGB-kuvat pidetään muuttumattomina, jottei värit muuttuisi.", "image_prefer_wide_gamut_setting_description": "Käytä Display P3 -nimiavaruutta pikkukuville. Tämä säilöö värien vivahteet paremmin, mutta kuvat saattavat näyttää erilaisilta vanhemmissa laitteissa. sRGB-kuvat pidetään muuttumattomina, jottei värit muuttuisi.",
"image_preview_description": "Keskikokoinen kuva, josta metatiedot on poistettu, käytetään yksittäisen resurssin katseluun ja koneoppimiseen", "image_preview_description": "Keskikokoinen kuva, josta metatiedot on poistettu, käytetään yksittäisen kohteen katseluun ja koneoppimiseen",
"image_preview_quality_description": "Esikatselulaatu 1-100. Korkeampi arvo on parempi, mutta tuottaa suurempia tiedostoja ja voi heikentää sovelluksen reagointikykyä. Matalan arvon asettaminen voi vaikuttaa koneoppimisen laatuun.", "image_preview_quality_description": "Esikatselulaatu 1-100. Korkeampi arvo on parempi, mutta tuottaa suurempia tiedostoja ja voi heikentää sovelluksen reagointikykyä. Matalan arvon asettaminen voi vaikuttaa koneoppimisen laatuun.",
"image_preview_title": "Esikatselun asetukset", "image_preview_title": "Esikatselun asetukset",
"image_progressive": "Progressiivinen", "image_progressive": "Progressiivinen",
"image_progressive_description": "Prosessoi JPEG-kuvat progressiivisesti asteittaista näyttämistä varten. Tällä ei ole vaikutusta WebP-kuviin.",
"image_quality": "Laatu", "image_quality": "Laatu",
"image_resolution": "Resoluutio", "image_resolution": "Resoluutio",
"image_resolution_description": "Korkeammat resoluutiot voivat säilyttää enemmän yksityiskohtia, mutta niiden koodaus kestää kauemmin, tiedostokoot ovat suurempia ja ne voivat heikentää sovelluksen reagointikykyä.", "image_resolution_description": "Korkeammat resoluutiot voivat säilyttää enemmän yksityiskohtia, mutta niiden koodaus kestää kauemmin, tiedostokoot ovat suurempia ja ne voivat heikentää sovelluksen reagointikykyä.",
@@ -269,7 +272,7 @@
"oauth_auto_register": "Automaattinen rekisteröinti", "oauth_auto_register": "Automaattinen rekisteröinti",
"oauth_auto_register_description": "Rekisteröi uudet OAuth:lla kirjautuvat käyttäjät automaattisesti", "oauth_auto_register_description": "Rekisteröi uudet OAuth:lla kirjautuvat käyttäjät automaattisesti",
"oauth_button_text": "Painikkeen teksti", "oauth_button_text": "Painikkeen teksti",
"oauth_client_secret_description": "Vaaditaan, jos OAuth-palveluntarjoaja ei tue PKCE:tä (Proof Key for Code Exchange)", "oauth_client_secret_description": "Vaaditaan luottamukselliselle asiakasohjelmalle, tai jos julkinen asiakasohjelma ei tue PKCE:tä (Proof Key for Code Exchange).",
"oauth_enable_description": "Kirjaudu käyttäen OAuthia", "oauth_enable_description": "Kirjaudu käyttäen OAuthia",
"oauth_mobile_redirect_uri": "Mobiilin uudelleenohjaus-URI", "oauth_mobile_redirect_uri": "Mobiilin uudelleenohjaus-URI",
"oauth_mobile_redirect_uri_override": "Ohita mobiilin uudelleenohjaus-URI", "oauth_mobile_redirect_uri_override": "Ohita mobiilin uudelleenohjaus-URI",
@@ -308,7 +311,7 @@
"search_jobs": "Etsi tehtäviä…", "search_jobs": "Etsi tehtäviä…",
"send_welcome_email": "Lähetä tervetuloviesti", "send_welcome_email": "Lähetä tervetuloviesti",
"server_external_domain_settings": "Ulkoinen osoite", "server_external_domain_settings": "Ulkoinen osoite",
"server_external_domain_settings_description": "Osoite julkisille linkeille, http(s):// mukaan lukien", "server_external_domain_settings_description": "Osoite ulkopuolisille linkeille",
"server_public_users": "Julkiset käyttäjät", "server_public_users": "Julkiset käyttäjät",
"server_public_users_description": "Kaikki käyttäjät (nimi ja sähköpostiosoite) luetellaan, kun käyttäjä lisätään jaettuihin albumeihin. Kun toiminto on poistettu käytöstä, käyttäjäluettelo on vain pääkäyttäjien käytettävissä.", "server_public_users_description": "Kaikki käyttäjät (nimi ja sähköpostiosoite) luetellaan, kun käyttäjä lisätään jaettuihin albumeihin. Kun toiminto on poistettu käytöstä, käyttäjäluettelo on vain pääkäyttäjien käytettävissä.",
"server_settings": "Palvelimen asetukset", "server_settings": "Palvelimen asetukset",
@@ -327,8 +330,8 @@
"storage_template_hash_verification_enabled": "Tarkistussumman varmennus käytössä", "storage_template_hash_verification_enabled": "Tarkistussumman varmennus käytössä",
"storage_template_hash_verification_enabled_description": "Ottaa käyttöön tarkistussummien laskennan. Älä poista käytöstä, ellet ole aivan varma seurauksista", "storage_template_hash_verification_enabled_description": "Ottaa käyttöön tarkistussummien laskennan. Älä poista käytöstä, ellet ole aivan varma seurauksista",
"storage_template_migration": "Tallennustilan mallien migraatio", "storage_template_migration": "Tallennustilan mallien migraatio",
"storage_template_migration_description": "Käytä nykyistä <link>{template}a</link> aikaisemmin lähetettyihin kohteisiin", "storage_template_migration_description": "Käytä nykyistä <link>{template}</link> aikaisemmin lähetettyihin kohteisiin",
"storage_template_migration_info": "Tallennusmalli muuntaa kaikki tiedostopäätteet pieniksi kirjaimiksi. Mallipohjan muutokset koskevat vain uusia resursseja. Jos haluat käyttää mallipohjaa takautuvasti aiemmin ladattuihin resursseihin, suorita <link>{job}</link>.", "storage_template_migration_info": "Tallennusmalli muuntaa kaikki tiedostopäätteet pieniksi kirjaimiksi. Mallipohjan muutokset koskevat vain uusia kohteita. Jos haluat käyttää mallipohjaa takautuvasti aiemmin ladattuihin kohteisiin, suorita <link>{job}</link>.",
"storage_template_migration_job": "Tallennustilan mallin muutostyö", "storage_template_migration_job": "Tallennustilan mallin muutostyö",
"storage_template_more_details": "Saadaksesi lisätietoa tästä ominaisuudesta, katso <template-link>Tallennustilan Mallit</template-link> sekä <implications-link>mihin se vaikuttaa</implications-link>", "storage_template_more_details": "Saadaksesi lisätietoa tästä ominaisuudesta, katso <template-link>Tallennustilan Mallit</template-link> sekä <implications-link>mihin se vaikuttaa</implications-link>",
"storage_template_onboarding_description_v2": "Päälle kytkettynä toiminto järjestelee tiedostot automaattisesti käyttäjän määrittämän mallin mukaisesti. Lisätietoja <link>dokumentaatiosta</link>..", "storage_template_onboarding_description_v2": "Päälle kytkettynä toiminto järjestelee tiedostot automaattisesti käyttäjän määrittämän mallin mukaisesti. Lisätietoja <link>dokumentaatiosta</link>..",
@@ -348,7 +351,7 @@
"template_settings": "Ilmoitusmallit", "template_settings": "Ilmoitusmallit",
"template_settings_description": "Hallitse yksilöllisten ilmoitusten malleja", "template_settings_description": "Hallitse yksilöllisten ilmoitusten malleja",
"theme_custom_css_settings": "Mukautettu CSS", "theme_custom_css_settings": "Mukautettu CSS",
"theme_custom_css_settings_description": "Mukauta Immichin ulkoasua CSS:llä.", "theme_custom_css_settings_description": "Cascading Style Sheets mahdollistaa Immichin ulkoasun mukauttamisen.",
"theme_settings": "Teeman asetukset", "theme_settings": "Teeman asetukset",
"theme_settings_description": "Kustomoi Immichin web-käyttöliittymää", "theme_settings_description": "Kustomoi Immichin web-käyttöliittymää",
"thumbnail_generation_job": "Luo pikkukuvat", "thumbnail_generation_job": "Luo pikkukuvat",
@@ -408,7 +411,7 @@
"transcoding_tone_mapping": "Sävykartoitus", "transcoding_tone_mapping": "Sävykartoitus",
"transcoding_tone_mapping_description": "Pyrkii säilömään HDR-kuvien ulkonäön, kun muunnetaan peruskuvaksi. Jokaisella algoritmilla on omat heikkoutensa värien, yksityiskohtien tai kirkkauksien kesken. Hable säilöö yksityiskohdat, Mobius värit ja Reinhard kirkkaudet.", "transcoding_tone_mapping_description": "Pyrkii säilömään HDR-kuvien ulkonäön, kun muunnetaan peruskuvaksi. Jokaisella algoritmilla on omat heikkoutensa värien, yksityiskohtien tai kirkkauksien kesken. Hable säilöö yksityiskohdat, Mobius värit ja Reinhard kirkkaudet.",
"transcoding_transcode_policy": "Transkoodauskäytäntö", "transcoding_transcode_policy": "Transkoodauskäytäntö",
"transcoding_transcode_policy_description": "Käytäntö, miten video tulisi transkoodata. HDR-videot transkoodataan aina, paitsi jos transkoodaus on poistettu käytöstä.", "transcoding_transcode_policy_description": "Käytäntö, miten video tulisi transkoodata. HDR-videot ja videot, joissa pikselimuoto on jokin muu kuin YUV 4:2:0, transkoodataan aina, paitsi jos transkoodaus on poistettu käytöstä.",
"transcoding_two_pass_encoding": "Two-pass enkoodaus", "transcoding_two_pass_encoding": "Two-pass enkoodaus",
"transcoding_two_pass_encoding_setting_description": "Transkoodaa kahdessa vaiheessa tuottaaksesi paremmin koodattuja videoita. Kun maksimibittinopeus on käytössä (vaaditaan H.264- ja HEVC-koodaukselle), tämä tila käyttää bittinopeusaluetta, joka perustuu maksimibittinopeuteen ja ohittaa CRF. VP9 osalta CRF:ää voidaan käyttää, jos maksimibittinopeus on poistettu käytöstä.", "transcoding_two_pass_encoding_setting_description": "Transkoodaa kahdessa vaiheessa tuottaaksesi paremmin koodattuja videoita. Kun maksimibittinopeus on käytössä (vaaditaan H.264- ja HEVC-koodaukselle), tämä tila käyttää bittinopeusaluetta, joka perustuu maksimibittinopeuteen ja ohittaa CRF. VP9 osalta CRF:ää voidaan käyttää, jos maksimibittinopeus on poistettu käytöstä.",
"transcoding_video_codec": "Videokoodekki", "transcoding_video_codec": "Videokoodekki",
@@ -492,6 +495,7 @@
"album_summary": "Albumi tiivistelmä", "album_summary": "Albumi tiivistelmä",
"album_updated": "Albumi päivitetty", "album_updated": "Albumi päivitetty",
"album_updated_setting_description": "Saa sähköpostia kun jaetussa albumissa on uutta sisältöä", "album_updated_setting_description": "Saa sähköpostia kun jaetussa albumissa on uutta sisältöä",
"album_upload_assets": "Lataa kohteet tietokoneelta ja lisää ne albumiin",
"album_user_left": "Poistuttiin albumista {album}", "album_user_left": "Poistuttiin albumista {album}",
"album_user_removed": "{user} poistettu", "album_user_removed": "{user} poistettu",
"album_viewer_appbar_delete_confirm": "Haluatko varmasti poistaa tämän albumin tililtäsi?", "album_viewer_appbar_delete_confirm": "Haluatko varmasti poistaa tämän albumin tililtäsi?",
@@ -568,8 +572,11 @@
"asset_list_layout_sub_title": "Asettelu", "asset_list_layout_sub_title": "Asettelu",
"asset_list_settings_subtitle": "Kuvaruudukon asettelu", "asset_list_settings_subtitle": "Kuvaruudukon asettelu",
"asset_list_settings_title": "Kuvaruudukko", "asset_list_settings_title": "Kuvaruudukko",
"asset_not_found_on_device_android": "Kohdetta ei löytynyt laitteelta",
"asset_not_found_on_device_ios": "Kohdetta ei löytynyt laitteelta. Jos käytät iCloudia, voi kohde olla käyttämättömissä iCloudiin tallennetun viallisen tiedoston vuoksi",
"asset_not_found_on_icloud": "Kohdetta ei löytynyt iCloudista. Kohde voi olla käyttämättömissä iCloudiin tallennetun viallisen tiedoston vuoksi",
"asset_offline": "Aineisto offline-tilassa", "asset_offline": "Aineisto offline-tilassa",
"asset_offline_description": "Tätä ulkoista resurssia ei enää löydy levyltä. Ole hyvä ja ota yhteyttä Immich-järjestelmänvalvojaan saadaksesi apua.", "asset_offline_description": "Tätä ulkoista kohdetta ei enää löydy levyltä. Ole hyvä ja ota yhteyttä Immich-järjestelmänvalvojaan saadaksesi apua.",
"asset_restored_successfully": "Kohde palautettu onnistuneesti", "asset_restored_successfully": "Kohde palautettu onnistuneesti",
"asset_skipped": "Ohitettu", "asset_skipped": "Ohitettu",
"asset_skipped_in_trash": "Roskakorissa", "asset_skipped_in_trash": "Roskakorissa",
@@ -656,7 +663,7 @@
"backup_controller_page_filename": "Tiedostonimi: {filename} [{size}]", "backup_controller_page_filename": "Tiedostonimi: {filename} [{size}]",
"backup_controller_page_id": "ID: {id}", "backup_controller_page_id": "ID: {id}",
"backup_controller_page_info": "Varmuuskopioinnin tiedot", "backup_controller_page_info": "Varmuuskopioinnin tiedot",
"backup_controller_page_none_selected": "Ei mitään", "backup_controller_page_none_selected": "Ei mitään valittuna",
"backup_controller_page_remainder": "Jäljellä", "backup_controller_page_remainder": "Jäljellä",
"backup_controller_page_remainder_sub": "Varmuuskopiointia odottavat kuvat ja videot", "backup_controller_page_remainder_sub": "Varmuuskopiointia odottavat kuvat ja videot",
"backup_controller_page_server_storage": "Palvelimen tallennustila", "backup_controller_page_server_storage": "Palvelimen tallennustila",
@@ -757,9 +764,13 @@
"cleanup_deleted_assets": "Siirretty {count} kohdetta laitteen roskakoriin", "cleanup_deleted_assets": "Siirretty {count} kohdetta laitteen roskakoriin",
"cleanup_deleting": "Siirretään roskakoriin...", "cleanup_deleting": "Siirretään roskakoriin...",
"cleanup_found_assets": "Löytyi {count} varmuuskopioitua kohdetta", "cleanup_found_assets": "Löytyi {count} varmuuskopioitua kohdetta",
"cleanup_found_assets_with_size": "Löytyi {count} varmuuskopioitua kohdetta ({size})",
"cleanup_icloud_shared_albums_excluded": "Jaettuja iCloud-albumeja ei skannata", "cleanup_icloud_shared_albums_excluded": "Jaettuja iCloud-albumeja ei skannata",
"cleanup_no_assets_found": "Ehtojasi vastaavia varmuuskopioituja kohteita ei löytynyt", "cleanup_no_assets_found": "Kriteerejä vastaavia kohteita ei löytynyt. Levytilan vapautus voi poistaa vain kohteita, jotka on varmuuskopioitu palvelimelle",
"cleanup_preview_title": "Poistettavia kohteita {count}", "cleanup_preview_title": "Poistettavia kohteita {count}",
"cleanup_step3_description": "Etsi tallennettua sisältöä joka vastaa valittua päivämäärää ja pidä asetukset.",
"cleanup_step4_summary": "{count} kohdetta (luotu ennen {date}) poistetaan paikalliselta laitteeltasi. Kuvat pysyvät saatavilla Immich-sovelluksessa.",
"cleanup_trash_hint": "Vapauttaaksesi tallennustilan kokonaan, avaa järjestelmän galleria-sovellus ja tyhjennä roskakori",
"clear": "Tyhjennä", "clear": "Tyhjennä",
"clear_all": "Tyhjennä kaikki", "clear_all": "Tyhjennä kaikki",
"clear_all_recent_searches": "Tyhjennä viimeisimmät haut", "clear_all_recent_searches": "Tyhjennä viimeisimmät haut",
@@ -771,6 +782,8 @@
"client_cert_import": "Tuo", "client_cert_import": "Tuo",
"client_cert_import_success_msg": "Asiakasvarmenne tuotu", "client_cert_import_success_msg": "Asiakasvarmenne tuotu",
"client_cert_invalid_msg": "Virheellinen varmennetiedosto tai väärä salasana", "client_cert_invalid_msg": "Virheellinen varmennetiedosto tai väärä salasana",
"client_cert_password_message": "Syötä salasana tälle sertifikaatille",
"client_cert_password_title": "Sertifikaatin salasana",
"client_cert_remove_msg": "Asiakassertifikaatti on poistettu", "client_cert_remove_msg": "Asiakassertifikaatti on poistettu",
"client_cert_subtitle": "Vain PKCS12 (.p12, .pfx) -muotoa tuetaan. Varmenteen tuonti/poisto on käytettävissä vain ennen sisäänkirjautumista", "client_cert_subtitle": "Vain PKCS12 (.p12, .pfx) -muotoa tuetaan. Varmenteen tuonti/poisto on käytettävissä vain ennen sisäänkirjautumista",
"client_cert_title": "SSL-asiakassertifikaatti [KOKEELLINEN]", "client_cert_title": "SSL-asiakassertifikaatti [KOKEELLINEN]",
@@ -781,6 +794,11 @@
"color": "Väri", "color": "Väri",
"color_theme": "Väriteema", "color_theme": "Väriteema",
"command": "Komento", "command": "Komento",
"command_palette_prompt": "Löydä nopeasti sivuja, toimintoja tai komentoja",
"command_palette_to_close": "sulkea",
"command_palette_to_navigate": "syöttää",
"command_palette_to_select": "valita",
"command_palette_to_show_all": "näyttää kaikki",
"comment_deleted": "Kommentti poistettu", "comment_deleted": "Kommentti poistettu",
"comment_options": "Kommentin valinnat", "comment_options": "Kommentin valinnat",
"comments_and_likes": "Kommentit ja tykkäykset", "comments_and_likes": "Kommentit ja tykkäykset",
@@ -846,15 +864,19 @@
"creating_linked_albums": "Luodaan linkattuja albumeita...", "creating_linked_albums": "Luodaan linkattuja albumeita...",
"crop": "Rajaa", "crop": "Rajaa",
"crop_aspect_ratio_fixed": "Kiinteä", "crop_aspect_ratio_fixed": "Kiinteä",
"crop_aspect_ratio_free": "Vapaa",
"crop_aspect_ratio_original": "Alkuperäinen", "crop_aspect_ratio_original": "Alkuperäinen",
"curated_object_page_title": "Asiat", "curated_object_page_title": "Asiat",
"current_device": "Nykyinen laite", "current_device": "Nykyinen laite",
"current_pin_code": "Nykyinen PIN-koodi", "current_pin_code": "Nykyinen PIN-koodi",
"current_server_address": "Nykyinen palvelinosoite", "current_server_address": "Nykyinen palvelinosoite",
"custom_date": "Mukautettu päivä", "custom_date": "Mukautettu päivä",
"custom_locale": "Muokatut maa-asetukset", "custom_locale": "Mukautettu alueasetus",
"custom_locale_description": "Muotoile päivämäärät ja numerot perustuen alueen kieleen", "custom_locale_description": "Muotoile päivämäärät, kellonajat ja numerot valitun kielen ja alueen mukaan",
"custom_url": "Mukautettu URL", "custom_url": "Mukautettu URL",
"cutoff_date_description": "Säilytä kuvat viimeisimmältä…",
"cutoff_day": "{count, plural, one {päivä} other {päivää}}",
"cutoff_year": "{count, plural, one {vuosi} other {vuotta}}",
"daily_title_text_date": "E, dd MMM", "daily_title_text_date": "E, dd MMM",
"daily_title_text_date_year": "E, dd MMM, yyyy", "daily_title_text_date_year": "E, dd MMM, yyyy",
"dark": "Tumma", "dark": "Tumma",
@@ -873,8 +895,6 @@
"deduplication_criteria_2": "EXIF-datan määrä", "deduplication_criteria_2": "EXIF-datan määrä",
"deduplication_info": "Deduplikaatiotieto", "deduplication_info": "Deduplikaatiotieto",
"deduplication_info_description": "Jotta voimme automaattisesti esivalita aineistot ja poistaa kaksoiskappaleet suurina erinä, tarkastelemme:", "deduplication_info_description": "Jotta voimme automaattisesti esivalita aineistot ja poistaa kaksoiskappaleet suurina erinä, tarkastelemme:",
"default_locale": "Oletuskieliasetus",
"default_locale_description": "Muotoile päivämäärät ja numerot selaimesi kielen mukaan",
"delete": "Poista", "delete": "Poista",
"delete_action_confirmation_message": "Haluatko varmasti poistaa tämän aineiston? Tämä toiminto siirtää aineiston palvelimen roskakoriin ja kysyy, haluatko poistaa sen myös paikallisesti", "delete_action_confirmation_message": "Haluatko varmasti poistaa tämän aineiston? Tämä toiminto siirtää aineiston palvelimen roskakoriin ja kysyy, haluatko poistaa sen myös paikallisesti",
"delete_action_prompt": "{count} poistettu", "delete_action_prompt": "{count} poistettu",
@@ -980,6 +1000,11 @@
"editor_close_without_save_prompt": "Muutoksia ei tallenneta", "editor_close_without_save_prompt": "Muutoksia ei tallenneta",
"editor_close_without_save_title": "Suljetaanko editori?", "editor_close_without_save_title": "Suljetaanko editori?",
"editor_confirm_reset_all_changes": "Haluatko varmasti nollata kaikki muutokset?", "editor_confirm_reset_all_changes": "Haluatko varmasti nollata kaikki muutokset?",
"editor_discard_edits_confirm": "Hylkää muutokset",
"editor_discard_edits_prompt": "Sinulla on tallentamattomia muutoksia. Haluatko varmasti hylätä ne?",
"editor_discard_edits_title": "Hylkää muutokset?",
"editor_edits_applied_error": "Muutosten käyttöönotto epäonnistui",
"editor_edits_applied_success": "Muutokset otettu käyttöön",
"editor_flip_horizontal": "Käännä vaakatasossa", "editor_flip_horizontal": "Käännä vaakatasossa",
"editor_flip_vertical": "Käännä pystytasossa", "editor_flip_vertical": "Käännä pystytasossa",
"editor_orientation": "Suunta", "editor_orientation": "Suunta",
@@ -1007,9 +1032,11 @@
"error_loading_albums": "Virhe albumeita ladatessa", "error_loading_albums": "Virhe albumeita ladatessa",
"error_loading_image": "Kuvan lataus ei onnistunut", "error_loading_image": "Kuvan lataus ei onnistunut",
"error_loading_partners": "Ongelma partnerin haussa: {error}", "error_loading_partners": "Ongelma partnerin haussa: {error}",
"error_retrieving_asset_information": "Virhe kohdetietojen hakemisessa",
"error_saving_image": "Virhe: {error}", "error_saving_image": "Virhe: {error}",
"error_tag_face_bounding_box": "Kasvojen merkitseminen epäonnistui rajausruudun koordinaatteja ei löydy", "error_tag_face_bounding_box": "Kasvojen merkitseminen epäonnistui rajausruudun koordinaatteja ei löydy",
"error_title": "Virhe - Jotain meni pieleen", "error_title": "Virhe - Jotain meni pieleen",
"error_while_navigating": "Virhe siirryttäessä kohteeseen",
"errors": { "errors": {
"cannot_navigate_next_asset": "Seuraavaan mediaan ei voi siirtyä", "cannot_navigate_next_asset": "Seuraavaan mediaan ei voi siirtyä",
"cannot_navigate_previous_asset": "Edelliseen mediaan ei voi siirtyä", "cannot_navigate_previous_asset": "Edelliseen mediaan ei voi siirtyä",
@@ -1045,6 +1072,7 @@
"failed_to_update_notification_status": "Ilmoituksen tilan päivittäminen epäonnistui", "failed_to_update_notification_status": "Ilmoituksen tilan päivittäminen epäonnistui",
"incorrect_email_or_password": "Väärä sähköpostiosoite tai salasana", "incorrect_email_or_password": "Väärä sähköpostiosoite tai salasana",
"library_folder_already_exists": "Tämä tuonnin polku on jo olemassa.", "library_folder_already_exists": "Tämä tuonnin polku on jo olemassa.",
"page_not_found": "Sivua ei löytynyt",
"paths_validation_failed": "{paths, plural, one {# polun} other {# polun}} validointi epäonnistui", "paths_validation_failed": "{paths, plural, one {# polun} other {# polun}} validointi epäonnistui",
"profile_picture_transparent_pixels": "Profiilikuvassa ei voi olla läpinäkyviä pikseleitä. Zoomaa lähemmäs ja/tai siirrä kuvaa.", "profile_picture_transparent_pixels": "Profiilikuvassa ei voi olla läpinäkyviä pikseleitä. Zoomaa lähemmäs ja/tai siirrä kuvaa.",
"quota_higher_than_disk_size": "Asettamasi kiintiö on suurempi kuin levyn koko", "quota_higher_than_disk_size": "Asettamasi kiintiö on suurempi kuin levyn koko",
@@ -1118,6 +1146,7 @@
"unable_to_scan_library": "Kirjaston skannaaminen epäonnistui", "unable_to_scan_library": "Kirjaston skannaaminen epäonnistui",
"unable_to_set_feature_photo": "Ei voida asettaa ominaiskuvaa", "unable_to_set_feature_photo": "Ei voida asettaa ominaiskuvaa",
"unable_to_set_profile_picture": "Profiilikuvan asetus epäonnistui", "unable_to_set_profile_picture": "Profiilikuvan asetus epäonnistui",
"unable_to_set_rating": "Luokitusta ei voida asettaa",
"unable_to_submit_job": "Työtä ei voitu lähettää", "unable_to_submit_job": "Työtä ei voitu lähettää",
"unable_to_trash_asset": "Median siirto roskakoriin epäonnistui", "unable_to_trash_asset": "Median siirto roskakoriin epäonnistui",
"unable_to_unlink_account": "Tunnuksen irroitus epäonnistui", "unable_to_unlink_account": "Tunnuksen irroitus epäonnistui",
@@ -1143,6 +1172,7 @@
"exif_bottom_sheet_people": "IHMISET", "exif_bottom_sheet_people": "IHMISET",
"exif_bottom_sheet_person_add_person": "Lisää nimi", "exif_bottom_sheet_person_add_person": "Lisää nimi",
"exit_slideshow": "Poistu diaesityksestä", "exit_slideshow": "Poistu diaesityksestä",
"expand": "Laajenna",
"expand_all": "Laajenna kaikki", "expand_all": "Laajenna kaikki",
"experimental_settings_new_asset_list_subtitle": "Työn alla", "experimental_settings_new_asset_list_subtitle": "Työn alla",
"experimental_settings_new_asset_list_title": "Ota käyttöön kokeellinen kuvaruudukko", "experimental_settings_new_asset_list_title": "Ota käyttöön kokeellinen kuvaruudukko",
@@ -1178,12 +1208,16 @@
"features_in_development": "Kehityksessä olevat ominaisuudet", "features_in_development": "Kehityksessä olevat ominaisuudet",
"features_setting_description": "Hallitse sovelluksen ominaisuuksia", "features_setting_description": "Hallitse sovelluksen ominaisuuksia",
"file_name_or_extension": "Tiedostonimi tai tiedostopääte", "file_name_or_extension": "Tiedostonimi tai tiedostopääte",
"file_name_text": "Tiedoston nimi",
"file_name_with_value": "Tiedoston nimi: {file_name}",
"file_size": "Tiedostokoko", "file_size": "Tiedostokoko",
"filename": "Tiedostonimi", "filename": "Tiedostonimi",
"filetype": "Tiedostotyyppi", "filetype": "Tiedostotyyppi",
"filter": "Suodatin", "filter": "Suodatin",
"filter_description": "Tavoitekohteiden suodatusehdot",
"filter_people": "Suodata henkilöt", "filter_people": "Suodata henkilöt",
"filter_places": "Suodata paikkoja", "filter_places": "Suodata paikkoja",
"filter_tags": "Suodatintunnisteet",
"filters": "Suodattimet", "filters": "Suodattimet",
"find_them_fast": "Löydä nopeasti hakemalla nimellä", "find_them_fast": "Löydä nopeasti hakemalla nimellä",
"first": "Ensimmäinen", "first": "Ensimmäinen",
@@ -1194,12 +1228,16 @@
"folders_feature_description": "Käytetään kansionäkymää valokuvien ja videoiden selaamiseen järjestelmässä", "folders_feature_description": "Käytetään kansionäkymää valokuvien ja videoiden selaamiseen järjestelmässä",
"forgot_pin_code_question": "Unohditko PIN-koodisi?", "forgot_pin_code_question": "Unohditko PIN-koodisi?",
"forward": "Eteenpäin", "forward": "Eteenpäin",
"free_up_space": "Vapauta tilaa",
"free_up_space_description": "Siirrä varmuuskopioidut valokuvat ja videot laitteen roskakoriin vapauttaaksesi tilaa. Palvelimella olevat kopiosi säilyvät turvassa.",
"free_up_space_settings_subtitle": "Vapauta laitteen tilaa",
"full_path": "Koko polku: {path}", "full_path": "Koko polku: {path}",
"gcast_enabled": "Google Cast", "gcast_enabled": "Google Cast",
"gcast_enabled_description": "Ominaisuus lataa ulkoisia resursseja Googlelta toimiakseen.", "gcast_enabled_description": "Ominaisuus lataa ulkoisia kohteita Googlelta toimiakseen.",
"general": "Yleinen", "general": "Yleinen",
"geolocation_instruction_location": "Napsauta kuvaa, jossa on GPS-koordinaatit, käyttääksesi sen sijaintia, tai valitse sijainti suoraan kartalta", "geolocation_instruction_location": "Napsauta kuvaa, jossa on GPS-koordinaatit, käyttääksesi sen sijaintia, tai valitse sijainti suoraan kartalta",
"get_help": "Hae apua", "get_help": "Hae apua",
"get_people_error": "Virhe haettaessa henkilöitä",
"get_wifiname_error": "Wi-Fi-verkon nimen hakeminen epäonnistui. Varmista, että olet myöntänyt tarvittavat käyttöoikeudet ja että olet yhteydessä Wi-Fi-verkkoon", "get_wifiname_error": "Wi-Fi-verkon nimen hakeminen epäonnistui. Varmista, että olet myöntänyt tarvittavat käyttöoikeudet ja että olet yhteydessä Wi-Fi-verkkoon",
"getting_started": "Aloittaminen", "getting_started": "Aloittaminen",
"go_back": "Palaa", "go_back": "Palaa",
@@ -1309,6 +1347,7 @@
"json_error": "JSON-virhe", "json_error": "JSON-virhe",
"keep": "Säilytä", "keep": "Säilytä",
"keep_albums": "Säilytä albumit", "keep_albums": "Säilytä albumit",
"keep_albums_count": "Säilytetään {count} {count, plural, one {albumi} other {albumia}}",
"keep_all": "Säilytä kaikki", "keep_all": "Säilytä kaikki",
"keep_description": "Valitse, mitä laitteella säilytetään tilan vapautuksen yhteydessä.", "keep_description": "Valitse, mitä laitteella säilytetään tilan vapautuksen yhteydessä.",
"keep_favorites": "Säilytä suosikit", "keep_favorites": "Säilytä suosikit",
@@ -1357,6 +1396,7 @@
"local": "Paikallinen", "local": "Paikallinen",
"local_asset_cast_failed": "Kohdetta, joka ei ole ladattuna palvelimelle, ei voida striimata", "local_asset_cast_failed": "Kohdetta, joka ei ole ladattuna palvelimelle, ei voida striimata",
"local_assets": "Paikalliset kohteet", "local_assets": "Paikalliset kohteet",
"local_id": "Paikallinen ID",
"local_media_summary": "Paikallisen median yhteenveto", "local_media_summary": "Paikallisen median yhteenveto",
"local_network": "Lähiverkko", "local_network": "Lähiverkko",
"local_network_sheet_info": "Sovellus muodostaa yhteyden palvelimeen tämän URL-osoitteen kautta, kun käytetään määritettyä Wi-Fi-verkkoa", "local_network_sheet_info": "Sovellus muodostaa yhteyden palvelimeen tämän URL-osoitteen kautta, kun käytetään määritettyä Wi-Fi-verkkoa",
@@ -1416,11 +1456,15 @@
"maintenance_restore_from_backup": "Palauta varmuuskopiosta", "maintenance_restore_from_backup": "Palauta varmuuskopiosta",
"maintenance_restore_library": "Palauta kirjastosta", "maintenance_restore_library": "Palauta kirjastosta",
"maintenance_restore_library_confirm": "Jos tämä vaikuttaa oikealta, jatka varmuuskopion palauttamista!", "maintenance_restore_library_confirm": "Jos tämä vaikuttaa oikealta, jatka varmuuskopion palauttamista!",
"maintenance_restore_library_description": "Tietokannan palauttaminen",
"maintenance_restore_library_folder_has_files": "{folder} sisältää {count, plural, one {kansion} other {kansiota}}",
"maintenance_restore_library_folder_no_files": "Kansiosta {folder} puuttuu tiedostoja!",
"maintenance_restore_library_folder_pass": "luettavissa ja kirjoitettavissa", "maintenance_restore_library_folder_pass": "luettavissa ja kirjoitettavissa",
"maintenance_restore_library_folder_read_fail": "ei luettavissa", "maintenance_restore_library_folder_read_fail": "ei luettavissa",
"maintenance_restore_library_folder_write_fail": "ei kirjoitettavissa", "maintenance_restore_library_folder_write_fail": "ei kirjoitettavissa",
"maintenance_restore_library_hint_missing_files": "Sinulta saattaa puuttua tärkeitä tiedostoja", "maintenance_restore_library_hint_missing_files": "Sinulta saattaa puuttua tärkeitä tiedostoja",
"maintenance_restore_library_hint_regenerate_later": "Voit luoda ne uudelleen myöhemmin asetuksissa", "maintenance_restore_library_hint_regenerate_later": "Voit luoda ne uudelleen myöhemmin asetuksissa",
"maintenance_restore_library_hint_storage_template_missing_files": "Käytätkö tallennusmallia? Sinulta saattaa puuttua tiedostoja",
"maintenance_restore_library_loading": "Ladataan eheystarkistuksia ja heurestiikkaa…", "maintenance_restore_library_loading": "Ladataan eheystarkistuksia ja heurestiikkaa…",
"maintenance_task_backup": "Luodaan varmuuskopiota olemassa olevasta tietokannasta…", "maintenance_task_backup": "Luodaan varmuuskopiota olemassa olevasta tietokannasta…",
"maintenance_task_migrations": "Suoritetaan tietokantamigraatioita…", "maintenance_task_migrations": "Suoritetaan tietokantamigraatioita…",
@@ -1487,6 +1531,8 @@
"minimize": "Pienennä", "minimize": "Pienennä",
"minute": "Minuutti", "minute": "Minuutti",
"minutes": "Minuutit", "minutes": "Minuutit",
"mirror_horizontal": "Vaakasuora",
"mirror_vertical": "Pystysuora",
"missing": "Puuttuvat", "missing": "Puuttuvat",
"mobile_app": "Mobiilisovellus", "mobile_app": "Mobiilisovellus",
"mobile_app_download_onboarding_note": "Lataa mobiilisovellus käyttämällä seuraavia vaihtoehtoja", "mobile_app_download_onboarding_note": "Lataa mobiilisovellus käyttämällä seuraavia vaihtoehtoja",
@@ -1495,11 +1541,14 @@
"monthly_title_text_date_format": "MMMM y", "monthly_title_text_date_format": "MMMM y",
"more": "Enemmän", "more": "Enemmän",
"move": "Siirrä", "move": "Siirrä",
"move_down": "Siirrä alas",
"move_off_locked_folder": "Siirrä pois lukitusta kansiosta", "move_off_locked_folder": "Siirrä pois lukitusta kansiosta",
"move_to": "Siirrä kohteeseen", "move_to": "Siirrä kohteeseen",
"move_to_device_trash": "Siirrä laitteen roskakoriin",
"move_to_lock_folder_action_prompt": "{count} lisätty lukittuun kansioon", "move_to_lock_folder_action_prompt": "{count} lisätty lukittuun kansioon",
"move_to_locked_folder": "Siirrä lukittuun kansioon", "move_to_locked_folder": "Siirrä lukittuun kansioon",
"move_to_locked_folder_confirmation": "Nämä kuvat ja videot poistetaan kaikista albumeista, ja ne ovat nähtävissä vain lukitussa kansiossa", "move_to_locked_folder_confirmation": "Nämä kuvat ja videot poistetaan kaikista albumeista, ja ne ovat nähtävissä vain lukitussa kansiossa",
"move_up": "Siirrä ylös",
"moved_to_archive": "Siirretty {count, plural, one {# kohde} other {# kohdetta}} arkistoon", "moved_to_archive": "Siirretty {count, plural, one {# kohde} other {# kohdetta}} arkistoon",
"moved_to_library": "Siirretty {count, plural, one {# kohde} other {# kohdetta}} kirjastoon", "moved_to_library": "Siirretty {count, plural, one {# kohde} other {# kohdetta}} kirjastoon",
"moved_to_trash": "Siirretty roskakoriin", "moved_to_trash": "Siirretty roskakoriin",
@@ -1545,9 +1594,10 @@
"no_cast_devices_found": "Cast-laitteita ei löytynyt", "no_cast_devices_found": "Cast-laitteita ei löytynyt",
"no_checksum_local": "Ei tarkistussummaa - paikallista sisältöä ei voida hakea", "no_checksum_local": "Ei tarkistussummaa - paikallista sisältöä ei voida hakea",
"no_checksum_remote": "Ei tarkistussummaa - etänä olevaa sisältöä ei voida hakea", "no_checksum_remote": "Ei tarkistussummaa - etänä olevaa sisältöä ei voida hakea",
"no_configuration_needed": "Konfiguraatiota ei tarvita",
"no_devices": "Ei valtuutettuja laitteita", "no_devices": "Ei valtuutettuja laitteita",
"no_duplicates_found": "Kaksoiskappaleita ei löytynyt.", "no_duplicates_found": "Kaksoiskappaleita ei löytynyt.",
"no_exif_info_available": "EXIF-tietoa ei saatavilla", "no_exif_info_available": "Exif-tietoja ei ole saatavilla",
"no_explore_results_message": "Lataa lisää kuvia tutkiaksesi kokoelmaasi.", "no_explore_results_message": "Lataa lisää kuvia tutkiaksesi kokoelmaasi.",
"no_favorites_message": "Lisää suosikkeja löytääksesi nopeasti parhaat kuvasi ja videosi", "no_favorites_message": "Lisää suosikkeja löytääksesi nopeasti parhaat kuvasi ja videosi",
"no_filters_added": "Suodattimia ei ole vielä lisätty", "no_filters_added": "Suodattimia ei ole vielä lisätty",
@@ -1564,6 +1614,7 @@
"no_results_description": "Kokeile synonyymiä tai yleisempää avainsanaa", "no_results_description": "Kokeile synonyymiä tai yleisempää avainsanaa",
"no_shared_albums_message": "Luo albumi, jotta voit jakaa kuvia ja videoita toisille", "no_shared_albums_message": "Luo albumi, jotta voit jakaa kuvia ja videoita toisille",
"no_uploads_in_progress": "Ei käynnissä olevia latauksia", "no_uploads_in_progress": "Ei käynnissä olevia latauksia",
"none": "Ei mitään",
"not_allowed": "Ei sallittu", "not_allowed": "Ei sallittu",
"not_available": "N/A", "not_available": "N/A",
"not_in_any_album": "Ei yhdessäkään albumissa", "not_in_any_album": "Ei yhdessäkään albumissa",
@@ -1597,6 +1648,8 @@
"online": "Online", "online": "Online",
"only_favorites": "Vain suosikit", "only_favorites": "Vain suosikit",
"open": "Avaa", "open": "Avaa",
"open_calendar": "Avaa kalenteri",
"open_in_browser": "Avaa selaimessa",
"open_in_map_view": "Avaa karttanäkymässä", "open_in_map_view": "Avaa karttanäkymässä",
"open_in_openstreetmap": "Avaa OpenStreetMapissa", "open_in_openstreetmap": "Avaa OpenStreetMapissa",
"open_the_search_filters": "Avaa hakusuodattimet", "open_the_search_filters": "Avaa hakusuodattimet",
@@ -1645,6 +1698,7 @@
"people": "Ihmiset", "people": "Ihmiset",
"people_edits_count": "Muokattu {count, plural, one {# henkilö} other {# henkilöä}}", "people_edits_count": "Muokattu {count, plural, one {# henkilö} other {# henkilöä}}",
"people_feature_description": "Selataan valokuvia ja videoita, jotka on ryhmitelty henkilöiden mukaan", "people_feature_description": "Selataan valokuvia ja videoita, jotka on ryhmitelty henkilöiden mukaan",
"people_selected": "{count, plural, one {# henkilö valittu} other {# henkilöä valittu}}",
"people_sidebar_description": "Näytä linkki Henkilöihin sivupalkissa", "people_sidebar_description": "Näytä linkki Henkilöihin sivupalkissa",
"permanent_deletion_warning": "Pysyvän poiston varoitus", "permanent_deletion_warning": "Pysyvän poiston varoitus",
"permanent_deletion_warning_setting_description": "Näytä varoitus, kun poistat kohteita pysyvästi", "permanent_deletion_warning_setting_description": "Näytä varoitus, kun poistat kohteita pysyvästi",
@@ -1752,10 +1806,11 @@
"purchase_settings_server_activated": "Palvelimen tuoteavainta hallinnoi ylläpitäjä", "purchase_settings_server_activated": "Palvelimen tuoteavainta hallinnoi ylläpitäjä",
"query_asset_id": "Kysy sisällön ID:tä", "query_asset_id": "Kysy sisällön ID:tä",
"queue_status": "Jonossa {count}/{total}", "queue_status": "Jonossa {count}/{total}",
"rating": "Tähtiarvostelu", "rate_asset": "Luokittele kohde",
"rating_clear": "Tyhjennä arvostelu", "rating": "Tähtiluokitus",
"rating_count": "{count, plural, one {# tähti} other {# tähteä}}", "rating_clear": "Tyhjennä luokitus",
"rating_description": "Näytä EXIF-arvosana lisätietopaneelissa", "rating_count": "{count, plural, =0 {Ei arvioitu} one {# tähti} other {# tähteä}}",
"rating_description": "Näytä EXIF-luokitus tietopaneelissa",
"reaction_options": "Reaktioasetukset", "reaction_options": "Reaktioasetukset",
"read_changelog": "Lue muutosloki", "read_changelog": "Lue muutosloki",
"readonly_mode_disabled": "Muokkaustila päällä", "readonly_mode_disabled": "Muokkaustila päällä",
@@ -1827,7 +1882,10 @@
"reset_pin_code_success": "PIN-koodi nollattu onnistuneesti", "reset_pin_code_success": "PIN-koodi nollattu onnistuneesti",
"reset_pin_code_with_password": "Voit aina nollata PIN-koodisi salasanan avulla", "reset_pin_code_with_password": "Voit aina nollata PIN-koodisi salasanan avulla",
"reset_sqlite": "Nollaa SQLite Tietokanta", "reset_sqlite": "Nollaa SQLite Tietokanta",
"reset_sqlite_confirmation": "Haluatko varmasti nollata SQLite tietokannan? Sinun tulee kirjautua sovelluksesta ulos ja takaisin sisään uudelleensynkronoidaksesi datan", "reset_sqlite_clear_app_data": "Tyhjennä tiedot",
"reset_sqlite_confirmation": "Haluatko varmasti poistaa sovelluksen tiedot? Tämä poistaa kaikki asetukset ja kirjaa sinut ulos.",
"reset_sqlite_confirmation_note": "Huomaa: Sinun on käynnistettävä sovellus uudelleen tyhjentämisen jälkeen.",
"reset_sqlite_done": "Sovelluksen tiedot on tyhjennetty. Käynnistä Immich uudelleen ja kirjaudu sisään uudelleen.",
"reset_sqlite_success": "SQLite Tietokanta nollattu onnistuneesti", "reset_sqlite_success": "SQLite Tietokanta nollattu onnistuneesti",
"reset_to_default": "Palauta oletusasetukset", "reset_to_default": "Palauta oletusasetukset",
"resolution": "Resoluutio", "resolution": "Resoluutio",
@@ -1855,9 +1913,12 @@
"saved_settings": "Asetukset tallennettu", "saved_settings": "Asetukset tallennettu",
"say_something": "Sano jotain", "say_something": "Sano jotain",
"scaffold_body_error_occurred": "Tapahtui virhe", "scaffold_body_error_occurred": "Tapahtui virhe",
"scaffold_body_error_unrecoverable": "Korjaamaton virhe on tapahtunut. Jaa virhe ja pinojälki Discordissa tai GitHubissa, jotta voimme auttaa. Pyydettäessä voit tyhjentää sovelluksen tiedot alla.",
"scan": "Skannaa",
"scan_all_libraries": "Skannaa kaikki kirjastot", "scan_all_libraries": "Skannaa kaikki kirjastot",
"scan_library": "Skannaa", "scan_library": "Skannaa",
"scan_settings": "Skannausasetukset", "scan_settings": "Skannausasetukset",
"scanning": "Skannataan",
"scanning_for_album": "Etsitään albumia...", "scanning_for_album": "Etsitään albumia...",
"search": "Haku", "search": "Haku",
"search_albums": "Etsi albumeita", "search_albums": "Etsi albumeita",
@@ -1887,6 +1948,8 @@
"search_filter_media_type_title": "Valitse mediatyyppi", "search_filter_media_type_title": "Valitse mediatyyppi",
"search_filter_ocr": "Hae tekstintunnistuksella (OCR)", "search_filter_ocr": "Hae tekstintunnistuksella (OCR)",
"search_filter_people_title": "Valitse ihmiset", "search_filter_people_title": "Valitse ihmiset",
"search_filter_star_rating": "Tähtiluokitus",
"search_filter_tags_title": "Valitse tunnisteita",
"search_for": "Hae", "search_for": "Hae",
"search_for_existing_person": "Etsi olemassa olevaa henkilöä", "search_for_existing_person": "Etsi olemassa olevaa henkilöä",
"search_no_more_result": "Ei enää tuloksia", "search_no_more_result": "Ei enää tuloksia",
@@ -1928,12 +1991,15 @@
"select_all_duplicates": "Valitse kaikki kaksoiskappaleet", "select_all_duplicates": "Valitse kaikki kaksoiskappaleet",
"select_all_in": "Valitse kaikki {group}", "select_all_in": "Valitse kaikki {group}",
"select_avatar_color": "Valitse avatarin väri", "select_avatar_color": "Valitse avatarin väri",
"select_count": "{count, plural, one {Valitse #} other {Valitse #}}",
"select_cutoff_date": "Valitse katkaisuajankohta",
"select_face": "Valitse kasvo", "select_face": "Valitse kasvo",
"select_featured_photo": "Valitse esittelykuva", "select_featured_photo": "Valitse esittelykuva",
"select_from_computer": "Valitse koneeltasi", "select_from_computer": "Valitse koneeltasi",
"select_keep_all": "Valitse pidä kaikki", "select_keep_all": "Valitse pidä kaikki",
"select_library_owner": "Valitse kirjaston omistaja", "select_library_owner": "Valitse kirjaston omistaja",
"select_new_face": "Valitse uudet kasvot", "select_new_face": "Valitse uudet kasvot",
"select_people": "Valitse henkilöitä",
"select_person": "Valitse henkilö", "select_person": "Valitse henkilö",
"select_person_to_tag": "Valitse henkilö, jonka haluat merkitä", "select_person_to_tag": "Valitse henkilö, jonka haluat merkitä",
"select_photos": "Valitse kuvat", "select_photos": "Valitse kuvat",
@@ -1963,6 +2029,9 @@
"set_profile_picture": "Aseta profiilikuva", "set_profile_picture": "Aseta profiilikuva",
"set_slideshow_to_fullscreen": "Näytä diaesitys koko ruudulla", "set_slideshow_to_fullscreen": "Näytä diaesitys koko ruudulla",
"set_stack_primary_asset": "Aseta pääkohteeksi", "set_stack_primary_asset": "Aseta pääkohteeksi",
"setting_image_navigation_enable_subtitle": "Jos tämä toiminto on käytössä, voit siirtyä edelliseen/seuraavaan kuvaan napauttamalla näytön vasenta/oikeaa reunaa.",
"setting_image_navigation_enable_title": "Napauta navigoidaksesi",
"setting_image_navigation_title": "Kuvien selaus",
"setting_image_viewer_help": "Kuvaa katseltaessa ensin ladataan pikkukuva, sitten keskilaatuinen pikkukuva (jos käytössä) ja lopuksi alkuperäinen (jos käytössä).", "setting_image_viewer_help": "Kuvaa katseltaessa ensin ladataan pikkukuva, sitten keskilaatuinen pikkukuva (jos käytössä) ja lopuksi alkuperäinen (jos käytössä).",
"setting_image_viewer_original_subtitle": "Ota käyttöön ladataksesi alkuperäinen täysitarkkuuksinen kuva (suuri!). Poista käytöstä vähentääksesi datan käyttöä (sekä verkossa että laitteen välimuistissa).", "setting_image_viewer_original_subtitle": "Ota käyttöön ladataksesi alkuperäinen täysitarkkuuksinen kuva (suuri!). Poista käytöstä vähentääksesi datan käyttöä (sekä verkossa että laitteen välimuistissa).",
"setting_image_viewer_original_title": "Lataa alkuperäinen kuva", "setting_image_viewer_original_title": "Lataa alkuperäinen kuva",
@@ -2026,7 +2095,7 @@
"shared_link_edit_expire_after_option_year": "{count} vuosi", "shared_link_edit_expire_after_option_year": "{count} vuosi",
"shared_link_edit_password_hint": "Syötä jaon salasana", "shared_link_edit_password_hint": "Syötä jaon salasana",
"shared_link_edit_submit_button": "Päivitä linkki", "shared_link_edit_submit_button": "Päivitä linkki",
"shared_link_error_server_url_fetch": "Palvelimen URL-osoitetta ei voitu hakea", "shared_link_error_server_url_fetch": "Palvelimen url-osoitetta ei voitu hakea",
"shared_link_expires_day": "Vanhenee {count} päivässä", "shared_link_expires_day": "Vanhenee {count} päivässä",
"shared_link_expires_days": "Vanhenee {count} päivässä", "shared_link_expires_days": "Vanhenee {count} päivässä",
"shared_link_expires_hour": "Vanhenee {count} tunnissa", "shared_link_expires_hour": "Vanhenee {count} tunnissa",
@@ -2129,6 +2198,7 @@
"support": "Tuki", "support": "Tuki",
"support_and_feedback": "Tuki ja palaute", "support_and_feedback": "Tuki ja palaute",
"support_third_party_description": "Immich-asennuksesi on pakattu kolmannen osapuolen toimesta. Kohtaamasi ongelmat saattavat johtua tästä paketista, joten ilmoita niistä ensisijaisesti heille alla olevien linkkien kautta.", "support_third_party_description": "Immich-asennuksesi on pakattu kolmannen osapuolen toimesta. Kohtaamasi ongelmat saattavat johtua tästä paketista, joten ilmoita niistä ensisijaisesti heille alla olevien linkkien kautta.",
"supporter": "Tukija",
"swap_merge_direction": "Käännä yhdistämissuunta", "swap_merge_direction": "Käännä yhdistämissuunta",
"sync": "Synkronoi", "sync": "Synkronoi",
"sync_albums": "Synkronoi albumit", "sync_albums": "Synkronoi albumit",
@@ -2142,7 +2212,7 @@
"tag_assets": "Lisää tunnisteita", "tag_assets": "Lisää tunnisteita",
"tag_created": "Luotu tunniste: {tag}", "tag_created": "Luotu tunniste: {tag}",
"tag_feature_description": "Selaa valokuvia ja videoita, jotka on ryhmitelty loogisten tunnisteotsikoiden mukaan", "tag_feature_description": "Selaa valokuvia ja videoita, jotka on ryhmitelty loogisten tunnisteotsikoiden mukaan",
"tag_not_found_question": "Etkö löydä tunnistetta? <link> Luo uusi tunniste </link>", "tag_not_found_question": "Etkö löydä tunnistetta? <link>Luo uusi tunniste.</link>",
"tag_people": "Merkitse henkilö tunnisteella", "tag_people": "Merkitse henkilö tunnisteella",
"tag_updated": "Päivitetty tunniste: {tag}", "tag_updated": "Päivitetty tunniste: {tag}",
"tagged_assets": "Tunnistettu {count, plural, one {# kohde} other {# kohdetta}}", "tagged_assets": "Tunnistettu {count, plural, one {# kohde} other {# kohdetta}}",
@@ -2166,6 +2236,7 @@
"theme_setting_theme_subtitle": "Valitse sovelluksen teema-asetukset", "theme_setting_theme_subtitle": "Valitse sovelluksen teema-asetukset",
"theme_setting_three_stage_loading_subtitle": "Kolmivaiheinen lataus saattaa parantaa lataustehoa, mutta aiheuttaa huomattavasti suuremman verkon kuormituksen", "theme_setting_three_stage_loading_subtitle": "Kolmivaiheinen lataus saattaa parantaa lataustehoa, mutta aiheuttaa huomattavasti suuremman verkon kuormituksen",
"theme_setting_three_stage_loading_title": "Ota kolmivaiheinen lataus käyttöön", "theme_setting_three_stage_loading_title": "Ota kolmivaiheinen lataus käyttöön",
"then": "Sitten",
"they_will_be_merged_together": "Nämä tullaan yhdistämään", "they_will_be_merged_together": "Nämä tullaan yhdistämään",
"third_party_resources": "Kolmannen osapuolen resurssit", "third_party_resources": "Kolmannen osapuolen resurssit",
"time": "Aika", "time": "Aika",
@@ -2201,6 +2272,8 @@
"trash_page_title": "Roskakori ({count})", "trash_page_title": "Roskakori ({count})",
"trashed_items_will_be_permanently_deleted_after": "Roskakorin kohteet poistetaan pysyvästi {days, plural, one {# päivän} other {# päivän}} päästä.", "trashed_items_will_be_permanently_deleted_after": "Roskakorin kohteet poistetaan pysyvästi {days, plural, one {# päivän} other {# päivän}} päästä.",
"trigger": "Laukaisin", "trigger": "Laukaisin",
"trigger_asset_uploaded": "Kohde ladattu",
"trigger_asset_uploaded_description": "Käynnistyy, kun uusi kohde ladataan",
"trigger_description": "Työnkulun aloittava tapahtuma", "trigger_description": "Työnkulun aloittava tapahtuma",
"trigger_person_recognized": "Henkilö tunnistettu", "trigger_person_recognized": "Henkilö tunnistettu",
"trigger_person_recognized_description": "Laukaistaan kun henkilö tunnistetaan", "trigger_person_recognized_description": "Laukaistaan kun henkilö tunnistetaan",
@@ -2237,6 +2310,7 @@
"unstack_action_prompt": "{count} purettu pinosta", "unstack_action_prompt": "{count} purettu pinosta",
"unstacked_assets_count": "Poistettu pinosta {count, plural, one {# kohde} other {# kohdetta}}", "unstacked_assets_count": "Poistettu pinosta {count, plural, one {# kohde} other {# kohdetta}}",
"unsupported_field_type": "Ei-tuettu kentän tyyppi", "unsupported_field_type": "Ei-tuettu kentän tyyppi",
"unsupported_file_type": "Tiedostoa {file} ei voi ladata, koska sen tiedostotyyppi {type} ei ole tuettu.",
"untagged": "Ilman tunnistetta", "untagged": "Ilman tunnistetta",
"untitled_workflow": "Nimetön työnkulku", "untitled_workflow": "Nimetön työnkulku",
"up_next": "Seuraavaksi", "up_next": "Seuraavaksi",
@@ -2248,6 +2322,7 @@
"upload_details": "Lähetyksen tiedot", "upload_details": "Lähetyksen tiedot",
"upload_dialog_info": "Haluatko varmuuskopioida valitut kohteet palvelimelle?", "upload_dialog_info": "Haluatko varmuuskopioida valitut kohteet palvelimelle?",
"upload_dialog_title": "Lähetä kohde", "upload_dialog_title": "Lähetä kohde",
"upload_error_with_count": "Latausvirhe {count} kohteelle",
"upload_errors": "Lataus valmistui {count, plural, one {# virheen} other {# virheen}} kanssa. Päivitä sivu nähdäksesi ladatut tiedot.", "upload_errors": "Lataus valmistui {count, plural, one {# virheen} other {# virheen}} kanssa. Päivitä sivu nähdäksesi ladatut tiedot.",
"upload_finished": "Lähetys valmistui", "upload_finished": "Lähetys valmistui",
"upload_progress": "Jäljellä {remaining, number} - Käsitelty {processed, number}/{total, number}", "upload_progress": "Jäljellä {remaining, number} - Käsitelty {processed, number}/{total, number}",
@@ -2262,6 +2337,8 @@
"url": "URL", "url": "URL",
"usage": "Käyttö", "usage": "Käyttö",
"use_biometric": "Käytä biometriikkaa", "use_biometric": "Käytä biometriikkaa",
"use_browser_locale": "Käytä selaimen kieliasetuksia",
"use_browser_locale_description": "Muotoile päivämäärät, kellonajat ja numerot selaimesi kieliasetusten mukaan",
"use_current_connection": "Käytä nykyistä yhteyttä", "use_current_connection": "Käytä nykyistä yhteyttä",
"use_custom_date_range": "Käytä omaa aikaväliä", "use_custom_date_range": "Käytä omaa aikaväliä",
"user": "Käyttäjä", "user": "Käyttäjä",
@@ -2338,12 +2415,14 @@
"workflow_update_success": "Työnkulku päivitetty onnistuneesti", "workflow_update_success": "Työnkulku päivitetty onnistuneesti",
"workflow_updated": "Työnkulku päivitetty", "workflow_updated": "Työnkulku päivitetty",
"workflows": "Työnkulut", "workflows": "Työnkulut",
"workflows_help_text": "Työnkulut automatisoivat toimintoja kohteillesi laukaisimien ja suodattimien perusteella",
"wrong_pin_code": "Väärä PIN-koodi", "wrong_pin_code": "Väärä PIN-koodi",
"year": "Vuosi", "year": "Vuosi",
"years_ago": "{years, plural, one {# vuosi} other {# vuotta}} sitten", "years_ago": "{years, plural, one {# vuosi} other {# vuotta}} sitten",
"yes": "Kyllä", "yes": "Kyllä",
"you_dont_have_any_shared_links": "Sinulla ei ole jaettuja linkkejä", "you_dont_have_any_shared_links": "Sinulla ei ole jaettuja linkkejä",
"your_wifi_name": "Wi-Fi-verkkosi nimi", "your_wifi_name": "Wi-Fi-verkkosi nimi",
"zero_to_clear_rating": "paina 0 poistaaksesi kohteen luokituksen",
"zoom_image": "Zoomaa kuvaa", "zoom_image": "Zoomaa kuvaa",
"zoom_to_bounds": "Zoomaa reunoihin" "zoom_to_bounds": "Zoomaa reunoihin"
} }
+28 -15
View File
@@ -61,7 +61,7 @@
"backup_onboarding_1_description": "copie hors site dans le cloud ou sur un site distant.", "backup_onboarding_1_description": "copie hors site dans le cloud ou sur un site distant.",
"backup_onboarding_2_description": "copies locales sur différents appareils. Cela inclut les fichiers principaux ainsi qu'une sauvegarde locale de ces fichiers.", "backup_onboarding_2_description": "copies locales sur différents appareils. Cela inclut les fichiers principaux ainsi qu'une sauvegarde locale de ces fichiers.",
"backup_onboarding_3_description": "copies total de vos données, incluant les fichiers originaux. Cela inclut 1 copie hors site ainsi que 2 copies locales.", "backup_onboarding_3_description": "copies total de vos données, incluant les fichiers originaux. Cela inclut 1 copie hors site ainsi que 2 copies locales.",
"backup_onboarding_description": "Une <backblaze-link>stratégie de sauvegarde 3-2-1</backblaze-link> est recommandé pour protéger vos données. Vous devriez conserver des copies de vos photos/vidéos téléversés ainsi que de la base de données d'Immich pour une solution de sauvegarde cohérente.", "backup_onboarding_description": "Une <backblaze-link>stratégie de sauvegarde 3-2-1</backblaze-link> est recommandée pour protéger vos données. Vous devriez conserver des copies de vos photos/vidéos téléversés ainsi que de la base de données d'Immich pour une solution de sauvegarde cohérente.",
"backup_onboarding_footer": "Pour plus d'information sur la sauvegarde d'Immich, merci de vous référer à la <link>documentation</link>.", "backup_onboarding_footer": "Pour plus d'information sur la sauvegarde d'Immich, merci de vous référer à la <link>documentation</link>.",
"backup_onboarding_parts_title": "Une sauvegarde 3-2-1 inclut :", "backup_onboarding_parts_title": "Une sauvegarde 3-2-1 inclut :",
"backup_onboarding_title": "Sauvegardes", "backup_onboarding_title": "Sauvegardes",
@@ -173,7 +173,7 @@
"machine_learning_min_recognized_faces_description": "Nombre minimal de visages reconnus pour qu'une personne soit créée. Augmenter cette valeur rend la reconnaissance faciale plus précise au détriment d'augmenter la chance qu'un visage ne soit pas attribué à une personne.", "machine_learning_min_recognized_faces_description": "Nombre minimal de visages reconnus pour qu'une personne soit créée. Augmenter cette valeur rend la reconnaissance faciale plus précise au détriment d'augmenter la chance qu'un visage ne soit pas attribué à une personne.",
"machine_learning_ocr": "OCR", "machine_learning_ocr": "OCR",
"machine_learning_ocr_description": "Utiliser l'apprentissage automatique pour reconnaître le texte dans les images", "machine_learning_ocr_description": "Utiliser l'apprentissage automatique pour reconnaître le texte dans les images",
"machine_learning_ocr_enabled": "Activer la reconnaissance de caractères", "machine_learning_ocr_enabled": "Activer la reconnaissance de caractères OCR",
"machine_learning_ocr_enabled_description": "Si désactivé, la reconnaissance de texte ne s'appliquera pas aux images.", "machine_learning_ocr_enabled_description": "Si désactivé, la reconnaissance de texte ne s'appliquera pas aux images.",
"machine_learning_ocr_max_resolution": "Résolution maximale", "machine_learning_ocr_max_resolution": "Résolution maximale",
"machine_learning_ocr_max_resolution_description": "Les prévisualisations au-dessus de cette résolution seront retaillées en conservant leur ratio. Des valeurs plus grandes sont plus précises, mais sont plus lentes et utilisent plus de mémoire.", "machine_learning_ocr_max_resolution_description": "Les prévisualisations au-dessus de cette résolution seront retaillées en conservant leur ratio. Des valeurs plus grandes sont plus précises, mais sont plus lentes et utilisent plus de mémoire.",
@@ -181,7 +181,7 @@
"machine_learning_ocr_min_detection_score_description": "Score de confiance minimum pour la détection du textew entre 0 et 1. Des valeurs faibles permettront de reconnaître davantage de texte mais peuvent entraîner des faux positifs.", "machine_learning_ocr_min_detection_score_description": "Score de confiance minimum pour la détection du textew entre 0 et 1. Des valeurs faibles permettront de reconnaître davantage de texte mais peuvent entraîner des faux positifs.",
"machine_learning_ocr_min_recognition_score": "Score de reconnaissance minimum", "machine_learning_ocr_min_recognition_score": "Score de reconnaissance minimum",
"machine_learning_ocr_min_score_recognition_description": "Score de confiance minimum pour la reconnaissance du texte, entre 0 et 1. Des valeurs faible permettront de reconnaître davantage de texte, mais peuvent entraîner des faux positifs.", "machine_learning_ocr_min_score_recognition_description": "Score de confiance minimum pour la reconnaissance du texte, entre 0 et 1. Des valeurs faible permettront de reconnaître davantage de texte, mais peuvent entraîner des faux positifs.",
"machine_learning_ocr_model": "Modèle de Reconnaissance Optique de Caractères", "machine_learning_ocr_model": "Modèle de Reconnaissance Optique de Caractères OCR",
"machine_learning_ocr_model_description": "Les modèles du serveur sont plus précis que les modèles mobiles, mais ils sont plus lents et utilisent plus de mémoire.", "machine_learning_ocr_model_description": "Les modèles du serveur sont plus précis que les modèles mobiles, mais ils sont plus lents et utilisent plus de mémoire.",
"machine_learning_settings": "Paramètres d'apprentissage automatique", "machine_learning_settings": "Paramètres d'apprentissage automatique",
"machine_learning_settings_description": "Gérer les fonctionnalités et les paramètres d'apprentissage automatique", "machine_learning_settings_description": "Gérer les fonctionnalités et les paramètres d'apprentissage automatique",
@@ -214,7 +214,7 @@
"map_gps_settings_description": "Gérer les paramètres de la Carte & GPS", "map_gps_settings_description": "Gérer les paramètres de la Carte & GPS",
"map_implications": "La carte repose sur un service de tuiles externe (tiles.immich.cloud)", "map_implications": "La carte repose sur un service de tuiles externe (tiles.immich.cloud)",
"map_light_style": "Thème clair", "map_light_style": "Thème clair",
"map_manage_reverse_geocoding_settings": "Gérer les <link> paramètres de géocodage inversé</link>", "map_manage_reverse_geocoding_settings": "Gérer les <link>paramètres de géocodage inversé</link>",
"map_reverse_geocoding": "Géocodage inversé", "map_reverse_geocoding": "Géocodage inversé",
"map_reverse_geocoding_enable_description": "Activer le géocodage inversé", "map_reverse_geocoding_enable_description": "Activer le géocodage inversé",
"map_reverse_geocoding_settings": "Paramètres de géocodage inversé", "map_reverse_geocoding_settings": "Paramètres de géocodage inversé",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mappage tonal", "transcoding_tone_mapping": "Mappage tonal",
"transcoding_tone_mapping_description": "Tente de préserver l'apparence des vidéos HDR lorsqu'elles sont converties en SDR. Chaque algorithme effectue différents compromis pour la couleur, les détails et la luminosité. Hable préserve les détails, Mobius préserve la couleur, et Reinhard préserve la luminosité.", "transcoding_tone_mapping_description": "Tente de préserver l'apparence des vidéos HDR lorsqu'elles sont converties en SDR. Chaque algorithme effectue différents compromis pour la couleur, les détails et la luminosité. Hable préserve les détails, Mobius préserve la couleur, et Reinhard préserve la luminosité.",
"transcoding_transcode_policy": "Politique de transcodage", "transcoding_transcode_policy": "Politique de transcodage",
"transcoding_transcode_policy_description": "Politique indiquant quand une vidéo doit être transcodée. Les vidéos HDR seront toujours transcodées (sauf si le transcodage est désactivé).", "transcoding_transcode_policy_description": "Politique indiquant quand une vidéo doit être transcodée. Les vidéos HDR et les vidéos dans un format de pixel différent de YUV 4:2:0 seront toujours transcodées (sauf si le transcodage est désactivé).",
"transcoding_two_pass_encoding": "Encodage en deux passes", "transcoding_two_pass_encoding": "Encodage en deux passes",
"transcoding_two_pass_encoding_setting_description": "Transcoder en deux passes pour produire des vidéos mieux encodées. Lorsque le débit binaire maximum est activé (obligatoire pour qu'il fonctionne avec H.264 et HEVC), ce mode utilise une plage de débit binaire basée sur le débit binaire maximum et ignore le CRF. Pour VP9, CRF peut être utilisé si le débit binaire maximum est désactivé.", "transcoding_two_pass_encoding_setting_description": "Transcoder en deux passes pour produire des vidéos mieux encodées. Lorsque le débit binaire maximum est activé (obligatoire pour qu'il fonctionne avec H.264 et HEVC), ce mode utilise une plage de débit binaire basée sur le débit binaire maximum et ignore le CRF. Pour VP9, CRF peut être utilisé si le débit binaire maximum est désactivé.",
"transcoding_video_codec": "Codec vidéo", "transcoding_video_codec": "Codec vidéo",
@@ -872,7 +872,7 @@
"current_server_address": "Adresse actuelle du serveur", "current_server_address": "Adresse actuelle du serveur",
"custom_date": "Date personnalisée", "custom_date": "Date personnalisée",
"custom_locale": "Paramètres régionaux personnalisés", "custom_locale": "Paramètres régionaux personnalisés",
"custom_locale_description": "Afficher les dates et nombres en fonction des paramètres régionaux", "custom_locale_description": "Formater les dates, heures et nombres en fonction de la langue sélectionnée et de la région",
"custom_url": "URL personnalisée", "custom_url": "URL personnalisée",
"cutoff_date_description": "Conservez les photos depuis les derniers…", "cutoff_date_description": "Conservez les photos depuis les derniers…",
"cutoff_day": "{count, plural, one {jour} other {jours}}", "cutoff_day": "{count, plural, one {jour} other {jours}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Nombre de données EXIF", "deduplication_criteria_2": "Nombre de données EXIF",
"deduplication_info": "Info de déduplication", "deduplication_info": "Info de déduplication",
"deduplication_info_description": "Pour présélectionner automatiquement les médias et supprimer les doublons en masse, nous examinons :", "deduplication_info_description": "Pour présélectionner automatiquement les médias et supprimer les doublons en masse, nous examinons :",
"default_locale": "Région par défaut",
"default_locale_description": "Afficher les dates et nombres en fonction des paramètres de votre navigateur",
"delete": "Supprimer", "delete": "Supprimer",
"delete_action_confirmation_message": "Êtes-vous sûr de vouloir supprimer ce média? Cela déplacera le média dans la poubelle du serveur et vous demandera si vous voulez le supprimer localement", "delete_action_confirmation_message": "Êtes-vous sûr de vouloir supprimer ce média? Cela déplacera le média dans la poubelle du serveur et vous demandera si vous voulez le supprimer localement",
"delete_action_prompt": "{count} supprimé(s)", "delete_action_prompt": "{count} supprimé(s)",
@@ -1009,6 +1007,8 @@
"editor_edits_applied_success": "Editions appliquées avec succès", "editor_edits_applied_success": "Editions appliquées avec succès",
"editor_flip_horizontal": "Retourner horizontalement", "editor_flip_horizontal": "Retourner horizontalement",
"editor_flip_vertical": "Retourner verticalement", "editor_flip_vertical": "Retourner verticalement",
"editor_handle_corner": "Saisie du coin {corner, select, top_left {en haut à gauche} top_right {en haut à droite} bottom_left {en bas à gauche} bottom_right {en bas à droite} other {A}}",
"editor_handle_edge": "Saisie du bord {edge, select, top {haut} bottom {bas} left {gauche} right {droit} other {An}}",
"editor_orientation": "Orientation", "editor_orientation": "Orientation",
"editor_reset_all_changes": "Réinitialiser les modifications", "editor_reset_all_changes": "Réinitialiser les modifications",
"editor_rotate_left": "Rotation de 90° dans le sens inverse des aiguilles d'une montre", "editor_rotate_left": "Rotation de 90° dans le sens inverse des aiguilles d'une montre",
@@ -1074,6 +1074,7 @@
"failed_to_update_notification_status": "Erreur de mise à jour du statut des notifications", "failed_to_update_notification_status": "Erreur de mise à jour du statut des notifications",
"incorrect_email_or_password": "Courriel ou mot de passe incorrect", "incorrect_email_or_password": "Courriel ou mot de passe incorrect",
"library_folder_already_exists": "Ce chemin d'import existe déjà.", "library_folder_already_exists": "Ce chemin d'import existe déjà.",
"page_not_found": "Page non trouvée",
"paths_validation_failed": "Validation échouée pour {paths, plural, one {# un chemin} other {# plusieurs chemins}}", "paths_validation_failed": "Validation échouée pour {paths, plural, one {# un chemin} other {# plusieurs chemins}}",
"profile_picture_transparent_pixels": "Les images de profil ne peuvent pas avoir de pixels transparents. Veuillez agrandir et/ou déplacer l'image.", "profile_picture_transparent_pixels": "Les images de profil ne peuvent pas avoir de pixels transparents. Veuillez agrandir et/ou déplacer l'image.",
"quota_higher_than_disk_size": "Le quota saisi est supérieur à l'espace disponible", "quota_higher_than_disk_size": "Le quota saisi est supérieur à l'espace disponible",
@@ -1147,7 +1148,7 @@
"unable_to_scan_library": "Impossible de scanner la bibliothèque", "unable_to_scan_library": "Impossible de scanner la bibliothèque",
"unable_to_set_feature_photo": "Impossible de définir la photo de la personne", "unable_to_set_feature_photo": "Impossible de définir la photo de la personne",
"unable_to_set_profile_picture": "Impossible d'enregistrer la photo de profil", "unable_to_set_profile_picture": "Impossible d'enregistrer la photo de profil",
"unable_to_set_rating": "Impossible de définir une note", "unable_to_set_rating": "Impossible de définir l'évaluation",
"unable_to_submit_job": "Impossible d'exécuter la tâche", "unable_to_submit_job": "Impossible d'exécuter la tâche",
"unable_to_trash_asset": "Impossible de mettre le média à la corbeille", "unable_to_trash_asset": "Impossible de mettre le média à la corbeille",
"unable_to_unlink_account": "Impossible de détacher le compte", "unable_to_unlink_account": "Impossible de détacher le compte",
@@ -1218,6 +1219,7 @@
"filter_description": "Conditions pour filtrer les médias ciblés", "filter_description": "Conditions pour filtrer les médias ciblés",
"filter_people": "Filtrer les personnes", "filter_people": "Filtrer les personnes",
"filter_places": "Filtrer par lieu", "filter_places": "Filtrer par lieu",
"filter_tags": "Filtrer par étiquettes",
"filters": "Filtres", "filters": "Filtres",
"find_them_fast": "Pour les retrouver rapidement par leur nom", "find_them_fast": "Pour les retrouver rapidement par leur nom",
"first": "Premier", "first": "Premier",
@@ -1631,7 +1633,7 @@
"oauth": "OAuth", "oauth": "OAuth",
"obtainium_configurator": "Configuration pour Obtainium", "obtainium_configurator": "Configuration pour Obtainium",
"obtainium_configurator_instructions": "Utilisez Obtainium pour installer et mettre à jour l'application Android directement depuis la version d'Immich sur Github. Créer une clé d'API et sélectionner une variante pour créer votre lien de configuration pour Obtainium", "obtainium_configurator_instructions": "Utilisez Obtainium pour installer et mettre à jour l'application Android directement depuis la version d'Immich sur Github. Créer une clé d'API et sélectionner une variante pour créer votre lien de configuration pour Obtainium",
"ocr": "Reconnaissance Optique de Caractères", "ocr": "Reconnaissance Optique de Caractères OCR",
"official_immich_resources": "Ressources Immich officielles", "official_immich_resources": "Ressources Immich officielles",
"offline": "Hors ligne", "offline": "Hors ligne",
"offset": "Décalage", "offset": "Décalage",
@@ -1649,6 +1651,7 @@
"only_favorites": "Uniquement les favoris", "only_favorites": "Uniquement les favoris",
"open": "Ouvrir", "open": "Ouvrir",
"open_calendar": "Ouvrir le calendrier", "open_calendar": "Ouvrir le calendrier",
"open_in_browser": "Ouvrir dans le navigateur",
"open_in_map_view": "Montrer sur la carte", "open_in_map_view": "Montrer sur la carte",
"open_in_openstreetmap": "Ouvrir dans OpenStreetMap", "open_in_openstreetmap": "Ouvrir dans OpenStreetMap",
"open_the_search_filters": "Ouvrir les filtres de recherche", "open_the_search_filters": "Ouvrir les filtres de recherche",
@@ -1808,9 +1811,8 @@
"rate_asset": "Évaluer un média", "rate_asset": "Évaluer un média",
"rating": "Étoile d'évaluation", "rating": "Étoile d'évaluation",
"rating_clear": "Effacer l'évaluation", "rating_clear": "Effacer l'évaluation",
"rating_count": "{count, plural, one {# étoile} other {# étoiles}}", "rating_count": "{count, plural, =0 {Non évalué} one {# étoile} other {# étoiles}}",
"rating_description": "Afficher l'évaluation EXIF dans le panneau d'information", "rating_description": "Afficher l'évaluation EXIF dans le panneau d'information",
"rating_set": "Note définie sur {rating, plural, one {# étoile} other {# étoiles}}",
"reaction_options": "Options de réaction", "reaction_options": "Options de réaction",
"read_changelog": "Lire les changements", "read_changelog": "Lire les changements",
"readonly_mode_disabled": "Mode lecture seule désactivé", "readonly_mode_disabled": "Mode lecture seule désactivé",
@@ -1882,7 +1884,10 @@
"reset_pin_code_success": "Code PIN réinitialisé avec succès", "reset_pin_code_success": "Code PIN réinitialisé avec succès",
"reset_pin_code_with_password": "Vous pouvez toujours réinitialiser le code PIN avec votre mot de passe", "reset_pin_code_with_password": "Vous pouvez toujours réinitialiser le code PIN avec votre mot de passe",
"reset_sqlite": "Réinitialiser la base de données SQLite", "reset_sqlite": "Réinitialiser la base de données SQLite",
"reset_sqlite_confirmation": "Êtes-vous certain de vouloir réinitialiser la base de données SQLite? Vous devrez vous déconnecter puis vous reconnecter à nouveau pour resynchroniser les données", "reset_sqlite_clear_app_data": "Supprimer les données",
"reset_sqlite_confirmation": "Êtes-vous certain de vouloir supprimer les données de l'application? Cela va supprimer tous les paramètres et vous déconnecter.",
"reset_sqlite_confirmation_note": "Remarque : vous devrez redémarrer l'application après cette suppression.",
"reset_sqlite_done": "Les données de l'application ont été supprimées. Veuillez redémarrer Immich et vous reconnecter.",
"reset_sqlite_success": "La base de données SQLite à été réinitialisé avec succès", "reset_sqlite_success": "La base de données SQLite à été réinitialisé avec succès",
"reset_to_default": "Rétablir les valeurs par défaut", "reset_to_default": "Rétablir les valeurs par défaut",
"resolution": "Résolution", "resolution": "Résolution",
@@ -1910,6 +1915,7 @@
"saved_settings": "Paramètres enregistrés", "saved_settings": "Paramètres enregistrés",
"say_something": "Réagir", "say_something": "Réagir",
"scaffold_body_error_occurred": "Une erreur s'est produite", "scaffold_body_error_occurred": "Une erreur s'est produite",
"scaffold_body_error_unrecoverable": "Une erreur irrécupérable s'est produite. Veuillez partager l'erreur et la trace de pile sur Discord ou GitHub afin que nous puissions vous aider. Si nécessaire, vous pouvez effacer les données de l'appli ci-dessous.",
"scan": "Analyse", "scan": "Analyse",
"scan_all_libraries": "Analyser toutes les bibliothèques", "scan_all_libraries": "Analyser toutes les bibliothèques",
"scan_library": "Analyser", "scan_library": "Analyser",
@@ -1923,7 +1929,7 @@
"search_by_description_example": "Randonnée à Sapa", "search_by_description_example": "Randonnée à Sapa",
"search_by_filename": "Rechercher par nom du fichier ou extension", "search_by_filename": "Rechercher par nom du fichier ou extension",
"search_by_filename_example": "Exemple: IMG_1234.JPG ou PNG", "search_by_filename_example": "Exemple: IMG_1234.JPG ou PNG",
"search_by_ocr": "Recherche par OCR", "search_by_ocr": "Recherche par Reconnaissance Optique de Caractères OCR",
"search_by_ocr_example": "café latte", "search_by_ocr_example": "café latte",
"search_camera_lens_model": "Chercher par modèle d'objectif...", "search_camera_lens_model": "Chercher par modèle d'objectif...",
"search_camera_make": "Rechercher par marque d'appareil photo...", "search_camera_make": "Rechercher par marque d'appareil photo...",
@@ -1942,9 +1948,10 @@
"search_filter_location_title": "Sélectionner une localisation", "search_filter_location_title": "Sélectionner une localisation",
"search_filter_media_type": "Type de média", "search_filter_media_type": "Type de média",
"search_filter_media_type_title": "Sélectionner type de média", "search_filter_media_type_title": "Sélectionner type de média",
"search_filter_ocr": "Recherche par OCR", "search_filter_ocr": "Recherche par Reconnaissance Optique de Caractères OCR",
"search_filter_people_title": "Sélectionner une personne", "search_filter_people_title": "Sélectionner une personne",
"search_filter_star_rating": "Note par étoiles", "search_filter_star_rating": "Note par étoiles",
"search_filter_tags_title": "Sélectionner des étiquettes",
"search_for": "Chercher", "search_for": "Chercher",
"search_for_existing_person": "Rechercher une personne existante", "search_for_existing_person": "Rechercher une personne existante",
"search_no_more_result": "Plus de résultats", "search_no_more_result": "Plus de résultats",
@@ -2024,6 +2031,9 @@
"set_profile_picture": "Définir la photo de profil", "set_profile_picture": "Définir la photo de profil",
"set_slideshow_to_fullscreen": "Afficher le diaporama en plein écran", "set_slideshow_to_fullscreen": "Afficher le diaporama en plein écran",
"set_stack_primary_asset": "Marquer comme média principal", "set_stack_primary_asset": "Marquer comme média principal",
"setting_image_navigation_enable_subtitle": "Si activé, vous pouvez naviguer vers l'image précédente / suivante en appuyant sur le quart le plus à gauche / à droite de l'écran.",
"setting_image_navigation_enable_title": "Appuyer pour naviguer",
"setting_image_navigation_title": "Navigation dans les images",
"setting_image_viewer_help": "Le visualiseur de détails charge d'abord la petite miniature, puis l'aperçu de taille moyenne (s'il est activé), enfin l'original (s'il est activé).", "setting_image_viewer_help": "Le visualiseur de détails charge d'abord la petite miniature, puis l'aperçu de taille moyenne (s'il est activé), enfin l'original (s'il est activé).",
"setting_image_viewer_original_subtitle": "Activez cette option pour charger l'image en résolution originale (fichier volumineux!). Désactiver pour réduire l'utilisation des données (réseau et cache de l'appareil).", "setting_image_viewer_original_subtitle": "Activez cette option pour charger l'image en résolution originale (fichier volumineux!). Désactiver pour réduire l'utilisation des données (réseau et cache de l'appareil).",
"setting_image_viewer_original_title": "Charger l'image originale", "setting_image_viewer_original_title": "Charger l'image originale",
@@ -2302,6 +2312,7 @@
"unstack_action_prompt": "{count} dépilé(s)", "unstack_action_prompt": "{count} dépilé(s)",
"unstacked_assets_count": "{count, plural, one {# média dépilé} other {# médias dépilés}}", "unstacked_assets_count": "{count, plural, one {# média dépilé} other {# médias dépilés}}",
"unsupported_field_type": "Type de champ non supporté", "unsupported_field_type": "Type de champ non supporté",
"unsupported_file_type": "Le fichier {file} ne peut pas être téléversé car son type {type} n'est pas supporté.",
"untagged": "Sans étiquette", "untagged": "Sans étiquette",
"untitled_workflow": "Flux de traitement sans titre", "untitled_workflow": "Flux de traitement sans titre",
"up_next": "Suite", "up_next": "Suite",
@@ -2328,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Utilisation", "usage": "Utilisation",
"use_biometric": "Utiliser l'authentification biométrique", "use_biometric": "Utiliser l'authentification biométrique",
"use_browser_locale": "Utiliser les paramètres régionaux du navigateur",
"use_browser_locale_description": "Formate les dates, heures et nombres en fonction des paramètres régionaux de votre navigateur",
"use_current_connection": "Utiliser le réseau actuel", "use_current_connection": "Utiliser le réseau actuel",
"use_custom_date_range": "Utilisez une plage de date personnalisée à la place", "use_custom_date_range": "Utilisez une plage de date personnalisée à la place",
"user": "Utilisateur", "user": "Utilisateur",
+23 -10
View File
@@ -61,7 +61,7 @@
"backup_onboarding_1_description": "cóip lasmuigh den láthair sa scamall nó in áit fhisiciúil eile.", "backup_onboarding_1_description": "cóip lasmuigh den láthair sa scamall nó in áit fhisiciúil eile.",
"backup_onboarding_2_description": "cóipeanna áitiúla ar ghléasanna éagsúla. Áirítear leis seo na príomhchomhaid agus cúltaca de na comhaid sin go háitiúil.", "backup_onboarding_2_description": "cóipeanna áitiúla ar ghléasanna éagsúla. Áirítear leis seo na príomhchomhaid agus cúltaca de na comhaid sin go háitiúil.",
"backup_onboarding_3_description": "cóipeanna iomlána de do shonraí, lena n-áirítear na comhaid bhunaidh. Áirítear leis seo cóip amháin lasmuigh den láthair agus dhá chóip áitiúla.", "backup_onboarding_3_description": "cóipeanna iomlána de do shonraí, lena n-áirítear na comhaid bhunaidh. Áirítear leis seo cóip amháin lasmuigh den láthair agus dhá chóip áitiúla.",
"backup_onboarding_description": "Moltar straitéis chúltaca <backblaze-link>3-2-1</backblaze-link> chun do shonraí a chosaint. Ba chóir duit cóipeanna de do ghrianghraif/fhíseáin uaslódáilte a choinneáil chomh maith le bunachar sonraí Immich le haghaidh réiteach cúltaca cuimsitheach.", "backup_onboarding_description": "Moltar <backblaze-link>straitéis chúltaca 3-2-1</backblaze-link> chun do shonraí a chosaint. Ba chóir duit cóipeanna de do ghrianghraif/fhíseáin uaslódáilte chomh maith le bunachar sonraí Immich a choinneáil le haghaidh réiteach cúltaca cuimsitheach.",
"backup_onboarding_footer": "Le haghaidh tuilleadh eolais faoi chúltaca d'Immich, féach ar an <link>doiciméadú</link>.", "backup_onboarding_footer": "Le haghaidh tuilleadh eolais faoi chúltaca d'Immich, féach ar an <link>doiciméadú</link>.",
"backup_onboarding_parts_title": "Áirítear le cúltaca 3-2-1:", "backup_onboarding_parts_title": "Áirítear le cúltaca 3-2-1:",
"backup_onboarding_title": "Cúltacaí", "backup_onboarding_title": "Cúltacaí",
@@ -372,7 +372,7 @@
"transcoding_audio_codec": "Códac fuaime", "transcoding_audio_codec": "Códac fuaime",
"transcoding_audio_codec_description": "Is é Opus an rogha is airde cáilíochta, ach tá comhoiriúnacht níos ísle aige le seanghléasanna nó bogearraí.", "transcoding_audio_codec_description": "Is é Opus an rogha is airde cáilíochta, ach tá comhoiriúnacht níos ísle aige le seanghléasanna nó bogearraí.",
"transcoding_bitrate_description": "Físeáin níos airde ná an uasráta giotán nó nach bhfuil i bhformáid inghlactha", "transcoding_bitrate_description": "Físeáin níos airde ná an uasráta giotán nó nach bhfuil i bhformáid inghlactha",
"transcoding_codecs_learn_more": "Chun tuilleadh eolais a fháil faoin téarmaíocht a úsáidtear anseo, féach ar dhoiciméid FFmpeg le haghaidh <h264-link>cóc H.264</h264-link>, <hevc-link>cóc HEVC</hevc-link> agus <vp9-link>cóc VP9</vp9-link>.", "transcoding_codecs_learn_more": "Chun tuilleadh eolais a fháil faoin téarmaíocht a úsáidtear anseo, féach ar dhoiciméid FFmpeg le haghaidh <h264-link>cóideic H.264</h264-link>, <hevc-link>cóideic HEVC</hevc-link> agus <vp9-link>cóideic VP9</vp9-link>.",
"transcoding_constant_quality_mode": "Mód cáilíochta tairiseach", "transcoding_constant_quality_mode": "Mód cáilíochta tairiseach",
"transcoding_constant_quality_mode_description": "Tá ICQ níos fearr ná CQP, ach ní thacaíonn roinnt gléasanna luasghéaraithe crua-earraí leis an modh seo. Trí an rogha seo a shocrú, tabharfar tús áite don mhodh sonraithe agus ionchódú bunaithe ar cháilíocht á úsáid. Ní thacaíonn NVENC leis mar nach dtacaíonn sé le ICQ.", "transcoding_constant_quality_mode_description": "Tá ICQ níos fearr ná CQP, ach ní thacaíonn roinnt gléasanna luasghéaraithe crua-earraí leis an modh seo. Trí an rogha seo a shocrú, tabharfar tús áite don mhodh sonraithe agus ionchódú bunaithe ar cháilíocht á úsáid. Ní thacaíonn NVENC leis mar nach dtacaíonn sé le ICQ.",
"transcoding_constant_rate_factor": "Fachtóir ráta tairiseach (-crf)", "transcoding_constant_rate_factor": "Fachtóir ráta tairiseach (-crf)",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mapáil toin", "transcoding_tone_mapping": "Mapáil toin",
"transcoding_tone_mapping_description": "Déanann iarracht cuma físeáin HDR a chaomhnú nuair a dhéantar iad a thiontú go SDR. Déanann gach algartam comhbhabhtálacha difriúla maidir le dath, mionsonraí agus gile. Coinníonn Hable mionsonraí, coinníonn Mobius dath, agus coinníonn Reinhard gile.", "transcoding_tone_mapping_description": "Déanann iarracht cuma físeáin HDR a chaomhnú nuair a dhéantar iad a thiontú go SDR. Déanann gach algartam comhbhabhtálacha difriúla maidir le dath, mionsonraí agus gile. Coinníonn Hable mionsonraí, coinníonn Mobius dath, agus coinníonn Reinhard gile.",
"transcoding_transcode_policy": "Polasaí traschódála", "transcoding_transcode_policy": "Polasaí traschódála",
"transcoding_transcode_policy_description": "Polasaí maidir le cathain ba chóir físeán a thraschódú. Déanfar físeáin HDR a thraschódú i gcónaí (ach amháin má tá traschódú díchumasaithe).", "transcoding_transcode_policy_description": "Polasaí maidir le cathain ba chóir físeán a thraschódú. Déanfar físeáin HDR agus físeáin le formáid picteilín seachas YUV 4:2:0 a thraschódú i gcónaí (ach amháin má tá an traschódú díchumasaithe).",
"transcoding_two_pass_encoding": "Ionchódú dhá phas", "transcoding_two_pass_encoding": "Ionchódú dhá phas",
"transcoding_two_pass_encoding_setting_description": "Traschódaigh i ndá phas chun físeáin ionchódaithe níos fearr a tháirgeadh. Nuair a bhíonn an ráta giotán uasta cumasaithe (riachtanach chun go n-oibreoidh sé le H.264 agus HEVC), úsáideann an mód seo raon ráta giotán bunaithe ar an ráta giotán uasta agus ní thugann sé aird ar CRF. I gcás VP9, is féidir CRF a úsáid má tá an ráta giotán uasta díchumasaithe.", "transcoding_two_pass_encoding_setting_description": "Traschódaigh i ndá phas chun físeáin ionchódaithe níos fearr a tháirgeadh. Nuair a bhíonn an ráta giotán uasta cumasaithe (riachtanach chun go n-oibreoidh sé le H.264 agus HEVC), úsáideann an mód seo raon ráta giotán bunaithe ar an ráta giotán uasta agus ní thugann sé aird ar CRF. I gcás VP9, is féidir CRF a úsáid má tá an ráta giotán uasta díchumasaithe.",
"transcoding_video_codec": "Códac físe", "transcoding_video_codec": "Códac físe",
@@ -871,8 +871,8 @@
"current_pin_code": "Cód PIN reatha", "current_pin_code": "Cód PIN reatha",
"current_server_address": "Seoladh reatha an fhreastalaí", "current_server_address": "Seoladh reatha an fhreastalaí",
"custom_date": "Dáta saincheaptha", "custom_date": "Dáta saincheaptha",
"custom_locale": "Logán Saincheaptha", "custom_locale": "Logán saincheaptha",
"custom_locale_description": "Formáidigh dátaí agus uimhreacha bunaithe ar an teanga agus ar an réigiún", "custom_locale_description": "Formáidigh dátaí, amanna agus uimhreacha bunaithe ar an teanga agus an réigiún roghnaithe",
"custom_url": "URL Saincheaptha", "custom_url": "URL Saincheaptha",
"cutoff_date_description": "Coinnigh grianghraif ón uair dheireanach…", "cutoff_date_description": "Coinnigh grianghraif ón uair dheireanach…",
"cutoff_day": "{count, plural, one {lá} other {laethanta}}", "cutoff_day": "{count, plural, one {lá} other {laethanta}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Líon sonraí EXIF", "deduplication_criteria_2": "Líon sonraí EXIF",
"deduplication_info": "Eolas Dídhúblála", "deduplication_info": "Eolas Dídhúblála",
"deduplication_info_description": "Chun sócmhainní a réamhroghnú go huathoibríoch agus dúblaigh a bhaint i mórchóir, féachaimid ar:", "deduplication_info_description": "Chun sócmhainní a réamhroghnú go huathoibríoch agus dúblaigh a bhaint i mórchóir, féachaimid ar:",
"default_locale": "Logán Réamhshocraithe",
"default_locale_description": "Formáidigh dátaí agus uimhreacha bunaithe ar shuíomh do bhrabhsálaí",
"delete": "Scrios", "delete": "Scrios",
"delete_action_confirmation_message": "An bhfuil tú cinnte gur mian leat an tsócmhainn seo a scriosadh? Bogfaidh an gníomh seo an tsócmhainn go dtí bruscar an fhreastalaí agus fiafróidh sé díot an mian leat í a scriosadh go háitiúil", "delete_action_confirmation_message": "An bhfuil tú cinnte gur mian leat an tsócmhainn seo a scriosadh? Bogfaidh an gníomh seo an tsócmhainn go dtí bruscar an fhreastalaí agus fiafróidh sé díot an mian leat í a scriosadh go háitiúil",
"delete_action_prompt": "{count} scriosta", "delete_action_prompt": "{count} scriosta",
@@ -1009,6 +1007,8 @@
"editor_edits_applied_success": "Cuireadh na heagarthóireachtaí i bhfeidhm go rathúil", "editor_edits_applied_success": "Cuireadh na heagarthóireachtaí i bhfeidhm go rathúil",
"editor_flip_horizontal": "Fillte go cothrománach", "editor_flip_horizontal": "Fillte go cothrománach",
"editor_flip_vertical": "Smeach ingearach", "editor_flip_vertical": "Smeach ingearach",
"editor_handle_corner": "{corner, select, top_left {Top-left} top_right {Barr-deas} bottom_left {Bun-chlé} bottom_right {Bun-deas} other {A}} láimhseáil cúinne",
"editor_handle_edge": "{edge, select, top {Barr} bottom {Bun} left {Clé} right {Deas} other {An}} láimhseáil imeall",
"editor_orientation": "Treoshuíomh", "editor_orientation": "Treoshuíomh",
"editor_reset_all_changes": "Athshocraigh athruithe", "editor_reset_all_changes": "Athshocraigh athruithe",
"editor_rotate_left": "Rothlaigh 90° tuathalach", "editor_rotate_left": "Rothlaigh 90° tuathalach",
@@ -1074,6 +1074,7 @@
"failed_to_update_notification_status": "Theip ar stádas an fhógra a nuashonrú", "failed_to_update_notification_status": "Theip ar stádas an fhógra a nuashonrú",
"incorrect_email_or_password": "Ríomhphost nó pasfhocal mícheart", "incorrect_email_or_password": "Ríomhphost nó pasfhocal mícheart",
"library_folder_already_exists": "Tá an cosán allmhairithe seo ann cheana féin.", "library_folder_already_exists": "Tá an cosán allmhairithe seo ann cheana féin.",
"page_not_found": "Leathanach gan aimsiú",
"paths_validation_failed": "Theip ar bhailíochtú {paths, plural, one {# cosán} other {# cosáin}}", "paths_validation_failed": "Theip ar bhailíochtú {paths, plural, one {# cosán} other {# cosáin}}",
"profile_picture_transparent_pixels": "Ní féidir picteilíní trédhearcacha a bheith i bpictiúir phróifíle. Zúmáil isteach agus/nó bog an íomhá le do thoil.", "profile_picture_transparent_pixels": "Ní féidir picteilíní trédhearcacha a bheith i bpictiúir phróifíle. Zúmáil isteach agus/nó bog an íomhá le do thoil.",
"quota_higher_than_disk_size": "Shocraigh tú cuóta níos airde ná méid an diosca", "quota_higher_than_disk_size": "Shocraigh tú cuóta níos airde ná méid an diosca",
@@ -1218,6 +1219,7 @@
"filter_description": "Coinníollacha chun na sócmhainní sprice a scagadh", "filter_description": "Coinníollacha chun na sócmhainní sprice a scagadh",
"filter_people": "Scag daoine", "filter_people": "Scag daoine",
"filter_places": "Scag áiteanna", "filter_places": "Scag áiteanna",
"filter_tags": "Scagairí clibeanna",
"filters": "Scagairí", "filters": "Scagairí",
"find_them_fast": "Aimsigh iad go tapa de réir ainm le cuardach", "find_them_fast": "Aimsigh iad go tapa de réir ainm le cuardach",
"first": "Ar dtús", "first": "Ar dtús",
@@ -1649,6 +1651,7 @@
"only_favorites": "Is fearr leat amháin", "only_favorites": "Is fearr leat amháin",
"open": "Oscail", "open": "Oscail",
"open_calendar": "Oscail an féilire", "open_calendar": "Oscail an féilire",
"open_in_browser": "Oscail sa bhrabhsálaí",
"open_in_map_view": "Oscail i radharc léarscáile", "open_in_map_view": "Oscail i radharc léarscáile",
"open_in_openstreetmap": "Oscail in OpenStreetMap", "open_in_openstreetmap": "Oscail in OpenStreetMap",
"open_the_search_filters": "Oscail na scagairí cuardaigh", "open_the_search_filters": "Oscail na scagairí cuardaigh",
@@ -1808,9 +1811,8 @@
"rate_asset": "Rátáil Sócmhainn", "rate_asset": "Rátáil Sócmhainn",
"rating": "Rátáil réalta", "rating": "Rátáil réalta",
"rating_clear": "Glan rátáil", "rating_clear": "Glan rátáil",
"rating_count": "{count, plural, one {# réalta} other {# réaltaí}}", "rating_count": "{count, plural, =0 {Gan rátáil} one {# réalta} other {# réaltaí}}",
"rating_description": "Taispeáin an rátáil EXIF sa phainéal eolais", "rating_description": "Taispeáin an rátáil EXIF sa phainéal eolais",
"rating_set": "Socraithe go {rating, plural, one {# réalta} other {# réalta}}",
"reaction_options": "Roghanna imoibrithe", "reaction_options": "Roghanna imoibrithe",
"read_changelog": "Léigh an Log Athraithe", "read_changelog": "Léigh an Log Athraithe",
"readonly_mode_disabled": "Mód léite amháin díchumasaithe", "readonly_mode_disabled": "Mód léite amháin díchumasaithe",
@@ -1882,7 +1884,10 @@
"reset_pin_code_success": "Athshocraíodh an cód PIN go rathúil", "reset_pin_code_success": "Athshocraíodh an cód PIN go rathúil",
"reset_pin_code_with_password": "Is féidir leat do chód PIN a athshocrú i gcónaí le do phasfhocal", "reset_pin_code_with_password": "Is féidir leat do chód PIN a athshocrú i gcónaí le do phasfhocal",
"reset_sqlite": "Athshocraigh Bunachar Sonraí SQLite", "reset_sqlite": "Athshocraigh Bunachar Sonraí SQLite",
"reset_sqlite_confirmation": "An bhfuil tú cinnte gur mian leat bunachar sonraí SQLite a athshocrú? Beidh ort logáil amach agus logáil isteach arís chun na sonraí a athshioncronú", "reset_sqlite_clear_app_data": "Glan Sonraí",
"reset_sqlite_confirmation": "An bhfuil tú cinnte gur mian leat sonraí an aip a ghlanadh? Bainfear na socruithe go léir leis seo agus síneofar amach thú.",
"reset_sqlite_confirmation_note": "Nóta: Beidh ort an aip a atosú tar éis duit é a ghlanadh.",
"reset_sqlite_done": "Tá sonraí an aip glanta. Atosaigh Immich agus logáil isteach arís.",
"reset_sqlite_success": "Athshocraíodh bunachar sonraí SQLite go rathúil", "reset_sqlite_success": "Athshocraíodh bunachar sonraí SQLite go rathúil",
"reset_to_default": "Athshocraigh go réamhshocraithe", "reset_to_default": "Athshocraigh go réamhshocraithe",
"resolution": "Taifeach", "resolution": "Taifeach",
@@ -1910,6 +1915,7 @@
"saved_settings": "Socruithe sábháilte", "saved_settings": "Socruithe sábháilte",
"say_something": "Abair rud éigin", "say_something": "Abair rud éigin",
"scaffold_body_error_occurred": "Tharla earráid", "scaffold_body_error_occurred": "Tharla earráid",
"scaffold_body_error_unrecoverable": "Tharla earráid nach féidir a aisghabháil. Roinn an earráid agus an rian cruachta ar Discord nó GitHub le do thoil ionas gur féidir linn cabhrú leat. Más féidir leat comhairle a thabhairt duit, is féidir leat sonraí an aip thíos a ghlanadh.",
"scan": "Scanadh", "scan": "Scanadh",
"scan_all_libraries": "Scanáil Gach Leabharlann", "scan_all_libraries": "Scanáil Gach Leabharlann",
"scan_library": "Scanadh", "scan_library": "Scanadh",
@@ -1945,6 +1951,7 @@
"search_filter_ocr": "Cuardaigh de réir OCR", "search_filter_ocr": "Cuardaigh de réir OCR",
"search_filter_people_title": "Roghnaigh daoine", "search_filter_people_title": "Roghnaigh daoine",
"search_filter_star_rating": "Rátáil Réalta", "search_filter_star_rating": "Rátáil Réalta",
"search_filter_tags_title": "Roghnaigh clibeanna",
"search_for": "Cuardaigh le haghaidh", "search_for": "Cuardaigh le haghaidh",
"search_for_existing_person": "Cuardaigh duine atá ann cheana féin", "search_for_existing_person": "Cuardaigh duine atá ann cheana féin",
"search_no_more_result": "Gan aon torthaí eile", "search_no_more_result": "Gan aon torthaí eile",
@@ -2024,6 +2031,9 @@
"set_profile_picture": "Socraigh pictiúr próifíle", "set_profile_picture": "Socraigh pictiúr próifíle",
"set_slideshow_to_fullscreen": "Socraigh Sleamhnán go lánscáileán", "set_slideshow_to_fullscreen": "Socraigh Sleamhnán go lánscáileán",
"set_stack_primary_asset": "Socraigh mar phríomhshócmhainn", "set_stack_primary_asset": "Socraigh mar phríomhshócmhainn",
"setting_image_navigation_enable_subtitle": "Más cumasaithe é, is féidir leat nascleanúint a dhéanamh chuig an íomhá roimhe seo/chéad íomhá eile trí thapáil ar an gceathrú is faide ar chlé/ar dheis den scáileán.",
"setting_image_navigation_enable_title": "Tapáil chun nascleanúint a dhéanamh",
"setting_image_navigation_title": "Nascleanúint Íomhá",
"setting_image_viewer_help": "Lódálann an breathnóir sonraí an mionsamhail bheag ar dtús, ansin luchtaíonn sé an réamhamharc meánmhéide (más cumasaithe), agus ar deireadh luchtaíonn sé an bunleagan (más cumasaithe).", "setting_image_viewer_help": "Lódálann an breathnóir sonraí an mionsamhail bheag ar dtús, ansin luchtaíonn sé an réamhamharc meánmhéide (más cumasaithe), agus ar deireadh luchtaíonn sé an bunleagan (más cumasaithe).",
"setting_image_viewer_original_subtitle": "Cumasaigh chun an íomhá lántaifigh bhunaidh (mór!) a luchtú. Díchumasaigh chun úsáid sonraí a laghdú (ar an líonra agus ar an taisce ar an ngléas araon).", "setting_image_viewer_original_subtitle": "Cumasaigh chun an íomhá lántaifigh bhunaidh (mór!) a luchtú. Díchumasaigh chun úsáid sonraí a laghdú (ar an líonra agus ar an taisce ar an ngléas araon).",
"setting_image_viewer_original_title": "Luchtaigh an íomhá bhunaidh", "setting_image_viewer_original_title": "Luchtaigh an íomhá bhunaidh",
@@ -2302,6 +2312,7 @@
"unstack_action_prompt": "{count} gan chruachadh", "unstack_action_prompt": "{count} gan chruachadh",
"unstacked_assets_count": "Gan chruachadh {count, plural, one {# sócmhainn} other {# sócmhainní}}", "unstacked_assets_count": "Gan chruachadh {count, plural, one {# sócmhainn} other {# sócmhainní}}",
"unsupported_field_type": "Cineál réimse nach dtacaítear leis", "unsupported_field_type": "Cineál réimse nach dtacaítear leis",
"unsupported_file_type": "Ní féidir an comhad {file} a uaslódáil mar nach dtacaítear lena chineál comhaid {type}.",
"untagged": "Gan Chlib", "untagged": "Gan Chlib",
"untitled_workflow": "Sreabhadh oibre gan teideal", "untitled_workflow": "Sreabhadh oibre gan teideal",
"up_next": "Ar aghaidh", "up_next": "Ar aghaidh",
@@ -2328,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Úsáid", "usage": "Úsáid",
"use_biometric": "Úsáid bithmhéadrach", "use_biometric": "Úsáid bithmhéadrach",
"use_browser_locale": "Úsáid logán brabhsálaí",
"use_browser_locale_description": "Formáidigh dátaí, amanna agus uimhreacha bunaithe ar shuíomh do bhrabhsálaí",
"use_current_connection": "Úsáid an nasc reatha", "use_current_connection": "Úsáid an nasc reatha",
"use_custom_date_range": "Úsáid raon dáta saincheaptha ina ionad", "use_custom_date_range": "Úsáid raon dáta saincheaptha ina ionad",
"user": "Úsáideoir", "user": "Úsáideoir",
+29 -8
View File
@@ -311,7 +311,7 @@
"search_jobs": "Buscar traballos…", "search_jobs": "Buscar traballos…",
"send_welcome_email": "Enviar correo electrónico de benvida", "send_welcome_email": "Enviar correo electrónico de benvida",
"server_external_domain_settings": "Dominio externo", "server_external_domain_settings": "Dominio externo",
"server_external_domain_settings_description": "Dominio para ligazóns públicas compartidas, incluíndo http(s)://", "server_external_domain_settings_description": "Dominio empregado para links externos",
"server_public_users": "Usuarios públicos", "server_public_users": "Usuarios públicos",
"server_public_users_description": "Todos os usuarios (nome e correo electrónico) lístanse ao engadir un usuario a álbums compartidos. Cando está desactivado, a lista de usuarios só estará dispoñible para os usuarios administradores.", "server_public_users_description": "Todos os usuarios (nome e correo electrónico) lístanse ao engadir un usuario a álbums compartidos. Cando está desactivado, a lista de usuarios só estará dispoñible para os usuarios administradores.",
"server_settings": "Configuración do servidor", "server_settings": "Configuración do servidor",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mapeo de tons", "transcoding_tone_mapping": "Mapeo de tons",
"transcoding_tone_mapping_description": "Intenta preservar a aparencia dos vídeos HDR cando se converten a SDR. Cada algoritmo fai diferentes compromisos para cor, detalle e brillo. Hable preserva o detalle, Mobius preserva a cor e Reinhard preserva o brillo.", "transcoding_tone_mapping_description": "Intenta preservar a aparencia dos vídeos HDR cando se converten a SDR. Cada algoritmo fai diferentes compromisos para cor, detalle e brillo. Hable preserva o detalle, Mobius preserva a cor e Reinhard preserva o brillo.",
"transcoding_transcode_policy": "Política de transcodificación", "transcoding_transcode_policy": "Política de transcodificación",
"transcoding_transcode_policy_description": "Política para cando un vídeo debe ser transcodificado. Os vídeos HDR sempre serán transcodificados (excepto se a transcodificación está desactivada).", "transcoding_transcode_policy_description": "Política para cando un vídeo debe ser transcodificado. Os vídeos HDR e vídeos con formato de Pixel disintos de YUV 4:2:0 sempre serán transcodificados (excepto se a transcodificación está desactivada).",
"transcoding_two_pass_encoding": "Codificación en dous pasos", "transcoding_two_pass_encoding": "Codificación en dous pasos",
"transcoding_two_pass_encoding_setting_description": "Transcodificar en dous pasos para producir vídeos codificados de mellor calidade. Cando o bitrate máximo está activado (requirido para que funcione con H.264 e HEVC), este modo usa un rango de bitrate baseado no bitrate máximo e ignora CRF. Para VP9, pódese usar CRF se o bitrate máximo está desactivado.", "transcoding_two_pass_encoding_setting_description": "Transcodificar en dous pasos para producir vídeos codificados de mellor calidade. Cando o bitrate máximo está activado (requirido para que funcione con H.264 e HEVC), este modo usa un rango de bitrate baseado no bitrate máximo e ignora CRF. Para VP9, pódese usar CRF se o bitrate máximo está desactivado.",
"transcoding_video_codec": "Códec de vídeo", "transcoding_video_codec": "Códec de vídeo",
@@ -794,6 +794,11 @@
"color": "Cor", "color": "Cor",
"color_theme": "Tema de cor", "color_theme": "Tema de cor",
"command": "Comando", "command": "Comando",
"command_palette_prompt": "Atopa rapidamente páxinas, accións ou comandos",
"command_palette_to_close": "para pechar",
"command_palette_to_navigate": "para entrar",
"command_palette_to_select": "para seleccionar",
"command_palette_to_show_all": "para amosar todo",
"comment_deleted": "Comentario eliminado", "comment_deleted": "Comentario eliminado",
"comment_options": "Opcións de comentario", "comment_options": "Opcións de comentario",
"comments_and_likes": "Comentarios e Gústames", "comments_and_likes": "Comentarios e Gústames",
@@ -867,7 +872,7 @@
"current_server_address": "Enderezo do servidor actual", "current_server_address": "Enderezo do servidor actual",
"custom_date": "Data personalizada", "custom_date": "Data personalizada",
"custom_locale": "Configuración Rexional Personalizada", "custom_locale": "Configuración Rexional Personalizada",
"custom_locale_description": "Formatar datas e números baseándose na lingua e a rexión", "custom_locale_description": "Formatar datas, tempos e números baseándose na lingua e a rexión",
"custom_url": "URL personalizada", "custom_url": "URL personalizada",
"cutoff_date_description": "Manter fotos dos últimos…", "cutoff_date_description": "Manter fotos dos últimos…",
"cutoff_day": "{count, plural, one {day} other {days}}", "cutoff_day": "{count, plural, one {day} other {days}}",
@@ -890,8 +895,6 @@
"deduplication_criteria_2": "Reconto de datos EXIF", "deduplication_criteria_2": "Reconto de datos EXIF",
"deduplication_info": "Información de Deduplicación", "deduplication_info": "Información de Deduplicación",
"deduplication_info_description": "Para preseleccionar automaticamente activos e eliminar duplicados masivamente, miramos:", "deduplication_info_description": "Para preseleccionar automaticamente activos e eliminar duplicados masivamente, miramos:",
"default_locale": "Configuración Rexional Predeterminada",
"default_locale_description": "Formatar datas e números baseándose na configuración rexional do seu navegador",
"delete": "Eliminar", "delete": "Eliminar",
"delete_action_confirmation_message": "Está seguro de que quere eliminar este ficheiro? Esta acción moverá o ficheiro ao lixo do servidor e preguntaralle se tamén quere eliminalo localmente", "delete_action_confirmation_message": "Está seguro de que quere eliminar este ficheiro? Esta acción moverá o ficheiro ao lixo do servidor e preguntaralle se tamén quere eliminalo localmente",
"delete_action_prompt": "{count} eliminado(s)", "delete_action_prompt": "{count} eliminado(s)",
@@ -1004,6 +1007,8 @@
"editor_edits_applied_success": "As edicións aplicáronse correctamente", "editor_edits_applied_success": "As edicións aplicáronse correctamente",
"editor_flip_horizontal": "Xirar horizontalmente", "editor_flip_horizontal": "Xirar horizontalmente",
"editor_flip_vertical": "Xirar verticalmente", "editor_flip_vertical": "Xirar verticalmente",
"editor_handle_corner": "{corner, select, top_left {Top-left} top_right {Top-right} bottom_left {Bottom-left} bottom_right {Bottom-right} other {A}} tirador de esquina",
"editor_handle_edge": "{edge, select, top {Top} bottom {Bottom} left {Left} right {Right} other {An}} tirador de borde",
"editor_orientation": "Orientación", "editor_orientation": "Orientación",
"editor_reset_all_changes": "Restablecer os cambios", "editor_reset_all_changes": "Restablecer os cambios",
"editor_rotate_left": "Xirar 90° en sentido antihorario", "editor_rotate_left": "Xirar 90° en sentido antihorario",
@@ -1069,6 +1074,7 @@
"failed_to_update_notification_status": "Erro ao actualizar o estado das notificacións", "failed_to_update_notification_status": "Erro ao actualizar o estado das notificacións",
"incorrect_email_or_password": "Correo electrónico ou contrasinal incorrectos", "incorrect_email_or_password": "Correo electrónico ou contrasinal incorrectos",
"library_folder_already_exists": "Esta ruta de importación xa existe.", "library_folder_already_exists": "Esta ruta de importación xa existe.",
"page_not_found": "Páxina non atopada",
"paths_validation_failed": "{paths, plural, one {# ruta fallou} other {# rutas fallaron}} na validación", "paths_validation_failed": "{paths, plural, one {# ruta fallou} other {# rutas fallaron}} na validación",
"profile_picture_transparent_pixels": "As imaxes de perfil non poden ter píxeles transparentes. Por favor, faga zoom e/ou mova a imaxe.", "profile_picture_transparent_pixels": "As imaxes de perfil non poden ter píxeles transparentes. Por favor, faga zoom e/ou mova a imaxe.",
"quota_higher_than_disk_size": "Estableceu unha cota superior ao tamaño do disco", "quota_higher_than_disk_size": "Estableceu unha cota superior ao tamaño do disco",
@@ -1168,6 +1174,7 @@
"exif_bottom_sheet_people": "PERSOAS", "exif_bottom_sheet_people": "PERSOAS",
"exif_bottom_sheet_person_add_person": "Engadir nome", "exif_bottom_sheet_person_add_person": "Engadir nome",
"exit_slideshow": "Saír da Presentación", "exit_slideshow": "Saír da Presentación",
"expand": "Expandir",
"expand_all": "Expandir todo", "expand_all": "Expandir todo",
"experimental_settings_new_asset_list_subtitle": "Traballo en progreso", "experimental_settings_new_asset_list_subtitle": "Traballo en progreso",
"experimental_settings_new_asset_list_title": "Activar grella de fotos experimental", "experimental_settings_new_asset_list_title": "Activar grella de fotos experimental",
@@ -1212,6 +1219,7 @@
"filter_description": "Condicións para filtrar os activos obxectivo", "filter_description": "Condicións para filtrar os activos obxectivo",
"filter_people": "Filtrar persoas", "filter_people": "Filtrar persoas",
"filter_places": "Filtrar lugares", "filter_places": "Filtrar lugares",
"filter_tags": "Filtrar etiquetas",
"filters": "Filtros", "filters": "Filtros",
"find_them_fast": "Atópeos rápido por nome coa busca", "find_them_fast": "Atópeos rápido por nome coa busca",
"first": "Primeiro/a", "first": "Primeiro/a",
@@ -1642,6 +1650,8 @@
"online": "En liña", "online": "En liña",
"only_favorites": "Só favoritos", "only_favorites": "Só favoritos",
"open": "Abrir", "open": "Abrir",
"open_calendar": "Abrir calendario",
"open_in_browser": "Abrir no navegador",
"open_in_map_view": "Abrir na vista de mapa", "open_in_map_view": "Abrir na vista de mapa",
"open_in_openstreetmap": "Abrir en OpenStreetMap", "open_in_openstreetmap": "Abrir en OpenStreetMap",
"open_the_search_filters": "Abrir os filtros de busca", "open_the_search_filters": "Abrir os filtros de busca",
@@ -1801,9 +1811,8 @@
"rate_asset": "Clasificar activo", "rate_asset": "Clasificar activo",
"rating": "Valoración", "rating": "Valoración",
"rating_clear": "Borrar clasificación", "rating_clear": "Borrar clasificación",
"rating_count": "{count, plural, one {# estrela} other {# estrelas}}", "rating_count": "{count, plural, =0 {Sen Clasificación} one {# estrela} other {# estrelas}}",
"rating_description": "Mostrar a clasificación EXIF no panel de información", "rating_description": "Mostrar a clasificación EXIF no panel de información",
"rating_set": "Clasificación definida en {rating, plural, one {# star} other {# stars}}",
"reaction_options": "Opcións de reacción", "reaction_options": "Opcións de reacción",
"read_changelog": "Ler Rexistro de Cambios", "read_changelog": "Ler Rexistro de Cambios",
"readonly_mode_disabled": "Modo só lectura desactivado", "readonly_mode_disabled": "Modo só lectura desactivado",
@@ -1875,7 +1884,10 @@
"reset_pin_code_success": "Código PIN restablecido correctamente", "reset_pin_code_success": "Código PIN restablecido correctamente",
"reset_pin_code_with_password": "Sempre podes restablecer o teu código PIN coa túa contrasinal", "reset_pin_code_with_password": "Sempre podes restablecer o teu código PIN coa túa contrasinal",
"reset_sqlite": "Restablecer a Base de Datos SQLite", "reset_sqlite": "Restablecer a Base de Datos SQLite",
"reset_sqlite_confirmation": "Estás seguro de que queres restablecer a base de datos SQLite? Terás que pechar a sesión e iniciar sesión de novo para sincronizar os datos outra vez", "reset_sqlite_clear_app_data": "Limpar Datos",
"reset_sqlite_confirmation": "Estás seguro de que queres borrar os datos da aplicación? Isto eliminará toda a configuración e pechará a túa sesión.",
"reset_sqlite_confirmation_note": "Nota: Deberás reiniciar a aplicación despois de borrala.",
"reset_sqlite_done": "Borráronse os datos da aplicación. Por favor reiniciei Immich e inicie sesión de novo.",
"reset_sqlite_success": "Base de datos SQLite restablecida correctamente", "reset_sqlite_success": "Base de datos SQLite restablecida correctamente",
"reset_to_default": "Restablecer ao predeterminado", "reset_to_default": "Restablecer ao predeterminado",
"resolution": "Resolución", "resolution": "Resolución",
@@ -1903,6 +1915,7 @@
"saved_settings": "Configuración gardada", "saved_settings": "Configuración gardada",
"say_something": "Dicir algo", "say_something": "Dicir algo",
"scaffold_body_error_occurred": "Ocorreu un erro", "scaffold_body_error_occurred": "Ocorreu un erro",
"scaffold_body_error_unrecoverable": "Produciuse un error irrecuperable. Comparte o erro e a \"stack trace\" no Discord ou no GitHub para poder axudarche. No caso de indicarse, pode borrar os datos da aplicación a continuación.",
"scan": "Escanear", "scan": "Escanear",
"scan_all_libraries": "Escanear Todas as Bibliotecas", "scan_all_libraries": "Escanear Todas as Bibliotecas",
"scan_library": "Escanear", "scan_library": "Escanear",
@@ -1938,6 +1951,7 @@
"search_filter_ocr": "Buscar por OCR", "search_filter_ocr": "Buscar por OCR",
"search_filter_people_title": "Seleccionar persoas", "search_filter_people_title": "Seleccionar persoas",
"search_filter_star_rating": "Clasificación por estrelas", "search_filter_star_rating": "Clasificación por estrelas",
"search_filter_tags_title": "Seleccionar etiquetas",
"search_for": "Buscar por", "search_for": "Buscar por",
"search_for_existing_person": "Buscar persoa existente", "search_for_existing_person": "Buscar persoa existente",
"search_no_more_result": "Non hai máis resultados", "search_no_more_result": "Non hai máis resultados",
@@ -2017,6 +2031,9 @@
"set_profile_picture": "Establecer imaxe de perfil", "set_profile_picture": "Establecer imaxe de perfil",
"set_slideshow_to_fullscreen": "Poñer Presentación a pantalla completa", "set_slideshow_to_fullscreen": "Poñer Presentación a pantalla completa",
"set_stack_primary_asset": "Establecer como activo principal", "set_stack_primary_asset": "Establecer como activo principal",
"setting_image_navigation_enable_subtitle": "Se está activado, podes navegar entre as imáxenes seguintes e anteriores ao tocar na parte esquerda e dereita da pantalla.",
"setting_image_navigation_enable_title": "Toca para navegar",
"setting_image_navigation_title": "Navegación de Imaxes",
"setting_image_viewer_help": "O visor de detalles carga primeiro a miniatura pequena, despois carga a vista previa de tamaño medio (se está activada), e finalmente carga o orixinal (se está activado).", "setting_image_viewer_help": "O visor de detalles carga primeiro a miniatura pequena, despois carga a vista previa de tamaño medio (se está activada), e finalmente carga o orixinal (se está activado).",
"setting_image_viewer_original_subtitle": "Activar para cargar a imaxe orixinal a resolución completa (grande!). Desactivar para reducir o uso de datos (tanto na rede como na caché do dispositivo).", "setting_image_viewer_original_subtitle": "Activar para cargar a imaxe orixinal a resolución completa (grande!). Desactivar para reducir o uso de datos (tanto na rede como na caché do dispositivo).",
"setting_image_viewer_original_title": "Cargar imaxe orixinal", "setting_image_viewer_original_title": "Cargar imaxe orixinal",
@@ -2183,6 +2200,7 @@
"support": "Soporte", "support": "Soporte",
"support_and_feedback": "Soporte e Comentarios", "support_and_feedback": "Soporte e Comentarios",
"support_third_party_description": "A súa instalación de Immich foi empaquetada por un terceiro. Os problemas que experimente poden ser causados por ese paquete, así que por favor, comunique os problemas con eles en primeira instancia usando as ligazóns a continuación.", "support_third_party_description": "A súa instalación de Immich foi empaquetada por un terceiro. Os problemas que experimente poden ser causados por ese paquete, así que por favor, comunique os problemas con eles en primeira instancia usando as ligazóns a continuación.",
"supporter": "Colaborador",
"swap_merge_direction": "Intercambiar dirección de fusión", "swap_merge_direction": "Intercambiar dirección de fusión",
"sync": "Sincronizar", "sync": "Sincronizar",
"sync_albums": "Sincronizar álbums", "sync_albums": "Sincronizar álbums",
@@ -2294,6 +2312,7 @@
"unstack_action_prompt": "{count} desapilados", "unstack_action_prompt": "{count} desapilados",
"unstacked_assets_count": "Desapilados {count, plural, one {# activo} other {# activos}}", "unstacked_assets_count": "Desapilados {count, plural, one {# activo} other {# activos}}",
"unsupported_field_type": "Tipo de campo non soportado", "unsupported_field_type": "Tipo de campo non soportado",
"unsupported_file_type": "O arquivo {file} non puido cargarse porque o seu tipo de arquivo {type} non se soporta.",
"untagged": "Sen etiquetar", "untagged": "Sen etiquetar",
"untitled_workflow": "Fluxo de traballo sen título", "untitled_workflow": "Fluxo de traballo sen título",
"up_next": "A continuación", "up_next": "A continuación",
@@ -2320,6 +2339,8 @@
"url": "URL", "url": "URL",
"usage": "Uso", "usage": "Uso",
"use_biometric": "Usar biometría", "use_biometric": "Usar biometría",
"use_browser_locale": "Usar navegador local",
"use_browser_locale_description": "Formatear datas, tempos e números basado na configuración do teu navegador local",
"use_current_connection": "Empregar conexión actual", "use_current_connection": "Empregar conexión actual",
"use_custom_date_range": "Usar rango de datas personalizado no seu lugar", "use_custom_date_range": "Usar rango de datas personalizado no seu lugar",
"user": "Usuario", "user": "Usuario",
+1 -2
View File
@@ -15,6 +15,7 @@
"add_a_location": "Standort hiifüege", "add_a_location": "Standort hiifüege",
"add_a_name": "Name hiifüege", "add_a_name": "Name hiifüege",
"add_a_title": "Titel hiifüege", "add_a_title": "Titel hiifüege",
"add_action": "Aktion hiifüege",
"add_birthday": "Geburtsdatum hiifüege", "add_birthday": "Geburtsdatum hiifüege",
"add_endpoint": "Endpunkt hiifüege", "add_endpoint": "Endpunkt hiifüege",
"add_exclusion_pattern": "Ausschlussmuster hiifüege", "add_exclusion_pattern": "Ausschlussmuster hiifüege",
@@ -838,8 +839,6 @@
"deduplication_criteria_2": "Anzahl vo de EXIF Date", "deduplication_criteria_2": "Anzahl vo de EXIF Date",
"deduplication_info": "Deduplizierungsinformatione", "deduplication_info": "Deduplizierungsinformatione",
"deduplication_info_description": "Für dautomatischi Datei-Voruswahl und sDedupliziere vo allne Dateie berücksichtige mir:", "deduplication_info_description": "Für dautomatischi Datei-Voruswahl und sDedupliziere vo allne Dateie berücksichtige mir:",
"default_locale": "Standard Sproch",
"default_locale_description": "Datumsangabe und Zahle basierend uf em Gebietsschema vom Browser formatiere",
"delete": "Lösche", "delete": "Lösche",
"delete_action_confirmation_message": "Bisch du sicher, dass du dies Objekt lösche wotsch? Die Aktion verschiebt sObjekt i de Papirkorb vom Server und fragt dich, ob dus lokal löösche wotsch", "delete_action_confirmation_message": "Bisch du sicher, dass du dies Objekt lösche wotsch? Die Aktion verschiebt sObjekt i de Papirkorb vom Server und fragt dich, ob dus lokal löösche wotsch",
"delete_action_prompt": "{count} glöscht", "delete_action_prompt": "{count} glöscht",
+79 -2
View File
@@ -2,16 +2,93 @@
"about": "વિશે", "about": "વિશે",
"account": "ખાતું", "account": "ખાતું",
"account_settings": "ખાતાનાં સેટિંગ્સ", "account_settings": "ખાતાનાં સેટિંગ્સ",
"acknowledge": "જાણકારી મળી",
"action": "ક્રિયા",
"action_common_update": "સુધારો",
"action_description": "છાંટેલી વસ્તુઓ પર કરી શકાય તેવી ક્રિયાઓ",
"actions": "ક્રિયાઓ",
"active": "સક્રિય", "active": "સક્રિય",
"active_count": "સક્રિય: {count}", "active_count": "સક્રિય: {count}",
"activity": "પ્રવૃત્તિ", "activity": "પ્રવૃત્તિ",
"activity_changed": "પ્રવૃત્તિ {enabled, select, true {સક્રિય} other {નિષ્ક્રિય}} છે",
"add": "ઉમેરો", "add": "ઉમેરો",
"add_a_description": "એક વર્ણન ઉમેરો", "add_a_description": "એક વર્ણન ઉમેરો",
"add_a_location": "એક સ્થાન ઉમેરો", "add_a_location": "એક સ્થાન ઉમેરો",
"add_a_name": "એક નામ ઉમેરો", "add_a_name": "એક નામ ઉમેરો",
"add_a_title": "એક શીર્ષક ઉમેરો", "add_a_title": "એક શીર્ષક ઉમેરો",
"add_birthday": "એક જન્મદિવસ ઉમેરો", "add_action": "ક્રિયા ઉમેરો",
"add_action_description": "ક્રિયા ઉમેરવા માટે ક્લિક કરો",
"add_assets": "સંસાધનો ઉમેરો",
"add_birthday": "જન્મદિવસ ઉમેરો",
"add_endpoint": "એન્ડપોઇન્ટ ઉમેરો", "add_endpoint": "એન્ડપોઇન્ટ ઉમેરો",
"add_exclusion_pattern": "બાકાત રાખવાની પદ્ધતિ ઉમેરો",
"add_filter": "ફિલ્ટર ઉમેરો",
"add_filter_description": "ફિલ્ટર શરત ઉમેરવા માટે ક્લિક કરો",
"add_location": "સ્થાન ઉમેરો", "add_location": "સ્થાન ઉમેરો",
"add_partner": "સાથી ઉમેરો" "add_more_users": "વધારે યુઝર ઉમેરો",
"add_partner": "સાથી ઉમેરો",
"add_path": "પાથ ઉમેરો",
"add_photos": "ફોટો ઉમેરો",
"add_tag": "ટેગ ઉમેરો",
"add_to": "માં ઉમેરો",
"add_to_album": "આલ્બમમાં ઉમેરો",
"add_to_album_bottom_sheet_added": "{album} માં ઉમેરો",
"add_to_album_bottom_sheet_already_exists": "પહેલેથી જ {album} માં છે",
"add_to_album_bottom_sheet_some_local_assets": "કેટલાક લોકલ એસેટ્સને એલ્બમમાં ઉમેરવામાં આવી શક્યા નથી",
"add_to_album_toggle": "{album} માટે પસંદગી ટૉગલ કરો",
"add_to_albums": "આલ્બમો ઉમેરો",
"add_to_albums_count": "આલ્બમો માં ઉમેરો {count}",
"add_to_bottom_bar": "માં ઉમેરો",
"add_to_shared_album": "શેર કરેલ આલ્બમમાં ઉમેરો",
"add_upload_to_stack": "અપલોડને સ્ટેકમાં ઉમેરો",
"add_url": "URL ઉમેરો",
"add_workflow_step": "વર્કફ્લો પગલુ ઉમેરો",
"added_to_archive": "આર્કાઇવમાં સંગ્રહિત કરવામાં આવી છે",
"added_to_favorites": "મનપસંદ તરીકે ચિન્હીત કરેલ છે",
"added_to_favorites_count": "મનપસંદ તરીકે {count, number} ને ચિહ્નિત કરવામાં આવેલ છે",
"admin": {
"add_exclusion_pattern_description": "એક્સક્લુઝન પેટર્ન ઉમેરો. ‘*’, ‘**’, ‘?’ થી ગ્લોબિંગ સપોર્ટેડ છે. \"Raw\" ડિરેક્ટરી ઇગ્નોર કરવા \"/Raw/\", \".tif\" ફાઈલો માટે \"/*.tif\" અને એબ્સોલ્યુટ પાથ માટે \"/path/to/ignore/\" નો ઉપયોગ કરો.",
"admin_user": "વયવસ્થાપક વપરાશકર્તા",
"asset_offline_description": "આ બાહ્ય લાઇબ્રેરી એસેટ હવે ડિસ્ક પર મળતો નથી અને તેને ટ્રેશમાં ખસેડવામાં આવ્યો છે. જો ફાઇલ લાઇબ્રેરીની અંદર જ ખસેડાઈ હોય, તો નવા સંબંધિત એસેટ માટે તમારી ટાઈમલાઇન તપાસો. આ એસેટને પુનઃસ્થાપિત કરવા માટે, કૃપા કરીને ખાતરી કરો કે નીચે દર્શાવેલ ફાઇલ પથ Immich દ્વારા ઍક્સેસ કરી શકાય છે અને ત્યારબાદ લાઇબ્રેરી સ્કેન કરો.",
"authentication_settings": "પ્રમાણિકરણ સેટિંગ્સ",
"authentication_settings_description": "પાસવર્ડ, OAuth અને અન્ય પ્રમાણિકરણ સેટિંગ્સ મેનેજ કરો",
"authentication_settings_disable_all": "શું તમે ખાતરી કરો છો કે તમે તમામ લૉગિન પદ્ધતિઓ નિષ્ક્રિય કરવા માંગો છો? લૉગિન સંપૂર્ણ રીતે બંધ થઈ જશે.",
"authentication_settings_reenable": "ફરીથી સક્રિય કરવા માટે, <link>સર્વર કમાન્ડ</link> નો ઉપયોગ કરો.",
"background_task_job": "પૃષ્ઠભૂમિ કાર્યો",
"backup_database": "ડેટાબેઝ ડમ્પ બનાવો",
"backup_database_enable_description": "ડેટાબેઝ ડમ્પ સક્રિય કરો",
"backup_keep_last_amount": "અગાઉના ડમ્પ્સની સંખ્યા જાળવી રાખવા માટે",
"backup_onboarding_1_description": "ક્લાઉડમાં અથવા અન્ય ભૌતિક સ્થળે ઑફસાઇટ નકલ.",
"backup_onboarding_2_description": "વિવિધ ઉપકરણોમાં સ્થાનિક નકલો. તેમાં મુખ્ય ફાઇલો તેમજ તેમની સ્થાનિક બેકઅપ નકલ બંને સામેલ છે.",
"backup_onboarding_3_description": "તમારા ડેટાની કુલ નકલો, જેમાં મૂળ ફાઇલોનો સમાવેશ થાય છે. તેમાં 1 ઑફસાઇટ નકલ અને 2 સ્થાનિક નકલો સામેલ છે.",
"backup_onboarding_description": "તમારા ડેટાને સુરક્ષિત રાખવા માટે <backblaze-link>3-2-1 બેકઅપ વ્યૂહરચના</backblaze-link> ભલામણ કરવામાં આવે છે. સંપૂર્ણ બેકઅપ સોલ્યુશન માટે તમે તમારા અપલોડ કરેલા ફોટા/વિડિઓ તેમજ Immich ડેટાબેઝની નકલો જાળવી રાખવી જોઈએ.",
"backup_onboarding_footer": "Immich નું બેકઅપ લેવા અંગે વધુ માહિતી માટે, કૃપા કરીને <link>documentation</link> જુઓ.",
"backup_onboarding_parts_title": "3-2-1 બેકઅપમાં સામેલ છે:",
"backup_onboarding_title": "બેકઅપ્સ",
"backup_settings": "ડેટાબેઝ ડમ્પ સેટિંગ્સ",
"backup_settings_description": "ડેટાબેઝ ડમ્પ સેટિંગ્સના પ્રબંધ કરો.",
"cleared_jobs": "{job} માટે કાર્યો સાફ કરવામાં આવ્યા",
"config_set_by_file": "રૂપરેખા હાલમાં રૂપરેખા ફાઇલ દ્વારા સેટ કરવામાં આવી છે",
"confirm_delete_library": "શું તમે ખાતરી કરો છો કે તમે {library} લાઇબ્રેરી કાઢી નાખવા માંગો છો?",
"confirm_delete_library_assets": "શું તમે ખાતરી કરો છો કે તમે આ લાઇબ્રેરી કાઢી નાખવા માંગો છો? આ Immich માંથી {count, plural, one {# સમાવાયેલ એસેટ} other {બધા # સમાવાયેલ એસેટ્સ}} કાઢી નાખશે અને તેને પાછું લાવી શકાશે નહીં. ફાઇલો ડિસ્ક પર જ રહેશે.",
"confirm_email_below": "પુષ્ટિ કરવા માટે, નીચે \"{email}\" લખો",
"confirm_reprocess_all_faces": "શું તમે ખાતરી કરો છો કે તમે તમામ ચહેરાઓને ફરીથી પ્રોસેસ કરવા માંગો છો? આ નામ આપવામાં આવેલા લોકોની માહિતી પણ સાફ કરશે.",
"confirm_user_password_reset": "શું તમે ખાતરી કરો છો કે તમે {user} નો પાસવર્ડ રીસેટ કરવા માંગો છો?",
"confirm_user_pin_code_reset": "શું તમે ખાતરી કરો છો કે તમે {user} નો PIN કોડ રીસેટ કરવા માંગો છો?",
"copy_config_to_clipboard_description": "વર્તમાન સિસ્ટમ કન્ફિગને JSON ઓબ્જેક્ટ તરીકે ક્લિપબોર્ડમાં કૉપી કરો",
"create_job": "કાર્ય બનાવો",
"cron_expression": "ક્રોન એક્સપ્રેશન",
"cron_expression_description": "ક્રોન ફોર્મેટનો ઉપયોગ કરીને સ્કેનિંગ ઇન્ટરવલ સેટ કરો. વધુ માહિતી માટે કૃપા કરીને <link>Crontab Guru</link> જુઓ.",
"cron_expression_presets": "ક્રોન એક્સપ્રેશન પ્રીસેટ્સ",
"disable_login": "લોગિન ડિસેબલ કરો",
"duplicate_detection_job_description": "સરખી ઈમેજો શોધવા માટે તમારા સંસાધનો પર મશીન લર્નિંગનો ઉપયોગ કરો. આ સુવિધા સ્માર્ટ સર્ચ પર આધારિત છે",
"exclusion_pattern_description": "તમારા સંગ્રહને સ્કેન કરતી વખતે એક્સક્લુઝન પેટર્ન તમને ફાઇલો અને ફોલ્ડર્સને અવગણવામાં મદદ કરે છે. જો તમારી પાસે એવી ફાઇલો ધરાવતા ફોલ્ડર્સ હોય જેને તમે ઈમ્પોર્ટ કરવા નથી માંગતા, જેમ કે RAW ફાઇલો, તો આ સુવિધા ઉપયોગી છે.",
"export_config_as_json_description": "વર્તમાન સિસ્ટમ કોન્ફિગને JSON ફાઇલ તરીકે ડાઉનલોડ કરો",
"external_libraries_page_description": "એડમિન એક્સટર્નલ લાઈબ્રેરી પેજ",
"face_detection": "ચહેરાની પરખ",
"face_detection_description": "મશીન લર્નિંગનો ઉપયોગ કરીને સંસાધનોમાં ચહેરાની પરખ કરો. વીડિયો માટે, ફક્ત થંબનેલ જ ધ્યાનમાં લેવામાં આવે છે. \"રિફ્રેશ\" બધા સંસાધનો પર ફરીથી પ્રક્રિયા કરે છે. \"રીસેટ\" વધારામાં ચહેરાના તમામ વર્તમાન ડેટાને સાફ કરે છે. \"ખૂટતા\" તેવા સંસાધનોને કતારમાં મૂકે છે જેના પર હજુ સુધી પ્રક્રિયા કરવામાં આવી નથી. ચહેરાની પરખ પૂર્ણ થયા પછી, શોધાયેલા ચહેરાઓને 'ચહેરાની ઓળખ' માટે કતારમાં મૂકવામાં આવશે, જે તેમને હાલની અથવા નવી વ્યક્તિઓના જૂથમાં વિભાજિત કરશે.",
"facial_recognition_job_description": "શોધાયેલા ચહેરાઓને વ્યક્તિઓના જૂથમાં વિભાજિત કરો. આ પગલું 'ચહેરાની પરખ' પૂર્ણ થયા પછી શરૂ થાય છે. \"રીસેટ\" બધા ચહેરાઓનું ફરીથી જૂથીકરણ કરે છે. \"ખૂટતા\" તેવા ચહેરાઓને કતારમાં મૂકે છે જેમને હજુ સુધી કોઈ વ્યક્તિ ફાળવવામાં આવી નથી.",
"failed_job_command": "આ કાર્ય માટે આદેશ {command} નિષ્ફળ રહ્યો: {job}",
"force_delete_user_warning": "ચેતવણી: આ પ્રક્રિયા તરત જ વપરાશકર્તા અને તમામ સંસાધનોને દૂર કરી દેશે. આ નિર્ણય બદલી શકાશે નહીં અને ફાઇલોને ફરીથી મેળવી શકાશે નહીં."
}
} }
+202 -14
View File
@@ -18,6 +18,7 @@
"add_a_title": "הוספת כותרת", "add_a_title": "הוספת כותרת",
"add_action": "הוסף פעולה", "add_action": "הוסף פעולה",
"add_action_description": "לחץ כדי להוסיף פעולה לביצוע", "add_action_description": "לחץ כדי להוסיף פעולה לביצוע",
"add_assets": "הוסף תמונות",
"add_birthday": "הוספת יום הולדת", "add_birthday": "הוספת יום הולדת",
"add_endpoint": "הוסף כתובת URL", "add_endpoint": "הוסף כתובת URL",
"add_exclusion_pattern": "הוספת דפוס החרגה", "add_exclusion_pattern": "הוספת דפוס החרגה",
@@ -41,7 +42,7 @@
"add_to_shared_album": "הוספה לאלבום משותף", "add_to_shared_album": "הוספה לאלבום משותף",
"add_upload_to_stack": "הוסף את ההעלאה לערימה", "add_upload_to_stack": "הוסף את ההעלאה לערימה",
"add_url": "הוספת קישור", "add_url": "הוספת קישור",
"add_workflow_step": "הוסף שלב בסדר פעולות", "add_workflow_step": "הוספת שלב זרימת עבודה",
"added_to_archive": "נוסף לארכיון", "added_to_archive": "נוסף לארכיון",
"added_to_favorites": "נוסף למועדפים", "added_to_favorites": "נוסף למועדפים",
"added_to_favorites_count": "{count, number} נוספו למועדפים", "added_to_favorites_count": "{count, number} נוספו למועדפים",
@@ -52,7 +53,7 @@
"authentication_settings": "הגדרות התחברות", "authentication_settings": "הגדרות התחברות",
"authentication_settings_description": "ניהול סיסמה, OAuth, והגדרות התחברות אחרות", "authentication_settings_description": "ניהול סיסמה, OAuth, והגדרות התחברות אחרות",
"authentication_settings_disable_all": "האם ברצונך להשבית את כל שיטות ההתחברות? כניסה למערכת תהיה מושבתת לחלוטין.", "authentication_settings_disable_all": "האם ברצונך להשבית את כל שיטות ההתחברות? כניסה למערכת תהיה מושבתת לחלוטין.",
"authentication_settings_reenable": "כדי לאפשר מחדש, נא להשתמש ב<link>פקודת שרת</link>.", "authentication_settings_reenable": "כדי לאפשר מחדש, יש להשתמש ב<link>פקודת שרת</link>.",
"background_task_job": "משימות רקע", "background_task_job": "משימות רקע",
"backup_database": "גיבוי מסד נתונים", "backup_database": "גיבוי מסד נתונים",
"backup_database_enable_description": "אפשר גיבויי מסד נתונים", "backup_database_enable_description": "אפשר גיבויי מסד נתונים",
@@ -103,6 +104,8 @@
"image_preview_description": "תמונה בגודל בינוני עם מטא-נתונים שהוסרו, משמשת בעת צפייה בתמונה בודדת ועבור למידת מכונה", "image_preview_description": "תמונה בגודל בינוני עם מטא-נתונים שהוסרו, משמשת בעת צפייה בתמונה בודדת ועבור למידת מכונה",
"image_preview_quality_description": "איכות תצוגה מקדימה מ-1 עד 100. איכות גבוהה יותר היא טובה יותר, אבל מייצרת קבצים גדולים יותר ויכולה להפחית את תגובתיות היישום. הגדרת ערך נמוך עשויה להשפיע על איכות תוצאות של למידת מכונה.", "image_preview_quality_description": "איכות תצוגה מקדימה מ-1 עד 100. איכות גבוהה יותר היא טובה יותר, אבל מייצרת קבצים גדולים יותר ויכולה להפחית את תגובתיות היישום. הגדרת ערך נמוך עשויה להשפיע על איכות תוצאות של למידת מכונה.",
"image_preview_title": "הגדרות תצוגה מקדימה", "image_preview_title": "הגדרות תצוגה מקדימה",
"image_progressive": "הדרגתיות",
"image_progressive_description": "קידוד תמונות JPEG באופן הדרגתי לתצוגת טעינה הדרגתית. אין לכך השפעה על תמונות WebP.",
"image_quality": "איכות", "image_quality": "איכות",
"image_resolution": "רזולוציה", "image_resolution": "רזולוציה",
"image_resolution_description": "רזולוציות גבוהות יותר יכולות לשמר פרטים רבים יותר אך לוקחות זמן רב יותר לקידוד, יש להן גדלי קבצים גדולים יותר ויכולות להפחית את תגובתיות היישום.", "image_resolution_description": "רזולוציות גבוהות יותר יכולות לשמר פרטים רבים יותר אך לוקחות זמן רב יותר לקידוד, יש להן גדלי קבצים גדולים יותר ויכולות להפחית את תגובתיות היישום.",
@@ -187,10 +190,21 @@
"machine_learning_smart_search_enabled": "אפשר חיפוש חכם", "machine_learning_smart_search_enabled": "אפשר חיפוש חכם",
"machine_learning_smart_search_enabled_description": "אם מושבת, תמונות לא יקודדו לחיפוש חכם.", "machine_learning_smart_search_enabled_description": "אם מושבת, תמונות לא יקודדו לחיפוש חכם.",
"machine_learning_url_description": "כתובת ה-URL של שרת למידת המכונה. אם ניתנת יותר מכתובת URL אחת, כל שרת ינוסה ניסיון אחד בכל פעם עד שאחד מהם יגיב בהצלחה, לפי הסדר מהראשון עד האחרון. שרתים שלא מגיבים יוזנחו זמנית עד שיחזרו להיות מקוונים.", "machine_learning_url_description": "כתובת ה-URL של שרת למידת המכונה. אם ניתנת יותר מכתובת URL אחת, כל שרת ינוסה ניסיון אחד בכל פעם עד שאחד מהם יגיב בהצלחה, לפי הסדר מהראשון עד האחרון. שרתים שלא מגיבים יוזנחו זמנית עד שיחזרו להיות מקוונים.",
"maintenance_delete_backup": "מחק גיבוי",
"maintenance_delete_backup_description": "קובץ זה ימחק לצמיתות.",
"maintenance_delete_error": "מחיקת הגיבוי נכשלה.",
"maintenance_restore_backup": "שחזור מגיבוי",
"maintenance_restore_backup_description": "Immich יימחק וישוחזר מהגיבוי שנבחר. גיבוי ייווצר לפני שתמשיך.",
"maintenance_restore_backup_different_version": "גיבוי זה נוצר עם גרסה שונה של Immich!",
"maintenance_restore_backup_unknown_version": "לא ניתן היה לקבוע את גרסת הגיבוי.",
"maintenance_restore_database_backup": "שחזור גיבוי מסד הנתונים",
"maintenance_restore_database_backup_description": "חזרה למצב קודם של מסד נתונים באמצעות קובץ גיבוי",
"maintenance_settings": "תחזוקה", "maintenance_settings": "תחזוקה",
"maintenance_settings_description": "העבר את Immich למצב תחזוקה.", "maintenance_settings_description": "העבר את Immich למצב תחזוקה.",
"maintenance_start": תחלת מצב תחזוקה", "maintenance_start": פעלת מצב תחזוקה",
"maintenance_start_error": "התחלת מצב תחזוקה נכשלה.", "maintenance_start_error": "התחלת מצב תחזוקה נכשלה.",
"maintenance_upload_backup": "העלאת קובץ גיבוי של מסד הנתונים",
"maintenance_upload_backup_error": "לא ניתן היה להעלות את הגיבוי, האם זהו קובץ .sql/.sql.gz?",
"manage_concurrency": "ניהול מקביליות", "manage_concurrency": "ניהול מקביליות",
"manage_concurrency_description": "עבור לדף העבודות כדי לנהל הרצת עבודות במקביל", "manage_concurrency_description": "עבור לדף העבודות כדי לנהל הרצת עבודות במקביל",
"manage_log_settings": "ניהול הגדרות רישום ביומן", "manage_log_settings": "ניהול הגדרות רישום ביומן",
@@ -258,7 +272,7 @@
"oauth_auto_register": "רישום אוטומטי", "oauth_auto_register": "רישום אוטומטי",
"oauth_auto_register_description": "רשום אוטומטית משתמשים חדשים לאחר כניסה עם OAuth", "oauth_auto_register_description": "רשום אוטומטית משתמשים חדשים לאחר כניסה עם OAuth",
"oauth_button_text": "טקסט לחצן", "oauth_button_text": "טקסט לחצן",
"oauth_client_secret_description": "נדרש כאשר ספק ה־OAuth אינו תומך ב־PKCE (מפתח הוכחה להחלפת קוד)", "oauth_client_secret_description": "נדרש עבור לקוח סודי, או אם PKCE (מפתח הוכחה להחלפת קוד) אינו נתמך עבור לקוח ציבורי.",
"oauth_enable_description": "התחבר עם OAuth", "oauth_enable_description": "התחבר עם OAuth",
"oauth_mobile_redirect_uri": "URI להפניה מחדש בנייד", "oauth_mobile_redirect_uri": "URI להפניה מחדש בנייד",
"oauth_mobile_redirect_uri_override": "עקיפת URI להפניה מחדש בנייד", "oauth_mobile_redirect_uri_override": "עקיפת URI להפניה מחדש בנייד",
@@ -297,7 +311,7 @@
"search_jobs": "חיפוש עבודות…", "search_jobs": "חיפוש עבודות…",
"send_welcome_email": "שלח דוא\"ל ברוכים הבאים", "send_welcome_email": "שלח דוא\"ל ברוכים הבאים",
"server_external_domain_settings": "דומיין חיצוני", "server_external_domain_settings": "דומיין חיצוני",
"server_external_domain_settings_description": "דומיין עבור קישורים משותפים ציבוריים, כולל //:http(s)", "server_external_domain_settings_description": "דומיין המשמש עבור קישורים חיצוניים",
"server_public_users": "משתמשים ציבוריים", "server_public_users": "משתמשים ציבוריים",
"server_public_users_description": "כל המשתמשים (שם ודוא\"ל) מופיעים בעת הוספת משתמש לאלבומים משותפים. כאשר התכונה מושבתת, רשימת המשתמשים תהיה זמינה רק למשתמשים בעלי הרשאות ניהול.", "server_public_users_description": "כל המשתמשים (שם ודוא\"ל) מופיעים בעת הוספת משתמש לאלבומים משותפים. כאשר התכונה מושבתת, רשימת המשתמשים תהיה זמינה רק למשתמשים בעלי הרשאות ניהול.",
"server_settings": "הגדרות שרת", "server_settings": "הגדרות שרת",
@@ -397,7 +411,7 @@
"transcoding_tone_mapping": "מיפוי גוונים", "transcoding_tone_mapping": "מיפוי גוונים",
"transcoding_tone_mapping_description": "מנסה לשמר את המראה של סרטוני HDR כשהם מומרים ל-SDR. כל אלגוריתם עושה פשרות שונות עבור צבע, פירוט ובהירות. Hable משמר פרטים, Mobius משמר צבע, ו-Reinhard משמר בהירות.", "transcoding_tone_mapping_description": "מנסה לשמר את המראה של סרטוני HDR כשהם מומרים ל-SDR. כל אלגוריתם עושה פשרות שונות עבור צבע, פירוט ובהירות. Hable משמר פרטים, Mobius משמר צבע, ו-Reinhard משמר בהירות.",
"transcoding_transcode_policy": "מדיניות המרת קידוד", "transcoding_transcode_policy": "מדיניות המרת קידוד",
"transcoding_transcode_policy_description": "מדיניות לגבי מתי יש להמיר קידוד של סרטון. תמיד יומר הקידוד של סרטוני HDR (למעט אם המרת קידוד מושבתת).", "transcoding_transcode_policy_description": "מדיניות לגבי מתי יש להמיר קידוד של סרטון. תמיד יומר הקידוד של סרטוני HDR וסרטונים עם פורמט פיקסל השונה מ־YUV 4:2:0 (למעט אם המרת קידוד מושבתת).",
"transcoding_two_pass_encoding": "קידוד בשני מעברים", "transcoding_two_pass_encoding": "קידוד בשני מעברים",
"transcoding_two_pass_encoding_setting_description": "המר קידוד בשני מעברים כדי לייצר סרטונים מקודדים טוב יותר. כאשר קצב סיביות מרבי מופעל (נדרש כדי שזה יעבוד עם H.264 ו-HEVC), מצב זה משתמש בטווח קצב סיביות המבוסס על קצב הסיביות המרבי ומתעלם מ-CRF. עבור VP9, ניתן להשתמש ב-CRF אם קצב סיביות מרבי מושבת.", "transcoding_two_pass_encoding_setting_description": "המר קידוד בשני מעברים כדי לייצר סרטונים מקודדים טוב יותר. כאשר קצב סיביות מרבי מופעל (נדרש כדי שזה יעבוד עם H.264 ו-HEVC), מצב זה משתמש בטווח קצב סיביות המבוסס על קצב הסיביות המרבי ומתעלם מ-CRF. עבור VP9, ניתן להשתמש ב-CRF אם קצב סיביות מרבי מושבת.",
"transcoding_video_codec": "מקודד סרטון", "transcoding_video_codec": "מקודד סרטון",
@@ -437,6 +451,9 @@
"admin_password": "סיסמת מנהל", "admin_password": "סיסמת מנהל",
"administration": "ניהול", "administration": "ניהול",
"advanced": "מתקדם", "advanced": "מתקדם",
"advanced_settings_clear_image_cache": "נקה קבצי מטמון",
"advanced_settings_clear_image_cache_error": "לא ניתן היה לנקות את קבצי המטמון",
"advanced_settings_clear_image_cache_success": "נוקה בהצלחה {size}",
"advanced_settings_enable_alternate_media_filter_subtitle": "השתמש באפשרות זו כדי לסנן מדיה במהלך הסנכרון לפי קריטריונים חלופיים. מומלץ להשתמש בזה רק אם יש בעיה בזיהוי כל האלבומים באפליקציה.", "advanced_settings_enable_alternate_media_filter_subtitle": "השתמש באפשרות זו כדי לסנן מדיה במהלך הסנכרון לפי קריטריונים חלופיים. מומלץ להשתמש בזה רק אם יש בעיה בזיהוי כל האלבומים באפליקציה.",
"advanced_settings_enable_alternate_media_filter_title": "[ניסיוני] השתמש במסנן סנכרון אלבום חלופי שמבכשיר", "advanced_settings_enable_alternate_media_filter_title": "[ניסיוני] השתמש במסנן סנכרון אלבום חלופי שמבכשיר",
"advanced_settings_log_level_title": "רמת רישום ביומן: {level}", "advanced_settings_log_level_title": "רמת רישום ביומן: {level}",
@@ -478,6 +495,7 @@
"album_summary": "תקציר אלבום", "album_summary": "תקציר אלבום",
"album_updated": "אלבום עודכן", "album_updated": "אלבום עודכן",
"album_updated_setting_description": "קבל הודעת דוא\"ל כאשר לאלבום משותף יש תמונות חדשות", "album_updated_setting_description": "קבל הודעת דוא\"ל כאשר לאלבום משותף יש תמונות חדשות",
"album_upload_assets": "העלה תמונות מהמחשב שלך והוסף לאלבום",
"album_user_left": "עזב את {album}", "album_user_left": "עזב את {album}",
"album_user_removed": "{user} הוסר", "album_user_removed": "{user} הוסר",
"album_viewer_appbar_delete_confirm": "האם את/ה בטוח/ה שברצונך למחוק את האלבום הזה מהחשבון שלך?", "album_viewer_appbar_delete_confirm": "האם את/ה בטוח/ה שברצונך למחוק את האלבום הזה מהחשבון שלך?",
@@ -495,9 +513,11 @@
"albums_default_sort_order_description": "סדר מיון תמונות ראשוני בעת יצירת אלבומים חדשים.", "albums_default_sort_order_description": "סדר מיון תמונות ראשוני בעת יצירת אלבומים חדשים.",
"albums_feature_description": "אוספים של תמונות אשר ניתנים לשיתוף עם משתמשים אחרים.", "albums_feature_description": "אוספים של תמונות אשר ניתנים לשיתוף עם משתמשים אחרים.",
"albums_on_device_count": "אלבומים במכשיר ({count})", "albums_on_device_count": "אלבומים במכשיר ({count})",
"albums_selected": "{count, plural, one {אלבום אחד נבחר} other {# אלבומים נבחרו}}",
"all": "הכל", "all": "הכל",
"all_albums": "כל האלבומים", "all_albums": "כל האלבומים",
"all_people": "כל האנשים", "all_people": "כל האנשים",
"all_photos": "כל התמונות",
"all_videos": "כל הסרטונים", "all_videos": "כל הסרטונים",
"allow_dark_mode": "אפשר מצב כהה", "allow_dark_mode": "אפשר מצב כהה",
"allow_edits": "אפשר עריכות", "allow_edits": "אפשר עריכות",
@@ -505,6 +525,9 @@
"allow_public_user_to_upload": "אפשר למשתמש ציבורי להעלות", "allow_public_user_to_upload": "אפשר למשתמש ציבורי להעלות",
"allowed": "מורשה", "allowed": "מורשה",
"alt_text_qr_code": "תמונת קוד QR", "alt_text_qr_code": "תמונת קוד QR",
"always_keep": "שמור תמיד",
"always_keep_photos_hint": "פינוי מקום ישמור את כל התמונות במכשיר זה.",
"always_keep_videos_hint": "פינוי מקום ישמור את כל הסרטונים במכשיר זה.",
"anti_clockwise": "נגד כיוון השעון", "anti_clockwise": "נגד כיוון השעון",
"api_key": "מפתח API", "api_key": "מפתח API",
"api_key_description": "הערך הזה יוצג רק פעם אחת. נא לוודא שהעתקת אותו לפני סגירת החלון.", "api_key_description": "הערך הזה יוצג רק פעם אחת. נא לוודא שהעתקת אותו לפני סגירת החלון.",
@@ -549,6 +572,9 @@
"asset_list_layout_sub_title": "פריסה", "asset_list_layout_sub_title": "פריסה",
"asset_list_settings_subtitle": "הגדרות תבנית רשת תמונות", "asset_list_settings_subtitle": "הגדרות תבנית רשת תמונות",
"asset_list_settings_title": "רשת תמונות", "asset_list_settings_title": "רשת תמונות",
"asset_not_found_on_device_android": "מדיה לא נמצאה במכשיר",
"asset_not_found_on_device_ios": "המדיה לא נמצאה במכשיר. אם אתה משתמש ב-iCloud, ייתכן שהמדיה אינה נגישה עקב קובץ פגום המאוחסן ב-iCloud",
"asset_not_found_on_icloud": "המדיה לא נמצאה ב-iCloud. ייתכן שהמדיה אינה נגישה עקב קובץ פגום המאוחסן ב-iCloud",
"asset_offline": "תמונה לא מקוונת", "asset_offline": "תמונה לא מקוונת",
"asset_offline_description": "התמונה החיצונית הזאת כבר לא נמצאת בדיסק. נא ליצור קשר עם מנהל Immich שלך לקבלת עזרה.", "asset_offline_description": "התמונה החיצונית הזאת כבר לא נמצאת בדיסק. נא ליצור קשר עם מנהל Immich שלך לקבלת עזרה.",
"asset_restored_successfully": "תמונה שוחזרה בהצלחה", "asset_restored_successfully": "תמונה שוחזרה בהצלחה",
@@ -720,6 +746,8 @@
"change_password_form_password_mismatch": "סיסמאות לא תואמות", "change_password_form_password_mismatch": "סיסמאות לא תואמות",
"change_password_form_reenter_new_password": "הכנס שוב סיסמה חדשה", "change_password_form_reenter_new_password": "הכנס שוב סיסמה חדשה",
"change_pin_code": "שנה קוד PIN", "change_pin_code": "שנה קוד PIN",
"change_trigger": "שנה טריגר",
"change_trigger_prompt": "האם אתה בטוח שברצונך לשנות את הטריגר? פעולה זו תסיר את כל הפעולות והמסננים הקיימים.",
"change_your_password": "החלף את הסיסמה שלך", "change_your_password": "החלף את הסיסמה שלך",
"changed_visibility_successfully": "הנראות שונתה בהצלחה", "changed_visibility_successfully": "הנראות שונתה בהצלחה",
"charging": "טוען", "charging": "טוען",
@@ -728,9 +756,21 @@
"check_corrupt_asset_backup_button": "בצע בדיקה", "check_corrupt_asset_backup_button": "בצע בדיקה",
"check_corrupt_asset_backup_description": "הרץ בדיקה זו רק על Wi-Fi ולאחר שכל התמונות גובו. ההליך עשוי לקחת כמה דקות.", "check_corrupt_asset_backup_description": "הרץ בדיקה זו רק על Wi-Fi ולאחר שכל התמונות גובו. ההליך עשוי לקחת כמה דקות.",
"check_logs": "בדוק יומני רישום", "check_logs": "בדוק יומני רישום",
"checksum": "Checksum", "checksum": "סיכום ביקורת",
"choose_matching_people_to_merge": "בחר אנשים תואמים למיזוג", "choose_matching_people_to_merge": "בחר אנשים תואמים למיזוג",
"city": "עיר", "city": "עיר",
"cleanup_confirm_description": "Immich מצא {count} תמונות וסרטונים (שנוצרו לפני {date}) מגובים בבטחה לשרת. להסיר את העותקים המקומיים ממכשיר זה?",
"cleanup_confirm_prompt_title": "להסיר ממכשיר זה?",
"cleanup_deleted_assets": "{count} תמונות וסרטונים הועברו לאשפה של המכשיר",
"cleanup_deleting": "מעביר לאשפה...",
"cleanup_found_assets": "נמצאו {count} תמונות וסרטונים מגובים",
"cleanup_found_assets_with_size": "נמצאו {count} תמונות וסרטונים מגובים ({size})",
"cleanup_icloud_shared_albums_excluded": "אלבומי iCloud משותפים אינם כלולים בסריקה",
"cleanup_no_assets_found": "לא נמצאו תמונות וסרטונים התואמים את הקריטריונים לעיל. פינוי שטח יכול להסיר רק נכסים שגובו לשרת",
"cleanup_preview_title": "תמונות וסרטונים להסרה ({count})",
"cleanup_step3_description": "סרוק אחר תמונות וסרטונים מגובים התואמים את התאריך שבחרת ושמור את ההגדרות.",
"cleanup_step4_summary": "{count} תמונות וסרטונים (שנוצרו לפני {date}) להסרה מהמכשיר המקומי שלך. התמונות והסרטונים יישארו נגישים מאפליקציית Immich.",
"cleanup_trash_hint": "כדי לפנות שטח אחסון במכשיר, פתחו את אפליקציית הגלריה במכשיר ורוקנו את האשפה",
"clear": "נקה", "clear": "נקה",
"clear_all": "נקה הכל", "clear_all": "נקה הכל",
"clear_all_recent_searches": "נקה את כל החיפושים האחרונים", "clear_all_recent_searches": "נקה את כל החיפושים האחרונים",
@@ -742,6 +782,8 @@
"client_cert_import": "ייבוא", "client_cert_import": "ייבוא",
"client_cert_import_success_msg": "תעודת לקוח מיובאת", "client_cert_import_success_msg": "תעודת לקוח מיובאת",
"client_cert_invalid_msg": "קובץ תעודה לא תקין או סיסמה שגויה", "client_cert_invalid_msg": "קובץ תעודה לא תקין או סיסמה שגויה",
"client_cert_password_message": "הזן את הסיסמה עבור תעודה זו",
"client_cert_password_title": "סיסמת התעודה",
"client_cert_remove_msg": "תעודת לקוח הוסרה", "client_cert_remove_msg": "תעודת לקוח הוסרה",
"client_cert_subtitle": "תומך בפורמט PKCS12 (.p12, .pfx) בלבד. ייבוא/הסרה של תעודה זמינה רק לפני התחברות", "client_cert_subtitle": "תומך בפורמט PKCS12 (.p12, .pfx) בלבד. ייבוא/הסרה של תעודה זמינה רק לפני התחברות",
"client_cert_title": "תעודת לקוח SSL [ניסיוני]", "client_cert_title": "תעודת לקוח SSL [ניסיוני]",
@@ -752,6 +794,11 @@
"color": "צבע", "color": "צבע",
"color_theme": "צבע ערכת נושא", "color_theme": "צבע ערכת נושא",
"command": "פקודה", "command": "פקודה",
"command_palette_prompt": "מצא במהירות דפים, פעולות או פקודות",
"command_palette_to_close": "לסגור",
"command_palette_to_navigate": "להיכנס",
"command_palette_to_select": "לבחור",
"command_palette_to_show_all": "להציג הכל",
"comment_deleted": "תגובה נמחקה", "comment_deleted": "תגובה נמחקה",
"comment_options": "אפשרויות תגובה", "comment_options": "אפשרויות תגובה",
"comments_and_likes": "תגובות & לייקים", "comments_and_likes": "תגובות & לייקים",
@@ -796,6 +843,7 @@
"create_album": "צור אלבום", "create_album": "צור אלבום",
"create_album_page_untitled": "ללא כותרת", "create_album_page_untitled": "ללא כותרת",
"create_api_key": "יצירת מפתח API", "create_api_key": "יצירת מפתח API",
"create_first_workflow": "צור זרימת עבודה ראשונית",
"create_library": "צור ספרייה", "create_library": "צור ספרייה",
"create_link": "צור קישור", "create_link": "צור קישור",
"create_link_to_share": "צור קישור לשיתוף", "create_link_to_share": "צור קישור לשיתוף",
@@ -810,17 +858,25 @@
"create_tag": "צור תג", "create_tag": "צור תג",
"create_tag_description": "צור תג חדש. עבור תגים מקוננים, נא להזין את הנתיב המלא של התג כולל קווים נטויים.", "create_tag_description": "צור תג חדש. עבור תגים מקוננים, נא להזין את הנתיב המלא של התג כולל קווים נטויים.",
"create_user": "צור משתמש", "create_user": "צור משתמש",
"create_workflow": "צור זרימת עבודה",
"created": "נוצר", "created": "נוצר",
"created_at": "נוצר", "created_at": "נוצר",
"creating_linked_albums": "יוצר אלבומים מקושרים...", "creating_linked_albums": "יוצר אלבומים מקושרים...",
"crop": "חתוך", "crop": "חתוך",
"crop_aspect_ratio_fixed": "תוקן",
"crop_aspect_ratio_free": "חינם",
"crop_aspect_ratio_original": "מקורי",
"curated_object_page_title": "דברים", "curated_object_page_title": "דברים",
"current_device": "מכשיר נוכחי", "current_device": "מכשיר נוכחי",
"current_pin_code": "קוד PIN הנוכחי", "current_pin_code": "קוד PIN הנוכחי",
"current_server_address": "כתובת שרת נוכחית", "current_server_address": "כתובת שרת נוכחית",
"custom_date": "תאריך מותאם אישית",
"custom_locale": "אזור שפה מותאם אישית", "custom_locale": "אזור שפה מותאם אישית",
"custom_locale_description": "עצב תאריכים ומספרים על סמך השפה והאזור", "custom_locale_description": "עצב תאריכים, זמנים, ומספרים על סמך השפה והאזור שנבחרו",
"custom_url": "קישור מותאם אישית", "custom_url": "קישור מותאם אישית",
"cutoff_date_description": "שמור תמונות מ…",
"cutoff_day": "{count, plural, one {יום} other {ימים}}",
"cutoff_year": "{count, plural, one {שנה} other {שנים}}",
"daily_title_text_date": "E, MMM dd", "daily_title_text_date": "E, MMM dd",
"daily_title_text_date_year": "E, MMM dd, yyyy", "daily_title_text_date_year": "E, MMM dd, yyyy",
"dark": "כהה", "dark": "כהה",
@@ -839,8 +895,6 @@
"deduplication_criteria_2": "כמות נתוני EXIF", "deduplication_criteria_2": "כמות נתוני EXIF",
"deduplication_info": "מידע על ביטול כפילויות", "deduplication_info": "מידע על ביטול כפילויות",
"deduplication_info_description": "כדי לבחור מראש תמונות באופן אוטומטי ולהסיר כפילויות בכמות גדולה, אנו מסתכלים על:", "deduplication_info_description": "כדי לבחור מראש תמונות באופן אוטומטי ולהסיר כפילויות בכמות גדולה, אנו מסתכלים על:",
"default_locale": "שפת ברירת מחדל",
"default_locale_description": "פורמט תאריכים ומספרים מבוסס שפת הדפדפן שלך",
"delete": "מחק", "delete": "מחק",
"delete_action_confirmation_message": "האם אתה בטוח שברצונך למחוק את התמונה הזאת? פעולה זו תעביר אותו לאשפה של השרת, ותשאל אם ברצונך למחוק אותו גם מהמכשיר המקומי", "delete_action_confirmation_message": "האם אתה בטוח שברצונך למחוק את התמונה הזאת? פעולה זו תעביר אותו לאשפה של השרת, ותשאל אם ברצונך למחוק אותו גם מהמכשיר המקומי",
"delete_action_prompt": "{count} נמחקו", "delete_action_prompt": "{count} נמחקו",
@@ -876,6 +930,7 @@
"deselect_all": "בטל הכל", "deselect_all": "בטל הכל",
"details": "פרטים", "details": "פרטים",
"direction": "כיוון", "direction": "כיוון",
"disable": "השבת",
"disabled": "מושבת", "disabled": "מושבת",
"disallow_edits": "אל תאפשר עריכות", "disallow_edits": "אל תאפשר עריכות",
"discord": "דיסקורד", "discord": "דיסקורד",
@@ -901,6 +956,7 @@
"download_include_embedded_motion_videos": "סרטונים מוטמעים", "download_include_embedded_motion_videos": "סרטונים מוטמעים",
"download_include_embedded_motion_videos_description": "כלול סרטונים מוטעמים בתמונות עם תנועה כקובץ נפרד", "download_include_embedded_motion_videos_description": "כלול סרטונים מוטעמים בתמונות עם תנועה כקובץ נפרד",
"download_notfound": "הורדה לא נמצא", "download_notfound": "הורדה לא נמצא",
"download_original": "הורד את המקור",
"download_paused": "הורדה הופסקה", "download_paused": "הורדה הופסקה",
"download_settings": "הורדה", "download_settings": "הורדה",
"download_settings_description": "ניהול הגדרות הקשורות להורדת תמונות", "download_settings_description": "ניהול הגדרות הקשורות להורדת תמונות",
@@ -910,6 +966,7 @@
"download_waiting_to_retry": "מחכה כדי לנסות שוב", "download_waiting_to_retry": "מחכה כדי לנסות שוב",
"downloading": "מוריד", "downloading": "מוריד",
"downloading_asset_filename": "מוריד תמונה {filename}", "downloading_asset_filename": "מוריד תמונה {filename}",
"downloading_from_icloud": "מוריד מ-iCloud",
"downloading_media": "מוריד מדיה", "downloading_media": "מוריד מדיה",
"drop_files_to_upload": "שחרר קבצים בכל מקום כדי להעלות", "drop_files_to_upload": "שחרר קבצים בכל מקום כדי להעלות",
"duplicates": "כפילויות", "duplicates": "כפילויות",
@@ -938,9 +995,22 @@
"edit_tag": "ערוך תג", "edit_tag": "ערוך תג",
"edit_title": "ערוך כותרת", "edit_title": "ערוך כותרת",
"edit_user": "ערוך משתמש", "edit_user": "ערוך משתמש",
"edit_workflow": "ערוך זרימת עבודה",
"editor": "עורך", "editor": "עורך",
"editor_close_without_save_prompt": "השינויים לא יישמרו", "editor_close_without_save_prompt": "השינויים לא יישמרו",
"editor_close_without_save_title": "לסגור את העורך?", "editor_close_without_save_title": "לסגור את העורך?",
"editor_confirm_reset_all_changes": "האם אתה בטוח שברצונך לאפס את כל השינויים?",
"editor_discard_edits_confirm": "בטל עריכות",
"editor_discard_edits_prompt": "יש לך עריכות שלא נשמרו. האם אתה בטוח שברצונך למחוק אותן?",
"editor_discard_edits_title": "למחוק את העריכות?",
"editor_edits_applied_error": "החלת העריכות נכשלה",
"editor_edits_applied_success": "עריכות יושמו בהצלחה",
"editor_flip_horizontal": "הפוך אופקית",
"editor_flip_vertical": "הפוך אנכית",
"editor_orientation": "כיוון",
"editor_reset_all_changes": "איפוס שינויים",
"editor_rotate_left": "סיבוב 90° נגד כיוון השעון",
"editor_rotate_right": "סיבוב 90° עם כיוון השעון",
"email": "דוא\"ל", "email": "דוא\"ל",
"email_notifications": "התראות באימייל", "email_notifications": "התראות באימייל",
"empty_folder": "תיקיה זו ריקה", "empty_folder": "תיקיה זו ריקה",
@@ -959,11 +1029,14 @@
"error_change_sort_album": "שינוי סדר מיון אלבום נכשל", "error_change_sort_album": "שינוי סדר מיון אלבום נכשל",
"error_delete_face": "שגיאה במחיקת פנים מתמונה", "error_delete_face": "שגיאה במחיקת פנים מתמונה",
"error_getting_places": "שגיאה בקבלת מקומות", "error_getting_places": "שגיאה בקבלת מקומות",
"error_loading_albums": "שגיאה בטעינת אלבומים",
"error_loading_image": "שגיאה בטעינת התמונה", "error_loading_image": "שגיאה בטעינת התמונה",
"error_loading_partners": "שגיאה בטעינת שותפים: {error}", "error_loading_partners": "שגיאה בטעינת שותפים: {error}",
"error_retrieving_asset_information": "שגיאה באחזור פרטי המדיה",
"error_saving_image": "שגיאה: {error}", "error_saving_image": "שגיאה: {error}",
"error_tag_face_bounding_box": "שגיאה בתיוג הפנים – לא ניתן לקבל את קואורדינטות המסגרת", "error_tag_face_bounding_box": "שגיאה בתיוג הפנים – לא ניתן לקבל את קואורדינטות המסגרת",
"error_title": "שגיאה - משהו השתבש", "error_title": "שגיאה - משהו השתבש",
"error_while_navigating": "שגיאה בניווט לתמונה",
"errors": { "errors": {
"cannot_navigate_next_asset": "לא ניתן לנווט לתמונה הבאה", "cannot_navigate_next_asset": "לא ניתן לנווט לתמונה הבאה",
"cannot_navigate_previous_asset": "לא ניתן לנווט לתמונה הקודמת", "cannot_navigate_previous_asset": "לא ניתן לנווט לתמונה הקודמת",
@@ -999,6 +1072,7 @@
"failed_to_update_notification_status": "שגיאה בעדכון ההתראה", "failed_to_update_notification_status": "שגיאה בעדכון ההתראה",
"incorrect_email_or_password": "דוא\"ל או סיסמה שגויים", "incorrect_email_or_password": "דוא\"ל או סיסמה שגויים",
"library_folder_already_exists": "נתיב הייבוא כבר מוגדר.", "library_folder_already_exists": "נתיב הייבוא כבר מוגדר.",
"page_not_found": "העמוד לא נמצא :/‬",
"paths_validation_failed": "{paths, plural, one {נתיב # נכשל} other {# נתיבים נכשלו}} אימות", "paths_validation_failed": "{paths, plural, one {נתיב # נכשל} other {# נתיבים נכשלו}} אימות",
"profile_picture_transparent_pixels": "תמונות פרופיל אינן יכולות לכלול פיקסלים שקופים. נא להגדיל ו/או להזיז את התמונה.", "profile_picture_transparent_pixels": "תמונות פרופיל אינן יכולות לכלול פיקסלים שקופים. נא להגדיל ו/או להזיז את התמונה.",
"quota_higher_than_disk_size": "הגדרת מכסה גבוהה יותר מגודל הדיסק", "quota_higher_than_disk_size": "הגדרת מכסה גבוהה יותר מגודל הדיסק",
@@ -1021,6 +1095,7 @@
"unable_to_complete_oauth_login": "לא ניתן להשלים התחברות OAuth", "unable_to_complete_oauth_login": "לא ניתן להשלים התחברות OAuth",
"unable_to_connect": "לא ניתן להתחבר", "unable_to_connect": "לא ניתן להתחבר",
"unable_to_copy_to_clipboard": "לא ניתן להעתיק ללוח, יש לודא שניגשת לדף דרך https", "unable_to_copy_to_clipboard": "לא ניתן להעתיק ללוח, יש לודא שניגשת לדף דרך https",
"unable_to_create": "לא ניתן ליצור זרימת עבודה",
"unable_to_create_admin_account": "לא ניתן ליצור חשבון מנהל", "unable_to_create_admin_account": "לא ניתן ליצור חשבון מנהל",
"unable_to_create_api_key": "לא ניתן ליצור מפתח API חדש", "unable_to_create_api_key": "לא ניתן ליצור מפתח API חדש",
"unable_to_create_library": "לא ניתן ליצור ספרייה", "unable_to_create_library": "לא ניתן ליצור ספרייה",
@@ -1031,6 +1106,7 @@
"unable_to_delete_exclusion_pattern": "לא ניתן למחוק דפוס החרגה", "unable_to_delete_exclusion_pattern": "לא ניתן למחוק דפוס החרגה",
"unable_to_delete_shared_link": "לא ניתן למחוק קישור משותף", "unable_to_delete_shared_link": "לא ניתן למחוק קישור משותף",
"unable_to_delete_user": "לא ניתן למחוק משתמש", "unable_to_delete_user": "לא ניתן למחוק משתמש",
"unable_to_delete_workflow": "לא ניתן למחוק את זרימת העבודה",
"unable_to_download_files": "לא ניתן להוריד קבצים", "unable_to_download_files": "לא ניתן להוריד קבצים",
"unable_to_edit_exclusion_pattern": "לא ניתן לערוך דפוס החרגה", "unable_to_edit_exclusion_pattern": "לא ניתן לערוך דפוס החרגה",
"unable_to_empty_trash": "לא ניתן לרוקן אשפה", "unable_to_empty_trash": "לא ניתן לרוקן אשפה",
@@ -1070,6 +1146,7 @@
"unable_to_scan_library": "לא ניתן לסרוק ספרייה", "unable_to_scan_library": "לא ניתן לסרוק ספרייה",
"unable_to_set_feature_photo": "לא ניתן להגדיר תמונה מייצגת", "unable_to_set_feature_photo": "לא ניתן להגדיר תמונה מייצגת",
"unable_to_set_profile_picture": "לא ניתן להגדיר תמונת פרופיל", "unable_to_set_profile_picture": "לא ניתן להגדיר תמונת פרופיל",
"unable_to_set_rating": "לא ניתן להגדיר דירוג",
"unable_to_submit_job": "לא ניתן לשלוח משימה", "unable_to_submit_job": "לא ניתן לשלוח משימה",
"unable_to_trash_asset": "לא ניתן להעביר תמונה לאשפה", "unable_to_trash_asset": "לא ניתן להעביר תמונה לאשפה",
"unable_to_unlink_account": "לא ניתן לבטל קישור חשבון", "unable_to_unlink_account": "לא ניתן לבטל קישור חשבון",
@@ -1081,8 +1158,10 @@
"unable_to_update_settings": "לא ניתן לעדכן הגדרות", "unable_to_update_settings": "לא ניתן לעדכן הגדרות",
"unable_to_update_timeline_display_status": "לא ניתן לעדכן את מצב תצוגת ציר הזמן", "unable_to_update_timeline_display_status": "לא ניתן לעדכן את מצב תצוגת ציר הזמן",
"unable_to_update_user": "לא ניתן לעדכן משתמש", "unable_to_update_user": "לא ניתן לעדכן משתמש",
"unable_to_update_workflow": "לא ניתן לעדכן את זרימת העבודה",
"unable_to_upload_file": "לא ניתן להעלות קובץ" "unable_to_upload_file": "לא ניתן להעלות קובץ"
}, },
"errors_text": "שגיאות",
"exclusion_pattern": "דפוס אי הכללה", "exclusion_pattern": "דפוס אי הכללה",
"exif": "Exif", "exif": "Exif",
"exif_bottom_sheet_description": "הוסף תיאור...", "exif_bottom_sheet_description": "הוסף תיאור...",
@@ -1093,6 +1172,7 @@
"exif_bottom_sheet_people": "אנשים", "exif_bottom_sheet_people": "אנשים",
"exif_bottom_sheet_person_add_person": "הוסף שם", "exif_bottom_sheet_person_add_person": "הוסף שם",
"exit_slideshow": "צא ממצגת שקופיות", "exit_slideshow": "צא ממצגת שקופיות",
"expand": "הרחב",
"expand_all": "הרחב הכל", "expand_all": "הרחב הכל",
"experimental_settings_new_asset_list_subtitle": "עבודה בתהליך", "experimental_settings_new_asset_list_subtitle": "עבודה בתהליך",
"experimental_settings_new_asset_list_title": "אפשר רשת תמונות ניסיונית", "experimental_settings_new_asset_list_title": "אפשר רשת תמונות ניסיונית",
@@ -1128,12 +1208,17 @@
"features_in_development": "תכונות בפיתוח", "features_in_development": "תכונות בפיתוח",
"features_setting_description": "ניהול תכונות היישום", "features_setting_description": "ניהול תכונות היישום",
"file_name_or_extension": "שם קובץ או סיומת", "file_name_or_extension": "שם קובץ או סיומת",
"file_name_text": "שם הקובץ",
"file_name_with_value": "שם הקובץ: {file_name}",
"file_size": "גודל קובץ", "file_size": "גודל קובץ",
"filename": "שם קובץ", "filename": "שם קובץ",
"filetype": "סוג קובץ", "filetype": "סוג קובץ",
"filter": "סנן", "filter": "סנן",
"filter_description": "תנאים לסינון תמונות וסרטונים רצויים",
"filter_people": "סנן אנשים", "filter_people": "סנן אנשים",
"filter_places": "סינון מקומות", "filter_places": "סינון מקומות",
"filter_tags": "תגי סינון",
"filters": "מסננים",
"find_them_fast": "מצא אותם מהר לפי שם עם חיפוש", "find_them_fast": "מצא אותם מהר לפי שם עם חיפוש",
"first": "ראשון", "first": "ראשון",
"fix_incorrect_match": "תקן התאמה שגויה", "fix_incorrect_match": "תקן התאמה שגויה",
@@ -1143,12 +1228,16 @@
"folders_feature_description": "עיון בתצוגת התיקייה עבור התמונות והסרטונים שבמערכת הקבצים", "folders_feature_description": "עיון בתצוגת התיקייה עבור התמונות והסרטונים שבמערכת הקבצים",
"forgot_pin_code_question": "שחכת את ה-PIN שלך?", "forgot_pin_code_question": "שחכת את ה-PIN שלך?",
"forward": "קדימה", "forward": "קדימה",
"free_up_space": "פינוי מקום",
"free_up_space_description": "העבר תמונות וסרטונים מגובים לאשפה של המכשיר שלך כדי לפנות מקום. העותקים בשרת נשארים בטוחים.",
"free_up_space_settings_subtitle": "פינוי אחסון במכשיר",
"full_path": "נתיב מלא: {path}", "full_path": "נתיב מלא: {path}",
"gcast_enabled": "Google Cast", "gcast_enabled": "Google Cast",
"gcast_enabled_description": "תכונה זאת טוענת משאבים חיצוניים מגוגל בכדי לפעול.", "gcast_enabled_description": "תכונה זאת טוענת משאבים חיצוניים מגוגל בכדי לפעול.",
"general": "כללי", "general": "כללי",
"geolocation_instruction_location": "לחץ על פריט עם קואורדינטות GPS כדי להשתמש במיקומו, או בחר מיקום ישירות מהמפה", "geolocation_instruction_location": "לחץ על פריט עם קואורדינטות GPS כדי להשתמש במיקומו, או בחר מיקום ישירות מהמפה",
"get_help": "קבל עזרה", "get_help": "קבל עזרה",
"get_people_error": "שגיאה בקבלת אנשים",
"get_wifiname_error": "לא היה ניתן לקבל את שם האינטרנט האלחוטי שלך. יש לודא שהענקת את ההרשאות הדרושות ושאת/ה מחובר/ת לרשת אינטרנט אלחוטי", "get_wifiname_error": "לא היה ניתן לקבל את שם האינטרנט האלחוטי שלך. יש לודא שהענקת את ההרשאות הדרושות ושאת/ה מחובר/ת לרשת אינטרנט אלחוטי",
"getting_started": "תחילת העבודה", "getting_started": "תחילת העבודה",
"go_back": "חזור", "go_back": "חזור",
@@ -1181,6 +1270,7 @@
"hide_named_person": "הסתר אדם {name}", "hide_named_person": "הסתר אדם {name}",
"hide_password": "הסתר סיסמה", "hide_password": "הסתר סיסמה",
"hide_person": "הסתר אדם", "hide_person": "הסתר אדם",
"hide_schema": "הסתר את הסכימה",
"hide_text_recognition": "הסתרת זיהוי טקסט", "hide_text_recognition": "הסתרת זיהוי טקסט",
"hide_unnamed_people": "הסתר אנשים ללא שם", "hide_unnamed_people": "הסתר אנשים ללא שם",
"home_page_add_to_album_conflicts": "{added} תמונות נוספו לאלבום {album}. {failed} תמונות כבר נמצאות באלבום.", "home_page_add_to_album_conflicts": "{added} תמונות נוספו לאלבום {album}. {failed} תמונות כבר נמצאות באלבום.",
@@ -1253,9 +1343,18 @@
"ios_debug_info_processing_ran_at": "העיבוד התבצע ב־{dateTime}", "ios_debug_info_processing_ran_at": "העיבוד התבצע ב־{dateTime}",
"items_count": "{count, plural, one {פריט #} other {# פריטים}}", "items_count": "{count, plural, one {פריט #} other {# פריטים}}",
"jobs": "משימות", "jobs": "משימות",
"json_editor": "עורך JSON",
"json_error": "שגיאת JSON",
"keep": "שמור", "keep": "שמור",
"keep_albums": "שמור אלבומים",
"keep_albums_count": "השארת {count, plural, one {אלבום אחד} other {{count} אלבומים}}",
"keep_all": "שמור הכל", "keep_all": "שמור הכל",
"keep_description": "בחר מה נשאר במכשיר שלך כשאתה מפנה מקום.",
"keep_favorites": "שמור מועדפים",
"keep_on_device": "שמור במכשיר",
"keep_on_device_hint": "בחר פריטים לשמירה במכשיר זה",
"keep_this_delete_others": "שמור על זה, מחק אחרים", "keep_this_delete_others": "שמור על זה, מחק אחרים",
"keeping": "שומר: {items}",
"kept_this_deleted_others": "תמונה זו נשמרה ונמחקו {count, plural, one {תמונה #} other {# תמונות}}", "kept_this_deleted_others": "תמונה זו נשמרה ונמחקו {count, plural, one {תמונה #} other {# תמונות}}",
"keyboard_shortcuts": "קיצורי מקלדת", "keyboard_shortcuts": "קיצורי מקלדת",
"language": "שפה", "language": "שפה",
@@ -1349,10 +1448,28 @@
"loop_videos_description": "אפשר הפעלה חוזרת אוטומטית של סרטון במציג הפרטים.", "loop_videos_description": "אפשר הפעלה חוזרת אוטומטית של סרטון במציג הפרטים.",
"main_branch_warning": "הגרסה המותקנת היא גרסת פיתוח; אנחנו ממליצים בחום להשתמש בגרסה יציבה!", "main_branch_warning": "הגרסה המותקנת היא גרסת פיתוח; אנחנו ממליצים בחום להשתמש בגרסה יציבה!",
"main_menu": "תפריט ראשי", "main_menu": "תפריט ראשי",
"maintenance_action_restore": "שחזור מסד נתונים",
"maintenance_description": "Immich הועבר למצב <link>תחזוקה</link>.", "maintenance_description": "Immich הועבר למצב <link>תחזוקה</link>.",
"maintenance_end": "סיום מצב תחזוקה", "maintenance_end": "סיום מצב תחזוקה",
"maintenance_end_error": "כשל בסיום מצב תחזוקה.", "maintenance_end_error": "כשל בסיום מצב תחזוקה.",
"maintenance_logged_in_as": "מחובר כרגע בתור {user}", "maintenance_logged_in_as": "מחובר כרגע בתור {user}",
"maintenance_restore_from_backup": "שחזור מגיבוי",
"maintenance_restore_library": "שחזר את הספרייה שלך",
"maintenance_restore_library_confirm": "אם זה נראה נכון, המשך לשחזר גיבוי!",
"maintenance_restore_library_description": "משחזר את מסד הנתונים",
"maintenance_restore_library_folder_has_files": "ל-{folder} יש {count} תיקיות",
"maintenance_restore_library_folder_no_files": "ל־{folder} חסרים קבצים!",
"maintenance_restore_library_folder_pass": "ניתנת לקריאה וכתיבה",
"maintenance_restore_library_folder_read_fail": "אינה ניתנת לקריאה",
"maintenance_restore_library_folder_write_fail": "אינה ניתנת לכתיבה",
"maintenance_restore_library_hint_missing_files": "ייתכן שחסרים לך קבצים חשובים",
"maintenance_restore_library_hint_regenerate_later": "ניתן לייצר מחדש את אלה מאוחר יותר בהגדרות",
"maintenance_restore_library_hint_storage_template_missing_files": "משתמש/ת בתבנית אחסון? ייתכן שחסרים לך קבצים",
"maintenance_restore_library_loading": "בתהליך טעינת בדיקות שלמות והיוריסטיקות…",
"maintenance_task_backup": "יצירת גיבוי של מסד הנתונים הנוכחי…",
"maintenance_task_migrations": "בתהליך הרצת הגירות של מסד נתונים…",
"maintenance_task_restore": "בתהליך שחזור של הגיבוי שנבחר…",
"maintenance_task_rollback": "השחזור כשל, בתהליך גלגול חזרה לנקודת שחזור…",
"maintenance_title": "לא זמין באופן זמני", "maintenance_title": "לא זמין באופן זמני",
"make": "תוצרת", "make": "תוצרת",
"manage_geolocation": "נהל מיקום", "manage_geolocation": "נהל מיקום",
@@ -1414,6 +1531,8 @@
"minimize": "מזער", "minimize": "מזער",
"minute": "דקה", "minute": "דקה",
"minutes": "דקות", "minutes": "דקות",
"mirror_horizontal": "אופקי",
"mirror_vertical": "אנכי",
"missing": "חסרים", "missing": "חסרים",
"mobile_app": "אפליקציה לטלפון", "mobile_app": "אפליקציה לטלפון",
"mobile_app_download_onboarding_note": "הורד את האפליקציה המלווה באחת מהאפשרויות הבאות", "mobile_app_download_onboarding_note": "הורד את האפליקציה המלווה באחת מהאפשרויות הבאות",
@@ -1422,11 +1541,14 @@
"monthly_title_text_date_format": "MMMM y", "monthly_title_text_date_format": "MMMM y",
"more": "עוד", "more": "עוד",
"move": "העבר", "move": "העבר",
"move_down": "הזזה למטה",
"move_off_locked_folder": "הוצאה מהתיקייה הנעולה", "move_off_locked_folder": "הוצאה מהתיקייה הנעולה",
"move_to": "העבר ל", "move_to": "העבר ל",
"move_to_device_trash": "העברה לפח האשפה של המכשיר",
"move_to_lock_folder_action_prompt": "{count} נוספו לתיקייה הנעולה", "move_to_lock_folder_action_prompt": "{count} נוספו לתיקייה הנעולה",
"move_to_locked_folder": "העבר לתיקיה הנעולה", "move_to_locked_folder": "העבר לתיקיה הנעולה",
"move_to_locked_folder_confirmation": "התמונות והסרטונים האלו יוסרו מכל האלבומים, ויהיו מוצגים רק בתיקיה הנעולה", "move_to_locked_folder_confirmation": "התמונות והסרטונים האלו יוסרו מכל האלבומים, ויהיו מוצגים רק בתיקיה הנעולה",
"move_up": "הזזה למעלה",
"moved_to_archive": "{count, plural, one {הועברה תמונה # } other {# תמונות הועברו}} לארכיון", "moved_to_archive": "{count, plural, one {הועברה תמונה # } other {# תמונות הועברו}} לארכיון",
"moved_to_library": "{count, plural, one {הועברה תמונה # } other {# תמונות הועברו}} לספריה", "moved_to_library": "{count, plural, one {הועברה תמונה # } other {# תמונות הועברו}} לספריה",
"moved_to_trash": "הועבר לאשפה", "moved_to_trash": "הועבר לאשפה",
@@ -1436,6 +1558,7 @@
"my_albums": "האלבומים שלי", "my_albums": "האלבומים שלי",
"name": "שם", "name": "שם",
"name_or_nickname": "שם או כינוי", "name_or_nickname": "שם או כינוי",
"name_required": "נדרש שם",
"navigate": "נווט", "navigate": "נווט",
"navigate_to_time": "נווט אל זמן", "navigate_to_time": "נווט אל זמן",
"network_requirement_photos_upload": "השתמש בנתונים ניידים לגיבוי תמונות", "network_requirement_photos_upload": "השתמש בנתונים ניידים לגיבוי תמונות",
@@ -1460,20 +1583,24 @@
"next": "הבא", "next": "הבא",
"next_memory": "הזיכרון הבא", "next_memory": "הזיכרון הבא",
"no": "לא", "no": "לא",
"no_actions_added": "עדיין לא נוספו פעולות",
"no_albums_found": "לא נמצאו אלבומים",
"no_albums_message": "צור אלבום כדי לארגן את התמונות והסרטונים שלך", "no_albums_message": "צור אלבום כדי לארגן את התמונות והסרטונים שלך",
"no_albums_with_name_yet": "זה נראה שאין לך עדיין אף אלבום עם השם הזה.", "no_albums_with_name_yet": "זה נראה שאין לך עדיין אף אלבום עם השם הזה.",
"no_albums_yet": "זה נראה שאין לך עדיין אלבומים.", "no_albums_yet": "זה נראה שאין לך עדיין אלבומים.",
"no_archived_assets_message": "העבר תמונות וסרטונים לארכיון כדי להסתיר אותם מתצוגת התמונות שלך", "no_archived_assets_message": "העבר תמונות וסרטונים לארכיון כדי להסתיר אותם מתצוגת התמונות שלך",
"no_assets_message": "לחץ כדי להעלות את התמונה הראשונה שלך", "no_assets_message": "יש ללחוץ כדי להעלות את התמונה הראשונה שלך",
"no_assets_to_show": "אין תמונות להצגה", "no_assets_to_show": "אין תמונות להצגה",
"no_cast_devices_found": "לא נמצאו מכשירי שידור", "no_cast_devices_found": "לא נמצאו מכשירי שידור",
"no_checksum_local": "אין Checksum זמין - לא ניתן לאחזר תמונות מקומיות", "no_checksum_local": "אין Checksum זמין - לא ניתן לאחזר תמונות מקומיות",
"no_checksum_remote": "אין Checksum זמין - לא ניתן לאחזר תמונות מהשרת", "no_checksum_remote": "אין Checksum זמין - לא ניתן לאחזר תמונות מהשרת",
"no_configuration_needed": "לא נדרשת תצורה",
"no_devices": "אין מכשירים מורשים", "no_devices": "אין מכשירים מורשים",
"no_duplicates_found": "לא נמצאו כפילויות.", "no_duplicates_found": "לא נמצאו כפילויות.",
"no_exif_info_available": "אין מידע זמין על מטא-נתונים (exif)", "no_exif_info_available": "אין מידע זמין על מטא-נתונים (exif)",
"no_explore_results_message": "העלה תמונות נוספות כדי לחקור את האוסף שלך.", "no_explore_results_message": "העלה תמונות נוספות כדי לחקור את האוסף שלך.",
"no_favorites_message": "הוסף מועדפים כדי למצוא במהירות את התמונות והסרטונים הכי טובים שלך", "no_favorites_message": "הוסף מועדפים כדי למצוא במהירות את התמונות והסרטונים הכי טובים שלך",
"no_filters_added": "עדיין לא נוספו מסננים",
"no_libraries_message": "צור ספרייה חיצונית כדי לראות את התמונות והסרטונים שלך", "no_libraries_message": "צור ספרייה חיצונית כדי לראות את התמונות והסרטונים שלך",
"no_local_assets_found": "לא נמצאו תמונות עם Checksum זהה", "no_local_assets_found": "לא נמצאו תמונות עם Checksum זהה",
"no_location_set": "לא הוגדר מיקום", "no_location_set": "לא הוגדר מיקום",
@@ -1487,6 +1614,7 @@
"no_results_description": "נסה להשתמש במילה נרדפת או במילת מפתח יותר כללית", "no_results_description": "נסה להשתמש במילה נרדפת או במילת מפתח יותר כללית",
"no_shared_albums_message": "צור אלבום כדי לשתף תמונות וסרטונים עם אנשים ברשת שלך", "no_shared_albums_message": "צור אלבום כדי לשתף תמונות וסרטונים עם אנשים ברשת שלך",
"no_uploads_in_progress": "אין העלאות בתהליך", "no_uploads_in_progress": "אין העלאות בתהליך",
"none": "אף אחד",
"not_allowed": "לא מורשה", "not_allowed": "לא מורשה",
"not_available": "לא רלוונטי", "not_available": "לא רלוונטי",
"not_in_any_album": "לא בשום אלבום", "not_in_any_album": "לא בשום אלבום",
@@ -1520,6 +1648,7 @@
"online": "מקוון", "online": "מקוון",
"only_favorites": "רק מועדפים", "only_favorites": "רק מועדפים",
"open": "פתח", "open": "פתח",
"open_calendar": "פתיחת לוח שנה",
"open_in_map_view": "פתח בתצוגת מפה", "open_in_map_view": "פתח בתצוגת מפה",
"open_in_openstreetmap": "פתח ב-OpenStreetMap", "open_in_openstreetmap": "פתח ב-OpenStreetMap",
"open_the_search_filters": "פתח את מסנני החיפוש", "open_the_search_filters": "פתח את מסנני החיפוש",
@@ -1568,6 +1697,7 @@
"people": "אנשים", "people": "אנשים",
"people_edits_count": "{count, plural, one {אדם # נערך} other {# אנשים נערכו}}", "people_edits_count": "{count, plural, one {אדם # נערך} other {# אנשים נערכו}}",
"people_feature_description": "עיון בתמונות וסרטונים שקובצו על ידי אנשים", "people_feature_description": "עיון בתמונות וסרטונים שקובצו על ידי אנשים",
"people_selected": "{count, plural, one {אדם אחד נבחר} other {# אנשים נבחרו}}",
"people_sidebar_description": "הצג קישור אל אנשים בסרגל הצד", "people_sidebar_description": "הצג קישור אל אנשים בסרגל הצד",
"permanent_deletion_warning": "אזהרת מחיקה לצמיתות", "permanent_deletion_warning": "אזהרת מחיקה לצמיתות",
"permanent_deletion_warning_setting_description": "הצג אזהרה בעת מחיקת תמונות לצמיתות", "permanent_deletion_warning_setting_description": "הצג אזהרה בעת מחיקת תמונות לצמיתות",
@@ -1592,11 +1722,14 @@
"person_age_years": "בגיל {years, plural, other {# שנים}}", "person_age_years": "בגיל {years, plural, other {# שנים}}",
"person_birthdate": "נולד בתאריך {date}", "person_birthdate": "נולד בתאריך {date}",
"person_hidden": "{name}{hidden, select, true { (מוסתר)} other {}}", "person_hidden": "{name}{hidden, select, true { (מוסתר)} other {}}",
"person_recognized": "זוהה אדם",
"person_selected": "נבחר אדם",
"photo_shared_all_users": "נראה ששיתפת את התמונות שלך עם כל המשתמשים או שאין לך אף משתמש לשתף איתו.", "photo_shared_all_users": "נראה ששיתפת את התמונות שלך עם כל המשתמשים או שאין לך אף משתמש לשתף איתו.",
"photos": "תמונות", "photos": "תמונות",
"photos_and_videos": "תמונות & סרטונים", "photos_and_videos": "תמונות & סרטונים",
"photos_count": "{count, plural, one {תמונה {count, number}} other {{count, number} תמונות}}", "photos_count": "{count, plural, one {תמונה {count, number}} other {{count, number} תמונות}}",
"photos_from_previous_years": "תמונות משנים קודמות", "photos_from_previous_years": "תמונות משנים קודמות",
"photos_only": "רק תמונות",
"pick_a_location": "בחר מיקום", "pick_a_location": "בחר מיקום",
"pick_custom_range": "טווח מותאם אישית", "pick_custom_range": "טווח מותאם אישית",
"pick_date_range": "בחר טווח תאריכים", "pick_date_range": "בחר טווח תאריכים",
@@ -1672,9 +1805,10 @@
"purchase_settings_server_activated": "מפתח המוצר של השרת מנוהל על ידי מנהל המערכת", "purchase_settings_server_activated": "מפתח המוצר של השרת מנוהל על ידי מנהל המערכת",
"query_asset_id": "שאילתה על מזהה הפריט", "query_asset_id": "שאילתה על מזהה הפריט",
"queue_status": "{count} מתוך {total} עומדים בתור", "queue_status": "{count} מתוך {total} עומדים בתור",
"rate_asset": "דירוג תמונה",
"rating": "דירוג כוכב", "rating": "דירוג כוכב",
"rating_clear": "נקה דירוג", "rating_clear": "נקה דירוג",
"rating_count": "{count, plural, one {כוכב #} other {# כוכבים}}", "rating_count": "{count, plural, =0 {ללא דירוג} one {כוכב אחד} other {# כוכבים}}",
"rating_description": "הצג את דירוג ה-EXIF בלוח המידע", "rating_description": "הצג את דירוג ה-EXIF בלוח המידע",
"reaction_options": "אפשרויות הגבה", "reaction_options": "אפשרויות הגבה",
"read_changelog": "קרא את יומן השינויים", "read_changelog": "קרא את יומן השינויים",
@@ -1747,7 +1881,10 @@
"reset_pin_code_success": "קוד ה-PIN אופס בהצלחה", "reset_pin_code_success": "קוד ה-PIN אופס בהצלחה",
"reset_pin_code_with_password": "באפשרותך תמיד לאפס את קוד ה-PIN שלך עם הסיסמה שלך", "reset_pin_code_with_password": "באפשרותך תמיד לאפס את קוד ה-PIN שלך עם הסיסמה שלך",
"reset_sqlite": "אפס את מסד הנתונים SQLite", "reset_sqlite": "אפס את מסד הנתונים SQLite",
"reset_sqlite_confirmation": "האם אתה בטוח שברצונך לאפס את מסד הנתונים SQLite? יהיה עליך להתנתק ולהתחבר מחדש כדי לסנכרן את הנתונים מחדש", "reset_sqlite_clear_app_data": "ניקוי נתונים",
"reset_sqlite_confirmation": "האם ברצונך לנקות את נתוני היישום? פעולה זו תסיר את כל ההגדרות ותנתק אותך.",
"reset_sqlite_confirmation_note": "הערה: יהיה צורך להתחיל מחדש את היישום לאחר הניקוי.",
"reset_sqlite_done": "נתונים היישום נוקו. נא להתחיל מחדש את Immich ולהיכנס שוב.",
"reset_sqlite_success": "איפוס מסד הנתונים SQLite בוצע בהצלחה", "reset_sqlite_success": "איפוס מסד הנתונים SQLite בוצע בהצלחה",
"reset_to_default": "אפס לברירת מחדל", "reset_to_default": "אפס לברירת מחדל",
"resolution": "רזולוציה", "resolution": "רזולוציה",
@@ -1775,9 +1912,12 @@
"saved_settings": "הגדרות שמורות", "saved_settings": "הגדרות שמורות",
"say_something": "להגיד משהו", "say_something": "להגיד משהו",
"scaffold_body_error_occurred": "אירעה שגיאה", "scaffold_body_error_occurred": "אירעה שגיאה",
"scaffold_body_error_unrecoverable": "אירעה שגיאה שאי אפשר להתאושש ממנה. נא לשתף את השגיאה ועקבות המחסנית ב־Discord או GitHub כך שנוכל לעזור. אם ניתנה המלצה, ניתן לנקות את נתוני היישום למטה.",
"scan": "סריקה",
"scan_all_libraries": "סרוק את כל הספריות", "scan_all_libraries": "סרוק את כל הספריות",
"scan_library": "סרוק", "scan_library": "סרוק",
"scan_settings": "הגדרות סריקה", "scan_settings": "הגדרות סריקה",
"scanning": "בתהליך סריקה",
"scanning_for_album": "סורק אחר אלבום...", "scanning_for_album": "סורק אחר אלבום...",
"search": "חיפוש", "search": "חיפוש",
"search_albums": "חיפוש אלבומים", "search_albums": "חיפוש אלבומים",
@@ -1807,6 +1947,8 @@
"search_filter_media_type_title": "בחר סוג מדיה", "search_filter_media_type_title": "בחר סוג מדיה",
"search_filter_ocr": "חיפוש לפי OCR", "search_filter_ocr": "חיפוש לפי OCR",
"search_filter_people_title": "בחר אנשים", "search_filter_people_title": "בחר אנשים",
"search_filter_star_rating": "דירוג כוכבים",
"search_filter_tags_title": "בחירת תגים",
"search_for": "חיפוש", "search_for": "חיפוש",
"search_for_existing_person": "חיפוש אדם קיים", "search_for_existing_person": "חיפוש אדם קיים",
"search_no_more_result": "אין עוד תוצאות", "search_no_more_result": "אין עוד תוצאות",
@@ -1841,17 +1983,23 @@
"second": "שנייה", "second": "שנייה",
"see_all_people": "ראה את כל האנשים", "see_all_people": "ראה את כל האנשים",
"select": "בחר", "select": "בחר",
"select_album": "בחירת אלבום",
"select_album_cover": "בחר עטיפת אלבום", "select_album_cover": "בחר עטיפת אלבום",
"select_albums": "בחירת אלבומים",
"select_all": "בחר הכל", "select_all": "בחר הכל",
"select_all_duplicates": "בחר את כל הכפילויות", "select_all_duplicates": "בחר את כל הכפילויות",
"select_all_in": "בחר הכול בתוך {group}", "select_all_in": "בחר הכול בתוך {group}",
"select_avatar_color": "בחר צבע יצגן", "select_avatar_color": "בחר צבע יצגן",
"select_count": "{count, plural, one {בחירת #} other {בחירת #}}",
"select_cutoff_date": "בחירת תאריך חיתוך",
"select_face": "בחר פנים", "select_face": "בחר פנים",
"select_featured_photo": "בחר תמונה מייצגת", "select_featured_photo": "בחר תמונה מייצגת",
"select_from_computer": "בחר מהמחשב", "select_from_computer": "בחר מהמחשב",
"select_keep_all": "בחר שמור הכל", "select_keep_all": "בחר שמור הכל",
"select_library_owner": "בחר את הבעלים של הספרייה", "select_library_owner": "בחר את הבעלים של הספרייה",
"select_new_face": "בחר פנים חדשות", "select_new_face": "בחר פנים חדשות",
"select_people": "בחירת אנשים",
"select_person": "בחירת אדם",
"select_person_to_tag": "בחר אדם לתיוג", "select_person_to_tag": "בחר אדם לתיוג",
"select_photos": "בחר תמונות", "select_photos": "בחר תמונות",
"select_trash_all": "בחר העבר הכל לאשפה", "select_trash_all": "בחר העבר הכל לאשפה",
@@ -1880,6 +2028,9 @@
"set_profile_picture": "הגדר תמונת פרופיל", "set_profile_picture": "הגדר תמונת פרופיל",
"set_slideshow_to_fullscreen": "הגדר מצגת שקופיות למסך מלא", "set_slideshow_to_fullscreen": "הגדר מצגת שקופיות למסך מלא",
"set_stack_primary_asset": "הגדרה כתמונה ראשית", "set_stack_primary_asset": "הגדרה כתמונה ראשית",
"setting_image_navigation_enable_subtitle": "אם הגדרה זו מופעלת, ניתן לנווט לתמונה הקודמת/הבאה על ידי הקשה על הרבע הימני/השמאלי ביותר של המסך.",
"setting_image_navigation_enable_title": "הקשה לניווט",
"setting_image_navigation_title": "ניווט תמונה",
"setting_image_viewer_help": "מציג הפרטים טוען את התמונה הממוזערת הקטנה קודם, לאחר מכן טוען את התצוגה המקדימה בגודל בינוני (אם מופעל), לבסוף טוען את המקורית (אם מופעל).", "setting_image_viewer_help": "מציג הפרטים טוען את התמונה הממוזערת הקטנה קודם, לאחר מכן טוען את התצוגה המקדימה בגודל בינוני (אם מופעל), לבסוף טוען את המקורית (אם מופעל).",
"setting_image_viewer_original_subtitle": "אפשר לטעון את התמונה המקורית ברזלוציה מלאה (גדולה!). השבת כדי להקטין שימוש בנתונים (גם בשרת וגם בזיכרון המטמון שבמכשיר).", "setting_image_viewer_original_subtitle": "אפשר לטעון את התמונה המקורית ברזלוציה מלאה (גדולה!). השבת כדי להקטין שימוש בנתונים (גם בשרת וגם בזיכרון המטמון שבמכשיר).",
"setting_image_viewer_original_title": "טען תמונה מקורית", "setting_image_viewer_original_title": "טען תמונה מקורית",
@@ -1987,6 +2138,7 @@
"show_password": "הראה סיסמה", "show_password": "הראה סיסמה",
"show_person_options": "הצג אפשרויות אדם", "show_person_options": "הצג אפשרויות אדם",
"show_progress_bar": "הצג סרגל התקדמות", "show_progress_bar": "הצג סרגל התקדמות",
"show_schema": "הצגת תרשים",
"show_search_options": "הצג אפשרויות חיפוש", "show_search_options": "הצג אפשרויות חיפוש",
"show_shared_links": "הצג קישורים משותפים", "show_shared_links": "הצג קישורים משותפים",
"show_slideshow_transition": "הצג מעבר מצגת", "show_slideshow_transition": "הצג מעבר מצגת",
@@ -2004,6 +2156,8 @@
"skip_to_folders": "דלג לתיקיות", "skip_to_folders": "דלג לתיקיות",
"skip_to_tags": "דלג לתגים", "skip_to_tags": "דלג לתגים",
"slideshow": "מצגת שקופיות", "slideshow": "מצגת שקופיות",
"slideshow_repeat": "חזרה על מצגת",
"slideshow_repeat_description": "חזרה להתחלה כאשר המצגת נגמרת",
"slideshow_settings": "הגדרות מצגת שקופיות", "slideshow_settings": "הגדרות מצגת שקופיות",
"sort_albums_by": "מיין אלבומים לפי...", "sort_albums_by": "מיין אלבומים לפי...",
"sort_created": "תאריך יצירה", "sort_created": "תאריך יצירה",
@@ -2043,6 +2197,7 @@
"support": "תמיכה", "support": "תמיכה",
"support_and_feedback": "תמיכה & משוב", "support_and_feedback": "תמיכה & משוב",
"support_third_party_description": "התקנת ה-Immich שלך נארזה על ידי צד שלישי. בעיות שאתה חווה עשויות להיגרם על ידי חבילה זו, אז בבקשה תעלה בעיות איתם ראשית כל באמצעות הקישורים למטה.", "support_third_party_description": "התקנת ה-Immich שלך נארזה על ידי צד שלישי. בעיות שאתה חווה עשויות להיגרם על ידי חבילה זו, אז בבקשה תעלה בעיות איתם ראשית כל באמצעות הקישורים למטה.",
"supporter": "תומך",
"swap_merge_direction": "החלף כיוון מיזוג", "swap_merge_direction": "החלף כיוון מיזוג",
"sync": "סנכרן", "sync": "סנכרן",
"sync_albums": "סנכרן אלבומים", "sync_albums": "סנכרן אלבומים",
@@ -2080,6 +2235,7 @@
"theme_setting_theme_subtitle": "בחר את הגדרת ערכת הנושא של היישום", "theme_setting_theme_subtitle": "בחר את הגדרת ערכת הנושא של היישום",
"theme_setting_three_stage_loading_subtitle": "טעינה בשלושה שלבים עשויה לשפר את ביצועי הטעינה אבל גורמת באופן משמעותי לעומס רשת גבוה יותר", "theme_setting_three_stage_loading_subtitle": "טעינה בשלושה שלבים עשויה לשפר את ביצועי הטעינה אבל גורמת באופן משמעותי לעומס רשת גבוה יותר",
"theme_setting_three_stage_loading_title": "אפשר טעינה בשלושה שלבים", "theme_setting_three_stage_loading_title": "אפשר טעינה בשלושה שלבים",
"then": "אז",
"they_will_be_merged_together": "הם יתמזגו יחד", "they_will_be_merged_together": "הם יתמזגו יחד",
"third_party_resources": "משאבי צד שלישי", "third_party_resources": "משאבי צד שלישי",
"time": "זמן", "time": "זמן",
@@ -2114,6 +2270,13 @@
"trash_page_select_assets_btn": "בחר תמונות", "trash_page_select_assets_btn": "בחר תמונות",
"trash_page_title": "אשפה ({count})", "trash_page_title": "אשפה ({count})",
"trashed_items_will_be_permanently_deleted_after": "פריטים באשפה ימחקו לצמיתות לאחר {days, plural, one {יום #} other {# ימים}}.", "trashed_items_will_be_permanently_deleted_after": "פריטים באשפה ימחקו לצמיתות לאחר {days, plural, one {יום #} other {# ימים}}.",
"trigger": "טריגר",
"trigger_asset_uploaded": "נכס הועלה",
"trigger_asset_uploaded_description": "מתעורר כאשר נכס חדש הועלה",
"trigger_description": "אירוע שמתחיל את זרימת העבודה",
"trigger_person_recognized": "זוהה אדם",
"trigger_person_recognized_description": "מתעורר כאשר זוהה אדם",
"trigger_type": "סוג הטריגר",
"troubleshoot": "פתור בעיות", "troubleshoot": "פתור בעיות",
"type": "סוג", "type": "סוג",
"unable_to_change_pin_code": "לא ניתן לשנות את קוד ה PIN", "unable_to_change_pin_code": "לא ניתן לשנות את קוד ה PIN",
@@ -2128,6 +2291,7 @@
"unhide_person": "בטל הסתרת אדם", "unhide_person": "בטל הסתרת אדם",
"unknown": "לא ידוע", "unknown": "לא ידוע",
"unknown_country": "מדינה לא ידועה", "unknown_country": "מדינה לא ידועה",
"unknown_date": "תאריך לא ידוע",
"unknown_year": "שנה לא ידועה", "unknown_year": "שנה לא ידועה",
"unlimited": "בלתי מוגבל", "unlimited": "בלתי מוגבל",
"unlink_motion_video": "בטל קישור סרטון תנועה", "unlink_motion_video": "בטל קישור סרטון תנועה",
@@ -2144,7 +2308,10 @@
"unstack": "בטל ערימה", "unstack": "בטל ערימה",
"unstack_action_prompt": "{count} הופרדו", "unstack_action_prompt": "{count} הופרדו",
"unstacked_assets_count": "{count, plural, one {תמונה # הוסרה} other {# תמונות הוסרו}} מהערימה", "unstacked_assets_count": "{count, plural, one {תמונה # הוסרה} other {# תמונות הוסרו}} מהערימה",
"unsupported_field_type": "סוג שדה לא ידוע",
"unsupported_file_type": "הקובץ {file} אינו ניתן להעלאה בגלל שסוג הקובץ שלו {type} אינו נתמך.",
"untagged": "לא מתיוגים", "untagged": "לא מתיוגים",
"untitled_workflow": "זרימת עבודה ללא כותרת",
"up_next": "הבא בתור", "up_next": "הבא בתור",
"update_location_action_prompt": "עדכן את המיקום של {count} פריטים שנבחרו עם:", "update_location_action_prompt": "עדכן את המיקום של {count} פריטים שנבחרו עם:",
"updated_at": "עודכן", "updated_at": "עודכן",
@@ -2154,6 +2321,7 @@
"upload_details": "פרטי העלאה", "upload_details": "פרטי העלאה",
"upload_dialog_info": "האם ברצונך לגבות את התמונות שנבחרו לשרת?", "upload_dialog_info": "האם ברצונך לגבות את התמונות שנבחרו לשרת?",
"upload_dialog_title": "העלאת תמונה", "upload_dialog_title": "העלאת תמונה",
"upload_error_with_count": "שגיאת העלאה עבור {count, plural, one {נכס אחד} other {# נכסים}}",
"upload_errors": "העלאה הושלמה עם {count, plural, one {שגיאה #} other {# שגיאות}}, רענן את הדף כדי לראות תמונות שהועלו.", "upload_errors": "העלאה הושלמה עם {count, plural, one {שגיאה #} other {# שגיאות}}, רענן את הדף כדי לראות תמונות שהועלו.",
"upload_finished": "העלאה הסתיימה", "upload_finished": "העלאה הסתיימה",
"upload_progress": "נותרו {remaining, number} - טופלו {processed, number}/{total, number}", "upload_progress": "נותרו {remaining, number} - טופלו {processed, number}/{total, number}",
@@ -2168,7 +2336,9 @@
"url": "URL", "url": "URL",
"usage": "שימוש", "usage": "שימוש",
"use_biometric": "השתמש באימות ביומטרי", "use_biometric": "השתמש באימות ביומטרי",
"use_current_connection": "השתמש בחיבור נוכחי", "use_browser_locale": "שימוש באזור השפה של הדפדפן",
"use_browser_locale_description": "עיצוב תאריכים, זמנים, ומספרים בהתבסס על אזור השפה של הדפדפן שלך",
"use_current_connection": "שימוש בחיבור הנוכחי",
"use_custom_date_range": "השתמש בטווח תאריכים מותאם במקום", "use_custom_date_range": "השתמש בטווח תאריכים מותאם במקום",
"user": "משתמש", "user": "משתמש",
"user_has_been_deleted": "משתמש זה נמחק.", "user_has_been_deleted": "משתמש זה נמחק.",
@@ -2189,6 +2359,7 @@
"utilities": "כלים", "utilities": "כלים",
"validate": "לאמת", "validate": "לאמת",
"validate_endpoint_error": "נא להזין כתובת URL תקנית", "validate_endpoint_error": "נא להזין כתובת URL תקנית",
"validation_error": "שגיאת תיקוף",
"variables": "משתנים", "variables": "משתנים",
"version": "גרסה", "version": "גרסה",
"version_announcement_closing": "החבר שלך, אלכס", "version_announcement_closing": "החבר שלך, אלכס",
@@ -2200,6 +2371,7 @@
"video_hover_setting_description": "הפעל תצוגת סרטון מקדימה כאשר העכבר מרחף מעל פריט. אפילו כשהגדרה זו מושבתת, ניתן להתחיל את הניגון על ידי ריחוף מעל סמל ההפעלה.", "video_hover_setting_description": "הפעל תצוגת סרטון מקדימה כאשר העכבר מרחף מעל פריט. אפילו כשהגדרה זו מושבתת, ניתן להתחיל את הניגון על ידי ריחוף מעל סמל ההפעלה.",
"videos": "סרטונים", "videos": "סרטונים",
"videos_count": "{count, plural, one {סרטון #} other {# סרטונים}}", "videos_count": "{count, plural, one {סרטון #} other {# סרטונים}}",
"videos_only": "רק סרטונים",
"view": "הצג", "view": "הצג",
"view_album": "הצג אלבום", "view_album": "הצג אלבום",
"view_all": "הצג הכל", "view_all": "הצג הכל",
@@ -2220,6 +2392,8 @@
"viewer_stack_use_as_main_asset": "השתמש כתמונה ראשית", "viewer_stack_use_as_main_asset": "השתמש כתמונה ראשית",
"viewer_unstack": "ביטול ערימה", "viewer_unstack": "ביטול ערימה",
"visibility_changed": "הנראות השתנתה עבור {count, plural, one {אדם #} other {# אנשים}}", "visibility_changed": "הנראות השתנתה עבור {count, plural, one {אדם #} other {# אנשים}}",
"visual": "חזותי",
"visual_builder": "בונה חזותי",
"waiting": "ממתין", "waiting": "ממתין",
"waiting_count": "ממתין: {count}", "waiting_count": "ממתין: {count}",
"warning": "אזהרה", "warning": "אזהרה",
@@ -2228,12 +2402,26 @@
"welcome_to_immich": "ברוכים הבאים אל immich", "welcome_to_immich": "ברוכים הבאים אל immich",
"width": "רוחב", "width": "רוחב",
"wifi_name": "שם הרשת האלחוטית", "wifi_name": "שם הרשת האלחוטית",
"workflow_delete_prompt": "האם ברצונך למחוק את זרימת העבודה הזו?",
"workflow_deleted": "זרימת העבודה נמחקה",
"workflow_description": "תיאור זרימת העבודה",
"workflow_info": "מידע על זרימת העבודה",
"workflow_json": "JSON של זרימת העבודה",
"workflow_json_help": "עריכת תצורת זרימת העבודה בפורמט JSON. השינויים יסתנכרנו עם הבונה החזותי.",
"workflow_name": "שם זרימת העבודה",
"workflow_navigation_prompt": "האם ברצונך לעזוב מבלי לשמור את השינויים שלך?",
"workflow_summary": "סיכום זרימת העבודה",
"workflow_update_success": "זרימת העבודה עודכנה בהצלחה",
"workflow_updated": "זרימת העבודה עודכנה",
"workflows": "זרימות עבודה",
"workflows_help_text": "זרימות עבודה מאטמטות פעולות על הנכסים שלך בהתבסס על טריגרים ומסננים",
"wrong_pin_code": "קוד PIN שגוי", "wrong_pin_code": "קוד PIN שגוי",
"year": "שנה", "year": "שנה",
"years_ago": "לפני {years, plural, one {שנה #} other {# שנים}}", "years_ago": "לפני {years, plural, one {שנה #} other {# שנים}}",
"yes": "כן", "yes": "כן",
"you_dont_have_any_shared_links": "אין לך קישורים משותפים", "you_dont_have_any_shared_links": "אין לך קישורים משותפים",
"your_wifi_name": "שם אינטרנט אלחוטי שלך", "your_wifi_name": "שם אינטרנט אלחוטי שלך",
"zero_to_clear_rating": "יש ללחוץ על 0 כדי לנקות את דירוג התמונה",
"zoom_image": "זום לתמונה", "zoom_image": "זום לתמונה",
"zoom_to_bounds": "התמקד באזור" "zoom_to_bounds": "התמקד באזור"
} }
+158 -20
View File
@@ -311,7 +311,7 @@
"search_jobs": "नौकरी खोजें…", "search_jobs": "नौकरी खोजें…",
"send_welcome_email": "स्वागत ईमेल भेजें", "send_welcome_email": "स्वागत ईमेल भेजें",
"server_external_domain_settings": "बाहरी डोमेन", "server_external_domain_settings": "बाहरी डोमेन",
"server_external_domain_settings_description": "सार्वजनिक साझा लिंक के लिए डोमेन, जिसमें http(s):// शामिल है", "server_external_domain_settings_description": "बाहरी लिंक के लिए डोमेन",
"server_public_users": "सार्वजनिक उपयोगकर्ता", "server_public_users": "सार्वजनिक उपयोगकर्ता",
"server_public_users_description": "साझा एल्बम में उपयोगकर्ता जोड़ते समय सभी उपयोगकर्ताओं (नाम और ईमेल) की सूची दिखाई जाती है। यदि यह विकल्प अक्षम किया गया है, तो उपयोगकर्ता सूची केवल व्यवस्थापक (एडमिन) उपयोगकर्ताओं के लिए उपलब्ध होगी।", "server_public_users_description": "साझा एल्बम में उपयोगकर्ता जोड़ते समय सभी उपयोगकर्ताओं (नाम और ईमेल) की सूची दिखाई जाती है। यदि यह विकल्प अक्षम किया गया है, तो उपयोगकर्ता सूची केवल व्यवस्थापक (एडमिन) उपयोगकर्ताओं के लिए उपलब्ध होगी।",
"server_settings": "सर्वर सेटिंग्स", "server_settings": "सर्वर सेटिंग्स",
@@ -472,7 +472,7 @@
"advanced_settings_troubleshooting_title": "समस्या निवारण", "advanced_settings_troubleshooting_title": "समस्या निवारण",
"age_months": "आयु {months, plural, one {# month} other {# months}}", "age_months": "आयु {months, plural, one {# month} other {# months}}",
"age_year_months": "आयु 1 वर्ष, {months, plural, one {# month} other {# months}}", "age_year_months": "आयु 1 वर्ष, {months, plural, one {# month} other {# months}}",
"age_years": "{years, plural, other {Age #}}", "age_years": "{years, plural, other {आयु # वर्ष}}",
"album": "एल्बम", "album": "एल्बम",
"album_added": "एल्बम डाला गया", "album_added": "एल्बम डाला गया",
"album_added_notification_setting_description": "जब आपको किसी साझा एल्बम में जोड़ा जाए तो एक ईमेल सूचना प्राप्त करें", "album_added_notification_setting_description": "जब आपको किसी साझा एल्बम में जोड़ा जाए तो एक ईमेल सूचना प्राप्त करें",
@@ -595,7 +595,7 @@
"assets_count": "{count, plural, one {# आइटम} other {# आइटम्स}}", "assets_count": "{count, plural, one {# आइटम} other {# आइटम्स}}",
"assets_deleted_permanently": "{count} संपत्ति(याँ) स्थायी रूप से हटा दी गईं", "assets_deleted_permanently": "{count} संपत्ति(याँ) स्थायी रूप से हटा दी गईं",
"assets_deleted_permanently_from_server": "{count} संपत्ति(याँ) इमिच सर्वर से स्थायी रूप से हटा दी गईं", "assets_deleted_permanently_from_server": "{count} संपत्ति(याँ) इमिच सर्वर से स्थायी रूप से हटा दी गईं",
"assets_downloaded_failed": "{count, plural, one {Downloaded # file - {error} file failed} other {Downloaded # files - {error} files failed}}", "assets_downloaded_failed": "{count, plural, one {# फ़ाइल डाउनलोड हुई - {error} फ़ाइल डाउनलोड नहीं हो सकी} other {# फ़ाइलें डाउनलोड हुईं - {error} फ़ाइलें डाउनलोड नहीं हो सकीं}}",
"assets_downloaded_successfully": "{count, plural, one {# फ़ाइल सफलतापूर्वक डाउनलोड की गई} other {# फ़ाइलें सफलतापूर्वक डाउनलोड की गईं}}", "assets_downloaded_successfully": "{count, plural, one {# फ़ाइल सफलतापूर्वक डाउनलोड की गई} other {# फ़ाइलें सफलतापूर्वक डाउनलोड की गईं}}",
"assets_moved_to_trash_count": "{count, plural, one {# asset} other {# assets}} को ट्रैश में ले जाया गया", "assets_moved_to_trash_count": "{count, plural, one {# asset} other {# assets}} को ट्रैश में ले जाया गया",
"assets_permanently_deleted_count": "स्थायी रूप से हटा दिया गया {count, plural, one {# asset} other {# assets}}", "assets_permanently_deleted_count": "स्थायी रूप से हटा दिया गया {count, plural, one {# asset} other {# assets}}",
@@ -788,12 +788,17 @@
"client_cert_subtitle": "केवल PKCS12 (.p12, .pfx) प्रारूप का समर्थन करता है। प्रमाणपत्र आयात/निकालना केवल लॉगिन से पहले ही उपलब्ध है", "client_cert_subtitle": "केवल PKCS12 (.p12, .pfx) प्रारूप का समर्थन करता है। प्रमाणपत्र आयात/निकालना केवल लॉगिन से पहले ही उपलब्ध है",
"client_cert_title": "SSL क्लाइंट प्रमाणपत्र [प्रायोगिक]", "client_cert_title": "SSL क्लाइंट प्रमाणपत्र [प्रायोगिक]",
"clockwise": "दक्षिणावर्त", "clockwise": "दक्षिणावर्त",
"close": "बंद करें", "close": "बंद",
"collapse": "गिर जाना", "collapse": "गिर जाना",
"collapse_all": "सभी को संकुचित करें", "collapse_all": "सभी को संकुचित करें",
"color": "रंग", "color": "रंग",
"color_theme": "रंग थीम", "color_theme": "रंग थीम",
"command": "आदेश", "command": "आदेश",
"command_palette_prompt": "जल्दी से पेज, कार्य या कमांड ढूंढें",
"command_palette_to_close": "बंद करें",
"command_palette_to_navigate": "दर्ज करें",
"command_palette_to_select": "चुनें",
"command_palette_to_show_all": "सभी दिखाएँ",
"comment_deleted": "टिप्पणी हटा दी गई", "comment_deleted": "टिप्पणी हटा दी गई",
"comment_options": "टिप्पणी विकल्प", "comment_options": "टिप्पणी विकल्प",
"comments_and_likes": "टिप्पणियाँ और पसंद", "comments_and_likes": "टिप्पणियाँ और पसंद",
@@ -858,6 +863,7 @@
"created_at": "बनाया था", "created_at": "बनाया था",
"creating_linked_albums": "जुड़े हुए एल्बम बनाए जा रहे हैं..।", "creating_linked_albums": "जुड़े हुए एल्बम बनाए जा रहे हैं..।",
"crop": "छाँटें", "crop": "छाँटें",
"crop_aspect_ratio_fixed": "निश्चित",
"crop_aspect_ratio_free": "स्वतंत्र", "crop_aspect_ratio_free": "स्वतंत्र",
"crop_aspect_ratio_original": "मूल अनुपात", "crop_aspect_ratio_original": "मूल अनुपात",
"curated_object_page_title": "चीज़ें", "curated_object_page_title": "चीज़ें",
@@ -868,6 +874,9 @@
"custom_locale": "कस्टम लोकेल", "custom_locale": "कस्टम लोकेल",
"custom_locale_description": "भाषा और क्षेत्र के आधार पर दिनांक और संख्याएँ प्रारूपित करें", "custom_locale_description": "भाषा और क्षेत्र के आधार पर दिनांक और संख्याएँ प्रारूपित करें",
"custom_url": "कस्टम URL", "custom_url": "कस्टम URL",
"cutoff_date_description": "पिछले कितने फ़ोटो रखें…",
"cutoff_day": "{count, plural, one {दिन} other {दिन}}",
"cutoff_year": "{count, plural, one {वर्ष} other {वर्ष}}",
"daily_title_text_date": "ई, एमएमएम डीडी", "daily_title_text_date": "ई, एमएमएम डीडी",
"daily_title_text_date_year": "ई, एमएमएम दिन, वर्ष", "daily_title_text_date_year": "ई, एमएमएम दिन, वर्ष",
"dark": "डार्क", "dark": "डार्क",
@@ -886,8 +895,6 @@
"deduplication_criteria_2": "EXIF डेटा की संख्या", "deduplication_criteria_2": "EXIF डेटा की संख्या",
"deduplication_info": "डुप्लीकेशन हटाने की जानकारी", "deduplication_info": "डुप्लीकेशन हटाने की जानकारी",
"deduplication_info_description": "परिसंपत्तियों का स्वचालित रूप से पूर्व-चयन करने और डुप्लिकेट को थोक में हटाने के लिए, हम निम्न पर ध्यान देते हैं:", "deduplication_info_description": "परिसंपत्तियों का स्वचालित रूप से पूर्व-चयन करने और डुप्लिकेट को थोक में हटाने के लिए, हम निम्न पर ध्यान देते हैं:",
"default_locale": "डिफ़ॉल्ट स्थान",
"default_locale_description": "अपने ब्राउज़र स्थान के आधार पर दिनांक और संख्याएँ प्रारूपित करें",
"delete": "हटाएँ", "delete": "हटाएँ",
"delete_action_confirmation_message": "क्या आप वाकई इस आइटम को हटाना चाहते हैं? यह कार्रवाई आइटम को सर्वर की ट्रैश में ले जाएगी और स्थानीय रूप से हटाने के लिए पुष्टि मांगेगी", "delete_action_confirmation_message": "क्या आप वाकई इस आइटम को हटाना चाहते हैं? यह कार्रवाई आइटम को सर्वर की ट्रैश में ले जाएगी और स्थानीय रूप से हटाने के लिए पुष्टि मांगेगी",
"delete_action_prompt": "{count} हटाए गए", "delete_action_prompt": "{count} हटाए गए",
@@ -923,6 +930,7 @@
"deselect_all": "सबको अचयनित करो", "deselect_all": "सबको अचयनित करो",
"details": "विवरण", "details": "विवरण",
"direction": "दिशा", "direction": "दिशा",
"disable": "निष्क्रिय करें",
"disabled": "अक्षम", "disabled": "अक्षम",
"disallow_edits": "संपादनों की अनुमति न दें", "disallow_edits": "संपादनों की अनुमति न दें",
"discord": "डिसकॉर्ड", "discord": "डिसकॉर्ड",
@@ -948,6 +956,7 @@
"download_include_embedded_motion_videos": "एम्बेडेड वीडियो", "download_include_embedded_motion_videos": "एम्बेडेड वीडियो",
"download_include_embedded_motion_videos_description": "मोशन फ़ोटो में एम्बेड किए गए वीडियो को एक अलग फ़ाइल के रूप में शामिल करें", "download_include_embedded_motion_videos_description": "मोशन फ़ोटो में एम्बेड किए गए वीडियो को एक अलग फ़ाइल के रूप में शामिल करें",
"download_notfound": "डाउनलोड नहीं मिला", "download_notfound": "डाउनलोड नहीं मिला",
"download_original": "मूल डाउनलोड करें",
"download_paused": "डाउनलोड स्थगित", "download_paused": "डाउनलोड स्थगित",
"download_settings": "डाउनलोड करना", "download_settings": "डाउनलोड करना",
"download_settings_description": "संपत्ति डाउनलोड से संबंधित सेटिंग्स प्रबंधित करें", "download_settings_description": "संपत्ति डाउनलोड से संबंधित सेटिंग्स प्रबंधित करें",
@@ -957,6 +966,7 @@
"download_waiting_to_retry": "पुनः प्रयास करने का इंतजार कर रहा है", "download_waiting_to_retry": "पुनः प्रयास करने का इंतजार कर रहा है",
"downloading": "डाउनलोड", "downloading": "डाउनलोड",
"downloading_asset_filename": "संपत्ति {filename} डाउनलोड हो रही है", "downloading_asset_filename": "संपत्ति {filename} डाउनलोड हो रही है",
"downloading_from_icloud": "iCloud से डाउनलोड हो रहा है",
"downloading_media": "मीडिया डाउनलोड हो रहा है", "downloading_media": "मीडिया डाउनलोड हो रहा है",
"drop_files_to_upload": "अपलोड करने के लिए फ़ाइलें कहीं भी छोड़ें", "drop_files_to_upload": "अपलोड करने के लिए फ़ाइलें कहीं भी छोड़ें",
"duplicates": "डुप्लिकेट", "duplicates": "डुप्लिकेट",
@@ -985,9 +995,22 @@
"edit_tag": "टैग बदलें", "edit_tag": "टैग बदलें",
"edit_title": "शीर्षक संपादित करें", "edit_title": "शीर्षक संपादित करें",
"edit_user": "यूजर को संपादित करो", "edit_user": "यूजर को संपादित करो",
"edit_workflow": "वर्कफ़्लो संपादित करें",
"editor": "संपादक", "editor": "संपादक",
"editor_close_without_save_prompt": "परिवर्तन सहेजे नहीं जाएँगे", "editor_close_without_save_prompt": "परिवर्तन सहेजे नहीं जाएँगे",
"editor_close_without_save_title": "संपादक बंद करें?", "editor_close_without_save_title": "संपादक बंद करें?",
"editor_confirm_reset_all_changes": "क्या आप वाकई सभी बदलाव रीसेट करना चाहते हैं?",
"editor_discard_edits_confirm": "संपादन त्यागें",
"editor_discard_edits_prompt": "आपके पास सहेजे न गए संपादन हैं। क्या आप वाकई उन्हें त्यागना चाहते हैं?",
"editor_discard_edits_title": "संपादन त्यागें?",
"editor_edits_applied_error": "संपादन लागू करने में विफल",
"editor_edits_applied_success": "संपादन सफलतापूर्वक लागू किए गए",
"editor_flip_horizontal": "क्षैतिज रूप से पलटें",
"editor_flip_vertical": "ऊपर-नीचे पलटें",
"editor_orientation": "दिशा सेटिंग",
"editor_reset_all_changes": "परिवर्तन रीसेट करें",
"editor_rotate_left": "90° बाईं ओर घुमाएँ",
"editor_rotate_right": "90° दाईं ओर घुमाएँ",
"email": "ईमेल", "email": "ईमेल",
"email_notifications": "ईमेल सूचनाएँ", "email_notifications": "ईमेल सूचनाएँ",
"empty_folder": "यह फ़ोल्डर खाली है", "empty_folder": "यह फ़ोल्डर खाली है",
@@ -1002,15 +1025,18 @@
"enter_wifi_name": "Wi-Fi का नाम लिखें", "enter_wifi_name": "Wi-Fi का नाम लिखें",
"enter_your_pin_code": "अपना पिन कोड डालें", "enter_your_pin_code": "अपना पिन कोड डालें",
"enter_your_pin_code_subtitle": "लॉक फ़ोल्डर खोलने के लिए पिन कोड डालें", "enter_your_pin_code_subtitle": "लॉक फ़ोल्डर खोलने के लिए पिन कोड डालें",
"error": "गलती", "error": "समस्या",
"error_change_sort_album": "एल्बम का क्रम बदलने में असफल रहा", "error_change_sort_album": "एल्बम का क्रम बदलने में असफल रहा",
"error_delete_face": "एसेट से चेहरे को हटाने में त्रुटि हुई", "error_delete_face": "एसेट से चेहरे को हटाने में त्रुटि हुई",
"error_getting_places": "स्थानों को प्राप्त करने में त्रुटि हुई", "error_getting_places": "स्थानों को प्राप्त करने में त्रुटि हुई",
"error_loading_albums": "एल्बम लोड करने में समस्या",
"error_loading_image": "छवि लोड करने में त्रुटि", "error_loading_image": "छवि लोड करने में त्रुटि",
"error_loading_partners": "जोड़ीदार लोड करने में त्रुटि हुई: {error}", "error_loading_partners": "जोड़ीदार लोड करने में त्रुटि हुई: {error}",
"error_retrieving_asset_information": "एसेट की जानकारी प्राप्त करने में समस्या",
"error_saving_image": "त्रुटि: {error}", "error_saving_image": "त्रुटि: {error}",
"error_tag_face_bounding_box": "चेहरे को टैग करने में त्रुटि – बाउंडिंग बॉक्स निर्देशांक प्राप्त नहीं कर सके", "error_tag_face_bounding_box": "चेहरे को टैग करने में त्रुटि – बाउंडिंग बॉक्स निर्देशांक प्राप्त नहीं कर सके",
"error_title": "त्रुटि - कुछ गलत हो गया", "error_title": "त्रुटि - कुछ गलत हो गया",
"error_while_navigating": "एसेट पर जाते समय समस्या",
"errors": { "errors": {
"cannot_navigate_next_asset": "अगली संपत्ति पर नेविगेट नहीं किया जा सकता", "cannot_navigate_next_asset": "अगली संपत्ति पर नेविगेट नहीं किया जा सकता",
"cannot_navigate_previous_asset": "पिछली संपत्ति पर नेविगेट नहीं किया जा सकता", "cannot_navigate_previous_asset": "पिछली संपत्ति पर नेविगेट नहीं किया जा सकता",
@@ -1068,6 +1094,7 @@
"unable_to_complete_oauth_login": "OAuth लॉगिन पूर्ण करने में असमर्थ", "unable_to_complete_oauth_login": "OAuth लॉगिन पूर्ण करने में असमर्थ",
"unable_to_connect": "कनेक्ट करने में असमर्थ", "unable_to_connect": "कनेक्ट करने में असमर्थ",
"unable_to_copy_to_clipboard": "क्लिपबोर्ड पर कॉपी नहीं किया जा सकता, सुनिश्चित करें कि आप https के माध्यम से पेज तक पहुंच रहे हैं", "unable_to_copy_to_clipboard": "क्लिपबोर्ड पर कॉपी नहीं किया जा सकता, सुनिश्चित करें कि आप https के माध्यम से पेज तक पहुंच रहे हैं",
"unable_to_create": "वर्कफ़्लो बनाने में असमर्थ",
"unable_to_create_admin_account": "व्यवस्थापक खाता बनाने में असमर्थ", "unable_to_create_admin_account": "व्यवस्थापक खाता बनाने में असमर्थ",
"unable_to_create_api_key": "नई API कुंजी बनाने में असमर्थ", "unable_to_create_api_key": "नई API कुंजी बनाने में असमर्थ",
"unable_to_create_library": "लाइब्रेरी बनाने में असमर्थ", "unable_to_create_library": "लाइब्रेरी बनाने में असमर्थ",
@@ -1078,6 +1105,7 @@
"unable_to_delete_exclusion_pattern": "बहिष्करण पैटर्न को हटाने में असमर्थ", "unable_to_delete_exclusion_pattern": "बहिष्करण पैटर्न को हटाने में असमर्थ",
"unable_to_delete_shared_link": "साझा लिंक हटाने में असमर्थ", "unable_to_delete_shared_link": "साझा लिंक हटाने में असमर्थ",
"unable_to_delete_user": "उपयोगकर्ता को हटाने में असमर्थ", "unable_to_delete_user": "उपयोगकर्ता को हटाने में असमर्थ",
"unable_to_delete_workflow": "वर्कफ़्लो मिटाने में असमर्थ",
"unable_to_download_files": "फ़ाइलें डाउनलोड करने में असमर्थ", "unable_to_download_files": "फ़ाइलें डाउनलोड करने में असमर्थ",
"unable_to_edit_exclusion_pattern": "बहिष्करण पैटर्न संपादित करने में असमर्थ", "unable_to_edit_exclusion_pattern": "बहिष्करण पैटर्न संपादित करने में असमर्थ",
"unable_to_empty_trash": "कचरा खाली करने में असमर्थ", "unable_to_empty_trash": "कचरा खाली करने में असमर्थ",
@@ -1117,6 +1145,7 @@
"unable_to_scan_library": "लाइब्रेरी स्कैन करने में असमर्थ", "unable_to_scan_library": "लाइब्रेरी स्कैन करने में असमर्थ",
"unable_to_set_feature_photo": "फ़ीचर फ़ोटो सेट करने में असमर्थ", "unable_to_set_feature_photo": "फ़ीचर फ़ोटो सेट करने में असमर्थ",
"unable_to_set_profile_picture": "प्रोफ़ाइल चित्र सेट करने में असमर्थ", "unable_to_set_profile_picture": "प्रोफ़ाइल चित्र सेट करने में असमर्थ",
"unable_to_set_rating": "रेटिंग सेट करने में असमर्थ",
"unable_to_submit_job": "कार्य प्रस्तुत करने में असमर्थ", "unable_to_submit_job": "कार्य प्रस्तुत करने में असमर्थ",
"unable_to_trash_asset": "संपत्ति को ट्रैश करने में असमर्थ", "unable_to_trash_asset": "संपत्ति को ट्रैश करने में असमर्थ",
"unable_to_unlink_account": "खाता अनलिंक करने में असमर्थ", "unable_to_unlink_account": "खाता अनलिंक करने में असमर्थ",
@@ -1128,8 +1157,10 @@
"unable_to_update_settings": "सेटिंग्स अपडेट करने में असमर्थ", "unable_to_update_settings": "सेटिंग्स अपडेट करने में असमर्थ",
"unable_to_update_timeline_display_status": "समयरेखा प्रदर्शन स्थिति अद्यतन करने में असमर्थ", "unable_to_update_timeline_display_status": "समयरेखा प्रदर्शन स्थिति अद्यतन करने में असमर्थ",
"unable_to_update_user": "उपयोगकर्ता को अद्यतन करने में असमर्थ", "unable_to_update_user": "उपयोगकर्ता को अद्यतन करने में असमर्थ",
"unable_to_update_workflow": "वर्कफ़्लो अपडेट करने में असमर्थ",
"unable_to_upload_file": "फाइल अपलोड करने में असमर्थ" "unable_to_upload_file": "फाइल अपलोड करने में असमर्थ"
}, },
"errors_text": "समस्याएँ",
"exclusion_pattern": "बहिष्करण पैटर्न", "exclusion_pattern": "बहिष्करण पैटर्न",
"exif": "एक्सिफ", "exif": "एक्सिफ",
"exif_bottom_sheet_description": "विवरण जोड़ें..।", "exif_bottom_sheet_description": "विवरण जोड़ें..।",
@@ -1140,6 +1171,7 @@
"exif_bottom_sheet_people": "लोग", "exif_bottom_sheet_people": "लोग",
"exif_bottom_sheet_person_add_person": "नाम डालें", "exif_bottom_sheet_person_add_person": "नाम डालें",
"exit_slideshow": "स्लाइड शो से बाहर निकलें", "exit_slideshow": "स्लाइड शो से बाहर निकलें",
"expand": "विस्तार करें",
"expand_all": "सभी का विस्तार", "expand_all": "सभी का विस्तार",
"experimental_settings_new_asset_list_subtitle": "कार्य प्रगति पर है", "experimental_settings_new_asset_list_subtitle": "कार्य प्रगति पर है",
"experimental_settings_new_asset_list_title": "प्रयोगात्मक फोटो ग्रिड सक्षम करें", "experimental_settings_new_asset_list_title": "प्रयोगात्मक फोटो ग्रिड सक्षम करें",
@@ -1161,6 +1193,7 @@
"external_network_sheet_info": "जब पसंदीदा वाई-फाई नेटवर्क पर नहीं होगा, तो ऐप नीचे दिए गए यूआरएल में से पहले के माध्यम से सर्वर से कनेक्ट होगा, ऊपर से नीचे तक शुरू करते हुए", "external_network_sheet_info": "जब पसंदीदा वाई-फाई नेटवर्क पर नहीं होगा, तो ऐप नीचे दिए गए यूआरएल में से पहले के माध्यम से सर्वर से कनेक्ट होगा, ऊपर से नीचे तक शुरू करते हुए",
"face_unassigned": "सौंपे नहीं गए", "face_unassigned": "सौंपे नहीं गए",
"failed": "विफल हुआ", "failed": "विफल हुआ",
"failed_count": "विफल: {count}",
"failed_to_authenticate": "प्रमाणित करने में विफल", "failed_to_authenticate": "प्रमाणित करने में विफल",
"failed_to_load_assets": "एसेट लोड करने में विफल", "failed_to_load_assets": "एसेट लोड करने में विफल",
"failed_to_load_folder": "फोल्डर लोड करने में विफल", "failed_to_load_folder": "फोल्डर लोड करने में विफल",
@@ -1174,12 +1207,17 @@
"features_in_development": "विकास में सुविधाएँ", "features_in_development": "विकास में सुविधाएँ",
"features_setting_description": "ऐप सुविधाओं का प्रबंधन करें", "features_setting_description": "ऐप सुविधाओं का प्रबंधन करें",
"file_name_or_extension": "फ़ाइल का नाम या एक्सटेंशन", "file_name_or_extension": "फ़ाइल का नाम या एक्सटेंशन",
"file_name_text": "फ़ाइल नाम",
"file_name_with_value": "फ़ाइल नाम: {file_name}",
"file_size": "फ़ाइल का साइज़", "file_size": "फ़ाइल का साइज़",
"filename": "फ़ाइल का नाम", "filename": "फ़ाइल का नाम",
"filetype": "फाइल का प्रकार", "filetype": "फाइल का प्रकार",
"filter": "फ़िल्टर", "filter": "फ़िल्टर",
"filter_description": "चुने गए एसेट को फ़िल्टर करने की शर्तें",
"filter_people": "लोगों को फ़िल्टर करें", "filter_people": "लोगों को फ़िल्टर करें",
"filter_places": "स्थानों को फ़िल्टर करें", "filter_places": "स्थानों को फ़िल्टर करें",
"filter_tags": "टैग फ़िल्टर करें",
"filters": "फ़िलटर्स",
"find_them_fast": "खोज के साथ नाम से उन्हें तेजी से ढूंढें", "find_them_fast": "खोज के साथ नाम से उन्हें तेजी से ढूंढें",
"first": "पहला", "first": "पहला",
"fix_incorrect_match": "ग़लत मिलान ठीक करें", "fix_incorrect_match": "ग़लत मिलान ठीक करें",
@@ -1189,12 +1227,16 @@
"folders_feature_description": "फ़ाइल सिस्टम पर फ़ोटो और वीडियो के लिए फ़ोल्डर दृश्य ब्राउज़ करना", "folders_feature_description": "फ़ाइल सिस्टम पर फ़ोटो और वीडियो के लिए फ़ोल्डर दृश्य ब्राउज़ करना",
"forgot_pin_code_question": "अपना पिन भूल गए?", "forgot_pin_code_question": "अपना पिन भूल गए?",
"forward": "आगे", "forward": "आगे",
"free_up_space": "जगह खाली करें",
"free_up_space_description": "जगह खाली करने के लिए बैकअप ली गई फ़ोटो और वीडियो को अपने डिवाइस के ट्रैश में भेजें। सर्वर पर आपकी प्रतियाँ सुरक्षित रहेंगी।",
"free_up_space_settings_subtitle": "डिवाइस स्टोरेज खाली करें",
"full_path": "पूरा पथ: {path}", "full_path": "पूरा पथ: {path}",
"gcast_enabled": "गूगल कास्ट", "gcast_enabled": "गूगल कास्ट",
"gcast_enabled_description": "यह सुविधा काम करने के लिए गूगल से बाह्य संसाधन लोड करती है।", "gcast_enabled_description": "यह सुविधा काम करने के लिए गूगल से बाह्य संसाधन लोड करती है।",
"general": "सामान्य", "general": "सामान्य",
"geolocation_instruction_location": "किसी परिसंपत्ति के स्थान का उपयोग करने के लिए GPS निर्देशांक वाली परिसंपत्ति पर क्लिक करें, या सीधे मानचित्र से कोई स्थान चुनें", "geolocation_instruction_location": "किसी परिसंपत्ति के स्थान का उपयोग करने के लिए GPS निर्देशांक वाली परिसंपत्ति पर क्लिक करें, या सीधे मानचित्र से कोई स्थान चुनें",
"get_help": "मदद लें", "get_help": "मदद लें",
"get_people_error": "लोगों को प्राप्त करने में समस्या",
"get_wifiname_error": "वाई-फ़ाई नाम नहीं मिल सका। सुनिश्चित करें कि आपने आवश्यक अनुमतियाँ दे दी हैं और वाई-फ़ाई नेटवर्क से कनेक्ट हैं", "get_wifiname_error": "वाई-फ़ाई नाम नहीं मिल सका। सुनिश्चित करें कि आपने आवश्यक अनुमतियाँ दे दी हैं और वाई-फ़ाई नेटवर्क से कनेक्ट हैं",
"getting_started": "शुरू करना", "getting_started": "शुरू करना",
"go_back": "वापस जाओ", "go_back": "वापस जाओ",
@@ -1220,12 +1262,14 @@
"header_settings_header_name_input": "हेडर का नाम", "header_settings_header_name_input": "हेडर का नाम",
"header_settings_header_value_input": "हेडर मान", "header_settings_header_value_input": "हेडर मान",
"headers_settings_tile_title": "कस्टम प्रॉक्सी हेडर", "headers_settings_tile_title": "कस्टम प्रॉक्सी हेडर",
"height": "ऊँचाई",
"hi_user": "नमस्ते {name} ({email})", "hi_user": "नमस्ते {name} ({email})",
"hide_all_people": "सभी लोगों को छुपाएं", "hide_all_people": "सभी लोगों को छुपाएं",
"hide_gallery": "गैलरी छिपाएँ", "hide_gallery": "गैलरी छिपाएँ",
"hide_named_person": "व्यक्ति को छिपाएँ {name}", "hide_named_person": "व्यक्ति को छिपाएँ {name}",
"hide_password": "पासवर्ड छिपाएं", "hide_password": "पासवर्ड छिपाएं",
"hide_person": "व्यक्ति छिपाएँ", "hide_person": "व्यक्ति छिपाएँ",
"hide_schema": "स्कीमा छिपाएँ",
"hide_text_recognition": "टेक्स्ट पहचान छिपाएँ", "hide_text_recognition": "टेक्स्ट पहचान छिपाएँ",
"hide_unnamed_people": "अनाम लोगों को छुपाएं", "hide_unnamed_people": "अनाम लोगों को छुपाएं",
"home_page_add_to_album_conflicts": "{added} संपत्तियां एल्बम {album} में जोड़ी गईं. {failed} संपत्तियां पहले से ही एल्बम में हैं।", "home_page_add_to_album_conflicts": "{added} संपत्तियां एल्बम {album} में जोड़ी गईं. {failed} संपत्तियां पहले से ही एल्बम में हैं।",
@@ -1294,13 +1338,22 @@
"ios_debug_info_last_sync_at": "अंतिम सिंक {dateTime}", "ios_debug_info_last_sync_at": "अंतिम सिंक {dateTime}",
"ios_debug_info_no_processes_queued": "कोई पृष्ठभूमि प्रक्रिया कतारबद्ध नहीं है", "ios_debug_info_no_processes_queued": "कोई पृष्ठभूमि प्रक्रिया कतारबद्ध नहीं है",
"ios_debug_info_no_sync_yet": "अभी तक कोई पृष्ठभूमि समन्वयन कार्य नहीं चलाया गया है", "ios_debug_info_no_sync_yet": "अभी तक कोई पृष्ठभूमि समन्वयन कार्य नहीं चलाया गया है",
"ios_debug_info_processes_queued": "{count, plural, one {{count} background process queued} other {{count} background processes queued}}", "ios_debug_info_processes_queued": "{count, plural, one {{count} बैकग्राउंड प्रोसेस कतार में जोड़ा गया} other {{count} बैकग्राउंड प्रोसेस कतार में जोड़े गए}}",
"ios_debug_info_processing_ran_at": "प्रसंस्करण {dateTime} पर चला", "ios_debug_info_processing_ran_at": "प्रसंस्करण {dateTime} पर चला",
"items_count": "{count, plural, one {# item} other {# items}}", "items_count": "{count, plural, one {# आइटम} other {# आइटम}}",
"jobs": "नौकरियां", "jobs": "नौकरियां",
"json_editor": "JSON संपादक",
"json_error": "JSON में समस्या",
"keep": "रखना", "keep": "रखना",
"keep_albums": "एल्बम बनाए रखें",
"keep_albums_count": "रखे जा रहे हैं {count} {count, plural, one {एल्बम} other {एल्बम}}",
"keep_all": "सभी रखना", "keep_all": "सभी रखना",
"keep_description": "जगह खाली करते समय तय करें कि आपके डिवाइस पर क्या रखा जाए।",
"keep_favorites": "पसंदीदा बनाए रखें",
"keep_on_device": "डिवाइस पर बनाए रखें",
"keep_on_device_hint": "इस डिवाइस पर रखने के लिए आइटम चुनें",
"keep_this_delete_others": "इसे रखें, अन्य को हटाएँ", "keep_this_delete_others": "इसे रखें, अन्य को हटाएँ",
"keeping": "रखे जा रहे हैं: {items}",
"kept_this_deleted_others": "इस संपत्ति को रखा गया और {count, plural, one {# asset} other {# assets}} को हटा दिया गया", "kept_this_deleted_others": "इस संपत्ति को रखा गया और {count, plural, one {# asset} other {# assets}} को हटा दिया गया",
"keyboard_shortcuts": "कुंजीपटल अल्प मार्ग", "keyboard_shortcuts": "कुंजीपटल अल्प मार्ग",
"language": "भाषा", "language": "भाषा",
@@ -1310,7 +1363,7 @@
"language_setting_description": "अपनी पसंदीदा भाषा चुनें", "language_setting_description": "अपनी पसंदीदा भाषा चुनें",
"large_files": "बड़ी फ़ाइलें", "large_files": "बड़ी फ़ाइलें",
"last": "अंतिम", "last": "अंतिम",
"last_months": "{count, plural, one {Last month} other {Last # months}}", "last_months": "{count, plural, one {पिछले महीने} other {पिछले # महीने}}",
"last_seen": "अंतिम बार देखा गया", "last_seen": "अंतिम बार देखा गया",
"latest_version": "नवीनतम संस्करण", "latest_version": "नवीनतम संस्करण",
"latitude": "अक्षांश", "latitude": "अक्षांश",
@@ -1342,6 +1395,7 @@
"local": "स्थानीय", "local": "स्थानीय",
"local_asset_cast_failed": "सर्वर पर अपलोड न की गई संपत्ति को कास्ट करने में असमर्थ", "local_asset_cast_failed": "सर्वर पर अपलोड न की गई संपत्ति को कास्ट करने में असमर्थ",
"local_assets": "स्थानीय संपत्तियाँ", "local_assets": "स्थानीय संपत्तियाँ",
"local_id": "लोकल आईडी",
"local_media_summary": "स्थानीय मीडिया सारांश", "local_media_summary": "स्थानीय मीडिया सारांश",
"local_network": "स्थानीय नेटवर्क", "local_network": "स्थानीय नेटवर्क",
"local_network_sheet_info": "निर्दिष्ट वाई-फाई नेटवर्क का उपयोग करते समय ऐप इस URL के माध्यम से सर्वर से कनेक्ट होगा", "local_network_sheet_info": "निर्दिष्ट वाई-फाई नेटवर्क का उपयोग करते समय ऐप इस URL के माध्यम से सर्वर से कनेक्ट होगा",
@@ -1393,10 +1447,28 @@
"loop_videos_description": "विवरण व्यूअर में किसी वीडियो को स्वचालित रूप से लूप करने में सक्षम करें।", "loop_videos_description": "विवरण व्यूअर में किसी वीडियो को स्वचालित रूप से लूप करने में सक्षम करें।",
"main_branch_warning": "आप विकास संस्करण का उपयोग कर रहे हैं; हम दृढ़ता से रिलीज़ संस्करण का उपयोग करने की अनुशंसा करते हैं!", "main_branch_warning": "आप विकास संस्करण का उपयोग कर रहे हैं; हम दृढ़ता से रिलीज़ संस्करण का उपयोग करने की अनुशंसा करते हैं!",
"main_menu": "मेनू चलाएँ", "main_menu": "मेनू चलाएँ",
"maintenance_action_restore": "डेटाबेस पुनर्स्थापित किया जा रहा है",
"maintenance_description": "Immich को <link>मेंटेनेंस मोड</link> में डाल दिया गया है।", "maintenance_description": "Immich को <link>मेंटेनेंस मोड</link> में डाल दिया गया है।",
"maintenance_end": "रखरखाव मोड समाप्त करें", "maintenance_end": "रखरखाव मोड समाप्त करें",
"maintenance_end_error": "मेंटेनेंस मोड खत्म नहीं हो सका।", "maintenance_end_error": "मेंटेनेंस मोड खत्म नहीं हो सका।",
"maintenance_logged_in_as": "अभी {user} के तौर पर लॉग इन हैं", "maintenance_logged_in_as": "अभी {user} के तौर पर लॉग इन हैं",
"maintenance_restore_from_backup": "बैकअप से पुनर्स्थापित करें",
"maintenance_restore_library": "अपनी लाइब्रेरी पुनर्स्थापित करें",
"maintenance_restore_library_confirm": "यदि यह सही लगता है, तो बैकअप पुनर्स्थापित करना जारी रखें!",
"maintenance_restore_library_description": "डेटाबेस पुनर्स्थापित किया जा रहा है",
"maintenance_restore_library_folder_has_files": "{folder} में {count} फ़ोल्डर हैं",
"maintenance_restore_library_folder_no_files": "{folder} में फ़ाइलें मौजूद नहीं हैं!",
"maintenance_restore_library_folder_pass": "पढ़ने और लिखने योग्य",
"maintenance_restore_library_folder_read_fail": "पढ़ने योग्य नहीं",
"maintenance_restore_library_folder_write_fail": "लिखने योग्य नहीं",
"maintenance_restore_library_hint_missing_files": "संभव है कि कुछ महत्वपूर्ण फ़ाइलें मौजूद नहीं हैं",
"maintenance_restore_library_hint_regenerate_later": "आप इन्हें बाद में सेटिंग्स में दोबारा बना सकते हैं",
"maintenance_restore_library_hint_storage_template_missing_files": "स्टोरेज टेम्पलेट का उपयोग कर रहे हैं? संभव है कि कुछ फ़ाइलें मौजूद नहीं हैं",
"maintenance_restore_library_loading": "इंटीग्रिटी जाँच और हीयूरिस्टिक्स लोड हो रहे हैं…",
"maintenance_task_backup": "मौजूदा डेटाबेस का बैकअप बनाया जा रहा है…",
"maintenance_task_migrations": "डेटाबेस माइग्रेशन चल रहे हैं…",
"maintenance_task_restore": "चुने गए बैकअप को पुनर्स्थापित किया जा रहा है…",
"maintenance_task_rollback": "पुनर्स्थापना विफल हुई, पुनर्स्थापना बिंदु पर वापस लौट रहे हैं…",
"maintenance_title": "अस्थाई रूप से अनुपलब्ध", "maintenance_title": "अस्थाई रूप से अनुपलब्ध",
"make": "बनाना", "make": "बनाना",
"manage_geolocation": "स्थान प्रबंधित करें", "manage_geolocation": "स्थान प्रबंधित करें",
@@ -1412,7 +1484,7 @@
"manage_your_devices": "अपने लॉग-इन डिवाइस प्रबंधित करें", "manage_your_devices": "अपने लॉग-इन डिवाइस प्रबंधित करें",
"manage_your_oauth_connection": "अपना OAuth कनेक्शन प्रबंधित करें", "manage_your_oauth_connection": "अपना OAuth कनेक्शन प्रबंधित करें",
"map": "नक्शा", "map": "नक्शा",
"map_assets_in_bounds": "{count, plural, =0 {No photos in this area} one {# photo} other {# photos}}", "map_assets_in_bounds": "{count, plural, =0 {यहाँ कोई फ़ोटो नहीं है} one {# फ़ोटो} other {# फ़ोटो}}",
"map_cannot_get_user_location": "उपयोगकर्ता का स्थान प्राप्त नहीं किया जा सका", "map_cannot_get_user_location": "उपयोगकर्ता का स्थान प्राप्त नहीं किया जा सका",
"map_location_dialog_yes": "हाँ", "map_location_dialog_yes": "हाँ",
"map_location_picker_page_use_location": "इस स्थान का उपयोग करें", "map_location_picker_page_use_location": "इस स्थान का उपयोग करें",
@@ -1458,6 +1530,8 @@
"minimize": "छोटा करना", "minimize": "छोटा करना",
"minute": "मिनट", "minute": "मिनट",
"minutes": "मिनट", "minutes": "मिनट",
"mirror_horizontal": "क्षैतिज",
"mirror_vertical": "ऊर्ध्वाधर",
"missing": "गुम", "missing": "गुम",
"mobile_app": "मोबाइल एप्लिकेशन", "mobile_app": "मोबाइल एप्लिकेशन",
"mobile_app_download_onboarding_note": "निम्नलिखित विकल्पों का उपयोग करके साथी मोबाइल ऐप डाउनलोड करें", "mobile_app_download_onboarding_note": "निम्नलिखित विकल्पों का उपयोग करके साथी मोबाइल ऐप डाउनलोड करें",
@@ -1466,11 +1540,14 @@
"monthly_title_text_date_format": "एमएमएमएम वाई", "monthly_title_text_date_format": "एमएमएमएम वाई",
"more": "अधिक", "more": "अधिक",
"move": "स्थान परिवर्तन", "move": "स्थान परिवर्तन",
"move_down": "नीचे ले जाएँ",
"move_off_locked_folder": "लॉक किए गए फ़ोल्डर से बाहर ले जाएं", "move_off_locked_folder": "लॉक किए गए फ़ोल्डर से बाहर ले जाएं",
"move_to": "करने के लिए कदम", "move_to": "करने के लिए कदम",
"move_to_device_trash": "डिवाइस के ट्रैश में ले जाएँ",
"move_to_lock_folder_action_prompt": "{count} लॉक किए गए फ़ोल्डर में जोड़ा गया", "move_to_lock_folder_action_prompt": "{count} लॉक किए गए फ़ोल्डर में जोड़ा गया",
"move_to_locked_folder": "लॉक किए गए फ़ोल्डर में ले जाएं", "move_to_locked_folder": "लॉक किए गए फ़ोल्डर में ले जाएं",
"move_to_locked_folder_confirmation": "ये फ़ोटो और वीडियो सभी एल्बमों से हटा दिए जाएँगे और केवल लॉक किए गए फ़ोल्डर से ही देखे जा सकेंगे", "move_to_locked_folder_confirmation": "ये फ़ोटो और वीडियो सभी एल्बमों से हटा दिए जाएँगे और केवल लॉक किए गए फ़ोल्डर से ही देखे जा सकेंगे",
"move_up": "ऊपर ले जाएँ",
"moved_to_archive": "{count, plural, one {# asset} other {# assets}} को संग्रह में ले जाया गया", "moved_to_archive": "{count, plural, one {# asset} other {# assets}} को संग्रह में ले जाया गया",
"moved_to_library": "{count, plural, one {# asset} other {# assets}} को लाइब्रेरी में ले जाया गया", "moved_to_library": "{count, plural, one {# asset} other {# assets}} को लाइब्रेरी में ले जाया गया",
"moved_to_trash": "कूड़ेदान में ले जाया गया", "moved_to_trash": "कूड़ेदान में ले जाया गया",
@@ -1480,6 +1557,7 @@
"my_albums": "मेरे एल्बम", "my_albums": "मेरे एल्बम",
"name": "नाम", "name": "नाम",
"name_or_nickname": "नाम या उपनाम", "name_or_nickname": "नाम या उपनाम",
"name_required": "नाम आवश्यक है",
"navigate": "नेविगेट", "navigate": "नेविगेट",
"navigate_to_time": "समय पर नेविगेट करें", "navigate_to_time": "समय पर नेविगेट करें",
"network_requirement_photos_upload": "फ़ोटो का बैकअप लेने के लिए सेलुलर डेटा का उपयोग करें", "network_requirement_photos_upload": "फ़ोटो का बैकअप लेने के लिए सेलुलर डेटा का उपयोग करें",
@@ -1504,6 +1582,8 @@
"next": "अगला", "next": "अगला",
"next_memory": "अगली स्मृति", "next_memory": "अगली स्मृति",
"no": "नहीं", "no": "नहीं",
"no_actions_added": "अभी तक कोई कार्रवाई जोड़ी नहीं गई है",
"no_albums_found": "कोई एल्बम नहीं मिला",
"no_albums_message": "अपनी फ़ोटो और वीडियो को व्यवस्थित करने के लिए एक एल्बम बनाएं", "no_albums_message": "अपनी फ़ोटो और वीडियो को व्यवस्थित करने के लिए एक एल्बम बनाएं",
"no_albums_with_name_yet": "ऐसा लगता है कि आपके पास अभी तक इस नाम का कोई एल्बम नहीं है।", "no_albums_with_name_yet": "ऐसा लगता है कि आपके पास अभी तक इस नाम का कोई एल्बम नहीं है।",
"no_albums_yet": "ऐसा लगता है कि आपके पास अभी तक कोई एल्बम नहीं है।", "no_albums_yet": "ऐसा लगता है कि आपके पास अभी तक कोई एल्बम नहीं है।",
@@ -1513,11 +1593,13 @@
"no_cast_devices_found": "कोई कास्ट डिवाइस नहीं मिला", "no_cast_devices_found": "कोई कास्ट डिवाइस नहीं मिला",
"no_checksum_local": "कोई चेकसम उपलब्ध नहीं है - स्थानीय संपत्तियां प्राप्त नहीं की जा सकतीं", "no_checksum_local": "कोई चेकसम उपलब्ध नहीं है - स्थानीय संपत्तियां प्राप्त नहीं की जा सकतीं",
"no_checksum_remote": "कोई चेकसम उपलब्ध नहीं है - दूरस्थ संपत्ति प्राप्त नहीं की जा सकती", "no_checksum_remote": "कोई चेकसम उपलब्ध नहीं है - दूरस्थ संपत्ति प्राप्त नहीं की जा सकती",
"no_configuration_needed": "किसी कॉन्फ़िगरेशन की आवश्यकता नहीं है",
"no_devices": "कोई अधिकृत उपकरण नहीं", "no_devices": "कोई अधिकृत उपकरण नहीं",
"no_duplicates_found": "कोई नकलची नहीं मिला।", "no_duplicates_found": "कोई नकलची नहीं मिला।",
"no_exif_info_available": "कोई एक्सिफ़ जानकारी उपलब्ध नहीं है", "no_exif_info_available": "कोई एक्सिफ़ जानकारी उपलब्ध नहीं है",
"no_explore_results_message": "अपने संग्रह का पता लगाने के लिए और फ़ोटो अपलोड करें।", "no_explore_results_message": "अपने संग्रह का पता लगाने के लिए और फ़ोटो अपलोड करें।",
"no_favorites_message": "अपनी सर्वश्रेष्ठ तस्वीरें और वीडियो तुरंत ढूंढने के लिए पसंदीदा जोड़ें", "no_favorites_message": "अपनी सर्वश्रेष्ठ तस्वीरें और वीडियो तुरंत ढूंढने के लिए पसंदीदा जोड़ें",
"no_filters_added": "अभी तक कोई फ़िल्टर जोड़ा नहीं गया है",
"no_libraries_message": "अपनी फ़ोटो और वीडियो देखने के लिए एक बाहरी लाइब्रेरी बनाएं", "no_libraries_message": "अपनी फ़ोटो और वीडियो देखने के लिए एक बाहरी लाइब्रेरी बनाएं",
"no_local_assets_found": "इस चेकसम के साथ कोई स्थानीय संपत्ति नहीं मिली", "no_local_assets_found": "इस चेकसम के साथ कोई स्थानीय संपत्ति नहीं मिली",
"no_location_set": "कोई स्थान निर्धारित नहीं", "no_location_set": "कोई स्थान निर्धारित नहीं",
@@ -1531,6 +1613,7 @@
"no_results_description": "कोई पर्यायवाची या अधिक सामान्य कीवर्ड आज़माएँ", "no_results_description": "कोई पर्यायवाची या अधिक सामान्य कीवर्ड आज़माएँ",
"no_shared_albums_message": "अपने नेटवर्क में लोगों के साथ फ़ोटो और वीडियो साझा करने के लिए एक एल्बम बनाएं", "no_shared_albums_message": "अपने नेटवर्क में लोगों के साथ फ़ोटो और वीडियो साझा करने के लिए एक एल्बम बनाएं",
"no_uploads_in_progress": "कोई अपलोड प्रगति पर नहीं है", "no_uploads_in_progress": "कोई अपलोड प्रगति पर नहीं है",
"none": "कोई नहीं",
"not_allowed": "अनुमति नहीं", "not_allowed": "अनुमति नहीं",
"not_available": "लागू नहीं", "not_available": "लागू नहीं",
"not_in_any_album": "किसी एलबम में नहीं", "not_in_any_album": "किसी एलबम में नहीं",
@@ -1564,6 +1647,7 @@
"online": "ऑनलाइन", "online": "ऑनलाइन",
"only_favorites": "केवल पसंदीदा", "only_favorites": "केवल पसंदीदा",
"open": "खुला", "open": "खुला",
"open_calendar": "कैलेंडर खोलें",
"open_in_map_view": "मानचित्र दृश्य में खोलें", "open_in_map_view": "मानचित्र दृश्य में खोलें",
"open_in_openstreetmap": "OpenStreetMap में खोलें", "open_in_openstreetmap": "OpenStreetMap में खोलें",
"open_the_search_filters": "खोज फ़िल्टर खोलें", "open_the_search_filters": "खोज फ़िल्टर खोलें",
@@ -1579,6 +1663,7 @@
"other_variables": "अन्य चर", "other_variables": "अन्य चर",
"owned": "स्वामित्व", "owned": "स्वामित्व",
"owner": "मालिक", "owner": "मालिक",
"page": "पेज",
"partner": "साथी", "partner": "साथी",
"partner_can_access": "{partner} एक्सेस कर सकते हैं", "partner_can_access": "{partner} एक्सेस कर सकते हैं",
"partner_can_access_assets": "संग्रहीत और हटाए गए को छोड़कर आपके सभी फ़ोटो और वीडियो", "partner_can_access_assets": "संग्रहीत और हटाए गए को छोड़कर आपके सभी फ़ोटो और वीडियो",
@@ -1611,6 +1696,7 @@
"people": "लोग", "people": "लोग",
"people_edits_count": "संपादित {count, plural, one {# person} other {# people}}", "people_edits_count": "संपादित {count, plural, one {# person} other {# people}}",
"people_feature_description": "लोगों द्वारा समूहीकृत फ़ोटो और वीडियो ब्राउज़ करना", "people_feature_description": "लोगों द्वारा समूहीकृत फ़ोटो और वीडियो ब्राउज़ करना",
"people_selected": "{count, plural, one {# व्यक्ति चुना गया} other {# लोग चुने गए}}",
"people_sidebar_description": "साइडबार में लोगों के लिए एक लिंक प्रदर्शित करें", "people_sidebar_description": "साइडबार में लोगों के लिए एक लिंक प्रदर्शित करें",
"permanent_deletion_warning": "स्थायी विलोपन चेतावनी", "permanent_deletion_warning": "स्थायी विलोपन चेतावनी",
"permanent_deletion_warning_setting_description": "संपत्तियों को स्थायी रूप से हटाते समय एक चेतावनी दिखाएं", "permanent_deletion_warning_setting_description": "संपत्तियों को स्थायी रूप से हटाते समय एक चेतावनी दिखाएं",
@@ -1634,12 +1720,15 @@
"person_age_year_months": "1 वर्ष, {months, plural, one {# month} other {# months}} पुराना", "person_age_year_months": "1 वर्ष, {months, plural, one {# month} other {# months}} पुराना",
"person_age_years": "{years, plural, other {# years}} पुराना", "person_age_years": "{years, plural, other {# years}} पुराना",
"person_birthdate": "{date} को जन्मे", "person_birthdate": "{date} को जन्मे",
"person_hidden": "{name}{hidden, select, true { (hidden)} other {}}", "person_hidden": "{name}{hidden, select, true { (छिपा हुआ)} other {}}",
"person_recognized": "व्यक्ति पहचाना गया",
"person_selected": "व्यक्ति चुना गया",
"photo_shared_all_users": "ऐसा लगता है कि आपने अपनी तस्वीरें सभी उपयोगकर्ताओं के साथ साझा कीं या आपके पास साझा करने के लिए कोई उपयोगकर्ता नहीं है।", "photo_shared_all_users": "ऐसा लगता है कि आपने अपनी तस्वीरें सभी उपयोगकर्ताओं के साथ साझा कीं या आपके पास साझा करने के लिए कोई उपयोगकर्ता नहीं है।",
"photos": "तस्वीरें", "photos": "तस्वीरें",
"photos_and_videos": "तस्वीरें और वीडियो", "photos_and_videos": "तस्वीरें और वीडियो",
"photos_count": "{count, plural, one {{count, number} Photo} other {{count, number} Photos}}", "photos_count": "{count, plural, one {{count, number} फ़ोटो} other {{count, number} फ़ोटो}}",
"photos_from_previous_years": "पिछले वर्षों की तस्वीरें", "photos_from_previous_years": "पिछले वर्षों की तस्वीरें",
"photos_only": "केवल फ़ोटो",
"pick_a_location": "एक स्थान चुनें", "pick_a_location": "एक स्थान चुनें",
"pick_custom_range": "कस्टम रेंज", "pick_custom_range": "कस्टम रेंज",
"pick_date_range": "दिनांक सीमा चुनें", "pick_date_range": "दिनांक सीमा चुनें",
@@ -1649,7 +1738,7 @@
"pin_verification": "पिन कोड सत्यापन", "pin_verification": "पिन कोड सत्यापन",
"place": "जगह", "place": "जगह",
"places": "स्थानों", "places": "स्थानों",
"places_count": "{count, plural, one {{count, number} Place} other {{count, number} Places}}", "places_count": "{count, plural, one {{count, number} स्थान} other {{count, number} स्थान}}",
"play": "खेल", "play": "खेल",
"play_memories": "यादें खेलें", "play_memories": "यादें खेलें",
"play_motion_photo": "मोशन फ़ोटो चलाएं", "play_motion_photo": "मोशन फ़ोटो चलाएं",
@@ -1715,9 +1804,10 @@
"purchase_settings_server_activated": "सर्वर उत्पाद कुंजी व्यवस्थापक द्वारा प्रबंधित की जाती है", "purchase_settings_server_activated": "सर्वर उत्पाद कुंजी व्यवस्थापक द्वारा प्रबंधित की जाती है",
"query_asset_id": "क्वेरी एसेट आईडी", "query_asset_id": "क्वेरी एसेट आईडी",
"queue_status": "कतारबद्ध {count}/{total}", "queue_status": "कतारबद्ध {count}/{total}",
"rate_asset": "एसेट को रेट करें",
"rating": "स्टार रेटिंग", "rating": "स्टार रेटिंग",
"rating_clear": "स्पष्ट रेटिंग", "rating_clear": "स्पष्ट रेटिंग",
"rating_count": "{count, plural, one {# star} other {# stars}}", "rating_count": "{count, plural, one {# स्टार} other {# स्टार}}",
"rating_description": "जानकारी पैनल में EXIF रेटिंग प्रदर्शित करें", "rating_description": "जानकारी पैनल में EXIF रेटिंग प्रदर्शित करें",
"reaction_options": "प्रतिक्रिया विकल्प", "reaction_options": "प्रतिक्रिया विकल्प",
"read_changelog": "चेंजलॉग पढ़ें", "read_changelog": "चेंजलॉग पढ़ें",
@@ -1818,9 +1908,11 @@
"saved_settings": "सहेजी गई सेटिंग्स", "saved_settings": "सहेजी गई सेटिंग्स",
"say_something": "कुछ कहें", "say_something": "कुछ कहें",
"scaffold_body_error_occurred": "त्रुटि हुई", "scaffold_body_error_occurred": "त्रुटि हुई",
"scan": "स्कैन",
"scan_all_libraries": "सभी पुस्तकालयों को स्कैन करें", "scan_all_libraries": "सभी पुस्तकालयों को स्कैन करें",
"scan_library": "स्कैन", "scan_library": "स्कैन",
"scan_settings": "सेटिंग्स स्कैन करें", "scan_settings": "सेटिंग्स स्कैन करें",
"scanning": "स्कैन हो रहा है",
"scanning_for_album": "एल्बम के लिए स्कैन किया जा रहा है..।", "scanning_for_album": "एल्बम के लिए स्कैन किया जा रहा है..।",
"search": "खोज", "search": "खोज",
"search_albums": "एल्बम खोजें", "search_albums": "एल्बम खोजें",
@@ -1850,6 +1942,8 @@
"search_filter_media_type_title": "मीडिया प्रकार चुनें", "search_filter_media_type_title": "मीडिया प्रकार चुनें",
"search_filter_ocr": "OCR द्वारा खोजें", "search_filter_ocr": "OCR द्वारा खोजें",
"search_filter_people_title": "लोगों का चयन करें", "search_filter_people_title": "लोगों का चयन करें",
"search_filter_star_rating": "स्टार रेटिंग",
"search_filter_tags_title": "टैग चुनें",
"search_for": "निम्न को खोजें", "search_for": "निम्न को खोजें",
"search_for_existing_person": "मौजूदा व्यक्ति को खोजें", "search_for_existing_person": "मौजूदा व्यक्ति को खोजें",
"search_no_more_result": "कोई और परिणाम नहीं", "search_no_more_result": "कोई और परिणाम नहीं",
@@ -1884,23 +1978,29 @@
"second": "दूसरा", "second": "दूसरा",
"see_all_people": "सभी लोगों को देखें", "see_all_people": "सभी लोगों को देखें",
"select": "चुनना", "select": "चुनना",
"select_album": "एल्बम चुने",
"select_album_cover": "एल्बम कवर चुनें", "select_album_cover": "एल्बम कवर चुनें",
"select_albums": "अलबुमस चुनें",
"select_all": "सबका चयन करें", "select_all": "सबका चयन करें",
"select_all_duplicates": "सभी डुप्लिकेट का चयन करें", "select_all_duplicates": "सभी डुप्लिकेट का चयन करें",
"select_all_in": "{group} में सभी का चयन करें", "select_all_in": "{group} में सभी का चयन करें",
"select_avatar_color": "अवतार रंग चुनें", "select_avatar_color": "अवतार रंग चुनें",
"select_count": "{count, plural, one {# चुनें} other {# चुनें}}",
"select_cutoff_date": "कटऑफ़ तिथि चुनें",
"select_face": "चेहरा चुनें", "select_face": "चेहरा चुनें",
"select_featured_photo": "चुनिंदा फ़ोटो चुनें", "select_featured_photo": "चुनिंदा फ़ोटो चुनें",
"select_from_computer": "कंप्यूटर से चयन करें", "select_from_computer": "कंप्यूटर से चयन करें",
"select_keep_all": "सभी रखें का चयन करें", "select_keep_all": "सभी रखें का चयन करें",
"select_library_owner": "लाइब्रेरी स्वामी का चयन करें", "select_library_owner": "लाइब्रेरी स्वामी का चयन करें",
"select_new_face": "नया चेहरा चुनें", "select_new_face": "नया चेहरा चुनें",
"select_people": "लोग चुनें",
"select_person": "व्यक्ति चुनें",
"select_person_to_tag": "टैग करने के लिए किसी व्यक्ति का चयन करें", "select_person_to_tag": "टैग करने के लिए किसी व्यक्ति का चयन करें",
"select_photos": "फ़ोटो चुनें", "select_photos": "फ़ोटो चुनें",
"select_trash_all": "ट्रैश ऑल का चयन करें", "select_trash_all": "ट्रैश ऑल का चयन करें",
"select_user_for_sharing_page_err_album": "एल्बम बनाने में विफल", "select_user_for_sharing_page_err_album": "एल्बम बनाने में विफल",
"selected": "चयनित", "selected": "चयनित",
"selected_count": "{count, plural, other {# selected}}", "selected_count": "{count, plural, other {# चयनित}}",
"selected_gps_coordinates": "चयनित GPS निर्देशांक", "selected_gps_coordinates": "चयनित GPS निर्देशांक",
"send_message": "मेसेज भेजें", "send_message": "मेसेज भेजें",
"send_welcome_email": "स्वागत ईमेल भेजें", "send_welcome_email": "स्वागत ईमेल भेजें",
@@ -1986,7 +2086,7 @@
"shared_link_edit_expire_after_option_year": "{count} वर्ष", "shared_link_edit_expire_after_option_year": "{count} वर्ष",
"shared_link_edit_password_hint": "शेयर पासवर्ड दर्ज करें", "shared_link_edit_password_hint": "शेयर पासवर्ड दर्ज करें",
"shared_link_edit_submit_button": "अपडेट लिंक", "shared_link_edit_submit_button": "अपडेट लिंक",
"shared_link_error_server_url_fetch": "सर्वर URL प्राप्त नहीं किया जा सका", "shared_link_error_server_url_fetch": "सर्वर url प्राप्त नहीं किया जा सका",
"shared_link_expires_day": "{count} दिन में इसकी वैधता समाप्त हो जाएगी", "shared_link_expires_day": "{count} दिन में इसकी वैधता समाप्त हो जाएगी",
"shared_link_expires_days": "{count} दिनों में समाप्त हो जाएगा", "shared_link_expires_days": "{count} दिनों में समाप्त हो जाएगा",
"shared_link_expires_hour": "{count} घंटे में समाप्त हो जाएगा", "shared_link_expires_hour": "{count} घंटे में समाप्त हो जाएगा",
@@ -2003,7 +2103,7 @@
"shared_link_password_description": "इस शेयर किए गए लिंक को एक्सेस करने के लिए पासवर्ड ज़रूरी है", "shared_link_password_description": "इस शेयर किए गए लिंक को एक्सेस करने के लिए पासवर्ड ज़रूरी है",
"shared_links": "साझा किए गए लिंक", "shared_links": "साझा किए गए लिंक",
"shared_links_description": "लिंक के साथ फ़ोटो और वीडियो शेयर करें", "shared_links_description": "लिंक के साथ फ़ोटो और वीडियो शेयर करें",
"shared_photos_and_videos_count": "{assetCount, plural, other {# shared photos & videos.}}", "shared_photos_and_videos_count": "{assetCount, plural, other {# साझा फ़ोटो और वीडियो}}",
"shared_with_me": "मेरे साथ साझा किया गया", "shared_with_me": "मेरे साथ साझा किया गया",
"shared_with_partner": "{partner} के साथ शेयर किया गया", "shared_with_partner": "{partner} के साथ शेयर किया गया",
"sharing": "शेयरिंग", "sharing": "शेयरिंग",
@@ -2030,6 +2130,7 @@
"show_password": "पासवर्ड दिखाए", "show_password": "पासवर्ड दिखाए",
"show_person_options": "व्यक्ति विकल्प दिखाएँ", "show_person_options": "व्यक्ति विकल्प दिखाएँ",
"show_progress_bar": "प्रगति पट्टी दिखाएँ", "show_progress_bar": "प्रगति पट्टी दिखाएँ",
"show_schema": "स्कीमा दिखाएँ",
"show_search_options": "खोज विकल्प दिखाएँ", "show_search_options": "खोज विकल्प दिखाएँ",
"show_shared_links": "साझा लिंक दिखाएँ", "show_shared_links": "साझा लिंक दिखाएँ",
"show_slideshow_transition": "स्लाइड शो ट्रांज़िशन दिखाएँ", "show_slideshow_transition": "स्लाइड शो ट्रांज़िशन दिखाएँ",
@@ -2047,6 +2148,8 @@
"skip_to_folders": "फ़ोल्डरों पर जाएं", "skip_to_folders": "फ़ोल्डरों पर जाएं",
"skip_to_tags": "टैग पर जाएं", "skip_to_tags": "टैग पर जाएं",
"slideshow": "स्लाइड शो", "slideshow": "स्लाइड शो",
"slideshow_repeat": "स्लाइड शो दोहराएँ",
"slideshow_repeat_description": "स्लाइड शो समाप्त होने पर शुरुआत से दोबारा चलाएँ",
"slideshow_settings": "स्लाइड शो सेटिंग्स", "slideshow_settings": "स्लाइड शो सेटिंग्स",
"sort_albums_by": "एल्बम को क्रमबद्ध करें..।", "sort_albums_by": "एल्बम को क्रमबद्ध करें..।",
"sort_created": "बनाया गया दिनांक", "sort_created": "बनाया गया दिनांक",
@@ -2086,6 +2189,7 @@
"support": "सहायता", "support": "सहायता",
"support_and_feedback": "समर्थन और प्रतिक्रिया", "support_and_feedback": "समर्थन और प्रतिक्रिया",
"support_third_party_description": "आपका Immich इंस्टॉलेशन किसी थर्ड-पार्टी ने पैकेज किया था। आपको जो दिक्कतें आ रही हैं, वे उस पैकेज की वजह से हो सकती हैं, इसलिए कृपया नीचे दिए गए लिंक का इस्तेमाल करके सबसे पहले उनके साथ अपनी दिक्कतें बताएं।", "support_third_party_description": "आपका Immich इंस्टॉलेशन किसी थर्ड-पार्टी ने पैकेज किया था। आपको जो दिक्कतें आ रही हैं, वे उस पैकेज की वजह से हो सकती हैं, इसलिए कृपया नीचे दिए गए लिंक का इस्तेमाल करके सबसे पहले उनके साथ अपनी दिक्कतें बताएं।",
"supporter": "समर्थक",
"swap_merge_direction": "मर्ज दिशा स्वैप करें", "swap_merge_direction": "मर्ज दिशा स्वैप करें",
"sync": "साथ-साथ करना", "sync": "साथ-साथ करना",
"sync_albums": "एल्बम्स सिंक करें", "sync_albums": "एल्बम्स सिंक करें",
@@ -2123,6 +2227,7 @@
"theme_setting_theme_subtitle": "ऐप की थीम सेटिंग चुनें", "theme_setting_theme_subtitle": "ऐप की थीम सेटिंग चुनें",
"theme_setting_three_stage_loading_subtitle": "थ्री-स्टेज लोडिंग से लोडिंग परफॉर्मेंस बढ़ सकती है लेकिन इससे नेटवर्क लोड काफी बढ़ जाता है", "theme_setting_three_stage_loading_subtitle": "थ्री-स्टेज लोडिंग से लोडिंग परफॉर्मेंस बढ़ सकती है लेकिन इससे नेटवर्क लोड काफी बढ़ जाता है",
"theme_setting_three_stage_loading_title": "तीन-चरण लोडिंग सक्षम करें", "theme_setting_three_stage_loading_title": "तीन-चरण लोडिंग सक्षम करें",
"then": "फिर",
"they_will_be_merged_together": "इन्हें एक साथ मिला दिया जाएगा", "they_will_be_merged_together": "इन्हें एक साथ मिला दिया जाएगा",
"third_party_resources": "तृतीय-पक्ष संसाधन", "third_party_resources": "तृतीय-पक्ष संसाधन",
"time": "समय", "time": "समय",
@@ -2139,6 +2244,7 @@
"to_select": "चयन करने के लिए", "to_select": "चयन करने के लिए",
"to_trash": "कचरा", "to_trash": "कचरा",
"toggle_settings": "सेटिंग्स टॉगल करें", "toggle_settings": "सेटिंग्स टॉगल करें",
"toggle_theme_description": "थीम टॉगल करें",
"total": "कुल", "total": "कुल",
"total_usage": "कुल उपयोग", "total_usage": "कुल उपयोग",
"trash": "कचरा", "trash": "कचरा",
@@ -2156,6 +2262,13 @@
"trash_page_select_assets_btn": "संपत्तियों को चयन करें", "trash_page_select_assets_btn": "संपत्तियों को चयन करें",
"trash_page_title": "कचरा ({count})", "trash_page_title": "कचरा ({count})",
"trashed_items_will_be_permanently_deleted_after": "ट्रैश किए गए आइटम {days, plural, one {# day} other {# days}} के बाद स्थायी रूप से हटा दिए जाएंगे।", "trashed_items_will_be_permanently_deleted_after": "ट्रैश किए गए आइटम {days, plural, one {# day} other {# days}} के बाद स्थायी रूप से हटा दिए जाएंगे।",
"trigger": "ट्रिगर",
"trigger_asset_uploaded": "एसेट अपलोड किया गया",
"trigger_asset_uploaded_description": "जब नया एसेट अपलोड किया जाता है, तब ट्रिगर होता है",
"trigger_description": "वर्कफ़्लो शुरू करने वाली क्रिया",
"trigger_person_recognized": "व्यक्ति पहचाना गया",
"trigger_person_recognized_description": "जब किसी व्यक्ति का पता चलता है, तब ट्रिगर होता है",
"trigger_type": "ट्रिगर प्रकार",
"troubleshoot": "समस्याओं का निवारण", "troubleshoot": "समस्याओं का निवारण",
"type": "प्रकार", "type": "प्रकार",
"unable_to_change_pin_code": "पिन कोड बदलने में असमर्थ", "unable_to_change_pin_code": "पिन कोड बदलने में असमर्थ",
@@ -2163,13 +2276,14 @@
"unable_to_setup_pin_code": "पिन कोड सेट करने में असमर्थ", "unable_to_setup_pin_code": "पिन कोड सेट करने में असमर्थ",
"unarchive": "संग्रह से निकालें", "unarchive": "संग्रह से निकालें",
"unarchive_action_prompt": "{count} आर्काइव से हटा दिया गया", "unarchive_action_prompt": "{count} आर्काइव से हटा दिया गया",
"unarchived_count": "{count, plural, other {Unarchived #}}", "unarchived_count": "{count, plural, other {# आर्काइव से हटाए गए}}",
"undo": "पूर्ववत", "undo": "पूर्ववत",
"unfavorite": "नापसंद करें", "unfavorite": "नापसंद करें",
"unfavorite_action_prompt": "{count} को पसंदीदा से हटा दिया गया", "unfavorite_action_prompt": "{count} को पसंदीदा से हटा दिया गया",
"unhide_person": "व्यक्ति को उजागर करें", "unhide_person": "व्यक्ति को उजागर करें",
"unknown": "अज्ञात", "unknown": "अज्ञात",
"unknown_country": "अज्ञात देश", "unknown_country": "अज्ञात देश",
"unknown_date": "अज्ञात तिथि",
"unknown_year": "अज्ञात वर्ष", "unknown_year": "अज्ञात वर्ष",
"unlimited": "असीमित", "unlimited": "असीमित",
"unlink_motion_video": "मोशन वीडियो को अनलिंक करें", "unlink_motion_video": "मोशन वीडियो को अनलिंक करें",
@@ -2186,7 +2300,9 @@
"unstack": "स्टैक रद्द करें", "unstack": "स्टैक रद्द करें",
"unstack_action_prompt": "{count} अनस्टैक्ड", "unstack_action_prompt": "{count} अनस्टैक्ड",
"unstacked_assets_count": "अन-स्टैक्ड {count, plural, one {# asset} other {# assets}}", "unstacked_assets_count": "अन-स्टैक्ड {count, plural, one {# asset} other {# assets}}",
"unsupported_field_type": "असमर्थित फ़ील्ड प्रकार",
"untagged": "टैग नहीं किए गए", "untagged": "टैग नहीं किए गए",
"untitled_workflow": "बिना शीर्षक का वर्कफ़्लो",
"up_next": "अब अगला", "up_next": "अब अगला",
"update_location_action_prompt": "{count} चुने गए एसेट की लोकेशन अपडेट करें:", "update_location_action_prompt": "{count} चुने गए एसेट की लोकेशन अपडेट करें:",
"updated_at": "अपडेट किया गया", "updated_at": "अपडेट किया गया",
@@ -2196,6 +2312,7 @@
"upload_details": "विवरण अपलोड करें", "upload_details": "विवरण अपलोड करें",
"upload_dialog_info": "क्या आप चुने हुए एसेट का सर्वर पर बैकअप लेना चाहते हैं?", "upload_dialog_info": "क्या आप चुने हुए एसेट का सर्वर पर बैकअप लेना चाहते हैं?",
"upload_dialog_title": "संपत्ति अपलोड करें", "upload_dialog_title": "संपत्ति अपलोड करें",
"upload_error_with_count": "{count, plural, one {# एसेट} other {# एसेट}} अपलोड में समस्या",
"upload_errors": "अपलोड {count, plural, one {# error} other {# errors}} के साथ पूरा हुआ, नए अपलोड एसेट देखने के लिए पेज को रिफ्रेश करें।", "upload_errors": "अपलोड {count, plural, one {# error} other {# errors}} के साथ पूरा हुआ, नए अपलोड एसेट देखने के लिए पेज को रिफ्रेश करें।",
"upload_finished": "अपलोड समाप्त", "upload_finished": "अपलोड समाप्त",
"upload_progress": "शेष {remaining, number} - संसाधित {processed, number}/{total, number}", "upload_progress": "शेष {remaining, number} - संसाधित {processed, number}/{total, number}",
@@ -2231,6 +2348,7 @@
"utilities": "उपयोगिताओं", "utilities": "उपयोगिताओं",
"validate": "मान्य", "validate": "मान्य",
"validate_endpoint_error": "क्रुपया मान्य यूआरएल दर्ज करें", "validate_endpoint_error": "क्रुपया मान्य यूआरएल दर्ज करें",
"validation_error": "मान्यकरण में समस्या",
"variables": "चर", "variables": "चर",
"version": "संस्करण", "version": "संस्करण",
"version_announcement_closing": "आपका मित्र, एलेक्स", "version_announcement_closing": "आपका मित्र, एलेक्स",
@@ -2241,11 +2359,13 @@
"video_hover_setting": "होवर पर वीडियो थंबनेल चलाएं", "video_hover_setting": "होवर पर वीडियो थंबनेल चलाएं",
"video_hover_setting_description": "जब माउस आइटम पर घूम रहा हो तो वीडियो थंबनेल चलाएं।", "video_hover_setting_description": "जब माउस आइटम पर घूम रहा हो तो वीडियो थंबनेल चलाएं।",
"videos": "वीडियो", "videos": "वीडियो",
"videos_count": "{count, plural, one {# Video} other {# Videos}}", "videos_count": "{count, plural, one {# वीडियो} other {# वीडियो}}",
"videos_only": "केवल वीडियो",
"view": "देखना", "view": "देखना",
"view_album": "एल्बम देखें", "view_album": "एल्बम देखें",
"view_all": "सभी को देखें", "view_all": "सभी को देखें",
"view_all_users": "सभी उपयोगकर्ताओं को देखें", "view_all_users": "सभी उपयोगकर्ताओं को देखें",
"view_asset_owners": "एसेट के मालिक देखें",
"view_details": "विवरण देखें", "view_details": "विवरण देखें",
"view_in_timeline": "टाइमलाइन में देखें", "view_in_timeline": "टाइमलाइन में देखें",
"view_link": "लिंक देखें", "view_link": "लिंक देखें",
@@ -2261,18 +2381,36 @@
"viewer_stack_use_as_main_asset": "मुख्य संपत्ति के रूप में उपयोग करें", "viewer_stack_use_as_main_asset": "मुख्य संपत्ति के रूप में उपयोग करें",
"viewer_unstack": "स्टैक रद्द करें", "viewer_unstack": "स्टैक रद्द करें",
"visibility_changed": "{count, plural, one {# person} other {# people}} के लिए विज़िबिलिटी बदली गई", "visibility_changed": "{count, plural, one {# person} other {# people}} के लिए विज़िबिलिटी बदली गई",
"visual": "विज़ूअल",
"visual_builder": "विज़ूअल बिल्डर",
"waiting": "इंतज़ार में", "waiting": "इंतज़ार में",
"waiting_count": "प्रतीक्षा कर रहे हैं: {count}",
"warning": "चेतावनी", "warning": "चेतावनी",
"week": "सप्ताह", "week": "सप्ताह",
"welcome": "स्वागत", "welcome": "स्वागत",
"welcome_to_immich": "Immich में आपका स्वागत है", "welcome_to_immich": "Immich में आपका स्वागत है",
"width": "चौड़ाई",
"wifi_name": "वाई-फाई का नाम", "wifi_name": "वाई-फाई का नाम",
"workflow_delete_prompt": "क्या आप वाकई इस वर्कफ़्लो को मिटाना चाहते हैं?",
"workflow_deleted": "वर्कफ़्लो मिटाया गया",
"workflow_description": "वर्कफ़्लो विवरण",
"workflow_info": "वर्कफ़्लो जानकारी",
"workflow_json": "वर्कफ़्लो JSON",
"workflow_json_help": "JSON फ़ॉर्मेट में वर्कफ़्लो कॉन्फ़िगरेशन संपादित करें। बदलाव विज़ुअल बिल्डर में सिंक हो जाएंगे।",
"workflow_name": "वर्कफ़्लो नाम",
"workflow_navigation_prompt": "क्या आप बिना अपने बदलाव सहेजे यहाँ से बाहर जाना चाहते हैं?",
"workflow_summary": "वर्कफ़्लो सारांश",
"workflow_update_success": "वर्कफ़्लो सफलतापूर्वक अपडेट किया गया",
"workflow_updated": "वर्कफ़्लो अपडेट किया गया",
"workflows": "वर्कफ़्लों",
"workflows_help_text": "वर्कफ़्लो आपके एसेट के ट्रिगरों और फ़िल्टरों के आधार पर क्रियाओं को स्वचालित करते हैं",
"wrong_pin_code": "गलत पिन कोड", "wrong_pin_code": "गलत पिन कोड",
"year": "वर्ष", "year": "वर्ष",
"years_ago": "{years, plural, one {# year} other {# years}} पहले", "years_ago": "{years, plural, one {# year} other {# years}} पहले",
"yes": "हाँ", "yes": "हाँ",
"you_dont_have_any_shared_links": "आपके पास कोई साझा लिंक नहीं है", "you_dont_have_any_shared_links": "आपके पास कोई साझा लिंक नहीं है",
"your_wifi_name": "आपके वाईफाई का नाम", "your_wifi_name": "आपके वाईफाई का नाम",
"zero_to_clear_rating": "एसेट रेटिंग रीसेट करने के लिए 0 दबाएँ",
"zoom_image": "छवि ज़ूम करें", "zoom_image": "छवि ज़ूम करें",
"zoom_to_bounds": "सीमा तक ज़ूम करें" "zoom_to_bounds": "सीमा तक ज़ूम करें"
} }
-2
View File
@@ -833,8 +833,6 @@
"deduplication_criteria_2": "Broj EXIF podataka", "deduplication_criteria_2": "Broj EXIF podataka",
"deduplication_info": "Informacije o uklanjanju duplikata", "deduplication_info": "Informacije o uklanjanju duplikata",
"deduplication_info_description": "Za automatski odabir stavki i masovno uklanjanje duplikata, uzimamo u obzir:", "deduplication_info_description": "Za automatski odabir stavki i masovno uklanjanje duplikata, uzimamo u obzir:",
"default_locale": "Zadana lokalizacija",
"default_locale_description": "Oblikujte datume i brojeve na temelju jezika preglednika",
"delete": "Izbriši", "delete": "Izbriši",
"delete_action_confirmation_message": "Jeste li sigurni da želite izbrisati ovu stavku? Ova radnja će premjestiti stavku u smeće poslužitelja i pitati vas želite li ju izbrisati lokalno", "delete_action_confirmation_message": "Jeste li sigurni da želite izbrisati ovu stavku? Ova radnja će premjestiti stavku u smeće poslužitelja i pitati vas želite li ju izbrisati lokalno",
"delete_action_prompt": "{count} izbrisano", "delete_action_prompt": "{count} izbrisano",
+42 -13
View File
@@ -12,15 +12,15 @@
"activity": "Tevékenység", "activity": "Tevékenység",
"activity_changed": "A tevékenység {enabled, select, true {bekapcsolva} other {kikapcsolva}}", "activity_changed": "A tevékenység {enabled, select, true {bekapcsolva} other {kikapcsolva}}",
"add": "Hozzáadás", "add": "Hozzáadás",
"add_a_description": "Leírás hozzáadása", "add_a_description": "Leírás megadása",
"add_a_location": "Helyszín hozzáadása", "add_a_location": "Helyszín hozzáadása",
"add_a_name": "Név megadása", "add_a_name": "Név megadása",
"add_a_title": "Cím megadása", "add_a_title": "Cím megadása",
"add_action": "Művelet hozzáadása", "add_action": "Művelet hozzáadása",
"add_action_description": "Kattints ide egy végrehajtandó művelet hozzáadásához", "add_action_description": "Kattints ide egy végrehajtandó művelet hozzáadásához",
"add_assets": "Elemek hozzáadása", "add_assets": "Elemek hozzáadása",
"add_birthday": "Születésnap hozzáadása", "add_birthday": "Születésnap megadása",
"add_endpoint": "Végpont megadása", "add_endpoint": "Végpont hozzáadása",
"add_exclusion_pattern": "Kihagyási minta (pattern) hozzáadása", "add_exclusion_pattern": "Kihagyási minta (pattern) hozzáadása",
"add_filter": "Szűrő hozzáadása", "add_filter": "Szűrő hozzáadása",
"add_filter_description": "Kattints ide egy szűrési feltétel hozzáadásához", "add_filter_description": "Kattints ide egy szűrési feltétel hozzáadásához",
@@ -311,7 +311,7 @@
"search_jobs": "Feladatok keresése…", "search_jobs": "Feladatok keresése…",
"send_welcome_email": "Üdvözlő email küldése", "send_welcome_email": "Üdvözlő email küldése",
"server_external_domain_settings": "Külső domain", "server_external_domain_settings": "Külső domain",
"server_external_domain_settings_description": "Nyilvánosan megosztott linkek domainje (http(s)://-sel)", "server_external_domain_settings_description": "Külső linkekhez haszált domain",
"server_public_users": "Nyilvános felhasználók", "server_public_users": "Nyilvános felhasználók",
"server_public_users_description": "Az összes felhasználó (név és email) ki van írva, amikor egy felhasználót adsz hozzá egy megosztott albumhoz. Amikor le van tiltva, a felhasználólista csak adminok számára lesz elérhető.", "server_public_users_description": "Az összes felhasználó (név és email) ki van írva, amikor egy felhasználót adsz hozzá egy megosztott albumhoz. Amikor le van tiltva, a felhasználólista csak adminok számára lesz elérhető.",
"server_settings": "Szerver beállítások", "server_settings": "Szerver beállítások",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Tónusleképezés (tone-mapping)", "transcoding_tone_mapping": "Tónusleképezés (tone-mapping)",
"transcoding_tone_mapping_description": "Megpróbálja megőrizni a HDR videók kinézetét SDR-re való konvertálás során. Minden algoritmus különböző módon tesz kompromisszumot a színek, részletek, és a fényerő megőrzésében. A Hable inkább a részleteket őrzi meg, a Mobius a színeket, a Reinhard pedig a fényerőt.", "transcoding_tone_mapping_description": "Megpróbálja megőrizni a HDR videók kinézetét SDR-re való konvertálás során. Minden algoritmus különböző módon tesz kompromisszumot a színek, részletek, és a fényerő megőrzésében. A Hable inkább a részleteket őrzi meg, a Mobius a színeket, a Reinhard pedig a fényerőt.",
"transcoding_transcode_policy": "Átkódolási szabályzat", "transcoding_transcode_policy": "Átkódolási szabályzat",
"transcoding_transcode_policy_description": "Videó átkódolási szabályzat . HDR videók mindig átkódolásra kerülnek (kivéve, ha az átkódolás ki van kapcsolva).", "transcoding_transcode_policy_description": "Videó átkódolási szabályzat . HDR videók és YUV 4:2:0-tól eltérő pixelformátummal rendelkező videók mindig átkódolásra kerülnek (kivéve, ha az átkódolás ki van kapcsolva).",
"transcoding_two_pass_encoding": "Átkódolás két menetben", "transcoding_two_pass_encoding": "Átkódolás két menetben",
"transcoding_two_pass_encoding_setting_description": "A két menetben átkódolt videók jobb minőségűek lesznek. Ha engedélyezve van a bitráta maximalizálása (amely szükséges a H.264 és a HEVC használatakor), ez a funkció figyelmen kívül hagyja a CRF-et. VP9 használata esetén a CRF használható, ha a bitráta nincs maximalizálva (azaz ki van kapcsolva).", "transcoding_two_pass_encoding_setting_description": "A két menetben átkódolt videók jobb minőségűek lesznek. Ha engedélyezve van a bitráta maximalizálása (amely szükséges a H.264 és a HEVC használatakor), ez a funkció figyelmen kívül hagyja a CRF-et. VP9 használata esetén a CRF használható, ha a bitráta nincs maximalizálva (azaz ki van kapcsolva).",
"transcoding_video_codec": "Videó kodek", "transcoding_video_codec": "Videó kodek",
@@ -782,6 +782,8 @@
"client_cert_import": "Importálás", "client_cert_import": "Importálás",
"client_cert_import_success_msg": "Kliens tanúsítvány importálva", "client_cert_import_success_msg": "Kliens tanúsítvány importálva",
"client_cert_invalid_msg": "Érvénytelen tanúsítvány fájl vagy hibás jelszó", "client_cert_invalid_msg": "Érvénytelen tanúsítvány fájl vagy hibás jelszó",
"client_cert_password_message": "Add meg a tanúsítvány jelszavát",
"client_cert_password_title": "Tanúsítvány jelszó",
"client_cert_remove_msg": "Kliens tanúsítvány eltávolítva", "client_cert_remove_msg": "Kliens tanúsítvány eltávolítva",
"client_cert_subtitle": "Csak a PKCS12 (.p12, .pfx) formátum támogatott. Tanúsítvány importálása/eltávolítása csak a bejelentkezés előtt lehetséges", "client_cert_subtitle": "Csak a PKCS12 (.p12, .pfx) formátum támogatott. Tanúsítvány importálása/eltávolítása csak a bejelentkezés előtt lehetséges",
"client_cert_title": "SSL kliens tanúsítvány [KÍSÉRLETI]", "client_cert_title": "SSL kliens tanúsítvány [KÍSÉRLETI]",
@@ -792,6 +794,11 @@
"color": "Szín", "color": "Szín",
"color_theme": "Színtéma", "color_theme": "Színtéma",
"command": "Parancs", "command": "Parancs",
"command_palette_prompt": "Gyors keresés oldalak, műveletek és parancsok között",
"command_palette_to_close": "bezárás",
"command_palette_to_navigate": "Belépés",
"command_palette_to_select": "kiválaszt",
"command_palette_to_show_all": "összes megjelenítése",
"comment_deleted": "Megjegyzés törölve", "comment_deleted": "Megjegyzés törölve",
"comment_options": "Megjegyzés beállítások", "comment_options": "Megjegyzés beállítások",
"comments_and_likes": "Megjegyzések és reakciók", "comments_and_likes": "Megjegyzések és reakciók",
@@ -865,7 +872,7 @@
"current_server_address": "Jelenlegi szerver cím", "current_server_address": "Jelenlegi szerver cím",
"custom_date": "Egyéni dátum", "custom_date": "Egyéni dátum",
"custom_locale": "Egyéni területi beállítás", "custom_locale": "Egyéni területi beállítás",
"custom_locale_description": "Dátumok és számok formázása a nyelv és terület szerint", "custom_locale_description": "Dátumok, idők és számok formázása a kiválasztott nyelv és a terület szerint",
"custom_url": "Egyéni URL", "custom_url": "Egyéni URL",
"cutoff_date_description": "Fotók megtartása az elmúlt…", "cutoff_date_description": "Fotók megtartása az elmúlt…",
"cutoff_day": "{count, plural, one {nap} other {nap}}", "cutoff_day": "{count, plural, one {nap} other {nap}}",
@@ -888,8 +895,6 @@
"deduplication_criteria_2": "EXIF adatok mennyisége", "deduplication_criteria_2": "EXIF adatok mennyisége",
"deduplication_info": "Deduplikációs infó", "deduplication_info": "Deduplikációs infó",
"deduplication_info_description": "Az automatikus előválogatáshoz és a duplikátumok tömeges eltávolításához a következőket vizsgáljuk:", "deduplication_info_description": "Az automatikus előválogatáshoz és a duplikátumok tömeges eltávolításához a következőket vizsgáljuk:",
"default_locale": "Alapértelmezett területi beállítás",
"default_locale_description": "Dátumok és számok formázása a böngésződ területi beállítása alapján",
"delete": "Törlés", "delete": "Törlés",
"delete_action_confirmation_message": "Biztosan törölni szeretnéd ezt az elemet? Így az elem a szerver lomtárába kerül, és megkérdezi, hogy törölni szeretnéd-e a az eszközön is", "delete_action_confirmation_message": "Biztosan törölni szeretnéd ezt az elemet? Így az elem a szerver lomtárába kerül, és megkérdezi, hogy törölni szeretnéd-e a az eszközön is",
"delete_action_prompt": "{count} törölve", "delete_action_prompt": "{count} törölve",
@@ -995,8 +1000,15 @@
"editor_close_without_save_prompt": "A változtatások nem lesznek elmentve", "editor_close_without_save_prompt": "A változtatások nem lesznek elmentve",
"editor_close_without_save_title": "Szerkesztő bezárása?", "editor_close_without_save_title": "Szerkesztő bezárása?",
"editor_confirm_reset_all_changes": "Biztosan vissza szeretnéd állítani az összes módosítást?", "editor_confirm_reset_all_changes": "Biztosan vissza szeretnéd állítani az összes módosítást?",
"editor_discard_edits_confirm": "Módosítások elvetése",
"editor_discard_edits_prompt": "A módosításokat nem mentetted. Biztos vagy benne, hogy mindet elveted?",
"editor_discard_edits_title": "Elveted a módosításokat?",
"editor_edits_applied_error": "Sikertelen módosítás",
"editor_edits_applied_success": "Sikeres módosítás",
"editor_flip_horizontal": "Vízszintes tükrözés", "editor_flip_horizontal": "Vízszintes tükrözés",
"editor_flip_vertical": "Függőleges tükrözés", "editor_flip_vertical": "Függőleges tükrözés",
"editor_handle_corner": "{corner, select, top_left {Bal fent} top_right {Jobb fent} bottom_left {Bal lent} bottom_right {Jobb lent} other {A}} corner handle",
"editor_handle_edge": "{edge, select, top {Fent} bottom {Lent} left {Bal} right {Jobb} other {An}} edge handle",
"editor_orientation": "Orientáció", "editor_orientation": "Orientáció",
"editor_reset_all_changes": "Módosítások visszaállítása", "editor_reset_all_changes": "Módosítások visszaállítása",
"editor_rotate_left": "Forgatás balra 90°-kal", "editor_rotate_left": "Forgatás balra 90°-kal",
@@ -1062,6 +1074,7 @@
"failed_to_update_notification_status": "Értesítés státusz frissítése sikertelen", "failed_to_update_notification_status": "Értesítés státusz frissítése sikertelen",
"incorrect_email_or_password": "Helytelen email vagy jelszó", "incorrect_email_or_password": "Helytelen email vagy jelszó",
"library_folder_already_exists": "Az import mappa elérési útja már létezik.", "library_folder_already_exists": "Az import mappa elérési útja már létezik.",
"page_not_found": "Oldal nem található",
"paths_validation_failed": "A(z) {paths, plural, one {# elérési útvonal} other {# elérési útvonal}} érvényesítése sikertelen", "paths_validation_failed": "A(z) {paths, plural, one {# elérési útvonal} other {# elérési útvonal}} érvényesítése sikertelen",
"profile_picture_transparent_pixels": "Profilképek nem tartalmazhatnak átlátszó pixeleket. Közelíts rá és/vagy mozgasd a képet.", "profile_picture_transparent_pixels": "Profilképek nem tartalmazhatnak átlátszó pixeleket. Közelíts rá és/vagy mozgasd a képet.",
"quota_higher_than_disk_size": "Az elérhető lemezméretnél nagyobb kvótát állítottál be", "quota_higher_than_disk_size": "Az elérhető lemezméretnél nagyobb kvótát állítottál be",
@@ -1161,6 +1174,7 @@
"exif_bottom_sheet_people": "EMBEREK", "exif_bottom_sheet_people": "EMBEREK",
"exif_bottom_sheet_person_add_person": "Elnevez", "exif_bottom_sheet_person_add_person": "Elnevez",
"exit_slideshow": "Kilépés a diavetítésből", "exit_slideshow": "Kilépés a diavetítésből",
"expand": "Kinyit",
"expand_all": "Összes kinyitása", "expand_all": "Összes kinyitása",
"experimental_settings_new_asset_list_subtitle": "Fejlesztés alatt", "experimental_settings_new_asset_list_subtitle": "Fejlesztés alatt",
"experimental_settings_new_asset_list_title": "Kisérleti képrács engedélyezése", "experimental_settings_new_asset_list_title": "Kisérleti képrács engedélyezése",
@@ -1196,6 +1210,8 @@
"features_in_development": "Folyamatban lévő fejlesztések", "features_in_development": "Folyamatban lévő fejlesztések",
"features_setting_description": "Az alkalmazás jellemzőinek kezelése", "features_setting_description": "Az alkalmazás jellemzőinek kezelése",
"file_name_or_extension": "Fájlnév vagy kiterjesztés", "file_name_or_extension": "Fájlnév vagy kiterjesztés",
"file_name_text": "Fájl neve",
"file_name_with_value": "Fájlnév:{file_name}",
"file_size": "Fájlméret", "file_size": "Fájlméret",
"filename": "Fájlnév", "filename": "Fájlnév",
"filetype": "Fájltípus", "filetype": "Fájltípus",
@@ -1203,6 +1219,7 @@
"filter_description": "Az elemek szűrési feltételei", "filter_description": "Az elemek szűrési feltételei",
"filter_people": "Személyek szűrése", "filter_people": "Személyek szűrése",
"filter_places": "Helyszínek szűrése", "filter_places": "Helyszínek szűrése",
"filter_tags": "címkék szűrése",
"filters": "Szűrők", "filters": "Szűrők",
"find_them_fast": "Név alapján kereséssel gyorsan megtalálhatóak", "find_them_fast": "Név alapján kereséssel gyorsan megtalálhatóak",
"first": "Első", "first": "Első",
@@ -1633,6 +1650,7 @@
"online": "Online (elérhető)", "online": "Online (elérhető)",
"only_favorites": "Csak kedvencek", "only_favorites": "Csak kedvencek",
"open": "Nyitva", "open": "Nyitva",
"open_calendar": "Naptár megnyitása",
"open_in_map_view": "Megnyitás térkép nézetben", "open_in_map_view": "Megnyitás térkép nézetben",
"open_in_openstreetmap": "Megnyitás OpenStreetMap-ben", "open_in_openstreetmap": "Megnyitás OpenStreetMap-ben",
"open_the_search_filters": "Keresési szűrők megnyitása", "open_the_search_filters": "Keresési szűrők megnyitása",
@@ -1770,7 +1788,7 @@
"purchase_individual_description_1": "Egy magánszemélynek", "purchase_individual_description_1": "Egy magánszemélynek",
"purchase_individual_description_2": "Támogató állapot", "purchase_individual_description_2": "Támogató állapot",
"purchase_individual_title": "Magánszemély", "purchase_individual_title": "Magánszemély",
"purchase_input_suggestion": "Van egy termékkulcsod? Add meg a kulcsot alább", "purchase_input_suggestion": "Van már termékkulcsod? Add meg itt",
"purchase_license_subtitle": "Az Immich megvásárlásával támogasd a szolgáltatás folyamatos fejlesztését", "purchase_license_subtitle": "Az Immich megvásárlásával támogasd a szolgáltatás folyamatos fejlesztését",
"purchase_lifetime_description": "Élettartamra szóló vásárlás", "purchase_lifetime_description": "Élettartamra szóló vásárlás",
"purchase_option_title": "VÁSÁRLÁSI LEHETŐSÉGEK", "purchase_option_title": "VÁSÁRLÁSI LEHETŐSÉGEK",
@@ -1792,9 +1810,8 @@
"rate_asset": "Elem értékelése", "rate_asset": "Elem értékelése",
"rating": "Értékelés csillagokkal", "rating": "Értékelés csillagokkal",
"rating_clear": "Értékelés törlése", "rating_clear": "Értékelés törlése",
"rating_count": "{count, plural, one {# csillag} other {# csillag}}", "rating_count": "{count, plural, =0 {Nem értékelt} one {# csillag} other {# csillag}}",
"rating_description": "Exif értékelés megjelenítése az infópanelen", "rating_description": "Exif értékelés megjelenítése az infópanelen",
"rating_set": "Értékelés beállítva: {rating, plural, one {# csillag} other {# csillag}}",
"reaction_options": "Reakció lehetőségek", "reaction_options": "Reakció lehetőségek",
"read_changelog": "Változásnapló elolvasása", "read_changelog": "Változásnapló elolvasása",
"readonly_mode_disabled": "Csak olvasható mód kikapcsolva", "readonly_mode_disabled": "Csak olvasható mód kikapcsolva",
@@ -1866,7 +1883,10 @@
"reset_pin_code_success": "PIN kód sikeresen visszaállítva", "reset_pin_code_success": "PIN kód sikeresen visszaállítva",
"reset_pin_code_with_password": "A PIN kódod mindig visszaállíthatod a jelszavaddal", "reset_pin_code_with_password": "A PIN kódod mindig visszaállíthatod a jelszavaddal",
"reset_sqlite": "SQLite adatbázis visszaállítása", "reset_sqlite": "SQLite adatbázis visszaállítása",
"reset_sqlite_confirmation": "Biztosan vissza szeretnéd állítani az SQLite adatbázist? Az adatok újraszinkronizálásához ki kell jelentkezed, majd újra be kell lépned", "reset_sqlite_clear_app_data": "Adat kiürítés",
"reset_sqlite_confirmation": "Biztos benne, hogy törölni szeretné az alkalmazásadatokat? Ez törli az összes beállítást, és kijelentkezteti önt.",
"reset_sqlite_confirmation_note": "Megjegyzés: A kiürítés után újra kell indítani az alkalmazást.",
"reset_sqlite_done": "Az alkalmazásadatokat töröltük. Indítsd újra Immich-et és jelentkezz be újra.",
"reset_sqlite_success": "SQLite adatbázis sikeresen visszaállítva", "reset_sqlite_success": "SQLite adatbázis sikeresen visszaállítva",
"reset_to_default": "Visszaállítás alapállapotba", "reset_to_default": "Visszaállítás alapállapotba",
"resolution": "Felbontás", "resolution": "Felbontás",
@@ -1894,6 +1914,7 @@
"saved_settings": "Elmentett beállítások", "saved_settings": "Elmentett beállítások",
"say_something": "Szólj hozzá", "say_something": "Szólj hozzá",
"scaffold_body_error_occurred": "Hiba történt", "scaffold_body_error_occurred": "Hiba történt",
"scaffold_body_error_unrecoverable": "Visszafordíthatatlan hiba történt. Kérlek oszd meg a hiba és nyomkövetés üzeneteket Discordon vagy a GitHubon, hogy segíthessünk. Ha szükséges törölheted az alkalmazás adatait alul.",
"scan": "Átfésül", "scan": "Átfésül",
"scan_all_libraries": "Minden képtár átfésülése", "scan_all_libraries": "Minden képtár átfésülése",
"scan_library": "Beolvasás", "scan_library": "Beolvasás",
@@ -1929,6 +1950,7 @@
"search_filter_ocr": "Keresés szövegfelismeréssel (OCR)", "search_filter_ocr": "Keresés szövegfelismeréssel (OCR)",
"search_filter_people_title": "Válassz embereket", "search_filter_people_title": "Válassz embereket",
"search_filter_star_rating": "Értékelés", "search_filter_star_rating": "Értékelés",
"search_filter_tags_title": "Válasszon címkéket",
"search_for": "Keresés", "search_for": "Keresés",
"search_for_existing_person": "Már meglévő személy keresése", "search_for_existing_person": "Már meglévő személy keresése",
"search_no_more_result": "Nincs több találat", "search_no_more_result": "Nincs több találat",
@@ -2008,6 +2030,9 @@
"set_profile_picture": "Profilkép beállítása", "set_profile_picture": "Profilkép beállítása",
"set_slideshow_to_fullscreen": "Diavetítés teljes képernyőre állítása", "set_slideshow_to_fullscreen": "Diavetítés teljes képernyőre állítása",
"set_stack_primary_asset": "Beállítás elsődleges elemként", "set_stack_primary_asset": "Beállítás elsődleges elemként",
"setting_image_navigation_enable_subtitle": "Ha engedélyezett, akkor navigálhat az előző/következő képhez a képernyő bal/jobb széllének érintésével.",
"setting_image_navigation_enable_title": "Koppints a navigációhoz",
"setting_image_navigation_title": "Kép navigáció",
"setting_image_viewer_help": "Az Elem Megjelenítő először a kis bélyegképet tölti be, aztán a közepes méretű előnézetet (ha elérhető), végül az eredetit (ha elérhető).", "setting_image_viewer_help": "Az Elem Megjelenítő először a kis bélyegképet tölti be, aztán a közepes méretű előnézetet (ha elérhető), végül az eredetit (ha elérhető).",
"setting_image_viewer_original_subtitle": "Engedélyezi az eredeti teljes felbontású kép betöltését (nagy!). Kikapcsolva csökkenti az adathasználatot (a neten és az eszköz gyorsítótárán is).", "setting_image_viewer_original_subtitle": "Engedélyezi az eredeti teljes felbontású kép betöltését (nagy!). Kikapcsolva csökkenti az adathasználatot (a neten és az eszköz gyorsítótárán is).",
"setting_image_viewer_original_title": "Eredeti kép betöltése", "setting_image_viewer_original_title": "Eredeti kép betöltése",
@@ -2174,6 +2199,7 @@
"support": "Támogatás", "support": "Támogatás",
"support_and_feedback": "Támogatás és visszajelzés", "support_and_feedback": "Támogatás és visszajelzés",
"support_third_party_description": "Az Immich telepítésedet egy harmadik fél csomagolta. Mivel elképzelhető, hogy az esetlegesen felmerülő problémákat ez a csomag okozza, ezért kérjük, először velük közöld a problémákat az alábbi linkek segítségével.", "support_third_party_description": "Az Immich telepítésedet egy harmadik fél csomagolta. Mivel elképzelhető, hogy az esetlegesen felmerülő problémákat ez a csomag okozza, ezért kérjük, először velük közöld a problémákat az alábbi linkek segítségével.",
"supporter": "Támogató",
"swap_merge_direction": "Egyesítés irányának megfordítása", "swap_merge_direction": "Egyesítés irányának megfordítása",
"sync": "Szinkronizálás", "sync": "Szinkronizálás",
"sync_albums": "Albumok szinkronizálása", "sync_albums": "Albumok szinkronizálása",
@@ -2187,7 +2213,7 @@
"tag_assets": "Elemek címkézése", "tag_assets": "Elemek címkézése",
"tag_created": "Létrehozott címke: {tag}", "tag_created": "Létrehozott címke: {tag}",
"tag_feature_description": "Fényképek és videók böngészése a címkék témája szerint csoportosítva", "tag_feature_description": "Fényképek és videók böngészése a címkék témája szerint csoportosítva",
"tag_not_found_question": "Nem találod a címkét? Hozz létre egy <link>új címkét</link>", "tag_not_found_question": "Nem találod a címkét? <link>Hozz létre egy újat.</link>",
"tag_people": "Emberek címkézése", "tag_people": "Emberek címkézése",
"tag_updated": "Frissített címke: {tag}", "tag_updated": "Frissített címke: {tag}",
"tagged_assets": "{count, plural, one {# elem} other {# elem}} felcímkézve", "tagged_assets": "{count, plural, one {# elem} other {# elem}} felcímkézve",
@@ -2285,6 +2311,7 @@
"unstack_action_prompt": "{count} egymásra helyezés megszüntetése", "unstack_action_prompt": "{count} egymásra helyezés megszüntetése",
"unstacked_assets_count": "{count, plural, other {# elemből}} álló csoport szétszedve", "unstacked_assets_count": "{count, plural, other {# elemből}} álló csoport szétszedve",
"unsupported_field_type": "Nem támogatott mezőtípus", "unsupported_field_type": "Nem támogatott mezőtípus",
"unsupported_file_type": "A fájl {file} nem feltölthető mert a típusa {type} nem támogatott.",
"untagged": "Címke eltávolítva", "untagged": "Címke eltávolítva",
"untitled_workflow": "Névtelen folyamat", "untitled_workflow": "Névtelen folyamat",
"up_next": "Következik", "up_next": "Következik",
@@ -2311,6 +2338,8 @@
"url": "URL", "url": "URL",
"usage": "Használat", "usage": "Használat",
"use_biometric": "Biometrikus azonosítás használata", "use_biometric": "Biometrikus azonosítás használata",
"use_browser_locale": "Böngésző helyének használata",
"use_browser_locale_description": "Dátumok, idők és számok meghatározása a böngésző helye alapján",
"use_current_connection": "Jelenlegi kapcsolat használata", "use_current_connection": "Jelenlegi kapcsolat használata",
"use_custom_date_range": "Szabadon megadott időintervallum használata", "use_custom_date_range": "Szabadon megadott időintervallum használata",
"user": "Felhasználó", "user": "Felhasználó",
+738 -717
View File
File diff suppressed because it is too large Load Diff
+30 -19
View File
@@ -61,7 +61,7 @@
"backup_onboarding_1_description": "copia offsite nel cloud o in un'altra sede fisica.", "backup_onboarding_1_description": "copia offsite nel cloud o in un'altra sede fisica.",
"backup_onboarding_2_description": "copie locali su diversi dispositivi. Ciò include i file principali e un backup di tali file a livello locale.", "backup_onboarding_2_description": "copie locali su diversi dispositivi. Ciò include i file principali e un backup di tali file a livello locale.",
"backup_onboarding_3_description": "copie totali dei tuoi dati, compresi i file originali. Ciò include 1 copia offsite e 2 copie locali.", "backup_onboarding_3_description": "copie totali dei tuoi dati, compresi i file originali. Ciò include 1 copia offsite e 2 copie locali.",
"backup_onboarding_description": "Per proteggere i tuoi dati, è consigliato adottare una strategia di backup <backblaze-link>3-2-1</backblaze-link>. Per una soluzione di backup completa, è consigliato conservare copie delle foto/video caricati e del database Immich.", "backup_onboarding_description": "Per proteggere i dati, è raccomandata una <backblaze-link>strategia di backup 3-2-1</backblaze-link> . Per una soluzione di backup completa, è consigliabile conservare copia delle foto/video caricati e del database Immich.",
"backup_onboarding_footer": "Per ulteriori informazioni sul backup di Immich, consulta la <link>documentazione</link>.", "backup_onboarding_footer": "Per ulteriori informazioni sul backup di Immich, consulta la <link>documentazione</link>.",
"backup_onboarding_parts_title": "Un backup 3-2-1 include:", "backup_onboarding_parts_title": "Un backup 3-2-1 include:",
"backup_onboarding_title": "Backup", "backup_onboarding_title": "Backup",
@@ -104,7 +104,7 @@
"image_preview_description": "Immagine a media dimensione senza metadati, utilizzata durante la visualizzazione di una singola risorsa e per il machine learning", "image_preview_description": "Immagine a media dimensione senza metadati, utilizzata durante la visualizzazione di una singola risorsa e per il machine learning",
"image_preview_quality_description": "Qualità dell'anteprima da 1 a 100. Più alto è meglio ma produce file più pesanti e può ridurre la reattività dell'app. Impostare un valore basso può influenzare negativamente la qualità del machine learning.", "image_preview_quality_description": "Qualità dell'anteprima da 1 a 100. Più alto è meglio ma produce file più pesanti e può ridurre la reattività dell'app. Impostare un valore basso può influenzare negativamente la qualità del machine learning.",
"image_preview_title": "Impostazioni dell'anteprima", "image_preview_title": "Impostazioni dell'anteprima",
"image_progressive": "Progressiva", "image_progressive": "Progressivo",
"image_progressive_description": "Codifica progressivamente le immagini JPEG per mostrarle con un caricamento graduale. Questo non ha effetto sulle immagini WebP.", "image_progressive_description": "Codifica progressivamente le immagini JPEG per mostrarle con un caricamento graduale. Questo non ha effetto sulle immagini WebP.",
"image_quality": "Qualità", "image_quality": "Qualità",
"image_resolution": "Risoluzione", "image_resolution": "Risoluzione",
@@ -351,7 +351,7 @@
"template_settings": "Templates Notifiche", "template_settings": "Templates Notifiche",
"template_settings_description": "Gestisci i modelli personalizzati per le notifiche", "template_settings_description": "Gestisci i modelli personalizzati per le notifiche",
"theme_custom_css_settings": "CSS Personalizzato", "theme_custom_css_settings": "CSS Personalizzato",
"theme_custom_css_settings_description": "I Cascading Style Sheets (CSS) permettono di personalizzare l'interfaccia di Immich.", "theme_custom_css_settings_description": "I fogli di stile CSS consentono di personalizzare il design di Immich.",
"theme_settings": "Impostazioni Tema", "theme_settings": "Impostazioni Tema",
"theme_settings_description": "Gestisci la personalizzazione dell'interfaccia web di Immich", "theme_settings_description": "Gestisci la personalizzazione dell'interfaccia web di Immich",
"thumbnail_generation_job": "Genera Anteprime", "thumbnail_generation_job": "Genera Anteprime",
@@ -372,7 +372,7 @@
"transcoding_audio_codec": "Codifica Audio", "transcoding_audio_codec": "Codifica Audio",
"transcoding_audio_codec_description": "Opus è l'opzione con la qualità più alta, ma è meno compatibile con dispositivi o software vecchi.", "transcoding_audio_codec_description": "Opus è l'opzione con la qualità più alta, ma è meno compatibile con dispositivi o software vecchi.",
"transcoding_bitrate_description": "Video con bitrate superiore al massimo o in formato non accettato", "transcoding_bitrate_description": "Video con bitrate superiore al massimo o in formato non accettato",
"transcoding_codecs_learn_more": "Per saperne di più sulla terminologia utilizzata, fai riferimento alla documentazione di FFmpeg su <h264-link>codec H.264</h264-link>, <hevc-link>codec HEVC</hevc-link> e <vp9-link>codec VP9</vp9-link>.", "transcoding_codecs_learn_more": "Per maggiori informazioni sulla terminologia qui utilizzata, fare riferimento alla documentazione di FFmpeg per <h264-link>codec H.264</h264-link>, <hevc-link>codec HEVC</hevc-link> e <vp9-link>codec VP9</vp9-link>.",
"transcoding_constant_quality_mode": "Modalità qualità costante", "transcoding_constant_quality_mode": "Modalità qualità costante",
"transcoding_constant_quality_mode_description": "iCQ è migliore di CQP, però alcuni dispositivi di accelerazione hardware non supportano questa modalità. Impostando questa opzione l'applicazione preferirà il modo specificato quando è in uso la codifica quality-based. Ignorato da NVENC perché non supporta ICQ.", "transcoding_constant_quality_mode_description": "iCQ è migliore di CQP, però alcuni dispositivi di accelerazione hardware non supportano questa modalità. Impostando questa opzione l'applicazione preferirà il modo specificato quando è in uso la codifica quality-based. Ignorato da NVENC perché non supporta ICQ.",
"transcoding_constant_rate_factor": "Fattore di rateo costante (-crf)", "transcoding_constant_rate_factor": "Fattore di rateo costante (-crf)",
@@ -395,7 +395,7 @@
"transcoding_policy_description": "Imposta quando un video sarà transcodificato", "transcoding_policy_description": "Imposta quando un video sarà transcodificato",
"transcoding_preferred_hardware_device": "Dispositivo hardware preferito", "transcoding_preferred_hardware_device": "Dispositivo hardware preferito",
"transcoding_preferred_hardware_device_description": "Si applica solo a VAAPI e QSV. Imposta il nodo DRI utilizzato per la transcodifica hardware.", "transcoding_preferred_hardware_device_description": "Si applica solo a VAAPI e QSV. Imposta il nodo DRI utilizzato per la transcodifica hardware.",
"transcoding_preset_preset": "Preset (-preset)", "transcoding_preset_preset": "Preimpostazione (-preset)",
"transcoding_preset_preset_description": "Velocità di compressione. Preset più lenti producono file più piccoli e aumentano la qualità quando viene impostato un certo bitrate. VP9 ignora velocità superiori a `faster`.", "transcoding_preset_preset_description": "Velocità di compressione. Preset più lenti producono file più piccoli e aumentano la qualità quando viene impostato un certo bitrate. VP9 ignora velocità superiori a `faster`.",
"transcoding_reference_frames": "Frame di riferimento", "transcoding_reference_frames": "Frame di riferimento",
"transcoding_reference_frames_description": "Il numero di frame da prendere in considerazione nel comprimere un determinato frame. Valori più alti migliorano l'efficienza di compressione, ma rallentano la codifica. 0 imposta questo valore automaticamente.", "transcoding_reference_frames_description": "Il numero di frame da prendere in considerazione nel comprimere un determinato frame. Valori più alti migliorano l'efficienza di compressione, ma rallentano la codifica. 0 imposta questo valore automaticamente.",
@@ -411,7 +411,7 @@
"transcoding_tone_mapping": "Mappatura della tonalità", "transcoding_tone_mapping": "Mappatura della tonalità",
"transcoding_tone_mapping_description": "Tenta di preservare l'aspetto dei video HDR quando convertiti in SDR. Ciascun algoritmo fa diversi compromessi per colore, dettaglio e luminosità. Hable conserva il dettaglio, Mobius conserva il colore e Reinhard conserva la luminosità.", "transcoding_tone_mapping_description": "Tenta di preservare l'aspetto dei video HDR quando convertiti in SDR. Ciascun algoritmo fa diversi compromessi per colore, dettaglio e luminosità. Hable conserva il dettaglio, Mobius conserva il colore e Reinhard conserva la luminosità.",
"transcoding_transcode_policy": "Politica di transcodifica", "transcoding_transcode_policy": "Politica di transcodifica",
"transcoding_transcode_policy_description": "Politica che determina quando un video deve essere transcodificato. I video HDR verranno sempre transcodificati (eccetto quando la transcodifica è disabilitata).", "transcoding_transcode_policy_description": "Regola che determina se un video deve essere transcodificato. I video HDR e quelli che hanno un formato pixel diverso da YUV 4:2:0, saranno sempre transcodificati (sempre che la transcodifica sia abilitata).",
"transcoding_two_pass_encoding": "Codifica a due passaggi", "transcoding_two_pass_encoding": "Codifica a due passaggi",
"transcoding_two_pass_encoding_setting_description": "Transcodifica in due passaggi per produrre video codificati migliori. Quando il bitrate massimo è abilitato (necessario affinché funzioni con H.264 e HEVC), questa modalità utilizza un intervallo di bitrate basato sul bitrate massimo e ignora CRF. Per VP9, CRF può essere utilizzato se il bitrate massimo è disabilitato.", "transcoding_two_pass_encoding_setting_description": "Transcodifica in due passaggi per produrre video codificati migliori. Quando il bitrate massimo è abilitato (necessario affinché funzioni con H.264 e HEVC), questa modalità utilizza un intervallo di bitrate basato sul bitrate massimo e ignora CRF. Per VP9, CRF può essere utilizzato se il bitrate massimo è disabilitato.",
"transcoding_video_codec": "Codec video", "transcoding_video_codec": "Codec video",
@@ -526,7 +526,7 @@
"allowed": "Consentito", "allowed": "Consentito",
"alt_text_qr_code": "Immagine QR", "alt_text_qr_code": "Immagine QR",
"always_keep": "Mantieni sempre", "always_keep": "Mantieni sempre",
"always_keep_photos_hint": "Libera Spazio mantiene tutte le foto su questo dispositivo.", "always_keep_photos_hint": "Liberare spazio manterrà tutte le foto su questo dispositivo.",
"always_keep_videos_hint": "Libera Spazio mantiene tutti i video su questo dispositivo.", "always_keep_videos_hint": "Libera Spazio mantiene tutti i video su questo dispositivo.",
"anti_clockwise": "Senso anti-orario", "anti_clockwise": "Senso anti-orario",
"api_key": "Chiave API", "api_key": "Chiave API",
@@ -539,7 +539,7 @@
"app_bar_signout_dialog_title": "Disconnetti", "app_bar_signout_dialog_title": "Disconnetti",
"app_download_links": "Link per il download dell'app", "app_download_links": "Link per il download dell'app",
"app_settings": "Impostazioni Applicazione", "app_settings": "Impostazioni Applicazione",
"app_stores": "App Stores", "app_stores": "App Store",
"app_update_available": "Aggiornamento App disponibile", "app_update_available": "Aggiornamento App disponibile",
"appears_in": "Compare in", "appears_in": "Compare in",
"apply_count": "Applica ({count, number})", "apply_count": "Applica ({count, number})",
@@ -872,7 +872,7 @@
"current_server_address": "Indirizzo del server in uso", "current_server_address": "Indirizzo del server in uso",
"custom_date": "Data specifica", "custom_date": "Data specifica",
"custom_locale": "Localizzazione personalizzata", "custom_locale": "Localizzazione personalizzata",
"custom_locale_description": "Formatta data e numeri in base alla lingua e al paese", "custom_locale_description": "Formatta date e numeri in base alla lingua e al paese selezionati",
"custom_url": "URL personalizzato", "custom_url": "URL personalizzato",
"cutoff_date_description": "Mantieni le foto fino al…", "cutoff_date_description": "Mantieni le foto fino al…",
"cutoff_day": "{count, plural, one {giorno} other {giorni}}", "cutoff_day": "{count, plural, one {giorno} other {giorni}}",
@@ -895,8 +895,6 @@
"deduplication_criteria_2": "Numero di dati EXIF", "deduplication_criteria_2": "Numero di dati EXIF",
"deduplication_info": "Informazioni di deduplicazione", "deduplication_info": "Informazioni di deduplicazione",
"deduplication_info_description": "Per preselezionare automaticamente le risorse e rimuovere i duplicati in massa, verifichiamo:", "deduplication_info_description": "Per preselezionare automaticamente le risorse e rimuovere i duplicati in massa, verifichiamo:",
"default_locale": "Localizzazione preimpostata",
"default_locale_description": "Formatta la data e i numeri in base alle impostazioni del tuo browser",
"delete": "Elimina", "delete": "Elimina",
"delete_action_confirmation_message": "Vuoi davvero eliminare questa risorsa? Questa azione sposterà la risorsa nel cestino del server e ti chiederà se desideri eliminarla dal dispositivo", "delete_action_confirmation_message": "Vuoi davvero eliminare questa risorsa? Questa azione sposterà la risorsa nel cestino del server e ti chiederà se desideri eliminarla dal dispositivo",
"delete_action_prompt": "{count} elementi eliminati", "delete_action_prompt": "{count} elementi eliminati",
@@ -1074,6 +1072,7 @@
"failed_to_update_notification_status": "Aggiornamento stato notifiche fallito", "failed_to_update_notification_status": "Aggiornamento stato notifiche fallito",
"incorrect_email_or_password": "Email o password non corretta", "incorrect_email_or_password": "Email o password non corretta",
"library_folder_already_exists": "Questo path di importazione esiste già.", "library_folder_already_exists": "Questo path di importazione esiste già.",
"page_not_found": "Impossibile trovare la pagina",
"paths_validation_failed": "{paths, plural, one {# percorso} other {# percorsi}} hanno fallito la validazione", "paths_validation_failed": "{paths, plural, one {# percorso} other {# percorsi}} hanno fallito la validazione",
"profile_picture_transparent_pixels": "Le foto profilo non possono avere pixel trasparenti. Riprova ingrandendo e/o muovendo l'immagine.", "profile_picture_transparent_pixels": "Le foto profilo non possono avere pixel trasparenti. Riprova ingrandendo e/o muovendo l'immagine.",
"quota_higher_than_disk_size": "Hai impostato un limite più alto della dimensione del disco", "quota_higher_than_disk_size": "Hai impostato un limite più alto della dimensione del disco",
@@ -1218,6 +1217,7 @@
"filter_description": "Condizioni per filtrare le risorse obiettivo", "filter_description": "Condizioni per filtrare le risorse obiettivo",
"filter_people": "Filtra persone", "filter_people": "Filtra persone",
"filter_places": "Filtra luoghi", "filter_places": "Filtra luoghi",
"filter_tags": "Filtra tag",
"filters": "Filtri", "filters": "Filtri",
"find_them_fast": "Trovale velocemente con la ricerca", "find_them_fast": "Trovale velocemente con la ricerca",
"first": "Primo", "first": "Primo",
@@ -1441,7 +1441,7 @@
"login_password_changed_success": "Password aggiornata con successo", "login_password_changed_success": "Password aggiornata con successo",
"logout_all_device_confirmation": "Sei sicuro di volerti disconnettere da tutti i dispositivi?", "logout_all_device_confirmation": "Sei sicuro di volerti disconnettere da tutti i dispositivi?",
"logout_this_device_confirmation": "Sei sicuro di volerti disconnettere da questo dispositivo?", "logout_this_device_confirmation": "Sei sicuro di volerti disconnettere da questo dispositivo?",
"logs": "Logs", "logs": "Registri",
"longitude": "Longitudine", "longitude": "Longitudine",
"look": "Guarda", "look": "Guarda",
"loop_videos": "Riproduci video in loop", "loop_videos": "Riproduci video in loop",
@@ -1649,6 +1649,7 @@
"only_favorites": "Solo preferiti", "only_favorites": "Solo preferiti",
"open": "Apri", "open": "Apri",
"open_calendar": "Apri il calendario", "open_calendar": "Apri il calendario",
"open_in_browser": "Apri con il browser",
"open_in_map_view": "Apri nella visualizzazione mappa", "open_in_map_view": "Apri nella visualizzazione mappa",
"open_in_openstreetmap": "Apri su OpenStreetMap", "open_in_openstreetmap": "Apri su OpenStreetMap",
"open_the_search_filters": "Apri filtri di ricerca", "open_the_search_filters": "Apri filtri di ricerca",
@@ -1808,9 +1809,8 @@
"rate_asset": "Valuta la risorsa", "rate_asset": "Valuta la risorsa",
"rating": "Valutazione a stelle", "rating": "Valutazione a stelle",
"rating_clear": "Azzera valutazione", "rating_clear": "Azzera valutazione",
"rating_count": "{count, plural, one {# stella} other {# stelle}}", "rating_count": "{count, plural, =0 {Senza valutazione} one {# star} other {# stars}}",
"rating_description": "Visualizza la valutazione EXIF nel pannello informazioni", "rating_description": "Visualizza la valutazione EXIF nel pannello informazioni",
"rating_set": "Valutazione impostata a {rating, plural, one {# stella} other {# stelle}}",
"reaction_options": "Impostazioni Reazioni", "reaction_options": "Impostazioni Reazioni",
"read_changelog": "Leggi Riepilogo Modifiche", "read_changelog": "Leggi Riepilogo Modifiche",
"readonly_mode_disabled": "Modalità di sola lettura disabilitata", "readonly_mode_disabled": "Modalità di sola lettura disabilitata",
@@ -1882,7 +1882,10 @@
"reset_pin_code_success": "Codice PIN reimpostato con successo", "reset_pin_code_success": "Codice PIN reimpostato con successo",
"reset_pin_code_with_password": "Puoi sempre reimpostare il codice PIN usando la tua password", "reset_pin_code_with_password": "Puoi sempre reimpostare il codice PIN usando la tua password",
"reset_sqlite": "Resetta Database SQLite", "reset_sqlite": "Resetta Database SQLite",
"reset_sqlite_confirmation": "Vuoi davvero reimpostare il database SQLite? Dovrai disconnetterti e riconnetterti per risincronizzare i dati", "reset_sqlite_clear_app_data": "Cancella i dati",
"reset_sqlite_confirmation": "Sei sicuro di voler cancellare i dati dell'app? Questa azione rimuoverà tutte le impostazioni e verrai disconnesso.",
"reset_sqlite_confirmation_note": "Nota: dovrai riavviare l'app dopo la pulizia.",
"reset_sqlite_done": "I dati dell'app sono stati cancellati. Si prega di riavviare Immich ed accedere nuovamente.",
"reset_sqlite_success": "Database SQLite reimpostato correttamente", "reset_sqlite_success": "Database SQLite reimpostato correttamente",
"reset_to_default": "Ripristina i valori predefiniti", "reset_to_default": "Ripristina i valori predefiniti",
"resolution": "Risoluzione", "resolution": "Risoluzione",
@@ -1910,6 +1913,7 @@
"saved_settings": "Impostazioni salvate", "saved_settings": "Impostazioni salvate",
"say_something": "Dici qualcosa", "say_something": "Dici qualcosa",
"scaffold_body_error_occurred": "Si è verificato un errore", "scaffold_body_error_occurred": "Si è verificato un errore",
"scaffold_body_error_unrecoverable": "Si è verificato un errore irreversibile. Condividi l'errore e lo stack trace su Discord o GitHub per consentirci di aiutarti. Se necessario, puoi cancellare i dati dell'app qui sotto.",
"scan": "Scansione", "scan": "Scansione",
"scan_all_libraries": "Analizza tutte le librerie", "scan_all_libraries": "Analizza tutte le librerie",
"scan_library": "Scansione", "scan_library": "Scansione",
@@ -1945,6 +1949,7 @@
"search_filter_ocr": "Cerca tramite OCR", "search_filter_ocr": "Cerca tramite OCR",
"search_filter_people_title": "Seleziona persone", "search_filter_people_title": "Seleziona persone",
"search_filter_star_rating": "Voto in Stelle", "search_filter_star_rating": "Voto in Stelle",
"search_filter_tags_title": "Seleziona tag",
"search_for": "Cerca per", "search_for": "Cerca per",
"search_for_existing_person": "Cerca per persona esistente", "search_for_existing_person": "Cerca per persona esistente",
"search_no_more_result": "Non ci sono altri risultati", "search_no_more_result": "Non ci sono altri risultati",
@@ -2024,7 +2029,10 @@
"set_profile_picture": "Imposta foto profilo", "set_profile_picture": "Imposta foto profilo",
"set_slideshow_to_fullscreen": "Imposta presentazione a schermo intero", "set_slideshow_to_fullscreen": "Imposta presentazione a schermo intero",
"set_stack_primary_asset": "Imposta come risorsa primaria", "set_stack_primary_asset": "Imposta come risorsa primaria",
"setting_image_viewer_help": "Il visualizzatore dettagliato carica una piccola thumbnail per prima, per poi caricare un immagine di media grandezza (se abilitato). Ed infine carica l'originale (se abilitato).", "setting_image_navigation_enable_subtitle": "Se abilitata, puoi passare all'immagine precedente/successiva toccando il quarto di schermo più a sinistra/più a destra.",
"setting_image_navigation_enable_title": "Clicca per navigare",
"setting_image_navigation_title": "Navigazione delle immagini",
"setting_image_viewer_help": "Il visualizzatore dettagliato prima carica una piccola thumbnail , per poi caricare un immagine di media grandezza (se abilitato). Ed infine carica l'originale (se abilitato).",
"setting_image_viewer_original_subtitle": "Abilita il caricamento dellimmagine originale in alta risoluzione (dimensioni elevate). Disattiva per ridurre il consumo di dati, sia di rete che in cache locale.", "setting_image_viewer_original_subtitle": "Abilita il caricamento dellimmagine originale in alta risoluzione (dimensioni elevate). Disattiva per ridurre il consumo di dati, sia di rete che in cache locale.",
"setting_image_viewer_original_title": "Carica l'immagine originale", "setting_image_viewer_original_title": "Carica l'immagine originale",
"setting_image_viewer_preview_subtitle": "Abilita per caricare un'immagine a risoluzione media. Disabilita per caricare direttamente l'immagine originale o usare la thumbnail.", "setting_image_viewer_preview_subtitle": "Abilita per caricare un'immagine a risoluzione media. Disabilita per caricare direttamente l'immagine originale o usare la thumbnail.",
@@ -2045,7 +2053,7 @@
"setting_notifications_total_progress_title": "Mostra avanzamento del backup in background", "setting_notifications_total_progress_title": "Mostra avanzamento del backup in background",
"setting_video_viewer_auto_play_subtitle": "Avvia automaticamente la riproduzione dei video quando vengono aperti", "setting_video_viewer_auto_play_subtitle": "Avvia automaticamente la riproduzione dei video quando vengono aperti",
"setting_video_viewer_auto_play_title": "Riproduci video automaticamente", "setting_video_viewer_auto_play_title": "Riproduci video automaticamente",
"setting_video_viewer_looping_title": "Looping", "setting_video_viewer_looping_title": "Iterazione",
"setting_video_viewer_original_video_subtitle": "Quando riproduci un video dal server, riproduci l'originale anche se è disponibile una versione transcodificata. Questo potrebbe portare a buffering. I video disponibili localmente sono sempre riprodotti a qualità originale indipendentemente da questa impostazione.", "setting_video_viewer_original_video_subtitle": "Quando riproduci un video dal server, riproduci l'originale anche se è disponibile una versione transcodificata. Questo potrebbe portare a buffering. I video disponibili localmente sono sempre riprodotti a qualità originale indipendentemente da questa impostazione.",
"setting_video_viewer_original_video_title": "Forza video originale", "setting_video_viewer_original_video_title": "Forza video originale",
"settings": "Impostazioni", "settings": "Impostazioni",
@@ -2147,7 +2155,7 @@
"size": "Dimensione", "size": "Dimensione",
"skip_to_content": "Salta al contenuto", "skip_to_content": "Salta al contenuto",
"skip_to_folders": "Salta alle cartelle", "skip_to_folders": "Salta alle cartelle",
"skip_to_tags": "Salta alle etichette", "skip_to_tags": "Salta ai tag",
"slideshow": "Presentazione", "slideshow": "Presentazione",
"slideshow_repeat": "Ripeti presentazione", "slideshow_repeat": "Ripeti presentazione",
"slideshow_repeat_description": "Ricomincia da capo quando la presentazione termina", "slideshow_repeat_description": "Ricomincia da capo quando la presentazione termina",
@@ -2202,7 +2210,7 @@
"sync_upload_album_setting_subtitle": "Crea e carica le tue foto e video sull'album selezionato in Immich", "sync_upload_album_setting_subtitle": "Crea e carica le tue foto e video sull'album selezionato in Immich",
"tag": "Tag", "tag": "Tag",
"tag_assets": "Tagga risorse", "tag_assets": "Tagga risorse",
"tag_created": "Tag creata: {tag}", "tag_created": "Tag creato: {tag}",
"tag_feature_description": "Navigazione foto e video raggruppati per argomenti tag logici", "tag_feature_description": "Navigazione foto e video raggruppati per argomenti tag logici",
"tag_not_found_question": "Non riesci a trovare un tag? <link>Creane uno nuovo.</link>", "tag_not_found_question": "Non riesci a trovare un tag? <link>Creane uno nuovo.</link>",
"tag_people": "Tagga persone", "tag_people": "Tagga persone",
@@ -2302,6 +2310,7 @@
"unstack_action_prompt": "{count} separati", "unstack_action_prompt": "{count} separati",
"unstacked_assets_count": "{count, plural, one {Separata # risorsa} other {Separate # risorse}}", "unstacked_assets_count": "{count, plural, one {Separata # risorsa} other {Separate # risorse}}",
"unsupported_field_type": "Tipo di campo non supportato", "unsupported_field_type": "Tipo di campo non supportato",
"unsupported_file_type": "Il file {file} non può essere caricato perché il tipo di file {type} non è supportato.",
"untagged": "Senza tag", "untagged": "Senza tag",
"untitled_workflow": "Flusso di lavoro senza titolo", "untitled_workflow": "Flusso di lavoro senza titolo",
"up_next": "Prossimo", "up_next": "Prossimo",
@@ -2328,6 +2337,8 @@
"url": "URL", "url": "URL",
"usage": "Utilizzo", "usage": "Utilizzo",
"use_biometric": "Usa biometrica", "use_biometric": "Usa biometrica",
"use_browser_locale": "Utilizza la localizzazione del browser",
"use_browser_locale_description": "Formatta date e numeri in base alla lingua e al paese del browser",
"use_current_connection": "Usa la connessione attuale", "use_current_connection": "Usa la connessione attuale",
"use_custom_date_range": "Altrimenti utilizza un intervallo date personalizzato", "use_custom_date_range": "Altrimenti utilizza un intervallo date personalizzato",
"user": "Utente", "user": "Utente",
+25 -28
View File
@@ -37,13 +37,13 @@
"add_to_album_bottom_sheet_some_local_assets": "いくつかの項目はまだサーバーへアップロードされていないためアルバムに追加できませんでした", "add_to_album_bottom_sheet_some_local_assets": "いくつかの項目はまだサーバーへアップロードされていないためアルバムに追加できませんでした",
"add_to_album_toggle": "{album}の選択を切り替え", "add_to_album_toggle": "{album}の選択を切り替え",
"add_to_albums": "アルバムに追加", "add_to_albums": "アルバムに追加",
"add_to_albums_count": "{count}つのアルバム追加", "add_to_albums_count": "{count}件をアルバム追加",
"add_to_bottom_bar": "追加する", "add_to_bottom_bar": "追加する",
"add_to_shared_album": "共有アルバムに追加", "add_to_shared_album": "共有アルバムに追加",
"add_upload_to_stack": "スタックにアップロードを追加", "add_upload_to_stack": "スタックにアップロードを追加",
"add_url": "URLを追加", "add_url": "URLを追加",
"add_workflow_step": "ワークフローのステップを追加", "add_workflow_step": "ワークフローのステップを追加",
"added_to_archive": "アーカイブしました", "added_to_archive": "アーカイブしました",
"added_to_favorites": "お気に入りに追加済", "added_to_favorites": "お気に入りに追加済",
"added_to_favorites_count": "{count, number} 枚の画像をお気に入りに追加しました", "added_to_favorites_count": "{count, number} 枚の画像をお気に入りに追加しました",
"admin": { "admin": {
@@ -52,34 +52,34 @@
"asset_offline_description": "この外部ライブラリのアセットはディスク上に見つからなくなってゴミ箱に移動されました。ファイルがライブラリの中で移動された場合はタイムラインで新しい対応するアセットを確認してください。このアセットを復元するには以下のファイルパスがImmichからアクセスできるか確認してライブラリをスキャンしてください。", "asset_offline_description": "この外部ライブラリのアセットはディスク上に見つからなくなってゴミ箱に移動されました。ファイルがライブラリの中で移動された場合はタイムラインで新しい対応するアセットを確認してください。このアセットを復元するには以下のファイルパスがImmichからアクセスできるか確認してライブラリをスキャンしてください。",
"authentication_settings": "認証設定", "authentication_settings": "認証設定",
"authentication_settings_description": "認証設定の管理(パスワード、OAuth、その他)", "authentication_settings_description": "認証設定の管理(パスワード、OAuth、その他)",
"authentication_settings_disable_all": "本当にてのログイン方法を無効にしますか? ログイン完全に無効になります。", "authentication_settings_disable_all": "本当にすべてのログイン方法を無効にしますか ログイン完全にできなくなります。",
"authentication_settings_reenable": "再び有効にするには、<link>サーバーコマンド</link>を使用してください。", "authentication_settings_reenable": "再び有効にするには、<link>サーバーコマンド</link>を使用してください。",
"background_task_job": "バックグラウンドタスク", "background_task_job": "バックグラウンドタスク",
"backup_database": "データベースのバックアップを作成", "backup_database": "データベースのバックアップを作成",
"backup_database_enable_description": "データベースバックアップの作成を有効にする", "backup_database_enable_description": "データベースバックアップを有効にする",
"backup_keep_last_amount": "過去のバックアップの保持数", "backup_keep_last_amount": "バックアップの保持数",
"backup_onboarding_1_description": "クラウドを利用したオフサイトのコピーか別の物理的な場所。", "backup_onboarding_1_description": "クラウドを利用したオフサイトのコピーか別の物理的な場所。",
"backup_onboarding_2_description": "別々のデバイス上のローカルコピー。これはメインファイルやそのローカルバックアップファイルを含みます。", "backup_onboarding_2_description": "別々のデバイス上のローカルコピー。これはメインファイルやそのローカルバックアップファイルを含みます。",
"backup_onboarding_3_description": "あなたのすべてのデータ(1つのオフサイトコピーと2つのローカルコピーを含む)のコピー。", "backup_onboarding_3_description": "あなたのすべてのデータ(1つのオフサイトコピーと2つのローカルコピーを含む)のコピー。",
"backup_onboarding_description": "データ保護には<backblaze-link>3-2-1バックアップ戦略</backblaze-link>が推奨されます。アップロードした写真/動画のコピーに加え、Immichデータベースのコピーも保持することで包括的なバックアップソリューションを実現できます。", "backup_onboarding_description": "データ保護には<backblaze-link>3-2-1バックアップ戦略</backblaze-link>の利用を推奨します。写真動画データとImmichデータベースをあわせてバックアップすることで、より安全に保管できます。",
"backup_onboarding_footer": "Immichのバックアップに関する情報は、<link>ドキュメンテーション</link>を確認してください。", "backup_onboarding_footer": "Immichのバックアップに関する情報は、<link>ドキュメンテーション</link>を確認してください。",
"backup_onboarding_parts_title": "3-2-1バックアップ:", "backup_onboarding_parts_title": "3-2-1バックアップ:",
"backup_onboarding_title": "バックアップ", "backup_onboarding_title": "バックアップ",
"backup_settings": "データベースバックアップ作成の設定", "backup_settings": "データベースバックアップの設定",
"backup_settings_description": "データベースのバックアップ作成設定管理 (このジョブはモニタリングされませんし、失敗が発生してもあなたに通知が行くことはありません)", "backup_settings_description": "データベースのバックアップ設定管理",
"cleared_jobs": "{job}のジョブをクリアしました", "cleared_jobs": "{job}のジョブをクリアしました",
"config_set_by_file": "設定は現在 Config File で設定されている", "config_set_by_file": "設定は現在 Config File で設定されている",
"confirm_delete_library": "本当に {library} を削除しますか?", "confirm_delete_library": "本当に {library} を削除しますか?",
"confirm_delete_library_assets": "本当にこのライブラリを削除しますか? {count, plural, one {#個の項目} other {#個の項目全て}} がImmichから削除され、元に戻すことはできません。ファイルはディスク上に残ります。", "confirm_delete_library_assets": "本当にこのライブラリを削除しますか? {count, plural, one {#個の項目} other {#個の項目全て}} がImmichから削除され、元に戻すことはできません。ファイルはディスク上に残ります。",
"confirm_email_below": "確認のため、以下に \"{email}\" と入力してください", "confirm_email_below": "確認のため、以下に \"{email}\" と入力してください",
"confirm_reprocess_all_faces": "本当にすべての顔を再処理しますか? これにより名前が付けられた人物も消去されます。", "confirm_reprocess_all_faces": "本当に顔データをすべて再処理しますか?登録済みの人物情報はリセットされます。",
"confirm_user_password_reset": "本当に {user} のパスワードをリセットしますか?", "confirm_user_password_reset": "本当に {user} のパスワードをリセットしますか?",
"confirm_user_pin_code_reset": "{user}のPINコードをリセットしてよいですか?", "confirm_user_pin_code_reset": "本当に{user}のPINコードをリセットしすか?",
"copy_config_to_clipboard_description": "JSONオブジェクトとして現在のシステムコンフィグをクリップボードにコピーする", "copy_config_to_clipboard_description": "JSONオブジェクトとして現在のシステムコンフィグをクリップボードにコピーする",
"create_job": "ジョブの作成", "create_job": "ジョブの作成",
"cron_expression": "Cron", "cron_expression": "実行スケジュール(Cron",
"cron_expression_description": "cronのフォーマットを使ってスキャン間隔を設定します。詳しくは<link>Crontab Guru</link>などを参照してください", "cron_expression_description": "cron形式で実行タイミングを設定します。詳しくは <link>Crontab Guru</link> を参照してください",
"cron_expression_presets": "Cron式のプリセット", "cron_expression_presets": "スケジュール(プリセット",
"disable_login": "ログインを無効にする", "disable_login": "ログインを無効にする",
"duplicate_detection_job_description": "機械学習を用いて類似画像の検出を行います。(スマートサーチに依存)", "duplicate_detection_job_description": "機械学習を用いて類似画像の検出を行います。(スマートサーチに依存)",
"exclusion_pattern_description": "除外パターンを使用すると、ライブラリをスキャンする際にファイルやフォルダを無視することができます。RAWファイルなど、インポートしたくないファイルを含むフォルダがある場合に便利です。", "exclusion_pattern_description": "除外パターンを使用すると、ライブラリをスキャンする際にファイルやフォルダを無視することができます。RAWファイルなど、インポートしたくないファイルを含むフォルダがある場合に便利です。",
@@ -89,7 +89,7 @@
"face_detection_description": "機械学習を使用してアセット内の顔を検出します。動画の場合は、サムネイルのみが対象となります。\"すべて\" はすべてのアセットを(再)処理します。 \"欠落\" はまだ処理されていないアセットをキューに入れます。顔検出の完了後、検出された顔は顔認識のキューへ入れられ、既存または新規の人物にグループ化されます。", "face_detection_description": "機械学習を使用してアセット内の顔を検出します。動画の場合は、サムネイルのみが対象となります。\"すべて\" はすべてのアセットを(再)処理します。 \"欠落\" はまだ処理されていないアセットをキューに入れます。顔検出の完了後、検出された顔は顔認識のキューへ入れられ、既存または新規の人物にグループ化されます。",
"facial_recognition_job_description": "検出された顔を人物にグループ化します。このステップは顔検出が完了した後に実行されます。 \"すべて\" はすべての顔を(再)クラスタリングし、 \"欠落\" は人物が割り当てられていない顔をキューに入れます。", "facial_recognition_job_description": "検出された顔を人物にグループ化します。このステップは顔検出が完了した後に実行されます。 \"すべて\" はすべての顔を(再)クラスタリングし、 \"欠落\" は人物が割り当てられていない顔をキューに入れます。",
"failed_job_command": "ジョブ {job}のコマンド {command}が失敗しました", "failed_job_command": "ジョブ {job}のコマンド {command}が失敗しました",
"force_delete_user_warning": "警告この操作を行うと、ユーザーとすべてのアセットが直ちに削除されます。これは元に戻せず、ファイルも復元できません。", "force_delete_user_warning": "警告: この操作を行うと、ユーザーとすべてのアセットが直ちに削除されます。これは元に戻せず、ファイルも復元できません。",
"image_format": "フォーマット", "image_format": "フォーマット",
"image_format_description": "WebPはJPEGよりもファイルサイズが小さいですが、エンコードに時間がかかります。", "image_format_description": "WebPはJPEGよりもファイルサイズが小さいですが、エンコードに時間がかかります。",
"image_fullsize_description": "画像を拡大する時に使われるメタデータを取り除いた原寸大画像", "image_fullsize_description": "画像を拡大する時に使われるメタデータを取り除いた原寸大画像",
@@ -242,7 +242,7 @@
"nightly_tasks_settings": "毎晩行うタスクの設定", "nightly_tasks_settings": "毎晩行うタスクの設定",
"nightly_tasks_settings_description": "毎晩行うタスクの管理", "nightly_tasks_settings_description": "毎晩行うタスクの管理",
"nightly_tasks_start_time_setting": "開始時間", "nightly_tasks_start_time_setting": "開始時間",
"nightly_tasks_start_time_setting_description": "このサーバーが毎晩行うタスクを行う時間", "nightly_tasks_start_time_setting_description": "夜間タスクの実行開始時刻",
"nightly_tasks_sync_quota_usage_setting": "割当容量の同期", "nightly_tasks_sync_quota_usage_setting": "割当容量の同期",
"nightly_tasks_sync_quota_usage_setting_description": "ユーザーの現在のストレージ使用状況に応じて割当容量を更新", "nightly_tasks_sync_quota_usage_setting_description": "ユーザーの現在のストレージ使用状況に応じて割当容量を更新",
"no_paths_added": "パスが追加されていません", "no_paths_added": "パスが追加されていません",
@@ -812,7 +812,7 @@
"connected_device": "接続されたデバイス", "connected_device": "接続されたデバイス",
"connected_to": "接続:", "connected_to": "接続:",
"contain": "収める", "contain": "収める",
"context": "状況", "context": "写真の内容",
"continue": "続ける", "continue": "続ける",
"control_bottom_app_bar_create_new_album": "アルバムを作成", "control_bottom_app_bar_create_new_album": "アルバムを作成",
"control_bottom_app_bar_delete_from_immich": "サーバーから削除", "control_bottom_app_bar_delete_from_immich": "サーバーから削除",
@@ -890,8 +890,6 @@
"deduplication_criteria_2": "EXIFデータ数", "deduplication_criteria_2": "EXIFデータ数",
"deduplication_info": "重複排除情報", "deduplication_info": "重複排除情報",
"deduplication_info_description": "写真/動画を自動的に選択して重複を一括で削除するには次のようにします:", "deduplication_info_description": "写真/動画を自動的に選択して重複を一括で削除するには次のようにします:",
"default_locale": "デフォルトのロケール",
"default_locale_description": "ブラウザのロケールに基づいて日付と数値をフォーマットします",
"delete": "削除", "delete": "削除",
"delete_action_confirmation_message": "この項目を削除しますか?まず、この項目はサーバー上のゴミ箱へ移動されます。その後、あなたのデバイス上から削除するかを決めていただきます", "delete_action_confirmation_message": "この項目を削除しますか?まず、この項目はサーバー上のゴミ箱へ移動されます。その後、あなたのデバイス上から削除するかを決めていただきます",
"delete_action_prompt": "{count}項目を削除しました", "delete_action_prompt": "{count}項目を削除しました",
@@ -921,7 +919,7 @@
"delete_user": "ユーザーを削除", "delete_user": "ユーザーを削除",
"deleted_shared_link": "共有リンクを削除", "deleted_shared_link": "共有リンクを削除",
"deletes_missing_assets": "ディスクからなくなったアセットを削除する", "deletes_missing_assets": "ディスクからなくなったアセットを削除する",
"description": "概要欄", "description": "説明",
"description_input_hint_text": "説明を追加", "description_input_hint_text": "説明を追加",
"description_input_submit_error": "説明の編集に失敗しました。詳細はログを確認してください。", "description_input_submit_error": "説明の編集に失敗しました。詳細はログを確認してください。",
"deselect_all": "すべての選択を解除", "deselect_all": "すべての選択を解除",
@@ -1320,10 +1318,10 @@
"individual_shares": "1枚ずつの共有", "individual_shares": "1枚ずつの共有",
"info": "情報", "info": "情報",
"interval": { "interval": {
"day_at_onepm": "毎日午後1時", "day_at_onepm": "毎日 午後1時",
"hours": "{hours, plural, one {1時間} other {{hours, number}時間}}ごと", "hours": "{hours, plural, one {1時間} other {{hours, number}時間}}ごと",
"night_at_midnight": "毎晩真夜中に", "night_at_midnight": "毎日 午前0時",
"night_at_twoam": "毎午前2時" "night_at_twoam": "毎午前2時"
}, },
"invalid_date": "日付が無効です", "invalid_date": "日付が無効です",
"invalid_date_format": "日付のフォーマットが無効です", "invalid_date_format": "日付のフォーマットが無効です",
@@ -1803,7 +1801,6 @@
"rating_clear": "評価を取り消す", "rating_clear": "評価を取り消す",
"rating_count": "星{count, plural, one {#つ} other {#つ}}", "rating_count": "星{count, plural, one {#つ} other {#つ}}",
"rating_description": "情報欄にEXIFの評価を表示", "rating_description": "情報欄にEXIFの評価を表示",
"rating_set": "お気に入り度 {rating, plural, one {# ツ星} other {# ツ星}}",
"reaction_options": "リアクションの選択", "reaction_options": "リアクションの選択",
"read_changelog": "変更履歴を読む", "read_changelog": "変更履歴を読む",
"readonly_mode_disabled": "読み取り専用モード無効", "readonly_mode_disabled": "読み取り専用モード無効",
@@ -1911,13 +1908,13 @@
"scanning_for_album": "アルバムをスキャン中…", "scanning_for_album": "アルバムをスキャン中…",
"search": "検索", "search": "検索",
"search_albums": "アルバムを検索", "search_albums": "アルバムを検索",
"search_by_context": "状況で検索", "search_by_context": "写真の内容で検索",
"search_by_description": "概要で検索", "search_by_description": "説明で検索",
"search_by_description_example": "サパでハイキングした日", "search_by_description_example": "京都の桜めぐり",
"search_by_filename": "ファイル名もしくは拡張子で検索", "search_by_filename": "ファイル名もしくは拡張子で検索",
"search_by_filename_example": "例: IMG_1234.JPG もしくは PNG", "search_by_filename_example": "例: IMG_1234.JPG もしくは PNG",
"search_by_ocr": "OCR検索", "search_by_ocr": "OCR検索",
"search_by_ocr_example": "お茶", "search_by_ocr_example": "バス 時刻表",
"search_camera_lens_model": "レンズモデルで検索…", "search_camera_lens_model": "レンズモデルで検索…",
"search_camera_make": "カメラメーカーを検索…", "search_camera_make": "カメラメーカーを検索…",
"search_camera_model": "カメラのモデルを検索…", "search_camera_model": "カメラのモデルを検索…",
@@ -2069,7 +2066,7 @@
"shared_link_clipboard_text": "リンク: {link}\nパスワード: {password}", "shared_link_clipboard_text": "リンク: {link}\nパスワード: {password}",
"shared_link_create_error": "共有用のリンク作成時にエラーが発生しました", "shared_link_create_error": "共有用のリンク作成時にエラーが発生しました",
"shared_link_custom_url_description": "この共有リンクにカスタムURLでアクセス", "shared_link_custom_url_description": "この共有リンクにカスタムURLでアクセス",
"shared_link_edit_description_hint": "概要を追加", "shared_link_edit_description_hint": "説明を追加",
"shared_link_edit_expire_after_option_day": "1日", "shared_link_edit_expire_after_option_day": "1日",
"shared_link_edit_expire_after_option_days": "{count}日", "shared_link_edit_expire_after_option_days": "{count}日",
"shared_link_edit_expire_after_option_hour": "1時間", "shared_link_edit_expire_after_option_hour": "1時間",
+47 -3
View File
@@ -5,18 +5,25 @@
"acknowledge": "បានដឹងនិងទទួលស្គាល់", "acknowledge": "បានដឹងនិងទទួលស្គាល់",
"action": "សកម្មភាព", "action": "សកម្មភាព",
"action_common_update": "ធ្វើបច្ចុប្បន្នភាព", "action_common_update": "ធ្វើបច្ចុប្បន្នភាព",
"action_description": "សំណុំសកម្មភាពសម្រាប់អនុវត្តលើឯកសារដែលបានត្រង",
"actions": "សកម្មភាពផ្សេងៗ", "actions": "សកម្មភាពផ្សេងៗ",
"active": "កំពុងសកម្ម", "active": "កំពុងសកម្ម",
"active_count": "ដំណើរការ :{count}", "active_count": "ដំណើរការ :{count}",
"activity": "សកម្មភាពផ្សេងៗ", "activity": "សកម្មភាពផ្សេងៗ",
"activity_changed": "សកម្មភាពគឺ {enabled, select, true {បានបើក} other {បានបិទ}}",
"add": "បន្ថែម", "add": "បន្ថែម",
"add_a_description": "បន្ថែមការពិពណ៌នា", "add_a_description": "បន្ថែមការពិពណ៌នា",
"add_a_location": "បន្ថែមទីតាំង", "add_a_location": "បន្ថែមទីតាំង",
"add_a_name": "បន្ងែមឈ្មោះ", "add_a_name": "បន្ងែមឈ្មោះ",
"add_a_title": "បន្ងែមចំណងជើង", "add_a_title": "បន្ងែមចំណងជើង",
"add_action": "បន្ថែមសកម្មភាព",
"add_action_description": "ចុចដើម្បីបន្ថែមសកម្មភាឲ្យអនុវត្ត",
"add_assets": "បន្ថែមទ្រព្យ",
"add_birthday": "បន្ថែមថ្ងៃខែឆ្មាំកំណើត", "add_birthday": "បន្ថែមថ្ងៃខែឆ្មាំកំណើត",
"add_endpoint": "បន្ថែម Endpoint", "add_endpoint": "បន្ថែម Endpoint",
"add_exclusion_pattern": "បន្ថែមលំនាំលើកលែង", "add_exclusion_pattern": "បន្ថែមលំនាំលើកលែង",
"add_filter": "បន្ថែមតម្រង",
"add_filter_description": "ចុចដើម្បីបន្ថែមតម្រងផ្សេងទៀត",
"add_location": "បន្ថែមទីតាំង", "add_location": "បន្ថែមទីតាំង",
"add_more_users": "បន្ថែមអ្នកប្រើប្រាស់", "add_more_users": "បន្ថែមអ្នកប្រើប្រាស់",
"add_partner": "បន្ថែមដៃគូ", "add_partner": "បន្ថែមដៃគូ",
@@ -27,7 +34,7 @@
"add_to_album": "បន្ថែមទៅក្នុងអាល់ប៊ុម", "add_to_album": "បន្ថែមទៅក្នុងអាល់ប៊ុម",
"add_to_album_bottom_sheet_added": "បានបន្ថែមទៅក្នុង {album}", "add_to_album_bottom_sheet_added": "បានបន្ថែមទៅក្នុង {album}",
"add_to_album_bottom_sheet_already_exists": "បន្ថែមក្នុង {album} រួចទៅហើយ", "add_to_album_bottom_sheet_already_exists": "បន្ថែមក្នុង {album} រួចទៅហើយ",
"add_to_album_bottom_sheet_some_local_assets": "Local assets មួយចំនួនមិនអាចបញ្ចូលទៅក្នុងអាល់ប៊ុមបានទេ", "add_to_album_bottom_sheet_some_local_assets": "ទ្រព្យក្នុងម៉ាស៊ីនមួយចំនួនមិនអាចបន្ថែមចូលអាល់ប៊ុមបានទេ",
"add_to_album_toggle": "បិទបើកការជ្រើសរើសសម្រាប់ {album}", "add_to_album_toggle": "បិទបើកការជ្រើសរើសសម្រាប់ {album}",
"add_to_albums": "បន្ថែមទៅក្នុងអាល់ប៊ុមច្រើន", "add_to_albums": "បន្ថែមទៅក្នុងអាល់ប៊ុមច្រើន",
"add_to_albums_count": "បន្ថែមទៅក្នុងអាល់ប៊ុមចំនួន ({count})", "add_to_albums_count": "បន្ថែមទៅក្នុងអាល់ប៊ុមចំនួន ({count})",
@@ -35,10 +42,12 @@
"add_to_shared_album": "បន្ថែមទៅក្នុងអាល់ប៊ុមដែលបានចែករំលែក", "add_to_shared_album": "បន្ថែមទៅក្នុងអាល់ប៊ុមដែលបានចែករំលែក",
"add_upload_to_stack": "បន្ថែមការបង្ហោះទៅជង់", "add_upload_to_stack": "បន្ថែមការបង្ហោះទៅជង់",
"add_url": "បន្ថែម URL", "add_url": "បន្ថែម URL",
"add_workflow_step": "បន្ថែមលំនាំការងារ",
"added_to_archive": "បានបន្ថែមទៅក្នុងបណ្ណសារ", "added_to_archive": "បានបន្ថែមទៅក្នុងបណ្ណសារ",
"added_to_favorites": "បានបន្ថែមទៅក្នុងចំណង់ចំណូលចិត្ត", "added_to_favorites": "បានបន្ថែមទៅក្នុងចំណង់ចំណូលចិត្ត",
"added_to_favorites_count": "បានបន្ថែម {count, number} ទៅក្នុងចំណង់ចំណូលចិត្ត", "added_to_favorites_count": "បានបន្ថែម {count, number} ទៅក្នុងចំណង់ចំណូលចិត្ត",
"admin": { "admin": {
"add_exclusion_pattern_description": "បន្ថែមទម្រង់មិនរាប់បញ្ចូល។ អាចប្រើប្រាស់ជាមួយ *, ** និងសញ្ញា ? បាន។ ដើម្បីមិនអើពើរាល់ឯកសារទាំងអស់ក្នុងកន្លែងដែលមានឈ្មោះ \"Raw\" សូមប្រើ \"**/Raw/**\"។ ដើម្បីមិនអើពើឯកសារដែលបញ្ចប់ដោយ \".tif\" សូមប្រើ \"**/*.tif\"។ ដើម្បីមិនអើពើទីតាំងពេញលេញ សូមប្រើ \"/path/to/ignore/**\"។",
"admin_user": "អ្នកប្រើប្រាស់អេតមីន", "admin_user": "អ្នកប្រើប្រាស់អេតមីន",
"asset_offline_description": "Asset ​បណ្ណាល័យ​ខាង​ក្រៅ​នេះ​លែង​ត្រូវ​បាន​រក​ឃើញ​នៅ​លើ​ថាស​ហើយ​ត្រូវ​បាន​ផ្លាស់ទី​តាំងទៅ​ធុង​សំរាម។ ប្រសិនបើឯកសារត្រូវបានផ្លាស់ទីក្នុងបណ្ណាល័យ, សូមពិនិត្យមើលការកំណត់ពេលវេលារបស់អ្នកសម្រាប់ Asset ដែលត្រូវគ្នាថ្មី។ ដើម្បីស្ដារ Asset នេះឡើងវិញ សូមប្រាកដថា Path ឯកសារខាងក្រោមអាចចូលប្រើបានដោយ Immich និងស្កេនបណ្ណាល័យបាន។", "asset_offline_description": "Asset ​បណ្ណាល័យ​ខាង​ក្រៅ​នេះ​លែង​ត្រូវ​បាន​រក​ឃើញ​នៅ​លើ​ថាស​ហើយ​ត្រូវ​បាន​ផ្លាស់ទី​តាំងទៅ​ធុង​សំរាម។ ប្រសិនបើឯកសារត្រូវបានផ្លាស់ទីក្នុងបណ្ណាល័យ, សូមពិនិត្យមើលការកំណត់ពេលវេលារបស់អ្នកសម្រាប់ Asset ដែលត្រូវគ្នាថ្មី។ ដើម្បីស្ដារ Asset នេះឡើងវិញ សូមប្រាកដថា Path ឯកសារខាងក្រោមអាចចូលប្រើបានដោយ Immich និងស្កេនបណ្ណាល័យបាន។",
"authentication_settings": "ការកំណត់ការផ្ទៀងផ្ទាត់", "authentication_settings": "ការកំណត់ការផ្ទៀងផ្ទាត់",
@@ -49,8 +58,43 @@
"backup_database": "បង្កើតមូលដ្ឋានទិន្នន័យ​ Dump", "backup_database": "បង្កើតមូលដ្ឋានទិន្នន័យ​ Dump",
"backup_database_enable_description": "បើកមូលដ្ឋានទិន្នន័យ Dumps", "backup_database_enable_description": "បើកមូលដ្ឋានទិន្នន័យ Dumps",
"backup_keep_last_amount": "ចំនួននៃ Dumps ពីមុនដែលត្រូវរក្សាទុក", "backup_keep_last_amount": "ចំនួននៃ Dumps ពីមុនដែលត្រូវរក្សាទុក",
"backup_onboarding_1_description": "ច្បាប់ចម្លងក្រៅបណ្តាញនៅក្នុងពពក ឬនៅកន្លែងផ្សេងទៀត។", "backup_onboarding_1_description": "ច្បាប់ចម្លងក្រៅបណ្តាញនៅក្នុងអនឡាន ឬនៅកន្លែងផ្សេងទៀត។",
"backup_onboarding_2_description": "ឯកសារចម្លងនៅលើឧបករណ៍ផ្សេងៗ។ នេះរួមបញ្ចូលទាំងឯកសារសំខាន់ៗ និងការបម្រុងទុកនៃឯកសារទាំងនោះ។", "backup_onboarding_2_description": "ឯកសារចម្លងនៅលើឧបករណ៍ផ្សេងៗ។ នេះរួមបញ្ចូលទាំងឯកសារសំខាន់ៗ និងការបម្រុងទុកនៃឯកសារទាំងនោះ។",
"backup_onboarding_3_description": "ចំនួនឯកសារចម្លងនៃទិន្នន័យរបស់អ្នក, រួមបញ្ចូលទាំងឯកសារដើម។ នេះរួមបញ្ចូលទាំងច្បាប់ចម្លងក្រៅបណ្តាញ 1 និងច្បាប់ចម្លងខាងក្រៅ 2 ។" "backup_onboarding_3_description": "ចំនួនឯកសារចម្លងនៃទិន្នន័យរបស់អ្នក, រួមបញ្ចូលទាំងឯកសារដើម។ នេះរួមបញ្ចូលទាំងច្បាប់ចម្លងក្រៅបណ្តាញ 1 និងច្បាប់ចម្លងខាងក្រៅ 2 ។",
"backup_onboarding_description": "<backblaze-link>យុទ្ធសាស្ត្របម្រុងទុក 3-2-1</backblaze-link> ត្រូវបានណែនាំដើម្បីការពារទិន្នន័យរបស់អ្នក។ អ្នកគួរតែរក្សាទុកច្បាប់ចម្លងនៃរូបថត/វីដេអូដែលបានបង្ហោះរបស់អ្នក ក៏ដូចជាមូលដ្ឋានទិន្នន័យ Immich សម្រាប់ដំណោះស្រាយបម្រុងទុកដែលពេញលេញមួយ។",
"backup_onboarding_footer": "សម្រាប់ព័ត៌មានបន្ថែមអំពីការបម្រុងទុក Immich សូមមើល <link>ឯកសារ</link>។",
"backup_onboarding_parts_title": "ការបម្រុងទុក 3-2-1 រួមមាន៖",
"backup_onboarding_title": "ការបម្រុងទុក",
"backup_settings": "ការកំណត់ការចាក់ទិន្នន័យ",
"backup_settings_description": "គ្រប់គ្រងការកំណត់នៃការចាក់ទិន្នន័យ។",
"cleared_jobs": "បានសម្អាតការងារសម្រាប់៖ {job}",
"config_set_by_file": "ការកំណត់ផ្សេងៗបច្ចុប្បន្នកំពុងត្រូវបានកំណត់ដោយឯកសារកំណត់រចនាសម្ព័ន្ធ",
"confirm_delete_library": "តើអ្នកពិតជាចង់លុបបណ្ណាល័យ {library} មែនទេ?",
"confirm_delete_library_assets": "តើអ្នកពិតជាចង់លុបបណ្ណាល័យនេះមែនទេ? វានឹងលុប {count, plural, one {# ឯកសារដែលពាក់ព័ន្ធ} other {ឯកសារពាក់ព័ន្ធទាំងអស់ #}} ចេញពី Immich ហើយមិនអាចយកមកវិញបានទេ។ ឯកសារនឹងនៅតែមាននៅលើថាស។",
"confirm_email_below": "ដើម្បីផ្ទៀងផ្ទាត់ សូមវាយ \"{email}\" ខាងក្រោម",
"confirm_reprocess_all_faces": "តើអ្នកប្រាកដទេថាចង់ដំណើរការស្កែនមុខទាំងអស់ឡើងវិញ? វានឹងលុបឈ្មោះមនុស្សដែលបានដាក់ផងដែរ។",
"confirm_user_password_reset": "តើអ្នកប្រាកដថាចង់កំណត់ពាក្យសម្ងាត់របស់ {user} ឡើងវិញ?",
"confirm_user_pin_code_reset": "តើអ្នកប្រាកដថាចង់កំណត់លេខសម្ងាត់ PIN របស់ {user} ឡើងវិញ?",
"copy_config_to_clipboard_description": "ចម្លងការកំណត់ប្រព័ន្ធបច្ចុប្បន្នជាJSON object ទៅកាន់clipboard",
"create_job": "បង្កើតការងារ",
"cron_expression": "គ្របគ្រងពេលវេលា",
"cron_expression_description": "កំណត់ចន្លោះពេលស្កេនដោយប្រើទម្រង់ cron ​format។ សម្រាប់ព័ត៌មានបន្ថែម សូមមើលឧទាហរណ៍នៅក្នុង <link>Crontab Guru</link>",
"cron_expression_presets": "ពុម្ភក្នុងការកំណត់ពេលវេលា",
"disable_login": "បិទមិនអោយលុកចូល",
"duplicate_detection_job_description": "បើកដំណើរការ Machine Learning លើទ្រព្យទាំងអស់ដើម្បីស្វែងរក រូបភាពដែលស្រដៀងគ្នា។ ផ្អែកលើ Smart Search",
"exclusion_pattern_description": "ទម្រង់មិនរាប់បញ្ចូល អនុញ្ញាតឱ្យអ្នកមិនអើពើពីប្រភេទរូបភាព និងថតឯកសារនៅពេលស្កេនបណ្ណាល័យរបស់អ្នក។ នេះមានប្រយោជន៍ប្រសិនបើអ្នកមានថតឯកសារដែលមានប្រភេទរូបភាពដែលអ្នកមិនចង់នាំចូល ដូចជារូបភាព RAW ជាដើម។",
"export_config_as_json_description": "ទាញយកការកំណត់ប្រព័ន្ធបច្ចុប្បន្នជាទម្រង់ JSON",
"external_libraries_page_description": "ទំព័របណ្ណាល័យខាងក្រៅរបស់អ្នកគ្រប់គ្រង",
"face_detection": "ការចាប់យកផ្ទែមុខ",
"face_detection_description": "រកមើលមុខក្នុងឯកសារដោយប្រើប្រាស់ machine learning។ សម្រាប់វីដេអូ មានតែរូបភាពតូច(Thunbnail)ប៉ុណ្ណោះដែលត្រូវបានពិចារណា។ \"Refresh\" (ដំណើរការឡើងវិញ) ដំណើរការឯកសារទាំងអស់ឡើងវិញ។ \"Reset\" នឹងបន្ថែមពីលើការលុបមុខទាំងអស់។ \"Missing\" ដាក់ជួរឯកសារដែលមិនទាន់បានដំណើរការ។ មុខដែលបានរកឃើញនឹងត្រូវបានដាក់ក្នុងជួរសម្រាប់ការសម្គាល់មុខ បន្ទាប់ពីការរកឃើញមុខបានបញ្ចប់ ដោយដាក់ជាក្រុមទៅក្នុងមនុស្សដែលមានស្រាប់ ឬមនុស្សថ្មី។",
"facial_recognition_job_description": "ដាក់ក្រុមមុខដែលបានរកឃើញទៅជាមនុស្ស។ ជំហាននេះដំណើរការបន្ទាប់ពីការរកឃើញមុខបានបញ្ចប់។ \"Reset\" (ធ្វើការចង្កោមឡើងវិញ) ដាក់មុខទាំងអស់ក្នុងក្រុមឡើងវិញ។ \"Missing\" ដាក់មុខដែលមិនមានមនុស្សកំណត់ក្នុងជួរ។",
"failed_job_command": "ពាក្យបញ្ជា {command} បានបរាជ័យសម្រាប់កិច្ចការ៖ {job}",
"force_delete_user_warning": "ការព្រមាន៖ វានឹងលុបអ្នកប្រើប្រាស់ និងឯកសារទាំងអស់ភ្លាមៗ។ វាមិនអាចត្រឡប់វិញបានទេ ហើយឯកសារមិនអាចទាញយកមកវិញបានទេ។",
"image_format": "ទ្រង់ទ្រាយ",
"image_format_description": "WebP ផលិតឯកសារតូចជាង JPEG ប៉ុន្តែដំណើរការក្នុងការ encode យឺតជាង។",
"image_fullsize_description": "រូបភាពពេញលេញដែលមានទិន្នន័យមេតាត្រូវបានដកចេញ វានឹងត្រូវបានប្រើនៅពេលពង្រីក",
"image_fullsize_enabled": "បើកការបង្កើតរូបភាពទំហំពេញ",
"image_fullsize_enabled_description": "បង្កើតរូបភាពទំហំពេញសម្រាប់ទម្រង់ដែលមិនមែនជា Web-friendly។ នៅពេលដែល \"Prefer embedded preview\" ត្រូវបានបើក ការមើលជាមុនដែលបានបង្កប់ត្រូវបានប្រើប្រាស់ដោយផ្ទាល់ដោយគ្មានការបម្លែង។ មិនប៉ះពាល់ដល់ទម្រង់ Web-friendly ដូចជា JPEG ទេ។",
"image_fullsize_quality_description": "គុណភាពរូបភាពទំហំពេញពី 1-100។ ខ្ពស់ជាងគឺល្អជាង ប៉ុន្តែបង្កើតឯកសារធំជាង។"
} }
} }

Some files were not shown because too many files have changed in this diff Show More